|
|
|
@ -47,64 +47,23 @@ import java.util.List;
|
|
|
|
|
public class SubscriptionManagerImpl implements SubscriptionManager {
|
|
|
|
|
|
|
|
|
|
private static final Log log = LogFactory.getLog(SubscriptionManagerImpl.class);
|
|
|
|
|
private static final String INSTALL_APPLICATION = "INSTALL_APPLICATION";
|
|
|
|
|
|
|
|
|
|
@Override
|
|
|
|
|
public List<DeviceIdentifier> installApplicationForDevices(String applicationUUID, String versionName,
|
|
|
|
|
List<DeviceIdentifier> deviceList)
|
|
|
|
|
throws ApplicationManagementException {
|
|
|
|
|
|
|
|
|
|
// Todo: try whether we can optimise this by sending bulk inserts to db
|
|
|
|
|
// Todo: atomicity is not maintained as deveice managment provider service uses separate db connection. fix this??
|
|
|
|
|
log.info("Install application: " + applicationUUID + " to: " + deviceList.size() + " devices.");
|
|
|
|
|
List<DeviceIdentifier> failedDeviceList = new ArrayList<>(deviceList);
|
|
|
|
|
for (DeviceIdentifier device : deviceList) {
|
|
|
|
|
org.wso2.carbon.device.mgt.common.DeviceIdentifier deviceIdentifier = new org.wso2.carbon.device.mgt
|
|
|
|
|
.common.DeviceIdentifier(device.getId(), device.getType());
|
|
|
|
|
try {
|
|
|
|
|
DeviceManagementProviderService dmpService = DataHolder.getInstance().getDeviceManagementService();
|
|
|
|
|
if (!dmpService.isEnrolled(deviceIdentifier)) {
|
|
|
|
|
log.error("Device with ID: " + device.getId() + " is not enrolled to install the application.");
|
|
|
|
|
} else {
|
|
|
|
|
if (log.isDebugEnabled()) {
|
|
|
|
|
log.debug("Installing application to : " + device.getId());
|
|
|
|
|
}
|
|
|
|
|
//Todo: generating one time download link for the application and put install operation to device.
|
|
|
|
|
|
|
|
|
|
// put app install operation to the device
|
|
|
|
|
ProfileOperation operation = new ProfileOperation();
|
|
|
|
|
operation.setCode("INSTALL_APPLICATION");
|
|
|
|
|
operation.setType(Operation.Type.PROFILE);
|
|
|
|
|
operation.setPayLoad("{'type':'enterprise', 'url':'http://10.100.5.76:8000/app-debug.apk', 'app':'" + applicationUUID + "'}");
|
|
|
|
|
List<org.wso2.carbon.device.mgt.common.DeviceIdentifier> deviceIdentifiers = new ArrayList<>();
|
|
|
|
|
deviceIdentifiers.add(deviceIdentifier);
|
|
|
|
|
DeviceManagementProviderService deviceManagementProviderService = HelperUtil.getDeviceManagementProviderService();
|
|
|
|
|
deviceManagementProviderService.addOperation(DeviceManagementConstants.MobileDeviceTypes.MOBILE_DEVICE_TYPE_ANDROID,
|
|
|
|
|
operation, deviceIdentifiers);
|
|
|
|
|
|
|
|
|
|
DeviceApplicationMapping deviceApp = new DeviceApplicationMapping();
|
|
|
|
|
deviceApp.setDeviceIdentifier(device.getId());
|
|
|
|
|
deviceApp.setApplicationUUID(applicationUUID);
|
|
|
|
|
deviceApp.setVersionName(versionName);
|
|
|
|
|
deviceApp.setInstalled(false);
|
|
|
|
|
deviceManagementProviderService.addDeviceApplicationMapping(deviceApp);
|
|
|
|
|
// DAOFactory.getSubscriptionDAO().addDeviceApplicationMapping(device.getId(), applicationUUID, false);
|
|
|
|
|
failedDeviceList.remove(device);
|
|
|
|
|
}
|
|
|
|
|
} catch (DeviceManagementException | OperationManagementException | InvalidDeviceException e) {
|
|
|
|
|
throw new ApplicationManagementException("Failed to install application " + applicationUUID + " on device " + deviceIdentifier, e);
|
|
|
|
|
}
|
|
|
|
|
}
|
|
|
|
|
return failedDeviceList;
|
|
|
|
|
return installApplication(applicationUUID, deviceList, versionName);
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
@Override
|
|
|
|
|
public List<DeviceIdentifier> installApplicationForUsers(String applicationUUID, List<String> userList)
|
|
|
|
|
throws ApplicationManagementException {
|
|
|
|
|
public List<DeviceIdentifier> installApplicationForUsers(String applicationUUID, List<String> userList,
|
|
|
|
|
String versionName) throws ApplicationManagementException {
|
|
|
|
|
log.info("Install application: " + applicationUUID + " to: " + userList.size() + " users.");
|
|
|
|
|
List<DeviceIdentifier> deviceList = new ArrayList<>();
|
|
|
|
|
for (String user : userList) {
|
|
|
|
|
try {
|
|
|
|
|
List<Device> devicesOfUser = DataHolder.getInstance().getDeviceManagementService().getDevicesOfUser(user);
|
|
|
|
|
List<Device> devicesOfUser = HelperUtil.getDeviceManagementProviderService().getDevicesOfUser(user);
|
|
|
|
|
for (Device device : devicesOfUser) {
|
|
|
|
|
deviceList.add(new DeviceIdentifier(device
|
|
|
|
|
.getDeviceIdentifier(), device.getType()));
|
|
|
|
@ -113,17 +72,17 @@ public class SubscriptionManagerImpl implements SubscriptionManager {
|
|
|
|
|
log.error("Error when extracting the device list from user[" + user + "].", e);
|
|
|
|
|
}
|
|
|
|
|
}
|
|
|
|
|
return installApplication(applicationUUID, deviceList);
|
|
|
|
|
return installApplication(applicationUUID, deviceList, versionName);
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
@Override
|
|
|
|
|
public List<DeviceIdentifier> installApplicationForRoles(String applicationUUID, List<String> roleList)
|
|
|
|
|
throws ApplicationManagementException {
|
|
|
|
|
public List<DeviceIdentifier> installApplicationForRoles(String applicationUUID, List<String> roleList,
|
|
|
|
|
String versionName) throws ApplicationManagementException {
|
|
|
|
|
log.info("Install application: " + applicationUUID + " to: " + roleList.size() + " roles.");
|
|
|
|
|
List<DeviceIdentifier> deviceList = new ArrayList<>();
|
|
|
|
|
for (String role : roleList) {
|
|
|
|
|
try {
|
|
|
|
|
List<Device> devicesOfRole = DataHolder.getInstance().getDeviceManagementService().getAllDevicesOfRole(role);
|
|
|
|
|
List<Device> devicesOfRole = HelperUtil.getDeviceManagementProviderService().getAllDevicesOfRole(role);
|
|
|
|
|
for (Device device : devicesOfRole) {
|
|
|
|
|
deviceList.add(new DeviceIdentifier(device
|
|
|
|
|
.getDeviceIdentifier(), device.getType()));
|
|
|
|
@ -132,7 +91,7 @@ public class SubscriptionManagerImpl implements SubscriptionManager {
|
|
|
|
|
log.error("Error when extracting the device list from role[" + role + "].", e);
|
|
|
|
|
}
|
|
|
|
|
}
|
|
|
|
|
return installApplication(applicationUUID, deviceList);
|
|
|
|
|
return installApplication(applicationUUID, deviceList, versionName);
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
@Override
|
|
|
|
@ -142,32 +101,54 @@ public class SubscriptionManagerImpl implements SubscriptionManager {
|
|
|
|
|
return null;
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
private List<DeviceIdentifier> installApplication(String applicationUUID, List<DeviceIdentifier> deviceList)
|
|
|
|
|
throws ApplicationManagementException {
|
|
|
|
|
private List<DeviceIdentifier> installApplication(String applicationUUID, List<DeviceIdentifier> deviceList,
|
|
|
|
|
String versionName) throws ApplicationManagementException {
|
|
|
|
|
List<DeviceIdentifier> failedDeviceList = new ArrayList<>(deviceList);
|
|
|
|
|
List<org.wso2.carbon.device.mgt.common.DeviceIdentifier> activeDeviceList = new ArrayList<>();
|
|
|
|
|
// Todo: try whether we can optimise this by sending bulk inserts to db
|
|
|
|
|
// Todo: atomicity is not maintained as deveice managment provider service uses separate db connection. fix this??
|
|
|
|
|
log.info("Install application: " + applicationUUID + "[" + versionName + "]" + " to: "
|
|
|
|
|
+ deviceList.size() + " devices.");
|
|
|
|
|
for (DeviceIdentifier device : deviceList) {
|
|
|
|
|
org.wso2.carbon.device.mgt.common.DeviceIdentifier deviceIdentifier = new org.wso2.carbon.device.mgt
|
|
|
|
|
.common.DeviceIdentifier(device.getId(), device.getType());
|
|
|
|
|
try {
|
|
|
|
|
DeviceManagementDAOFactory.openConnection();
|
|
|
|
|
if (DeviceManagementDAOFactory.getDeviceDAO().getDevice(deviceIdentifier).isEmpty()) {
|
|
|
|
|
log.error("Device with ID: " + device.getId() + " not found to install the application.");
|
|
|
|
|
DeviceManagementProviderService dmpService = HelperUtil.getDeviceManagementProviderService();
|
|
|
|
|
if (!dmpService.isEnrolled(deviceIdentifier)) {
|
|
|
|
|
log.error("Device with ID: [" + device.getId() + "] is not enrolled to install the application.");
|
|
|
|
|
} else {
|
|
|
|
|
if (log.isDebugEnabled()) {
|
|
|
|
|
log.debug("Prepare application install to : " + device.getId());
|
|
|
|
|
log.debug("Installing application to : " + device.getId());
|
|
|
|
|
}
|
|
|
|
|
activeDeviceList.add(deviceIdentifier);
|
|
|
|
|
DAOFactory.getSubscriptionDAO().addDeviceApplicationMapping(device.getId(), applicationUUID, false);
|
|
|
|
|
//Todo: generating one time download link for the application and put install operation to device.
|
|
|
|
|
|
|
|
|
|
// put app install operation to the device
|
|
|
|
|
ProfileOperation operation = new ProfileOperation();
|
|
|
|
|
operation.setCode(INSTALL_APPLICATION);
|
|
|
|
|
operation.setType(Operation.Type.PROFILE);
|
|
|
|
|
operation.setPayLoad("{'type':'enterprise', 'url':'http://10.100.5.76:8000/app-debug.apk', 'app':'"
|
|
|
|
|
+ applicationUUID + "'}");
|
|
|
|
|
List<org.wso2.carbon.device.mgt.common.DeviceIdentifier> deviceIdentifiers = new ArrayList<>();
|
|
|
|
|
deviceIdentifiers.add(deviceIdentifier);
|
|
|
|
|
dmpService.addOperation(DeviceManagementConstants.MobileDeviceTypes.MOBILE_DEVICE_TYPE_ANDROID,
|
|
|
|
|
operation, deviceIdentifiers);
|
|
|
|
|
|
|
|
|
|
DeviceApplicationMapping deviceApp = new DeviceApplicationMapping();
|
|
|
|
|
deviceApp.setDeviceIdentifier(device.getId());
|
|
|
|
|
deviceApp.setApplicationUUID(applicationUUID);
|
|
|
|
|
deviceApp.setVersionName(versionName);
|
|
|
|
|
deviceApp.setInstalled(false);
|
|
|
|
|
dmpService.addDeviceApplicationMapping(deviceApp);
|
|
|
|
|
// DeviceManagementDAOFactory.openConnection();
|
|
|
|
|
// DAOFactory.getSubscriptionDAO().addDeviceApplicationMapping(device.getId(), applicationUUID, false);
|
|
|
|
|
failedDeviceList.remove(device);
|
|
|
|
|
}
|
|
|
|
|
} catch (DeviceManagementDAOException | SQLException e) {
|
|
|
|
|
throw new ApplicationManagementException("Error locating device.", e);
|
|
|
|
|
} finally {
|
|
|
|
|
DeviceManagementDAOFactory.closeConnection();
|
|
|
|
|
} catch (DeviceManagementException | OperationManagementException | InvalidDeviceException e) {
|
|
|
|
|
log.error("Error while installing application to device[" + deviceIdentifier.getId() + "]", e);
|
|
|
|
|
}
|
|
|
|
|
// finally {
|
|
|
|
|
// DeviceManagementDAOFactory.closeConnection();
|
|
|
|
|
// }
|
|
|
|
|
}
|
|
|
|
|
//Todo: generating one time download link for the application and put install operation to devices.
|
|
|
|
|
return failedDeviceList;
|
|
|
|
|
}
|
|
|
|
|
}
|
|
|
|
|