|
|
@ -21,10 +21,12 @@ import com.google.gson.JsonObject;
|
|
|
|
import org.apache.commons.logging.Log;
|
|
|
|
import org.apache.commons.logging.Log;
|
|
|
|
import org.apache.commons.logging.LogFactory;
|
|
|
|
import org.apache.commons.logging.LogFactory;
|
|
|
|
import org.wso2.carbon.context.CarbonContext;
|
|
|
|
import org.wso2.carbon.context.CarbonContext;
|
|
|
|
|
|
|
|
import org.wso2.carbon.context.PrivilegedCarbonContext;
|
|
|
|
import org.wso2.carbon.device.mgt.common.Device;
|
|
|
|
import org.wso2.carbon.device.mgt.common.Device;
|
|
|
|
import org.wso2.carbon.device.mgt.common.DeviceIdentifier;
|
|
|
|
import org.wso2.carbon.device.mgt.common.DeviceIdentifier;
|
|
|
|
import org.wso2.carbon.device.mgt.common.DeviceManagementException;
|
|
|
|
import org.wso2.carbon.device.mgt.common.DeviceManagementException;
|
|
|
|
import org.wso2.carbon.device.mgt.core.service.DeviceManagementService;
|
|
|
|
import org.wso2.carbon.device.mgt.core.service.DeviceManagementService;
|
|
|
|
|
|
|
|
import org.wso2.carbon.utils.multitenancy.MultitenantConstants;
|
|
|
|
|
|
|
|
|
|
|
|
import javax.ws.rs.*;
|
|
|
|
import javax.ws.rs.*;
|
|
|
|
import javax.ws.rs.core.Response;
|
|
|
|
import javax.ws.rs.core.Response;
|
|
|
@ -36,66 +38,133 @@ import javax.ws.rs.core.Response;
|
|
|
|
public class Enrollment {
|
|
|
|
public class Enrollment {
|
|
|
|
|
|
|
|
|
|
|
|
private static Log log = LogFactory.getLog(Enrollment.class);
|
|
|
|
private static Log log = LogFactory.getLog(Enrollment.class);
|
|
|
|
|
|
|
|
|
|
|
|
@POST
|
|
|
|
@POST
|
|
|
|
public Response enrollDevice() {
|
|
|
|
public Response enrollDevice() {
|
|
|
|
JsonObject result = new JsonObject();
|
|
|
|
boolean result = false;
|
|
|
|
result.addProperty("senderId","jwwfowrjwqporqwrpqworpq");
|
|
|
|
int status = 0;
|
|
|
|
CarbonContext context = CarbonContext.getThreadLocalCarbonContext();
|
|
|
|
String msg = "";
|
|
|
|
DeviceManagementService dmService = (DeviceManagementService) context.getOSGiService(DeviceManagementService.class,null);
|
|
|
|
DeviceManagementService dmService;
|
|
|
|
Device device = AndroidAPIUtil.convertToDeviceObject(result);
|
|
|
|
|
|
|
|
try {
|
|
|
|
try {
|
|
|
|
dmService.enrollDevice(device);
|
|
|
|
PrivilegedCarbonContext.startTenantFlow();
|
|
|
|
|
|
|
|
PrivilegedCarbonContext ctx = PrivilegedCarbonContext.getThreadLocalCarbonContext();
|
|
|
|
|
|
|
|
ctx.setTenantDomain(MultitenantConstants.SUPER_TENANT_DOMAIN_NAME);
|
|
|
|
|
|
|
|
ctx.setTenantId(MultitenantConstants.SUPER_TENANT_ID);
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
dmService = (DeviceManagementService) ctx
|
|
|
|
|
|
|
|
.getOSGiService(DeviceManagementService.class, null);
|
|
|
|
|
|
|
|
} finally {
|
|
|
|
|
|
|
|
PrivilegedCarbonContext.endTenantFlow();
|
|
|
|
|
|
|
|
}
|
|
|
|
|
|
|
|
Device device = AndroidAPIUtil.convertToDeviceObject(null);
|
|
|
|
|
|
|
|
try {
|
|
|
|
|
|
|
|
result = dmService.enrollDevice(device);
|
|
|
|
|
|
|
|
status = 1;
|
|
|
|
} catch (DeviceManagementException e) {
|
|
|
|
} catch (DeviceManagementException e) {
|
|
|
|
String msg = "Error occurred while enrolling the device";
|
|
|
|
msg = "Error occurred while enrolling the device";
|
|
|
|
log.error(msg, e);
|
|
|
|
log.error(msg, e);
|
|
|
|
|
|
|
|
status = -1;
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
switch (status) {
|
|
|
|
|
|
|
|
case 1:
|
|
|
|
|
|
|
|
if (result) {
|
|
|
|
return Response.status(201).entity("Registration Successful").build();
|
|
|
|
return Response.status(201).entity("Registration Successful").build();
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
break;
|
|
|
|
|
|
|
|
case -1:
|
|
|
|
|
|
|
|
return Response.status(500).entity(msg).build();
|
|
|
|
|
|
|
|
}
|
|
|
|
|
|
|
|
return Response.status(400).entity("Registration Failed").build();
|
|
|
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
@GET
|
|
|
|
@GET
|
|
|
|
@Path("{id}")
|
|
|
|
@Path("{id}")
|
|
|
|
public Response isEnrolled(@PathParam("id") String id) {
|
|
|
|
public Response isEnrolled(@PathParam("id") String id) {
|
|
|
|
boolean status = false;
|
|
|
|
boolean result = false;
|
|
|
|
|
|
|
|
int status = 0;
|
|
|
|
|
|
|
|
String msg = "";
|
|
|
|
CarbonContext context = CarbonContext.getThreadLocalCarbonContext();
|
|
|
|
CarbonContext context = CarbonContext.getThreadLocalCarbonContext();
|
|
|
|
DeviceManagementService dmService = (DeviceManagementService) context.getOSGiService(DeviceManagementService.class,null);
|
|
|
|
DeviceManagementService dmService = (DeviceManagementService) context
|
|
|
|
|
|
|
|
.getOSGiService(DeviceManagementService.class, null);
|
|
|
|
try {
|
|
|
|
try {
|
|
|
|
DeviceIdentifier deviceIdentifier = AndroidAPIUtil.convertToDeviceIdentifierObject(id);
|
|
|
|
DeviceIdentifier deviceIdentifier = AndroidAPIUtil.convertToDeviceIdentifierObject(id);
|
|
|
|
status = dmService.isRegistered(deviceIdentifier);
|
|
|
|
result = dmService.isEnrolled(deviceIdentifier);
|
|
|
|
|
|
|
|
status = 1;
|
|
|
|
} catch (DeviceManagementException e) {
|
|
|
|
} catch (DeviceManagementException e) {
|
|
|
|
String msg = "Error occurred while checking enrollment of the device";
|
|
|
|
msg = "Error occurred while checking enrollment of the device";
|
|
|
|
log.error(msg, e);
|
|
|
|
log.error(msg, e);
|
|
|
|
|
|
|
|
status = -1;
|
|
|
|
}
|
|
|
|
}
|
|
|
|
return Response.status(200).entity(status).build();
|
|
|
|
switch (status) {
|
|
|
|
|
|
|
|
case 1:
|
|
|
|
|
|
|
|
if (result) {
|
|
|
|
|
|
|
|
return Response.status(200).entity(result).build();
|
|
|
|
|
|
|
|
}
|
|
|
|
|
|
|
|
break;
|
|
|
|
|
|
|
|
case -1:
|
|
|
|
|
|
|
|
return Response.status(500).entity(msg).build();
|
|
|
|
|
|
|
|
}
|
|
|
|
|
|
|
|
return Response.status(404).entity(result).build();
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
@PUT
|
|
|
|
@PUT
|
|
|
|
@Consumes("application/json")
|
|
|
|
@Consumes("application/json")
|
|
|
|
@Path("{id}")
|
|
|
|
@Path("{id}")
|
|
|
|
public Response modifyEnrollment(@PathParam("id") String id) {
|
|
|
|
public Response modifyEnrollment(@PathParam("id") String id) {
|
|
|
|
boolean status = false;
|
|
|
|
boolean result = false;
|
|
|
|
|
|
|
|
int status = 0;
|
|
|
|
|
|
|
|
String msg = "";
|
|
|
|
CarbonContext context = CarbonContext.getThreadLocalCarbonContext();
|
|
|
|
CarbonContext context = CarbonContext.getThreadLocalCarbonContext();
|
|
|
|
DeviceManagementService dmService = (DeviceManagementService) context.getOSGiService(DeviceManagementService.class,null);
|
|
|
|
DeviceManagementService dmService = (DeviceManagementService) context
|
|
|
|
|
|
|
|
.getOSGiService(DeviceManagementService.class, null);
|
|
|
|
|
|
|
|
Device device = AndroidAPIUtil.convertToDeviceObject(null);
|
|
|
|
try {
|
|
|
|
try {
|
|
|
|
status = dmService.isRegistered(null);
|
|
|
|
result = dmService.modifyEnrollment(device);
|
|
|
|
|
|
|
|
status = 1;
|
|
|
|
} catch (DeviceManagementException e) {
|
|
|
|
} catch (DeviceManagementException e) {
|
|
|
|
String msg = "Error occurred while modifying enrollment of the device";
|
|
|
|
msg = "Error occurred while modifying enrollment of the device";
|
|
|
|
log.error(msg, e);
|
|
|
|
log.error(msg, e);
|
|
|
|
|
|
|
|
status = -1;
|
|
|
|
|
|
|
|
}
|
|
|
|
|
|
|
|
switch (status) {
|
|
|
|
|
|
|
|
case 1:
|
|
|
|
|
|
|
|
if (result) {
|
|
|
|
|
|
|
|
return Response.status(200).entity("Device information modified").build();
|
|
|
|
|
|
|
|
}
|
|
|
|
|
|
|
|
break;
|
|
|
|
|
|
|
|
case -1:
|
|
|
|
|
|
|
|
return Response.status(500).entity(msg).build();
|
|
|
|
}
|
|
|
|
}
|
|
|
|
return Response.status(201).entity(status).build();
|
|
|
|
return Response.status(400).entity("Update enrollment failed").build();
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
@DELETE
|
|
|
|
@DELETE
|
|
|
|
@Path("{id}")
|
|
|
|
@Path("{id}")
|
|
|
|
public Response disenrollDevice(@PathParam("id") String id) {
|
|
|
|
public Response disenrollDevice(@PathParam("id") String id) {
|
|
|
|
boolean status = false;
|
|
|
|
boolean result = false;
|
|
|
|
|
|
|
|
int status = 0;
|
|
|
|
|
|
|
|
String msg = "";
|
|
|
|
CarbonContext context = CarbonContext.getThreadLocalCarbonContext();
|
|
|
|
CarbonContext context = CarbonContext.getThreadLocalCarbonContext();
|
|
|
|
DeviceManagementService dmService = (DeviceManagementService) context.getOSGiService(DeviceManagementService.class,null);
|
|
|
|
DeviceManagementService dmService = (DeviceManagementService) context
|
|
|
|
|
|
|
|
.getOSGiService(DeviceManagementService.class, null);
|
|
|
|
try {
|
|
|
|
try {
|
|
|
|
status = dmService.isRegistered(null);
|
|
|
|
DeviceIdentifier deviceIdentifier = AndroidAPIUtil.convertToDeviceIdentifierObject(id);
|
|
|
|
|
|
|
|
result = dmService.disenrollDevice(deviceIdentifier);
|
|
|
|
|
|
|
|
status = 1;
|
|
|
|
} catch (DeviceManagementException e) {
|
|
|
|
} catch (DeviceManagementException e) {
|
|
|
|
String msg = "Error occurred while disenrolling the device";
|
|
|
|
msg = "Error occurred while disenrolling the device";
|
|
|
|
log.error(msg, e);
|
|
|
|
log.error(msg, e);
|
|
|
|
|
|
|
|
status = -1;
|
|
|
|
|
|
|
|
}
|
|
|
|
|
|
|
|
switch (status) {
|
|
|
|
|
|
|
|
case 1:
|
|
|
|
|
|
|
|
if (result) {
|
|
|
|
|
|
|
|
return Response.status(200).entity(result).build();
|
|
|
|
|
|
|
|
}
|
|
|
|
|
|
|
|
break;
|
|
|
|
|
|
|
|
case -1:
|
|
|
|
|
|
|
|
return Response.status(500).entity(msg).build();
|
|
|
|
}
|
|
|
|
}
|
|
|
|
return Response.status(201).entity(status).build();
|
|
|
|
return Response.status(404).entity("Device not found").build();
|
|
|
|
}
|
|
|
|
}
|
|
|
|
}
|
|
|
|
}
|
|
|
|