forked from community/device-mgt-core
Merge pull request #1048 from GDLMadushanka/master
unit tests for deviceType plugin deployerrevert-70aa11f8
commit
aff48e4f24
@ -0,0 +1,95 @@
|
|||||||
|
/*
|
||||||
|
* Copyright (c) 2017, WSO2 Inc. (http://www.wso2.org) All Rights Reserved.
|
||||||
|
*
|
||||||
|
* WSO2 Inc. licenses this file to you under the Apache License,
|
||||||
|
* Version 2.0 (the "License"); you may not use this file except
|
||||||
|
* in compliance with the License.
|
||||||
|
* You may obtain a copy of the License at
|
||||||
|
*
|
||||||
|
* http://www.apache.org/licenses/LICENSE-2.0
|
||||||
|
*
|
||||||
|
* Unless required by applicable law or agreed to in writing,
|
||||||
|
* software distributed under the License is distributed on an
|
||||||
|
* "AS IS" BASIS, WITHOUT WARRANTIES OR CONDITIONS OF ANY
|
||||||
|
* KIND, either express or implied. See the License for the
|
||||||
|
* specific language governing permissions and limitations
|
||||||
|
* under the License.
|
||||||
|
*/
|
||||||
|
|
||||||
|
package org.wso2.carbon.device.mgt.extensions.device.type.deployer;
|
||||||
|
|
||||||
|
import org.apache.axis2.deployment.DeploymentException;
|
||||||
|
import org.apache.axis2.deployment.repository.util.DeploymentFileData;
|
||||||
|
import org.junit.Assert;
|
||||||
|
import org.mockito.Mockito;
|
||||||
|
import org.osgi.framework.ServiceRegistration;
|
||||||
|
import org.testng.annotations.BeforeClass;
|
||||||
|
import org.testng.annotations.Test;
|
||||||
|
import org.wso2.carbon.context.PrivilegedCarbonContext;
|
||||||
|
import org.wso2.carbon.device.mgt.extensions.device.type.template.DeviceTypeConfigIdentifier;
|
||||||
|
import org.wso2.carbon.registry.core.exceptions.RegistryException;
|
||||||
|
import java.io.File;
|
||||||
|
import java.io.IOException;
|
||||||
|
import java.lang.reflect.Field;
|
||||||
|
import java.util.Map;
|
||||||
|
import java.util.concurrent.ConcurrentHashMap;
|
||||||
|
|
||||||
|
/*
|
||||||
|
Unit tests for DeviceTypePluginDeployer
|
||||||
|
*/
|
||||||
|
public class DeviceTypePluginDeployerTest {
|
||||||
|
private DeviceTypePluginDeployer deviceTypePluginDeployer;
|
||||||
|
private DeploymentFileData deploymentFileData;
|
||||||
|
private Field deviceTypeServiceRegistrations = null;
|
||||||
|
private Field deviceTypeConfigurationDataMap = null;
|
||||||
|
private ServiceRegistration serviceRegistration = null;
|
||||||
|
|
||||||
|
@BeforeClass
|
||||||
|
public void init() throws NoSuchFieldException, IllegalAccessException, IOException, RegistryException {
|
||||||
|
deviceTypePluginDeployer = Mockito.mock(DeviceTypePluginDeployer.class, Mockito.CALLS_REAL_METHODS);
|
||||||
|
serviceRegistration = Mockito.mock(ServiceRegistration.class, Mockito.CALLS_REAL_METHODS);
|
||||||
|
Mockito.doReturn(serviceRegistration).when(deviceTypePluginDeployer).registerDeviceType(Mockito.any(),
|
||||||
|
Mockito.any());
|
||||||
|
deviceTypeServiceRegistrations = DeviceTypePluginDeployer.class.getDeclaredField
|
||||||
|
("deviceTypeServiceRegistrations");
|
||||||
|
deviceTypeServiceRegistrations.setAccessible(true);
|
||||||
|
deviceTypeServiceRegistrations.set(deviceTypePluginDeployer, new ConcurrentHashMap());
|
||||||
|
deviceTypeConfigurationDataMap = DeviceTypePluginDeployer.class.getDeclaredField
|
||||||
|
("deviceTypeConfigurationDataMap");
|
||||||
|
deviceTypeConfigurationDataMap.setAccessible(true);
|
||||||
|
deviceTypeConfigurationDataMap.set(deviceTypePluginDeployer, new ConcurrentHashMap());
|
||||||
|
this.initializeCarbonContext();
|
||||||
|
}
|
||||||
|
|
||||||
|
private void initializeCarbonContext() throws IOException, RegistryException {
|
||||||
|
|
||||||
|
if (System.getProperty("carbon.home") == null) {
|
||||||
|
File file = new File("src/test/resources");
|
||||||
|
if (file.exists()) {
|
||||||
|
System.setProperty("carbon.home", file.getAbsolutePath());
|
||||||
|
}
|
||||||
|
}
|
||||||
|
PrivilegedCarbonContext.getThreadLocalCarbonContext().setTenantDomain(
|
||||||
|
org.wso2.carbon.base.MultitenantConstants.SUPER_TENANT_DOMAIN_NAME);
|
||||||
|
PrivilegedCarbonContext.getThreadLocalCarbonContext().setTenantId(
|
||||||
|
org.wso2.carbon.base.MultitenantConstants.SUPER_TENANT_ID);
|
||||||
|
}
|
||||||
|
|
||||||
|
@SuppressWarnings("unchecked")
|
||||||
|
@Test(description = "Testing deviceType deploy method by deploying Android device type")
|
||||||
|
public void deploy() throws DeploymentException, IllegalAccessException {
|
||||||
|
File file = new File("src/test/resources/android.xml");
|
||||||
|
if (file.exists()) {
|
||||||
|
deploymentFileData = new DeploymentFileData(file);
|
||||||
|
}
|
||||||
|
deviceTypePluginDeployer.deploy(deploymentFileData);
|
||||||
|
Map<String, ServiceRegistration> tempServiceRegistration = (Map<String, ServiceRegistration>)
|
||||||
|
deviceTypeServiceRegistrations.get(deviceTypePluginDeployer);
|
||||||
|
Assert.assertEquals(tempServiceRegistration.get(deploymentFileData.getAbsolutePath()), serviceRegistration);
|
||||||
|
Map<String, DeviceTypeConfigIdentifier> tempDeviceTypeConfig = (Map<String, DeviceTypeConfigIdentifier>)
|
||||||
|
deviceTypeConfigurationDataMap.get(deviceTypePluginDeployer);
|
||||||
|
DeviceTypeConfigIdentifier deviceTypeConfigIdentifier = tempDeviceTypeConfig.get(deploymentFileData
|
||||||
|
.getAbsolutePath());
|
||||||
|
Assert.assertEquals(deviceTypeConfigIdentifier.getDeviceType(), "android");
|
||||||
|
}
|
||||||
|
}
|
@ -0,0 +1,382 @@
|
|||||||
|
<?xml version="1.0" encoding="utf-8"?>
|
||||||
|
<!--
|
||||||
|
~ Copyright (c) 2017, WSO2 Inc. (http://www.wso2.org) All Rights Reserved.
|
||||||
|
~
|
||||||
|
~ WSO2 Inc. licenses this file to you under the Apache License,
|
||||||
|
~ Version 2.0 (the "License"); you may not use this file except
|
||||||
|
~ in compliance with the License.
|
||||||
|
~ You may obtain a copy of the License at
|
||||||
|
~
|
||||||
|
~ http://www.apache.org/licenses/LICENSE-2.0
|
||||||
|
~
|
||||||
|
~ Unless required by applicable law or agreed to in writing,
|
||||||
|
~ software distributed under the License is distributed on an
|
||||||
|
~ "AS IS" BASIS, WITHOUT WARRANTIES OR CONDITIONS OF ANY
|
||||||
|
~ KIND, either express or implied. See the License for the
|
||||||
|
~ specific language governing permissions and limitations
|
||||||
|
~ under the License.
|
||||||
|
-->
|
||||||
|
<DeviceTypeConfiguration name="android">
|
||||||
|
|
||||||
|
<DeviceDetails table-id="AD_DEVICE"/>
|
||||||
|
|
||||||
|
<License>
|
||||||
|
<Language>en_US</Language>
|
||||||
|
<Version>1.0.0</Version>
|
||||||
|
<Text>This End User License Agreement ("Agreement") is a legal agreement between you ("You") and WSO2,
|
||||||
|
Inc., regarding the enrollment of Your personal mobile device ("Device") in SoR's mobile device
|
||||||
|
management program, and the loading to and removal from Your Device and Your use of certain
|
||||||
|
applications and any associated software and user documentation, whether provided in "online" or
|
||||||
|
electronic format, used in connection with the operation of or provision of services to WSO2,
|
||||||
|
Inc., BY SELECTING "I ACCEPT" DURING INSTALLATION, YOU ARE ENROLLING YOUR DEVICE, AND THEREBY
|
||||||
|
AUTHORIZING SOR OR ITS AGENTS TO INSTALL, UPDATE AND REMOVE THE APPS FROM YOUR DEVICE AS DESCRIBED
|
||||||
|
IN THIS AGREEMENT. YOU ARE ALSO EXPLICITLY ACKNOWLEDGING AND AGREEING THAT (1) THIS IS A BINDING
|
||||||
|
CONTRACT AND (2) YOU HAVE READ AND AGREE TO THE TERMS OF THIS AGREEMENT.
|
||||||
|
|
||||||
|
IF YOU DO NOT ACCEPT THESE TERMS, DO NOT ENROLL YOUR DEVICE AND DO NOT PROCEED ANY FURTHER.
|
||||||
|
|
||||||
|
You agree that: (1) You understand and agree to be bound by the terms and conditions contained in
|
||||||
|
this Agreement, and (2) You are at least 21 years old and have the legal capacity to enter into
|
||||||
|
this Agreement as defined by the laws of Your jurisdiction. SoR shall have the right, without
|
||||||
|
prior notice, to terminate or suspend (i) this Agreement, (ii) the enrollment of Your Device, or
|
||||||
|
(iii) the functioning of the Apps in the event of a violation of this Agreement or the cessation
|
||||||
|
of Your relationship with SoR (including termination of Your employment if You are an employee or
|
||||||
|
expiration or termination of Your applicable franchise or supply agreement if You are a franchisee
|
||||||
|
of or supplier to the WSO2 WSO2, Inc., system). SoR expressly reserves all rights not expressly
|
||||||
|
granted herein.
|
||||||
|
</Text>
|
||||||
|
</License>
|
||||||
|
|
||||||
|
<ProvisioningConfig>
|
||||||
|
<SharedWithAllTenants>true</SharedWithAllTenants>
|
||||||
|
</ProvisioningConfig>
|
||||||
|
<!--
|
||||||
|
isScheduled element used to enable scheduler task to send push notification.
|
||||||
|
Task will send push notification as batches. So this will reduce sudden request burst when many devices try to
|
||||||
|
access server after receiving push notification.
|
||||||
|
-->
|
||||||
|
<!--Configuration for enable firebase push notifications-->
|
||||||
|
<!--<PushNotificationProviderConfig type="FCM" isScheduled="false">-->
|
||||||
|
<!--</PushNotificationProviderConfig>-->
|
||||||
|
|
||||||
|
<DataSource>
|
||||||
|
<JndiConfig>
|
||||||
|
<Name>jdbc/MobileAndroidDM_DS</Name>
|
||||||
|
</JndiConfig>
|
||||||
|
<TableConfig>
|
||||||
|
<Table name="AD_DEVICE">
|
||||||
|
<PrimaryKey>DEVICE_ID</PrimaryKey>
|
||||||
|
<Attributes>
|
||||||
|
<Attribute>FCM_TOKEN</Attribute>
|
||||||
|
<Attribute>DEVICE_INFO</Attribute>
|
||||||
|
<Attribute>IMEI</Attribute>
|
||||||
|
<Attribute>IMSI</Attribute>
|
||||||
|
<Attribute>OS_VERSION</Attribute>
|
||||||
|
<Attribute>DEVICE_MODEL</Attribute>
|
||||||
|
<Attribute>VENDOR</Attribute>
|
||||||
|
<Attribute>LATITUDE</Attribute>
|
||||||
|
<Attribute>LONGITUDE</Attribute>
|
||||||
|
<Attribute>SERIAL</Attribute>
|
||||||
|
<Attribute>MAC_ADDRESS</Attribute>
|
||||||
|
<Attribute>DEVICE_NAME</Attribute>
|
||||||
|
<Attribute>OS_BUILD_DATE</Attribute>
|
||||||
|
</Attributes>
|
||||||
|
</Table>
|
||||||
|
</TableConfig>
|
||||||
|
</DataSource>
|
||||||
|
|
||||||
|
<Features>
|
||||||
|
<Feature code="DEVICE_RING">
|
||||||
|
<Name>Ring</Name>
|
||||||
|
<Description>Ring the device</Description>
|
||||||
|
<Operation context="/api/device-mgt/android/v1.0/admin/devices/ring" method="POST" type="application/json">
|
||||||
|
</Operation>
|
||||||
|
</Feature>
|
||||||
|
<Feature code="DEVICE_LOCK">
|
||||||
|
<Name>Device Lock</Name>
|
||||||
|
<Description>Lock the device</Description>
|
||||||
|
<Operation context="/api/device-mgt/android/v1.0/admin/devices/lock-devices" method="POST" type="application/json">
|
||||||
|
</Operation>
|
||||||
|
</Feature>
|
||||||
|
<Feature code="DEVICE_LOCATION">
|
||||||
|
<Name>Location</Name>
|
||||||
|
<Description>Request coordinates of device location</Description>
|
||||||
|
<Operation context="/api/device-mgt/android/v1.0/admin/devices/location" method="POST" type="application/json">
|
||||||
|
</Operation>
|
||||||
|
</Feature>
|
||||||
|
<Feature code="CLEAR_PASSWORD">
|
||||||
|
<Name>Clear Password</Name>
|
||||||
|
<Description>Clear current password</Description>
|
||||||
|
<Operation context="/api/device-mgt/android/v1.0/admin/devices/clear-password" method="POST" type="application/json">
|
||||||
|
</Operation>
|
||||||
|
</Feature>
|
||||||
|
<Feature code="DEVICE_REBOOT">
|
||||||
|
<Name>Reboot</Name>
|
||||||
|
<Description>Reboot the device</Description>
|
||||||
|
<Operation context="/api/device-mgt/android/v1.0/admin/devices/reboot" method="POST" type="application/json">
|
||||||
|
</Operation>
|
||||||
|
</Feature>
|
||||||
|
<Feature code="UPGRADE_FIRMWARE">
|
||||||
|
<Name>Upgrade Firmware</Name>
|
||||||
|
<Description>Upgrade Firmware</Description>
|
||||||
|
<Operation context="/api/device-mgt/android/v1.0/admin/devices/upgrade-firmware" method="POST" type="application/json">
|
||||||
|
</Operation>
|
||||||
|
</Feature>
|
||||||
|
<Feature code="DEVICE_MUTE">
|
||||||
|
<Name>Mute</Name>
|
||||||
|
<Description>Enable mute in the device</Description>
|
||||||
|
<Operation context="/api/device-mgt/android/v1.0/admin/devices/mute" method="POST" type="application/json">
|
||||||
|
</Operation>
|
||||||
|
</Feature>
|
||||||
|
<Feature code="NOTIFICATION">
|
||||||
|
<Name>Message</Name>
|
||||||
|
<Description>Send message</Description>
|
||||||
|
<Operation context="/api/device-mgt/android/v1.0/admin/devices/send-notification" method="POST" type="application/json">
|
||||||
|
</Operation>
|
||||||
|
</Feature>
|
||||||
|
<Feature code="CHANGE_LOCK_CODE">
|
||||||
|
<Name>Change Lock-code</Name>
|
||||||
|
<Description>Change current lock code</Description>
|
||||||
|
<Operation context="/api/device-mgt/android/v1.0/admin/devices/change-lock-code" method="POST" type="application/json">
|
||||||
|
</Operation>
|
||||||
|
</Feature>
|
||||||
|
<Feature code="ENTERPRISE_WIPE">
|
||||||
|
<Name>Enterprise Wipe</Name>
|
||||||
|
<Description>Remove enterprise applications</Description>
|
||||||
|
<Operation context="/api/device-mgt/android/v1.0/admin/devices/enterprise-wipe" method="POST" type="application/json">
|
||||||
|
</Operation>
|
||||||
|
</Feature>
|
||||||
|
<Feature code="WIPE_DATA">
|
||||||
|
<Name>Wipe Data</Name>
|
||||||
|
<Description>Factory reset the device</Description>
|
||||||
|
<Operation context="/api/device-mgt/android/v1.0/admin/devices/wipe" method="POST" type="application/json">
|
||||||
|
</Operation>
|
||||||
|
</Feature>
|
||||||
|
<Feature code="WIFI">
|
||||||
|
<Name>Wifi</Name>
|
||||||
|
<Description>Setting up wifi configuration</Description>
|
||||||
|
</Feature>
|
||||||
|
<Feature code="CAMERA">
|
||||||
|
<Name>Camera</Name>
|
||||||
|
<Description>Enable or disable camera</Description>
|
||||||
|
</Feature>
|
||||||
|
<Feature code="EMAIL">
|
||||||
|
<Name>Email</Name>
|
||||||
|
<Description>Configure email settings</Description>
|
||||||
|
</Feature>
|
||||||
|
<Feature code="DEVICE_INFO">
|
||||||
|
<Name>Device info</Name>
|
||||||
|
<Description>Request device information</Description>
|
||||||
|
</Feature>
|
||||||
|
<Feature code="APPLICATION_LIST">
|
||||||
|
<Name>Application List</Name>
|
||||||
|
<Description>Request list of current installed applications</Description>
|
||||||
|
</Feature>
|
||||||
|
<Feature code="INSTALL_APPLICATION">
|
||||||
|
<Name>Install App</Name>
|
||||||
|
<Description>Install App</Description>
|
||||||
|
</Feature>
|
||||||
|
<Feature code="UNINSTALL_APPLICATION">
|
||||||
|
<Name>Uninstall App</Name>
|
||||||
|
<Description>Uninstall App</Description>
|
||||||
|
</Feature>
|
||||||
|
<Feature code="BLACKLIST_APPLICATIONS">
|
||||||
|
<Name>Blacklist app</Name>
|
||||||
|
<Description>Blacklist applications</Description>
|
||||||
|
</Feature>
|
||||||
|
<Feature code="ENCRYPT_STORAGE">
|
||||||
|
<Name>Encrypt Storage</Name>
|
||||||
|
<Description>Encrypt storage</Description>
|
||||||
|
</Feature>
|
||||||
|
<Feature code="PASSCODE_POLICY">
|
||||||
|
<Name>Password Policy</Name>
|
||||||
|
<Description>Set passcode policy</Description>
|
||||||
|
</Feature>
|
||||||
|
<Feature code="VPN">
|
||||||
|
<Name>Configure VPN</Name>
|
||||||
|
<Description>Configure VPN settings</Description>
|
||||||
|
</Feature>
|
||||||
|
<Feature code="DISALLOW_ADJUST_VOLUME">
|
||||||
|
<Name>Disallow user to change volume</Name>
|
||||||
|
<Description>Allow or disallow user to change volume"</Description>
|
||||||
|
</Feature>
|
||||||
|
<Feature code="DISALLOW_CONFIG_BLUETOOTH">
|
||||||
|
<Name>Disallow bluetooth configuration</Name>
|
||||||
|
<Description>Allow or disallow bluetooth configuration</Description>
|
||||||
|
</Feature>
|
||||||
|
<Feature code="DISALLOW_CONFIG_CELL_BROADCASTS">
|
||||||
|
<Name>Disallow user to change cell broadcast configurations</Name>
|
||||||
|
<Description>Allow or disallow user to change cell broadcast configurations</Description>
|
||||||
|
</Feature>
|
||||||
|
<Feature code="DISALLOW_CONFIG_CREDENTIALS">
|
||||||
|
<Name>Disallow user to change user credentials</Name>
|
||||||
|
<Description>Allow or disallow user to change user credentials</Description>
|
||||||
|
</Feature>
|
||||||
|
<Feature code="DISALLOW_CONFIG_MOBILE_NETWORKS">
|
||||||
|
<Name>Disallow user to change mobile networks configurations</Name>
|
||||||
|
<Description>Allow or disallow user to change mobile networks configurations</Description>
|
||||||
|
</Feature>
|
||||||
|
<Feature code="DISALLOW_CONFIG_TETHERING">
|
||||||
|
<Name>Disallow user to change tethering configurations</Name>
|
||||||
|
<Description>Allow or disallow user to change tethering configurations</Description>
|
||||||
|
</Feature>
|
||||||
|
<Feature code="DISALLOW_CONFIG_VPN">
|
||||||
|
<Name>Disallow user to change VPN configurations</Name>
|
||||||
|
<Description>Allow or disallow user to change VPN configurations</Description>
|
||||||
|
</Feature>
|
||||||
|
<Feature code="DISALLOW_CONFIG_WIFI">
|
||||||
|
<Name>Disallow user to change WIFI configurations</Name>
|
||||||
|
<Description>Allow or disallow user to change WIFI configurations</Description>
|
||||||
|
</Feature>
|
||||||
|
<Feature code="DISALLOW_APPS_CONTROL">
|
||||||
|
<Name>Disallow user to change app control</Name>
|
||||||
|
<Description>Allow or disallow user to change app control</Description>
|
||||||
|
</Feature>
|
||||||
|
<Feature code="DISALLOW_CREATE_WINDOWS">
|
||||||
|
<Name>Disallow window creation</Name>
|
||||||
|
<Description>Allow or disallow window creation</Description>
|
||||||
|
</Feature>
|
||||||
|
<Feature code="DISALLOW_APPS_CONTROL">
|
||||||
|
<Name>Disallow user to change app control configurations</Name>
|
||||||
|
<Description>Allow or disallow user to change app control configurations</Description>
|
||||||
|
</Feature>
|
||||||
|
<Feature code="DISALLOW_CROSS_PROFILE_COPY_PASTE">
|
||||||
|
<Name>Disallow cross profile copy paste</Name>
|
||||||
|
<Description>Allow or disallow cross profile copy paste</Description>
|
||||||
|
</Feature>
|
||||||
|
<Feature code="DISALLOW_DEBUGGING_FEATURES">
|
||||||
|
<Name>Disallow debugging features</Name>
|
||||||
|
<Description>Allow or disallow debugging features</Description>
|
||||||
|
</Feature>
|
||||||
|
<Feature code="DISALLOW_FACTORY_RESET">
|
||||||
|
<Name>Disallow factory reset</Name>
|
||||||
|
<Description>Allow or disallow factory reset</Description>
|
||||||
|
</Feature>
|
||||||
|
<Feature code="DISALLOW_ADD_USER">
|
||||||
|
<Name>Disallow add user</Name>
|
||||||
|
<Description>Allow or disallow add user</Description>
|
||||||
|
</Feature>
|
||||||
|
<Feature code="DISALLOW_INSTALL_APPS">
|
||||||
|
<Name>Disallow install apps</Name>
|
||||||
|
<Description>Allow or disallow install apps</Description>
|
||||||
|
</Feature>
|
||||||
|
<Feature code="DISALLOW_INSTALL_UNKNOWN_SOURCES">
|
||||||
|
<Name>Disallow install unknown sources</Name>
|
||||||
|
<Description>Allow or disallow install unknown sources</Description>
|
||||||
|
</Feature>
|
||||||
|
<Feature code="DISALLOW_MODIFY_ACCOUNTS">
|
||||||
|
<Name>Disallow modify account</Name>
|
||||||
|
<Description>Allow or disallow modify account</Description>
|
||||||
|
</Feature>
|
||||||
|
<Feature code="DISALLOW_MOUNT_PHYSICAL_MEDIA">
|
||||||
|
<Name>Disallow mount physical media</Name>
|
||||||
|
<Description>Allow or disallow mount physical media</Description>
|
||||||
|
</Feature>
|
||||||
|
<Feature code="DISALLOW_NETWORK_RESET">
|
||||||
|
<Name>Disallow network reset</Name>
|
||||||
|
<Description>Allow or disallow network reset</Description>
|
||||||
|
</Feature>
|
||||||
|
<Feature code="DISALLOW_OUTGOING_BEAM">
|
||||||
|
<Name>Disallow outgoing beam</Name>
|
||||||
|
<Description>Allow or disallow outgoing beam</Description>
|
||||||
|
</Feature>
|
||||||
|
<Feature code="DISALLOW_OUTGOING_CALLS">
|
||||||
|
<Name>Disallow outgoing calls</Name>
|
||||||
|
<Description>Allow or disallow outgoing calls</Description>
|
||||||
|
</Feature>
|
||||||
|
<Feature code="DISALLOW_REMOVE_USER">
|
||||||
|
<Name>Disallow remove users</Name>
|
||||||
|
<Description>Allow or disallow remove users</Description>
|
||||||
|
</Feature>
|
||||||
|
<Feature code="DISALLOW_SAFE_BOOT">
|
||||||
|
<Name>Disallow safe boot</Name>
|
||||||
|
<Description>Allow or disallow safe boot</Description>
|
||||||
|
</Feature>
|
||||||
|
<Feature code="DISALLOW_SHARE_LOCATION">
|
||||||
|
<Name>Disallow share location</Name>
|
||||||
|
<Description>Allow or disallow share location</Description>
|
||||||
|
</Feature>
|
||||||
|
<Feature code="DISALLOW_SMS">
|
||||||
|
<Name>Disallow sms</Name>
|
||||||
|
<Description>Allow or disallow sms</Description>
|
||||||
|
</Feature>
|
||||||
|
<Feature code="DISALLOW_UNINSTALL_APPS">
|
||||||
|
<Name>Disallow uninstall app</Name>
|
||||||
|
<Description>Allow or disallow uninstall app</Description>
|
||||||
|
</Feature>
|
||||||
|
<Feature code="DISALLOW_UNMUTE_MICROPHONE">
|
||||||
|
<Name>Disallow unmute mic</Name>
|
||||||
|
<Description>Allow or disallow unmute mic</Description>
|
||||||
|
</Feature>
|
||||||
|
<Feature code="DISALLOW_USB_FILE_TRANSFER">
|
||||||
|
<Name>Disallow usb file transfer</Name>
|
||||||
|
<Description>Allow or disallow usb file transfer</Description>
|
||||||
|
</Feature>
|
||||||
|
<Feature code="ALLOW_PARENT_PROFILE_APP_LINKING">
|
||||||
|
<Name>Disallow parent profile app linking</Name>
|
||||||
|
<Description>Allow or disallow parent profile app linking</Description>
|
||||||
|
</Feature>
|
||||||
|
<Feature code="ENSURE_VERIFY_APPS">
|
||||||
|
<Name>Disallow ensure verify apps</Name>
|
||||||
|
<Description>Allow or disallow ensure verify apps</Description>
|
||||||
|
</Feature>
|
||||||
|
<Feature code="AUTO_TIME">
|
||||||
|
<Name>Disallow auto timing</Name>
|
||||||
|
<Description>Allow or disallow auto timing</Description>
|
||||||
|
</Feature>
|
||||||
|
<Feature code="REMOVE_DEVICE_OWNER">
|
||||||
|
<Name>Remove device owner</Name>
|
||||||
|
<Description>Remove device owner</Description>
|
||||||
|
</Feature>
|
||||||
|
<Feature code="LOGCAT">
|
||||||
|
<Name>Fetch device logcat</Name>
|
||||||
|
<Description>Fetch device logcat</Description>
|
||||||
|
</Feature>
|
||||||
|
<Feature code="DEVICE_UNLOCK">
|
||||||
|
<Name>Unlock the device</Name>
|
||||||
|
<Description>Unlock the device</Description>
|
||||||
|
</Feature>
|
||||||
|
</Features>
|
||||||
|
<TaskConfiguration>
|
||||||
|
<Enable>true</Enable>
|
||||||
|
<Frequency>60000</Frequency>
|
||||||
|
<Operations>
|
||||||
|
<Operation>
|
||||||
|
<Name>DEVICE_INFO</Name>
|
||||||
|
<RecurrentTimes>1</RecurrentTimes>
|
||||||
|
</Operation>
|
||||||
|
<Operation>
|
||||||
|
<Name>APPLICATION_LIST</Name>
|
||||||
|
<RecurrentTimes>5</RecurrentTimes>
|
||||||
|
</Operation>
|
||||||
|
<Operation>
|
||||||
|
<Name>DEVICE_LOCATION</Name>
|
||||||
|
<RecurrentTimes>1</RecurrentTimes>
|
||||||
|
</Operation>
|
||||||
|
</Operations>
|
||||||
|
</TaskConfiguration>
|
||||||
|
<PolicyMonitoring enabled="true"/>
|
||||||
|
<InitialOperationConfig>
|
||||||
|
<Operations>
|
||||||
|
<Operation>DEVICE_INFO</Operation>
|
||||||
|
<Operation>APPLICATION_LIST</Operation>
|
||||||
|
<Operation>DEVICE_LOCATION</Operation>
|
||||||
|
</Operations>
|
||||||
|
</InitialOperationConfig>
|
||||||
|
<!--This configures the Task service for the android device-type. Given below are the property definitions.
|
||||||
|
<RequireStatusMonitoring> - This will enable or disable status monitoring for that particular device-type.
|
||||||
|
<Frequency> - The time interval (in seconds) in which the task should run for this device-type
|
||||||
|
<IdleTimeToMarkInactive> - The time duration (in seconds) in which the device can be moved to inactive status
|
||||||
|
which means the device will be moved to inactive status if that device does not
|
||||||
|
contact the server within that time period. Better to have a multiplier of Frequency.
|
||||||
|
<IdleTimeToMarkUnreachable> - The time duration (in seconds) in which the device can be moved to unreachable status
|
||||||
|
which means the device will be moved to unreachable status if that device does not
|
||||||
|
contact the server within that time period. Better to have a multiplier of Frequency.
|
||||||
|
-->
|
||||||
|
<DeviceStatusTaskConfig>
|
||||||
|
<RequireStatusMonitoring>true</RequireStatusMonitoring>
|
||||||
|
<Frequency>300</Frequency>
|
||||||
|
<IdleTimeToMarkInactive>900</IdleTimeToMarkInactive>
|
||||||
|
<IdleTimeToMarkUnreachable>600</IdleTimeToMarkUnreachable>
|
||||||
|
</DeviceStatusTaskConfig>
|
||||||
|
</DeviceTypeConfiguration>
|
@ -0,0 +1,34 @@
|
|||||||
|
#
|
||||||
|
# Copyright (c) 2016, WSO2 Inc. (http://www.wso2.org) All Rights Reserved.
|
||||||
|
#
|
||||||
|
# WSO2 Inc. licenses this file to you under the Apache License,
|
||||||
|
# Version 2.0 (the "License"); you may not use this file except
|
||||||
|
# in compliance with the License.
|
||||||
|
# You may obtain a copy of the License at
|
||||||
|
#
|
||||||
|
# http://www.apache.org/licenses/LICENSE-2.0
|
||||||
|
#
|
||||||
|
# Unless required by applicable law or agreed to in writing,
|
||||||
|
# software distributed under the License is distributed on an
|
||||||
|
# "AS IS" BASIS, WITHOUT WARRANTIES OR CONDITIONS OF ANY
|
||||||
|
# KIND, either express or implied. See the License for the
|
||||||
|
# specific language governing permissions and limitations
|
||||||
|
# under the License.
|
||||||
|
#
|
||||||
|
|
||||||
|
#
|
||||||
|
# This is the log4j configuration file used by WSO2 Carbon
|
||||||
|
#
|
||||||
|
# IMPORTANT : Please do not remove or change the names of any
|
||||||
|
# of the Appender defined here. The layout pattern & log file
|
||||||
|
# can be changed using the WSO2 Carbon Management Console, and those
|
||||||
|
# settings will override the settings in this file.
|
||||||
|
#
|
||||||
|
|
||||||
|
log4j.rootLogger=DEBUG, STD_OUT
|
||||||
|
|
||||||
|
# Redirect log messages to console
|
||||||
|
log4j.appender.STD_OUT=org.apache.log4j.ConsoleAppender
|
||||||
|
log4j.appender.STD_OUT.Target=System.out
|
||||||
|
log4j.appender.STD_OUT.layout=org.apache.log4j.PatternLayout
|
||||||
|
log4j.appender.STD_OUT.layout.ConversionPattern=%d{yyyy-MM-dd HH:mm:ss} %-5p %c{1}:%L - %m%n
|
@ -0,0 +1,656 @@
|
|||||||
|
<?xml version="1.0" encoding="ISO-8859-1"?>
|
||||||
|
|
||||||
|
<!--
|
||||||
|
~ Copyright 2005-2017 WSO2 Inc. (http://wso2.com)
|
||||||
|
~
|
||||||
|
~ Licensed under the Apache License, Version 2.0 (the "License");
|
||||||
|
~ you may not use this file except in compliance with the License.
|
||||||
|
~ You may obtain a copy of the License at
|
||||||
|
~
|
||||||
|
~ http://www.apache.org/licenses/LICENSE-2.0
|
||||||
|
~
|
||||||
|
~ Unless required by applicable law or agreed to in writing, software
|
||||||
|
~ distributed under the License is distributed on an "AS IS" BASIS,
|
||||||
|
~ WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
|
||||||
|
~ See the License for the specific language governing permissions and
|
||||||
|
~ limitations under the License.
|
||||||
|
-->
|
||||||
|
|
||||||
|
<!--
|
||||||
|
This is the main server configuration file
|
||||||
|
|
||||||
|
${carbon.home} represents the carbon.home system property.
|
||||||
|
Other system properties can be specified in a similar manner.
|
||||||
|
-->
|
||||||
|
<Server xmlns="http://wso2.org/projects/carbon/carbon.xml">
|
||||||
|
|
||||||
|
<!--
|
||||||
|
Product Name
|
||||||
|
-->
|
||||||
|
<Name>${product.name}</Name>
|
||||||
|
|
||||||
|
<!--
|
||||||
|
machine readable unique key to identify each product
|
||||||
|
-->
|
||||||
|
<ServerKey>${product.key}</ServerKey>
|
||||||
|
|
||||||
|
<!--
|
||||||
|
Product Version
|
||||||
|
-->
|
||||||
|
<Version>${product.version}</Version>
|
||||||
|
|
||||||
|
<!--
|
||||||
|
Host name or IP address of the machine hosting this server
|
||||||
|
e.g. www.wso2.org, 192.168.1.10
|
||||||
|
This is will become part of the End Point Reference of the
|
||||||
|
services deployed on this server instance.
|
||||||
|
-->
|
||||||
|
<!--HostName>www.wso2.org</HostName-->
|
||||||
|
|
||||||
|
<!--
|
||||||
|
Host name to be used for the Carbon management console
|
||||||
|
-->
|
||||||
|
<!--MgtHostName>mgt.wso2.org</MgtHostName-->
|
||||||
|
|
||||||
|
<!--
|
||||||
|
The URL of the back end server. This is where the admin services are hosted and
|
||||||
|
will be used by the clients in the front end server.
|
||||||
|
This is required only for the Front-end server. This is used when seperating BE server from FE server
|
||||||
|
-->
|
||||||
|
<ServerURL>local:/${carbon.context}/services/</ServerURL>
|
||||||
|
<!--
|
||||||
|
<ServerURL>https://${carbon.local.ip}:${carbon.management.port}${carbon.context}/services/</ServerURL>
|
||||||
|
-->
|
||||||
|
<!--
|
||||||
|
The URL of the index page. This is where the user will be redirected after signing in to the
|
||||||
|
carbon server.
|
||||||
|
-->
|
||||||
|
<!-- IndexPageURL>/carbon/admin/index.jsp</IndexPageURL-->
|
||||||
|
|
||||||
|
<!--
|
||||||
|
For cApp deployment, we have to identify the roles that can be acted by the current server.
|
||||||
|
The following property is used for that purpose. Any number of roles can be defined here.
|
||||||
|
Regular expressions can be used in the role.
|
||||||
|
Ex : <Role>.*</Role> means this server can act any role
|
||||||
|
-->
|
||||||
|
<ServerRoles>
|
||||||
|
<Role>${default.server.role}</Role>
|
||||||
|
</ServerRoles>
|
||||||
|
|
||||||
|
<!-- uncommnet this line to subscribe to a bam instance automatically -->
|
||||||
|
<!--<BamServerURL>https://bamhost:bamport/services/</BamServerURL>-->
|
||||||
|
|
||||||
|
<!--
|
||||||
|
The fully qualified name of the server
|
||||||
|
-->
|
||||||
|
<Package>org.wso2.carbon</Package>
|
||||||
|
|
||||||
|
<!--
|
||||||
|
Webapp context root of WSO2 Carbon management console.
|
||||||
|
-->
|
||||||
|
<WebContextRoot>/</WebContextRoot>
|
||||||
|
|
||||||
|
<!--
|
||||||
|
Proxy context path is a useful parameter to add a proxy path when a Carbon server is fronted by reverse proxy. In addtion
|
||||||
|
to the proxy host and proxy port this parameter allows you add a path component to external URLs. e.g.
|
||||||
|
URL of the Carbon server -> https://10.100.1.1:9443/carbon
|
||||||
|
URL of the reverse proxy -> https://prod.abc.com/appserver/carbon
|
||||||
|
|
||||||
|
appserver - proxy context path. This specially required whenever you are generating URLs to displace in
|
||||||
|
Carbon UI components.
|
||||||
|
-->
|
||||||
|
<!--
|
||||||
|
<MgtProxyContextPath></MgtProxyContextPath>
|
||||||
|
<ProxyContextPath></ProxyContextPath>
|
||||||
|
-->
|
||||||
|
|
||||||
|
<!-- In-order to get the registry http Port from the back-end when the default http transport is not the same-->
|
||||||
|
<!--RegistryHttpPort>9763</RegistryHttpPort-->
|
||||||
|
|
||||||
|
<!--
|
||||||
|
Number of items to be displayed on a management console page. This is used at the
|
||||||
|
backend server for pagination of various items.
|
||||||
|
-->
|
||||||
|
<ItemsPerPage>15</ItemsPerPage>
|
||||||
|
|
||||||
|
<!-- The endpoint URL of the cloud instance management Web service -->
|
||||||
|
<!--<InstanceMgtWSEndpoint>https://ec2.amazonaws.com/</InstanceMgtWSEndpoint>-->
|
||||||
|
|
||||||
|
<!--
|
||||||
|
Ports used by this server
|
||||||
|
-->
|
||||||
|
<Ports>
|
||||||
|
|
||||||
|
<!-- Ports offset. This entry will set the value of the ports defined below to
|
||||||
|
the define value + Offset.
|
||||||
|
e.g. Offset=2 and HTTPS port=9443 will set the effective HTTPS port to 9445
|
||||||
|
-->
|
||||||
|
<Offset>0</Offset>
|
||||||
|
|
||||||
|
<!-- The JMX Ports -->
|
||||||
|
<JMX>
|
||||||
|
<!--The port RMI registry is exposed-->
|
||||||
|
<RMIRegistryPort>9999</RMIRegistryPort>
|
||||||
|
<!--The port RMI server should be exposed-->
|
||||||
|
<RMIServerPort>11111</RMIServerPort>
|
||||||
|
</JMX>
|
||||||
|
|
||||||
|
<!-- Embedded LDAP server specific ports -->
|
||||||
|
<EmbeddedLDAP>
|
||||||
|
<!-- Port which embedded LDAP server runs -->
|
||||||
|
<LDAPServerPort>10389</LDAPServerPort>
|
||||||
|
<!-- Port which KDC (Kerberos Key Distribution Center) server runs -->
|
||||||
|
<KDCServerPort>8000</KDCServerPort>
|
||||||
|
</EmbeddedLDAP>
|
||||||
|
|
||||||
|
<!--
|
||||||
|
Override datasources JNDIproviderPort defined in bps.xml and datasources.properties files
|
||||||
|
-->
|
||||||
|
<!--<JNDIProviderPort>2199</JNDIProviderPort>-->
|
||||||
|
<!--Override receive port of thrift based entitlement service.-->
|
||||||
|
<ThriftEntitlementReceivePort>10500</ThriftEntitlementReceivePort>
|
||||||
|
|
||||||
|
</Ports>
|
||||||
|
|
||||||
|
<!--
|
||||||
|
JNDI Configuration
|
||||||
|
-->
|
||||||
|
<JNDI>
|
||||||
|
<!--
|
||||||
|
The fully qualified name of the default initial context factory
|
||||||
|
-->
|
||||||
|
<DefaultInitialContextFactory>org.wso2.carbon.tomcat.jndi.CarbonJavaURLContextFactory</DefaultInitialContextFactory>
|
||||||
|
<!--
|
||||||
|
The restrictions that are done to various JNDI Contexts in a Multi-tenant environment
|
||||||
|
-->
|
||||||
|
<Restrictions>
|
||||||
|
<!--
|
||||||
|
Contexts that will be available only to the super-tenant
|
||||||
|
-->
|
||||||
|
<!-- <SuperTenantOnly>
|
||||||
|
<UrlContexts>
|
||||||
|
<UrlContext>
|
||||||
|
<Scheme>foo</Scheme>
|
||||||
|
</UrlContext>
|
||||||
|
<UrlContext>
|
||||||
|
<Scheme>bar</Scheme>
|
||||||
|
</UrlContext>
|
||||||
|
</UrlContexts>
|
||||||
|
</SuperTenantOnly> -->
|
||||||
|
<!--
|
||||||
|
Contexts that are common to all tenants
|
||||||
|
-->
|
||||||
|
<AllTenants>
|
||||||
|
<UrlContexts>
|
||||||
|
<UrlContext>
|
||||||
|
<Scheme>java</Scheme>
|
||||||
|
</UrlContext>
|
||||||
|
<!-- <UrlContext>
|
||||||
|
<Scheme>foo</Scheme>
|
||||||
|
</UrlContext> -->
|
||||||
|
</UrlContexts>
|
||||||
|
</AllTenants>
|
||||||
|
<!--
|
||||||
|
All other contexts not mentioned above will be available on a per-tenant basis
|
||||||
|
(i.e. will not be shared among tenants)
|
||||||
|
-->
|
||||||
|
</Restrictions>
|
||||||
|
</JNDI>
|
||||||
|
|
||||||
|
<!--
|
||||||
|
Property to determine if the server is running an a cloud deployment environment.
|
||||||
|
This property should only be used to determine deployment specific details that are
|
||||||
|
applicable only in a cloud deployment, i.e when the server deployed *-as-a-service.
|
||||||
|
-->
|
||||||
|
<IsCloudDeployment>false</IsCloudDeployment>
|
||||||
|
|
||||||
|
<!--
|
||||||
|
Property to determine whether usage data should be collected for metering purposes
|
||||||
|
-->
|
||||||
|
<EnableMetering>false</EnableMetering>
|
||||||
|
|
||||||
|
<!-- The Max time a thread should take for execution in seconds -->
|
||||||
|
<MaxThreadExecutionTime>600</MaxThreadExecutionTime>
|
||||||
|
|
||||||
|
<!--
|
||||||
|
A flag to enable or disable Ghost Deployer. By default this is set to false. That is
|
||||||
|
because the Ghost Deployer works only with the HTTP/S transports. If you are using
|
||||||
|
other transports, don't enable Ghost Deployer.
|
||||||
|
-->
|
||||||
|
<GhostDeployment>
|
||||||
|
<Enabled>false</Enabled>
|
||||||
|
</GhostDeployment>
|
||||||
|
|
||||||
|
|
||||||
|
<!--
|
||||||
|
Eager loading or lazy loading is a design pattern commonly used in computer programming which
|
||||||
|
will initialize an object upon creation or load on-demand. In carbon, lazy loading is used to
|
||||||
|
load tenant when a request is received only. Similarly Eager loading is used to enable load
|
||||||
|
existing tenants after carbon server starts up. Using this feature, you will be able to include
|
||||||
|
or exclude tenants which are to be loaded when server startup.
|
||||||
|
|
||||||
|
We can enable only one LoadingPolicy at a given time.
|
||||||
|
|
||||||
|
1. Tenant Lazy Loading
|
||||||
|
This is the default behaviour and enabled by default. With this policy, tenants are not loaded at
|
||||||
|
server startup, but loaded based on-demand (i.e when a request is received for a tenant).
|
||||||
|
The default tenant idle time is 30 minutes.
|
||||||
|
|
||||||
|
2. Tenant Eager Loading
|
||||||
|
This is by default not enabled. It can be be enabled by un-commenting the <EagerLoading> section.
|
||||||
|
The eager loading configurations supported are as below. These configurations can be given as the
|
||||||
|
value for <Include> element with eager loading.
|
||||||
|
(i)Load all tenants when server startup - *
|
||||||
|
(ii)Load all tenants except foo.com & bar.com - *,!foo.com,!bar.com
|
||||||
|
(iii)Load only foo.com & bar.com to be included - foo.com,bar.com
|
||||||
|
-->
|
||||||
|
<Tenant>
|
||||||
|
<LoadingPolicy>
|
||||||
|
<LazyLoading>
|
||||||
|
<IdleTime>30</IdleTime>
|
||||||
|
</LazyLoading>
|
||||||
|
<!-- <EagerLoading>
|
||||||
|
<Include>*,!foo.com,!bar.com</Include>
|
||||||
|
</EagerLoading>-->
|
||||||
|
</LoadingPolicy>
|
||||||
|
</Tenant>
|
||||||
|
|
||||||
|
<!--
|
||||||
|
Caching related configurations
|
||||||
|
-->
|
||||||
|
<Cache>
|
||||||
|
<!-- Default cache timeout in minutes -->
|
||||||
|
<DefaultCacheTimeout>15</DefaultCacheTimeout>
|
||||||
|
</Cache>
|
||||||
|
|
||||||
|
<!--
|
||||||
|
Axis2 related configurations
|
||||||
|
-->
|
||||||
|
<Axis2Config>
|
||||||
|
<!--
|
||||||
|
Location of the Axis2 Services & Modules repository
|
||||||
|
|
||||||
|
This can be a directory in the local file system, or a URL.
|
||||||
|
|
||||||
|
e.g.
|
||||||
|
1. /home/wso2wsas/repository/ - An absolute path
|
||||||
|
2. repository - In this case, the path is relative to CARBON_HOME
|
||||||
|
3. file:///home/wso2wsas/repository/
|
||||||
|
4. http://wso2wsas/repository/
|
||||||
|
-->
|
||||||
|
<RepositoryLocation>${carbon.home}/repository/deployment/server/</RepositoryLocation>
|
||||||
|
|
||||||
|
<!--
|
||||||
|
Deployment update interval in seconds. This is the interval between repository listener
|
||||||
|
executions.
|
||||||
|
-->
|
||||||
|
<DeploymentUpdateInterval>15</DeploymentUpdateInterval>
|
||||||
|
|
||||||
|
<!--
|
||||||
|
Location of the main Axis2 configuration descriptor file, a.k.a. axis2.xml file
|
||||||
|
|
||||||
|
This can be a file on the local file system, or a URL
|
||||||
|
|
||||||
|
e.g.
|
||||||
|
1. /home/repository/axis2.xml - An absolute path
|
||||||
|
2. conf/axis2.xml - In this case, the path is relative to CARBON_HOME
|
||||||
|
3. file:///home/carbon/repository/axis2.xml
|
||||||
|
4. http://repository/conf/axis2.xml
|
||||||
|
-->
|
||||||
|
<ConfigurationFile>${carbon.home}/repository/conf/axis2/axis2.xml</ConfigurationFile>
|
||||||
|
|
||||||
|
<!--
|
||||||
|
ServiceGroupContextIdleTime, which will be set in ConfigurationContex
|
||||||
|
for multiple clients which are going to access the same ServiceGroupContext
|
||||||
|
Default Value is 30 Sec.
|
||||||
|
-->
|
||||||
|
<ServiceGroupContextIdleTime>30000</ServiceGroupContextIdleTime>
|
||||||
|
|
||||||
|
<!--
|
||||||
|
This repository location is used to crete the client side configuration
|
||||||
|
context used by the server when calling admin services.
|
||||||
|
-->
|
||||||
|
<ClientRepositoryLocation>${carbon.home}/repository/deployment/client/</ClientRepositoryLocation>
|
||||||
|
<!-- This axis2 xml is used in createing the configuration context by the FE server
|
||||||
|
calling to BE server -->
|
||||||
|
<clientAxis2XmlLocation>${carbon.home}/repository/conf/axis2/axis2_client.xml</clientAxis2XmlLocation>
|
||||||
|
<!-- If this parameter is set, the ?wsdl on an admin service will not give the admin service wsdl. -->
|
||||||
|
<HideAdminServiceWSDLs>true</HideAdminServiceWSDLs>
|
||||||
|
|
||||||
|
<!--WARNING-Use With Care! Uncommenting bellow parameter would expose all AdminServices in HTTP transport.
|
||||||
|
With HTTP transport your credentials and data routed in public channels are vulnerable for sniffing attacks.
|
||||||
|
Use bellow parameter ONLY if your communication channels are confirmed to be secured by other means -->
|
||||||
|
<!--HttpAdminServices>*</HttpAdminServices-->
|
||||||
|
|
||||||
|
</Axis2Config>
|
||||||
|
|
||||||
|
<!--
|
||||||
|
The default user roles which will be created when the server
|
||||||
|
is started up for the first time.
|
||||||
|
-->
|
||||||
|
<ServiceUserRoles>
|
||||||
|
<Role>
|
||||||
|
<Name>admin</Name>
|
||||||
|
<Description>Default Administrator Role</Description>
|
||||||
|
</Role>
|
||||||
|
<Role>
|
||||||
|
<Name>user</Name>
|
||||||
|
<Description>Default User Role</Description>
|
||||||
|
</Role>
|
||||||
|
</ServiceUserRoles>
|
||||||
|
|
||||||
|
<!--
|
||||||
|
Enable following config to allow Emails as usernames.
|
||||||
|
-->
|
||||||
|
<!--EnableEmailUserName>true</EnableEmailUserName-->
|
||||||
|
|
||||||
|
<!--
|
||||||
|
Security configurations
|
||||||
|
-->
|
||||||
|
<Security>
|
||||||
|
<!--
|
||||||
|
KeyStore which will be used for encrypting/decrypting passwords
|
||||||
|
and other sensitive information.
|
||||||
|
-->
|
||||||
|
<KeyStore>
|
||||||
|
<!-- Keystore file location-->
|
||||||
|
<Location>${carbon.home}/repository/resources/security/wso2carbon.jks</Location>
|
||||||
|
<!-- Keystore type (JKS/PKCS12 etc.)-->
|
||||||
|
<Type>JKS</Type>
|
||||||
|
<!-- Keystore password-->
|
||||||
|
<Password>wso2carbon</Password>
|
||||||
|
<!-- Private Key alias-->
|
||||||
|
<KeyAlias>wso2carbon</KeyAlias>
|
||||||
|
<!-- Private Key password-->
|
||||||
|
<KeyPassword>wso2carbon</KeyPassword>
|
||||||
|
</KeyStore>
|
||||||
|
|
||||||
|
<!--
|
||||||
|
System wide trust-store which is used to maintain the certificates of all
|
||||||
|
the trusted parties.
|
||||||
|
-->
|
||||||
|
<TrustStore>
|
||||||
|
<!-- trust-store file location -->
|
||||||
|
<Location>${carbon.home}/repository/resources/security/client-truststore.jks</Location>
|
||||||
|
<!-- trust-store type (JKS/PKCS12 etc.) -->
|
||||||
|
<Type>JKS</Type>
|
||||||
|
<!-- trust-store password -->
|
||||||
|
<Password>wso2carbon</Password>
|
||||||
|
</TrustStore>
|
||||||
|
|
||||||
|
<!--
|
||||||
|
The Authenticator configuration to be used at the JVM level. We extend the
|
||||||
|
java.net.Authenticator to make it possible to authenticate to given servers and
|
||||||
|
proxies.
|
||||||
|
-->
|
||||||
|
<NetworkAuthenticatorConfig>
|
||||||
|
<!--
|
||||||
|
Below is a sample configuration for a single authenticator. Please note that
|
||||||
|
all child elements are mandatory. Not having some child elements would lead to
|
||||||
|
exceptions at runtime.
|
||||||
|
-->
|
||||||
|
<!-- <Credential> -->
|
||||||
|
<!--
|
||||||
|
the pattern that would match a subset of URLs for which this authenticator
|
||||||
|
would be used
|
||||||
|
-->
|
||||||
|
<!-- <Pattern>regularExpression</Pattern> -->
|
||||||
|
<!--
|
||||||
|
the type of this authenticator. Allowed values are:
|
||||||
|
1. server
|
||||||
|
2. proxy
|
||||||
|
-->
|
||||||
|
<!-- <Type>proxy</Type> -->
|
||||||
|
<!-- the username used to log in to server/proxy -->
|
||||||
|
<!-- <Username>username</Username> -->
|
||||||
|
<!-- the password used to log in to server/proxy -->
|
||||||
|
<!-- <Password>password</Password> -->
|
||||||
|
<!-- </Credential> -->
|
||||||
|
</NetworkAuthenticatorConfig>
|
||||||
|
|
||||||
|
<!--
|
||||||
|
The Tomcat realm to be used for hosted Web applications. Allowed values are;
|
||||||
|
1. UserManager
|
||||||
|
2. Memory
|
||||||
|
|
||||||
|
If this is set to 'UserManager', the realm will pick users & roles from the system's
|
||||||
|
WSO2 User Manager. If it is set to 'memory', the realm will pick users & roles from
|
||||||
|
CARBON_HOME/repository/conf/tomcat/tomcat-users.xml
|
||||||
|
-->
|
||||||
|
<TomcatRealm>UserManager</TomcatRealm>
|
||||||
|
|
||||||
|
<!--Option to disable storing of tokens issued by STS-->
|
||||||
|
<DisableTokenStore>false</DisableTokenStore>
|
||||||
|
|
||||||
|
<!--
|
||||||
|
Security token store class name. If this is not set, default class will be
|
||||||
|
org.wso2.carbon.security.util.SecurityTokenStore
|
||||||
|
-->
|
||||||
|
<!--TokenStoreClassName>org.wso2.carbon.identity.sts.store.DBTokenStore</TokenStoreClassName-->
|
||||||
|
</Security>
|
||||||
|
|
||||||
|
<!--
|
||||||
|
The temporary work directory
|
||||||
|
-->
|
||||||
|
<WorkDirectory>${carbon.home}/tmp/work</WorkDirectory>
|
||||||
|
|
||||||
|
<!--
|
||||||
|
House-keeping configuration
|
||||||
|
-->
|
||||||
|
<HouseKeeping>
|
||||||
|
|
||||||
|
<!--
|
||||||
|
true - Start House-keeping thread on server startup
|
||||||
|
false - Do not start House-keeping thread on server startup.
|
||||||
|
The user will run it manually as and when he wishes.
|
||||||
|
-->
|
||||||
|
<AutoStart>true</AutoStart>
|
||||||
|
|
||||||
|
<!--
|
||||||
|
The interval in *minutes*, between house-keeping runs
|
||||||
|
-->
|
||||||
|
<Interval>10</Interval>
|
||||||
|
|
||||||
|
<!--
|
||||||
|
The maximum time in *minutes*, temp files are allowed to live
|
||||||
|
in the system. Files/directories which were modified more than
|
||||||
|
"MaxTempFileLifetime" minutes ago will be removed by the
|
||||||
|
house-keeping task
|
||||||
|
-->
|
||||||
|
<MaxTempFileLifetime>30</MaxTempFileLifetime>
|
||||||
|
</HouseKeeping>
|
||||||
|
|
||||||
|
<!--
|
||||||
|
Configuration for handling different types of file upload & other file uploading related
|
||||||
|
config parameters.
|
||||||
|
To map all actions to a particular FileUploadExecutor, use
|
||||||
|
<Action>*</Action>
|
||||||
|
-->
|
||||||
|
<FileUploadConfig>
|
||||||
|
<!--
|
||||||
|
The total file upload size limit in MB
|
||||||
|
-->
|
||||||
|
<TotalFileSizeLimit>100</TotalFileSizeLimit>
|
||||||
|
|
||||||
|
<Mapping>
|
||||||
|
<Actions>
|
||||||
|
<Action>keystore</Action>
|
||||||
|
<Action>certificate</Action>
|
||||||
|
<Action>*</Action>
|
||||||
|
</Actions>
|
||||||
|
<Class>org.wso2.carbon.ui.transports.fileupload.AnyFileUploadExecutor</Class>
|
||||||
|
</Mapping>
|
||||||
|
|
||||||
|
<Mapping>
|
||||||
|
<Actions>
|
||||||
|
<Action>jarZip</Action>
|
||||||
|
</Actions>
|
||||||
|
<Class>org.wso2.carbon.ui.transports.fileupload.JarZipUploadExecutor</Class>
|
||||||
|
</Mapping>
|
||||||
|
<Mapping>
|
||||||
|
<Actions>
|
||||||
|
<Action>dbs</Action>
|
||||||
|
</Actions>
|
||||||
|
<Class>org.wso2.carbon.ui.transports.fileupload.DBSFileUploadExecutor</Class>
|
||||||
|
</Mapping>
|
||||||
|
<Mapping>
|
||||||
|
<Actions>
|
||||||
|
<Action>tools</Action>
|
||||||
|
</Actions>
|
||||||
|
<Class>org.wso2.carbon.ui.transports.fileupload.ToolsFileUploadExecutor</Class>
|
||||||
|
</Mapping>
|
||||||
|
<Mapping>
|
||||||
|
<Actions>
|
||||||
|
<Action>toolsAny</Action>
|
||||||
|
</Actions>
|
||||||
|
<Class>org.wso2.carbon.ui.transports.fileupload.ToolsAnyFileUploadExecutor</Class>
|
||||||
|
</Mapping>
|
||||||
|
</FileUploadConfig>
|
||||||
|
|
||||||
|
<!--
|
||||||
|
Processors which process special HTTP GET requests such as ?wsdl, ?policy etc.
|
||||||
|
|
||||||
|
In order to plug in a processor to handle a special request, simply add an entry to this
|
||||||
|
section.
|
||||||
|
|
||||||
|
The value of the Item element is the first parameter in the query string(e.g. ?wsdl)
|
||||||
|
which needs special processing
|
||||||
|
|
||||||
|
The value of the Class element is a class which implements
|
||||||
|
org.wso2.carbon.transport.HttpGetRequestProcessor
|
||||||
|
-->
|
||||||
|
<HttpGetRequestProcessors>
|
||||||
|
<Processor>
|
||||||
|
<Item>info</Item>
|
||||||
|
<Class>org.wso2.carbon.core.transports.util.InfoProcessor</Class>
|
||||||
|
</Processor>
|
||||||
|
<Processor>
|
||||||
|
<Item>wsdl</Item>
|
||||||
|
<Class>org.wso2.carbon.core.transports.util.Wsdl11Processor</Class>
|
||||||
|
</Processor>
|
||||||
|
<Processor>
|
||||||
|
<Item>wsdl2</Item>
|
||||||
|
<Class>org.wso2.carbon.core.transports.util.Wsdl20Processor</Class>
|
||||||
|
</Processor>
|
||||||
|
<Processor>
|
||||||
|
<Item>xsd</Item>
|
||||||
|
<Class>org.wso2.carbon.core.transports.util.XsdProcessor</Class>
|
||||||
|
</Processor>
|
||||||
|
</HttpGetRequestProcessors>
|
||||||
|
|
||||||
|
<!-- Deployment Synchronizer Configuration. t Enabled value to true when running with "svn based" dep sync.
|
||||||
|
In master nodes you need to set both AutoCommit and AutoCheckout to true
|
||||||
|
and in worker nodes set only AutoCheckout to true.
|
||||||
|
-->
|
||||||
|
<DeploymentSynchronizer>
|
||||||
|
<Enabled>false</Enabled>
|
||||||
|
<AutoCommit>false</AutoCommit>
|
||||||
|
<AutoCheckout>true</AutoCheckout>
|
||||||
|
<RepositoryType>svn</RepositoryType>
|
||||||
|
<SvnUrl>http://svnrepo.example.com/repos/</SvnUrl>
|
||||||
|
<SvnUser>username</SvnUser>
|
||||||
|
<SvnPassword>password</SvnPassword>
|
||||||
|
<SvnUrlAppendTenantId>true</SvnUrlAppendTenantId>
|
||||||
|
</DeploymentSynchronizer>
|
||||||
|
|
||||||
|
<!-- Deployment Synchronizer Configuration. Uncomment the following section when running with "registry based" dep sync.
|
||||||
|
In master nodes you need to set both AutoCommit and AutoCheckout to true
|
||||||
|
and in worker nodes set only AutoCheckout to true.
|
||||||
|
-->
|
||||||
|
<!--<DeploymentSynchronizer>
|
||||||
|
<Enabled>true</Enabled>
|
||||||
|
<AutoCommit>false</AutoCommit>
|
||||||
|
<AutoCheckout>true</AutoCheckout>
|
||||||
|
</DeploymentSynchronizer>-->
|
||||||
|
|
||||||
|
<!-- Mediation persistence configurations. Only valid if mediation features are available i.e. ESB -->
|
||||||
|
<!--<MediationConfig>
|
||||||
|
<LoadFromRegistry>false</LoadFromRegistry>
|
||||||
|
<SaveToFile>false</SaveToFile>
|
||||||
|
<Persistence>enabled</Persistence>
|
||||||
|
<RegistryPersistence>enabled</RegistryPersistence>
|
||||||
|
</MediationConfig>-->
|
||||||
|
|
||||||
|
<!--
|
||||||
|
Server intializing code, specified as implementation classes of org.wso2.carbon.core.ServerInitializer.
|
||||||
|
This code will be run when the Carbon server is initialized
|
||||||
|
-->
|
||||||
|
<ServerInitializers>
|
||||||
|
<!--<Initializer></Initializer>-->
|
||||||
|
</ServerInitializers>
|
||||||
|
|
||||||
|
<!--
|
||||||
|
Indicates whether the Carbon Servlet is required by the system, and whether it should be
|
||||||
|
registered
|
||||||
|
-->
|
||||||
|
<RequireCarbonServlet>${require.carbon.servlet}</RequireCarbonServlet>
|
||||||
|
|
||||||
|
<!--
|
||||||
|
Carbon H2 OSGI Configuration
|
||||||
|
By default non of the servers start.
|
||||||
|
name="web" - Start the web server with the H2 Console
|
||||||
|
name="webPort" - The port (default: 8082)
|
||||||
|
name="webAllowOthers" - Allow other computers to connect
|
||||||
|
name="webSSL" - Use encrypted (HTTPS) connections
|
||||||
|
name="tcp" - Start the TCP server
|
||||||
|
name="tcpPort" - The port (default: 9092)
|
||||||
|
name="tcpAllowOthers" - Allow other computers to connect
|
||||||
|
name="tcpSSL" - Use encrypted (SSL) connections
|
||||||
|
name="pg" - Start the PG server
|
||||||
|
name="pgPort" - The port (default: 5435)
|
||||||
|
name="pgAllowOthers" - Allow other computers to connect
|
||||||
|
name="trace" - Print additional trace information; for all servers
|
||||||
|
name="baseDir" - The base directory for H2 databases; for all servers
|
||||||
|
-->
|
||||||
|
<!--H2DatabaseConfiguration>
|
||||||
|
<property name="web" />
|
||||||
|
<property name="webPort">8082</property>
|
||||||
|
<property name="webAllowOthers" />
|
||||||
|
<property name="webSSL" />
|
||||||
|
<property name="tcp" />
|
||||||
|
<property name="tcpPort">9092</property>
|
||||||
|
<property name="tcpAllowOthers" />
|
||||||
|
<property name="tcpSSL" />
|
||||||
|
<property name="pg" />
|
||||||
|
<property name="pgPort">5435</property>
|
||||||
|
<property name="pgAllowOthers" />
|
||||||
|
<property name="trace" />
|
||||||
|
<property name="baseDir">${carbon.home}</property>
|
||||||
|
</H2DatabaseConfiguration-->
|
||||||
|
<!--Disabling statistics reporter by default-->
|
||||||
|
<StatisticsReporterDisabled>true</StatisticsReporterDisabled>
|
||||||
|
|
||||||
|
<!-- Enable accessing Admin Console via HTTP -->
|
||||||
|
<!-- EnableHTTPAdminConsole>true</EnableHTTPAdminConsole -->
|
||||||
|
|
||||||
|
<!--
|
||||||
|
Default Feature Repository of WSO2 Carbon.
|
||||||
|
-->
|
||||||
|
<FeatureRepository>
|
||||||
|
<RepositoryName>default repository</RepositoryName>
|
||||||
|
<RepositoryURL>${p2.repo.url}</RepositoryURL>
|
||||||
|
</FeatureRepository>
|
||||||
|
|
||||||
|
<!--
|
||||||
|
Configure API Management
|
||||||
|
-->
|
||||||
|
<APIManagement>
|
||||||
|
|
||||||
|
<!--Uses the embedded API Manager by default. If you want to use an external
|
||||||
|
API Manager instance to manage APIs, configure below externalAPIManager-->
|
||||||
|
|
||||||
|
<Enabled>true</Enabled>
|
||||||
|
|
||||||
|
<!--Uncomment and configure API Gateway and
|
||||||
|
Publisher URLs to use external API Manager instance-->
|
||||||
|
|
||||||
|
<!--ExternalAPIManager>
|
||||||
|
|
||||||
|
<APIGatewayURL>http://localhost:8281</APIGatewayURL>
|
||||||
|
<APIPublisherURL>http://localhost:8281/publisher</APIPublisherURL>
|
||||||
|
|
||||||
|
</ExternalAPIManager-->
|
||||||
|
|
||||||
|
<LoadAPIContextsInServerStartup>true</LoadAPIContextsInServerStartup>
|
||||||
|
</APIManagement>
|
||||||
|
</Server>
|
@ -0,0 +1,28 @@
|
|||||||
|
<!--
|
||||||
|
~ Copyright (c) 2017, WSO2 Inc. (http://www.wso2.org) All Rights Reserved.
|
||||||
|
~
|
||||||
|
~ WSO2 Inc. licenses this file to you under the Apache License,
|
||||||
|
~ Version 2.0 (the "License"); you may not use this file except
|
||||||
|
~ in compliance with the License.
|
||||||
|
~ you may obtain a copy of the License at
|
||||||
|
~
|
||||||
|
~ http://www.apache.org/licenses/LICENSE-2.0
|
||||||
|
~
|
||||||
|
~ Unless required by applicable law or agreed to in writing,
|
||||||
|
~ software distributed under the License is distributed on an
|
||||||
|
~ "AS IS" BASIS, WITHOUT WARRANTIES OR CONDITIONS OF ANY
|
||||||
|
~ KIND, either express or implied. See the License for the
|
||||||
|
~ specific language governing permissions and limitations
|
||||||
|
~ under the License.
|
||||||
|
-->
|
||||||
|
|
||||||
|
<!DOCTYPE suite SYSTEM "http://testng.org/testng-1.0.dtd" >
|
||||||
|
|
||||||
|
<suite name="DeviceManagementCore">
|
||||||
|
<parameter name="useDefaultListeners" value="false"/>
|
||||||
|
<test name="Extension Unit Tests" preserve-order="true">
|
||||||
|
<classes>
|
||||||
|
<class name="org.wso2.carbon.device.mgt.extensions.device.type.deployer.DeviceTypePluginDeployerTest"/>
|
||||||
|
</classes>
|
||||||
|
</test>
|
||||||
|
</suite>
|
Loading…
Reference in new issue