|
|
|
@ -20,6 +20,8 @@ package org.wso2.carbon.device.mgt.iot.api;
|
|
|
|
|
|
|
|
|
|
import org.apache.commons.logging.Log;
|
|
|
|
|
import org.apache.commons.logging.LogFactory;
|
|
|
|
|
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.DeviceIdentifier;
|
|
|
|
|
import org.wso2.carbon.device.mgt.common.PaginationResult;
|
|
|
|
@ -27,10 +29,10 @@ import org.wso2.carbon.device.mgt.group.common.DeviceGroup;
|
|
|
|
|
import org.wso2.carbon.device.mgt.group.common.GroupManagementException;
|
|
|
|
|
import org.wso2.carbon.device.mgt.group.common.GroupUser;
|
|
|
|
|
import org.wso2.carbon.device.mgt.group.core.providers.GroupManagementServiceProvider;
|
|
|
|
|
import org.wso2.carbon.device.mgt.iot.AbstractManagerService;
|
|
|
|
|
|
|
|
|
|
import javax.jws.WebService;
|
|
|
|
|
import javax.servlet.http.HttpServletResponse;
|
|
|
|
|
import javax.ws.rs.Consumes;
|
|
|
|
|
import javax.ws.rs.DELETE;
|
|
|
|
|
import javax.ws.rs.FormParam;
|
|
|
|
|
import javax.ws.rs.GET;
|
|
|
|
@ -46,7 +48,7 @@ import java.util.Date;
|
|
|
|
|
import java.util.List;
|
|
|
|
|
|
|
|
|
|
@WebService
|
|
|
|
|
public class GroupManagerService extends AbstractManagerService {
|
|
|
|
|
public class GroupManagerService {
|
|
|
|
|
|
|
|
|
|
private static final String DEFAULT_ADMIN_ROLE = "admin";
|
|
|
|
|
private static final String DEFAULT_OPERATOR_ROLE = "invoke-device-operations";
|
|
|
|
@ -64,33 +66,53 @@ public class GroupManagerService extends AbstractManagerService {
|
|
|
|
|
private static Log log = LogFactory.getLog(GroupManagerService.class);
|
|
|
|
|
@Context //injected response proxy supporting multiple threads
|
|
|
|
|
private HttpServletResponse response;
|
|
|
|
|
private PrivilegedCarbonContext ctx;
|
|
|
|
|
|
|
|
|
|
@Path("/groups")
|
|
|
|
|
private GroupManagementServiceProvider getServiceProvider() {
|
|
|
|
|
String tenantDomain = CarbonContext.getThreadLocalCarbonContext().getTenantDomain();
|
|
|
|
|
PrivilegedCarbonContext.startTenantFlow();
|
|
|
|
|
ctx = PrivilegedCarbonContext.getThreadLocalCarbonContext();
|
|
|
|
|
ctx.setTenantDomain(tenantDomain, true);
|
|
|
|
|
if (log.isDebugEnabled()) {
|
|
|
|
|
log.debug("Getting thread local carbon context for tenant domain: " + tenantDomain);
|
|
|
|
|
}
|
|
|
|
|
return (GroupManagementServiceProvider) ctx.getOSGiService(GroupManagementServiceProvider.class, null);
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
private void endTenantFlow() {
|
|
|
|
|
PrivilegedCarbonContext.endTenantFlow();
|
|
|
|
|
ctx = null;
|
|
|
|
|
if (log.isDebugEnabled()) {
|
|
|
|
|
log.debug("Tenant flow ended");
|
|
|
|
|
}
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
@Path("/group")
|
|
|
|
|
@POST
|
|
|
|
|
@Consumes("application/json")
|
|
|
|
|
@Produces("application/json")
|
|
|
|
|
public boolean createGroup(@FormParam("groupName") String groupName, @FormParam("userName") String userName,
|
|
|
|
|
public boolean createGroup(@FormParam("name") String name, @FormParam("username") String username,
|
|
|
|
|
@FormParam("description") String description) {
|
|
|
|
|
DeviceGroup group = new DeviceGroup();
|
|
|
|
|
group.setName(groupName);
|
|
|
|
|
group.setName(name);
|
|
|
|
|
group.setDescription(description);
|
|
|
|
|
group.setOwner(userName);
|
|
|
|
|
group.setOwner(username);
|
|
|
|
|
group.setDateOfCreation(new Date().getTime());
|
|
|
|
|
group.setDateOfLastUpdate(new Date().getTime());
|
|
|
|
|
boolean isAdded = false;
|
|
|
|
|
try {
|
|
|
|
|
GroupManagementServiceProvider groupManagementService = this.getServiceProvider(GroupManagementServiceProvider.class);
|
|
|
|
|
int groupId = groupManagementService.createGroup(group, DEFAULT_ADMIN_ROLE,
|
|
|
|
|
DEFAULT_ADMIN_PERMISSIONS);
|
|
|
|
|
GroupManagementServiceProvider groupManagementService = this.getServiceProvider();
|
|
|
|
|
int groupId = groupManagementService.createGroup(group, DEFAULT_ADMIN_ROLE, DEFAULT_ADMIN_PERMISSIONS);
|
|
|
|
|
response.setStatus(Response.Status.OK.getStatusCode());
|
|
|
|
|
isAdded = (groupId > 0) && groupManagementService.addSharing(userName, groupId, DEFAULT_OPERATOR_ROLE,
|
|
|
|
|
isAdded = (groupId > 0) && groupManagementService.addSharing(username, groupId, DEFAULT_OPERATOR_ROLE,
|
|
|
|
|
DEFAULT_OPERATOR_PERMISSIONS);
|
|
|
|
|
groupManagementService.addSharing(userName, groupId, DEFAULT_STATS_MONITOR_ROLE,
|
|
|
|
|
groupManagementService.addSharing(username, groupId, DEFAULT_STATS_MONITOR_ROLE,
|
|
|
|
|
DEFAULT_STATS_MONITOR_PERMISSIONS);
|
|
|
|
|
groupManagementService.addSharing(userName, groupId, DEFAULT_VIEW_POLICIES,
|
|
|
|
|
groupManagementService.addSharing(username, groupId, DEFAULT_VIEW_POLICIES,
|
|
|
|
|
DEFAULT_VIEW_POLICIES_PERMISSIONS);
|
|
|
|
|
groupManagementService.addSharing(userName, groupId, DEFAULT_MANAGE_POLICIES,
|
|
|
|
|
groupManagementService.addSharing(username, groupId, DEFAULT_MANAGE_POLICIES,
|
|
|
|
|
DEFAULT_MANAGE_POLICIES_PERMISSIONS);
|
|
|
|
|
groupManagementService.addSharing(userName, groupId, DEFAULT_VIEW_EVENTS,
|
|
|
|
|
groupManagementService.addSharing(username, groupId, DEFAULT_VIEW_EVENTS,
|
|
|
|
|
DEFAULT_VIEW_EVENTS_PERMISSIONS);
|
|
|
|
|
} catch (GroupManagementException e) {
|
|
|
|
|
response.setStatus(Response.Status.INTERNAL_SERVER_ERROR.getStatusCode());
|
|
|
|
@ -101,21 +123,22 @@ public class GroupManagerService extends AbstractManagerService {
|
|
|
|
|
return isAdded;
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
@Path("/groups/{groupId}")
|
|
|
|
|
@Path("/group/id/{groupId}")
|
|
|
|
|
@PUT
|
|
|
|
|
@Consumes("application/json")
|
|
|
|
|
@Produces("application/json")
|
|
|
|
|
public boolean updateGroup(@PathParam("groupId") int groupId, @FormParam("groupName") String groupName,
|
|
|
|
|
@FormParam("userName") String userName, @FormParam("description") String description) {
|
|
|
|
|
if (!isAuthorized(getCurrentUserName(), groupId, "/permission/device-mgt/admin/groups/modify")){
|
|
|
|
|
public boolean updateGroup(@PathParam("groupId") int groupId, @FormParam("name") String name,
|
|
|
|
|
@FormParam("username") String username, @FormParam("description") String description) {
|
|
|
|
|
if (!isAuthorized(username, groupId, "/permission/device-mgt/admin/groups/modify")){
|
|
|
|
|
response.setStatus(Response.Status.FORBIDDEN.getStatusCode());
|
|
|
|
|
return false;
|
|
|
|
|
}
|
|
|
|
|
try {
|
|
|
|
|
GroupManagementServiceProvider groupManagementService = this.getServiceProvider(GroupManagementServiceProvider.class);
|
|
|
|
|
GroupManagementServiceProvider groupManagementService = this.getServiceProvider();
|
|
|
|
|
DeviceGroup group = groupManagementService.getGroup(groupId);
|
|
|
|
|
group.setName(groupName);
|
|
|
|
|
group.setName(name);
|
|
|
|
|
group.setDescription(description);
|
|
|
|
|
group.setOwner(userName);
|
|
|
|
|
group.setOwner(username);
|
|
|
|
|
group.setDateOfLastUpdate(new Date().getTime());
|
|
|
|
|
response.setStatus(Response.Status.OK.getStatusCode());
|
|
|
|
|
groupManagementService.updateGroup(group);
|
|
|
|
@ -129,19 +152,19 @@ public class GroupManagerService extends AbstractManagerService {
|
|
|
|
|
}
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
@Path("/groups/{groupId}")
|
|
|
|
|
@Path("/group/id/{groupId}")
|
|
|
|
|
@DELETE
|
|
|
|
|
@Consumes("application/json")
|
|
|
|
|
@Produces("application/json")
|
|
|
|
|
public boolean deleteGroup(@PathParam("groupId") int groupId, @QueryParam("userName") String userName) {
|
|
|
|
|
if (!isAuthorized(getCurrentUserName(), groupId, "/permission/device-mgt/admin/groups/delete")){
|
|
|
|
|
public boolean deleteGroup(@PathParam("groupId") int groupId, @QueryParam("username") String username) {
|
|
|
|
|
if (!isAuthorized(username, groupId, "/permission/device-mgt/admin/groups/delete")){
|
|
|
|
|
response.setStatus(Response.Status.FORBIDDEN.getStatusCode());
|
|
|
|
|
return false;
|
|
|
|
|
}
|
|
|
|
|
boolean isDeleted = false;
|
|
|
|
|
try {
|
|
|
|
|
response.setStatus(Response.Status.OK.getStatusCode());
|
|
|
|
|
isDeleted = this.getServiceProvider(GroupManagementServiceProvider.class).deleteGroup(
|
|
|
|
|
groupId);
|
|
|
|
|
isDeleted = this.getServiceProvider().deleteGroup(groupId);
|
|
|
|
|
} catch (GroupManagementException e) {
|
|
|
|
|
response.setStatus(Response.Status.INTERNAL_SERVER_ERROR.getStatusCode());
|
|
|
|
|
log.error(e.getErrorMessage(), e);
|
|
|
|
@ -151,14 +174,15 @@ public class GroupManagerService extends AbstractManagerService {
|
|
|
|
|
return isDeleted;
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
@Path("/groups/{groupId}")
|
|
|
|
|
@Path("/group/id/{groupId}")
|
|
|
|
|
@GET
|
|
|
|
|
@Consumes("application/json")
|
|
|
|
|
@Produces("application/json")
|
|
|
|
|
public DeviceGroup getGroup(@PathParam("groupId") int groupId) {
|
|
|
|
|
public DeviceGroup getGroup(@PathParam("groupId") int groupId, @FormParam("username") String username) {
|
|
|
|
|
DeviceGroup deviceGroup = null;
|
|
|
|
|
try {
|
|
|
|
|
response.setStatus(Response.Status.OK.getStatusCode());
|
|
|
|
|
deviceGroup = this.getServiceProvider(GroupManagementServiceProvider.class).getGroup(groupId);
|
|
|
|
|
deviceGroup = this.getServiceProvider().getGroup(groupId);
|
|
|
|
|
} catch (GroupManagementException e) {
|
|
|
|
|
response.setStatus(Response.Status.INTERNAL_SERVER_ERROR.getStatusCode());
|
|
|
|
|
log.error(e.getErrorMessage(), e);
|
|
|
|
@ -168,14 +192,14 @@ public class GroupManagerService extends AbstractManagerService {
|
|
|
|
|
return deviceGroup;
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
//get groups for autocomplete
|
|
|
|
|
@Path("/groups/search")
|
|
|
|
|
@Path("/group/name/{groupName}")
|
|
|
|
|
@GET
|
|
|
|
|
@Consumes("application/json")
|
|
|
|
|
@Produces("application/json")
|
|
|
|
|
public DeviceGroup[] findGroups(@QueryParam("groupName") String groupName, @QueryParam("userName") String userName) {
|
|
|
|
|
public DeviceGroup[] findGroups(@PathParam("groupName") String groupName, @FormParam("username") String username) {
|
|
|
|
|
DeviceGroup[] deviceGroups = null;
|
|
|
|
|
try {
|
|
|
|
|
List<DeviceGroup> groups = this.getServiceProvider(GroupManagementServiceProvider.class).findGroups(groupName, userName);
|
|
|
|
|
List<DeviceGroup> groups = this.getServiceProvider().findGroups(groupName, username);
|
|
|
|
|
deviceGroups = new DeviceGroup[groups.size()];
|
|
|
|
|
response.setStatus(Response.Status.OK.getStatusCode());
|
|
|
|
|
groups.toArray(deviceGroups);
|
|
|
|
@ -188,20 +212,20 @@ public class GroupManagerService extends AbstractManagerService {
|
|
|
|
|
return deviceGroups;
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
//get groups by an specific permision
|
|
|
|
|
@Path("/groups")
|
|
|
|
|
@Path("/group/user/{username}/all")
|
|
|
|
|
@GET
|
|
|
|
|
@Consumes("application/json")
|
|
|
|
|
@Produces("application/json")
|
|
|
|
|
public DeviceGroup[] getGroups(@QueryParam("userName") String userName,
|
|
|
|
|
public DeviceGroup[] getGroups(@PathParam("username") String username,
|
|
|
|
|
@QueryParam("permission") String permission) {
|
|
|
|
|
DeviceGroup[] deviceGroups = null;
|
|
|
|
|
try {
|
|
|
|
|
GroupManagementServiceProvider groupManagementService = this.getServiceProvider(GroupManagementServiceProvider.class);
|
|
|
|
|
GroupManagementServiceProvider groupManagementService = this.getServiceProvider();
|
|
|
|
|
List<DeviceGroup> groups;
|
|
|
|
|
if(permission != null){
|
|
|
|
|
groups = groupManagementService.getGroups(userName, permission);
|
|
|
|
|
groups = groupManagementService.getGroups(username, permission);
|
|
|
|
|
}else{
|
|
|
|
|
groups = groupManagementService.getGroups(userName);
|
|
|
|
|
groups = groupManagementService.getGroups(username);
|
|
|
|
|
}
|
|
|
|
|
deviceGroups = new DeviceGroup[groups.size()];
|
|
|
|
|
response.setStatus(Response.Status.OK.getStatusCode());
|
|
|
|
@ -215,15 +239,15 @@ public class GroupManagerService extends AbstractManagerService {
|
|
|
|
|
return deviceGroups;
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
@Path("/groups/count")
|
|
|
|
|
@Path("/group/user/{username}/all/count")
|
|
|
|
|
@GET
|
|
|
|
|
@Consumes("application/json")
|
|
|
|
|
@Produces("application/json")
|
|
|
|
|
public int getGroupCount(@QueryParam("userName") String userName) {
|
|
|
|
|
public int getGroupCount(@PathParam("username") String username) {
|
|
|
|
|
int count = -1;
|
|
|
|
|
try {
|
|
|
|
|
response.setStatus(Response.Status.OK.getStatusCode());
|
|
|
|
|
count = this.getServiceProvider(GroupManagementServiceProvider.class).getGroupCount(
|
|
|
|
|
userName);
|
|
|
|
|
count = this.getServiceProvider().getGroupCount(username);
|
|
|
|
|
} catch (GroupManagementException e) {
|
|
|
|
|
response.setStatus(Response.Status.INTERNAL_SERVER_ERROR.getStatusCode());
|
|
|
|
|
log.error(e.getErrorMessage(), e);
|
|
|
|
@ -233,20 +257,20 @@ public class GroupManagerService extends AbstractManagerService {
|
|
|
|
|
return count;
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
@Path("/groups/{groupId}/share")
|
|
|
|
|
@Path("/group/id/{groupId}/share")
|
|
|
|
|
@POST
|
|
|
|
|
@Consumes("application/json")
|
|
|
|
|
@Produces("application/json")
|
|
|
|
|
public boolean shareGroup(@FormParam("userName") String userName, @FormParam("shareUser") String shareUser,
|
|
|
|
|
@PathParam("groupId") int groupId, @FormParam("roleName") String sharingRole) {
|
|
|
|
|
if (!isAuthorized(getCurrentUserName(), groupId, "/permission/device-mgt/admin/groups/share")){
|
|
|
|
|
public boolean shareGroup(@FormParam("username") String username, @FormParam("shareUser") String shareUser,
|
|
|
|
|
@PathParam("groupId") int groupId, @FormParam("role") String sharingRole) {
|
|
|
|
|
if (!isAuthorized(username, groupId, "/permission/device-mgt/admin/groups/share")){
|
|
|
|
|
response.setStatus(Response.Status.FORBIDDEN.getStatusCode());
|
|
|
|
|
return false;
|
|
|
|
|
}
|
|
|
|
|
boolean isShared = false;
|
|
|
|
|
try {
|
|
|
|
|
response.setStatus(Response.Status.OK.getStatusCode());
|
|
|
|
|
isShared = this.getServiceProvider(GroupManagementServiceProvider.class).shareGroup(
|
|
|
|
|
shareUser, groupId, sharingRole);
|
|
|
|
|
isShared = this.getServiceProvider().shareGroup(shareUser, groupId, sharingRole);
|
|
|
|
|
} catch (GroupManagementException e) {
|
|
|
|
|
response.setStatus(Response.Status.INTERNAL_SERVER_ERROR.getStatusCode());
|
|
|
|
|
log.error(e.getErrorMessage(), e);
|
|
|
|
@ -256,20 +280,20 @@ public class GroupManagerService extends AbstractManagerService {
|
|
|
|
|
return isShared;
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
@Path("/groups/{groupId}/unshare")
|
|
|
|
|
@Path("/group/id/{groupId}/unshare")
|
|
|
|
|
@POST
|
|
|
|
|
@Consumes("application/json")
|
|
|
|
|
@Produces("application/json")
|
|
|
|
|
public boolean unShareGroup(@FormParam("userName") String userName, @FormParam("unShareUser") String unShareUser,
|
|
|
|
|
@PathParam("groupId") int groupId, @FormParam("roleName") String sharingRole) {
|
|
|
|
|
if (!isAuthorized(getCurrentUserName(), groupId, "/permission/device-mgt/admin/groups/share")){
|
|
|
|
|
public boolean unShareGroup(@FormParam("username") String username, @FormParam("unShareUser") String unShareUser,
|
|
|
|
|
@PathParam("groupId") int groupId, @FormParam("role") String sharingRole) {
|
|
|
|
|
if (!isAuthorized(username, groupId, "/permission/device-mgt/admin/groups/share")){
|
|
|
|
|
response.setStatus(Response.Status.FORBIDDEN.getStatusCode());
|
|
|
|
|
return false;
|
|
|
|
|
}
|
|
|
|
|
boolean isUnShared = false;
|
|
|
|
|
try {
|
|
|
|
|
response.setStatus(Response.Status.OK.getStatusCode());
|
|
|
|
|
isUnShared = this.getServiceProvider(GroupManagementServiceProvider.class).unShareGroup(
|
|
|
|
|
unShareUser, groupId, sharingRole);
|
|
|
|
|
isUnShared = this.getServiceProvider().unShareGroup(unShareUser, groupId, sharingRole);
|
|
|
|
|
} catch (GroupManagementException e) {
|
|
|
|
|
response.setStatus(Response.Status.INTERNAL_SERVER_ERROR.getStatusCode());
|
|
|
|
|
log.error(e.getErrorMessage(), e);
|
|
|
|
@ -279,21 +303,20 @@ public class GroupManagerService extends AbstractManagerService {
|
|
|
|
|
return isUnShared;
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
//add sharing permissions
|
|
|
|
|
@Path("/groups/{groupId}/share/roles/{roleName}/permissions")
|
|
|
|
|
@Path("/group/id/{groupId}/role")
|
|
|
|
|
@POST
|
|
|
|
|
@Consumes("application/json")
|
|
|
|
|
@Produces("application/json")
|
|
|
|
|
public boolean addSharing(@QueryParam("userName") String userName, @PathParam("groupId") int groupId,
|
|
|
|
|
@PathParam("roleName") String roleName, @FormParam("permissions") String[] permissions) {
|
|
|
|
|
if (!isAuthorized(getCurrentUserName(), groupId, "/permission/device-mgt/admin/groups/share")){
|
|
|
|
|
public boolean addSharing(@FormParam("username") String username, @PathParam("groupId") int groupId,
|
|
|
|
|
@FormParam("role") String roleName, @FormParam("permissions") String[] permissions) {
|
|
|
|
|
if (!isAuthorized(username, groupId, "/permission/device-mgt/admin/groups/share")){
|
|
|
|
|
response.setStatus(Response.Status.FORBIDDEN.getStatusCode());
|
|
|
|
|
return false;
|
|
|
|
|
}
|
|
|
|
|
boolean isAdded = false;
|
|
|
|
|
try {
|
|
|
|
|
response.setStatus(Response.Status.OK.getStatusCode());
|
|
|
|
|
isAdded = this.getServiceProvider(GroupManagementServiceProvider.class).addSharing(
|
|
|
|
|
userName, groupId, roleName, permissions);
|
|
|
|
|
isAdded = this.getServiceProvider().addSharing(username, groupId, roleName, permissions);
|
|
|
|
|
} catch (GroupManagementException e) {
|
|
|
|
|
response.setStatus(Response.Status.INTERNAL_SERVER_ERROR.getStatusCode());
|
|
|
|
|
log.error(e.getErrorMessage(), e);
|
|
|
|
@ -303,19 +326,19 @@ public class GroupManagerService extends AbstractManagerService {
|
|
|
|
|
return isAdded;
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
//remove sharing permissions
|
|
|
|
|
@Path("/groups/{groupId}/share/roles/{roleName}/permissions")
|
|
|
|
|
@Path("/group/id/{groupId}/role/{role}")
|
|
|
|
|
@DELETE
|
|
|
|
|
@Consumes("application/json")
|
|
|
|
|
@Produces("application/json")
|
|
|
|
|
public boolean removeSharing(@QueryParam("userName") String userName, @PathParam("groupId") int groupId,
|
|
|
|
|
@PathParam("roleName") String roleName) {
|
|
|
|
|
if (!isAuthorized(getCurrentUserName(), groupId, "/permission/device-mgt/admin/groups/share")){
|
|
|
|
|
public boolean removeSharing(@QueryParam("username") String username, @PathParam("groupId") int groupId,
|
|
|
|
|
@PathParam("role") String roleName) {
|
|
|
|
|
if (!isAuthorized(username, groupId, "/permission/device-mgt/admin/groups/share")){
|
|
|
|
|
response.setStatus(Response.Status.FORBIDDEN.getStatusCode());
|
|
|
|
|
}
|
|
|
|
|
boolean isRemoved = false;
|
|
|
|
|
try {
|
|
|
|
|
response.setStatus(Response.Status.OK.getStatusCode());
|
|
|
|
|
isRemoved = this.getServiceProvider(GroupManagementServiceProvider.class).removeSharing(groupId, roleName);
|
|
|
|
|
isRemoved = this.getServiceProvider().removeSharing(groupId, roleName);
|
|
|
|
|
} catch (GroupManagementException e) {
|
|
|
|
|
response.setStatus(Response.Status.INTERNAL_SERVER_ERROR.getStatusCode());
|
|
|
|
|
log.error(e.getErrorMessage(), e);
|
|
|
|
@ -325,19 +348,34 @@ public class GroupManagerService extends AbstractManagerService {
|
|
|
|
|
return isRemoved;
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
@Path("/groups/{groupId}/share/roles")
|
|
|
|
|
@Path("/group/id/{groupId}/role/all")
|
|
|
|
|
@GET
|
|
|
|
|
@Consumes("application/json")
|
|
|
|
|
@Produces("application/json")
|
|
|
|
|
public String[] getRoles(@PathParam("groupId") int groupId, @QueryParam("userName") String userName) {
|
|
|
|
|
public String[] getRoles(@PathParam("groupId") int groupId) {
|
|
|
|
|
String[] rolesArray = null;
|
|
|
|
|
try {
|
|
|
|
|
List<String> roles = null;
|
|
|
|
|
if(userName != null && !userName.isEmpty()) {
|
|
|
|
|
roles = this.getServiceProvider(GroupManagementServiceProvider.class).getRoles(
|
|
|
|
|
userName, groupId);
|
|
|
|
|
}else {
|
|
|
|
|
roles = this.getServiceProvider(GroupManagementServiceProvider.class).getRoles(groupId);
|
|
|
|
|
}
|
|
|
|
|
List<String> roles = this.getServiceProvider().getRoles(groupId);
|
|
|
|
|
rolesArray = new String[roles.size()];
|
|
|
|
|
response.setStatus(Response.Status.OK.getStatusCode());
|
|
|
|
|
roles.toArray(rolesArray);
|
|
|
|
|
} catch (GroupManagementException e) {
|
|
|
|
|
response.setStatus(Response.Status.INTERNAL_SERVER_ERROR.getStatusCode());
|
|
|
|
|
log.error(e.getErrorMessage(), e);
|
|
|
|
|
} finally {
|
|
|
|
|
this.endTenantFlow();
|
|
|
|
|
}
|
|
|
|
|
return rolesArray;
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
@Path("/group/id/{groupId}/{user}/role/all")
|
|
|
|
|
@GET
|
|
|
|
|
@Consumes("application/json")
|
|
|
|
|
@Produces("application/json")
|
|
|
|
|
public String[] getRoles(@PathParam("user") String user, @PathParam("groupId") int groupId) {
|
|
|
|
|
String[] rolesArray = null;
|
|
|
|
|
try {
|
|
|
|
|
List<String> roles = this.getServiceProvider().getRoles(user, groupId);
|
|
|
|
|
rolesArray = new String[roles.size()];
|
|
|
|
|
response.setStatus(Response.Status.OK.getStatusCode());
|
|
|
|
|
roles.toArray(rolesArray);
|
|
|
|
@ -350,13 +388,14 @@ public class GroupManagerService extends AbstractManagerService {
|
|
|
|
|
return rolesArray;
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
@Path("/groups/{groupId}/users")
|
|
|
|
|
@Path("/group/id/{groupId}/user/all")
|
|
|
|
|
@GET
|
|
|
|
|
@Consumes("application/json")
|
|
|
|
|
@Produces("application/json")
|
|
|
|
|
public GroupUser[] getUsers(@PathParam("groupId") int groupId) {
|
|
|
|
|
GroupUser[] usersArray = null;
|
|
|
|
|
try {
|
|
|
|
|
List<GroupUser> users = this.getServiceProvider(GroupManagementServiceProvider.class).getUsers(groupId);
|
|
|
|
|
List<GroupUser> users = this.getServiceProvider().getUsers(groupId);
|
|
|
|
|
usersArray = new GroupUser[users.size()];
|
|
|
|
|
response.setStatus(Response.Status.OK.getStatusCode());
|
|
|
|
|
users.toArray(usersArray);
|
|
|
|
@ -369,13 +408,14 @@ public class GroupManagerService extends AbstractManagerService {
|
|
|
|
|
return usersArray;
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
@Path("/groups/{groupId}/devices/all")
|
|
|
|
|
@Path("/group/id/{groupId}/device/all")
|
|
|
|
|
@GET
|
|
|
|
|
@Consumes("application/json")
|
|
|
|
|
@Produces("application/json")
|
|
|
|
|
public Device[] getDevices(@PathParam("groupId") int groupId) {
|
|
|
|
|
Device[] deviceArray = null;
|
|
|
|
|
try {
|
|
|
|
|
List<Device> devices = this.getServiceProvider(GroupManagementServiceProvider.class).getDevices(groupId);
|
|
|
|
|
List<Device> devices = this.getServiceProvider().getDevices(groupId);
|
|
|
|
|
deviceArray = new Device[devices.size()];
|
|
|
|
|
response.setStatus(Response.Status.OK.getStatusCode());
|
|
|
|
|
devices.toArray(deviceArray);
|
|
|
|
@ -388,12 +428,13 @@ public class GroupManagerService extends AbstractManagerService {
|
|
|
|
|
return deviceArray;
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
@Path("/groups/{groupId}/devices/count")
|
|
|
|
|
@Path("/group/id/{groupId}/device/count")
|
|
|
|
|
@GET
|
|
|
|
|
@Consumes("application/json")
|
|
|
|
|
@Produces("application/json")
|
|
|
|
|
public int getDeviceCount(@PathParam("groupId") int groupId) {
|
|
|
|
|
try {
|
|
|
|
|
return this.getServiceProvider(GroupManagementServiceProvider.class).getDeviceCount(groupId);
|
|
|
|
|
return this.getServiceProvider().getDeviceCount(groupId);
|
|
|
|
|
} catch (GroupManagementException e) {
|
|
|
|
|
response.setStatus(Response.Status.INTERNAL_SERVER_ERROR.getStatusCode());
|
|
|
|
|
log.error(e.getErrorMessage(), e);
|
|
|
|
@ -403,14 +444,15 @@ public class GroupManagerService extends AbstractManagerService {
|
|
|
|
|
}
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
@Path("/groups/{groupId}/devices")
|
|
|
|
|
@Path("/group/id/{groupId}/device")
|
|
|
|
|
@GET
|
|
|
|
|
@Consumes("application/json")
|
|
|
|
|
@Produces("application/json")
|
|
|
|
|
public PaginationResult getDevices(@PathParam("groupId") int groupId,
|
|
|
|
|
@QueryParam("index") int index,
|
|
|
|
|
@QueryParam("limit") int limit) {
|
|
|
|
|
try {
|
|
|
|
|
return this.getServiceProvider(GroupManagementServiceProvider.class).getDevices(groupId, index, limit);
|
|
|
|
|
return this.getServiceProvider().getDevices(groupId, index, limit);
|
|
|
|
|
} catch (GroupManagementException e) {
|
|
|
|
|
response.setStatus(Response.Status.INTERNAL_SERVER_ERROR.getStatusCode());
|
|
|
|
|
log.error(e.getErrorMessage(), e);
|
|
|
|
@ -420,12 +462,13 @@ public class GroupManagerService extends AbstractManagerService {
|
|
|
|
|
}
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
@Path("/groups/{groupId}/devices/{deviceType}/{deviceId}")
|
|
|
|
|
@Path("/group/id/{groupId}/device/assign")
|
|
|
|
|
@PUT
|
|
|
|
|
@Consumes("application/json")
|
|
|
|
|
@Produces("application/json")
|
|
|
|
|
public boolean addDevice(@PathParam("groupId") int groupId, @PathParam("deviceId") String deviceId,
|
|
|
|
|
@PathParam("deviceType") String deviceType, @FormParam("userName") String userName) {
|
|
|
|
|
if (!isAuthorized(getCurrentUserName(), groupId, "/permission/device-mgt/admin/groups/add_devices")){
|
|
|
|
|
public boolean addDevice(@PathParam("groupId") int groupId, @FormParam("deviceId") String deviceId,
|
|
|
|
|
@FormParam("deviceType") String deviceType, @FormParam("username") String username) {
|
|
|
|
|
if (!isAuthorized(username, groupId, "/permission/device-mgt/admin/groups/add_devices")){
|
|
|
|
|
response.setStatus(Response.Status.FORBIDDEN.getStatusCode());
|
|
|
|
|
return false;
|
|
|
|
|
}
|
|
|
|
@ -433,7 +476,7 @@ public class GroupManagerService extends AbstractManagerService {
|
|
|
|
|
try {
|
|
|
|
|
DeviceIdentifier deviceIdentifier = new DeviceIdentifier(deviceId, deviceType);
|
|
|
|
|
response.setStatus(Response.Status.OK.getStatusCode());
|
|
|
|
|
isAdded = this.getServiceProvider(GroupManagementServiceProvider.class).addDevice(deviceIdentifier, groupId);
|
|
|
|
|
isAdded = this.getServiceProvider().addDevice(deviceIdentifier, groupId);
|
|
|
|
|
} catch (GroupManagementException e) {
|
|
|
|
|
response.setStatus(Response.Status.INTERNAL_SERVER_ERROR.getStatusCode());
|
|
|
|
|
log.error(e.getErrorMessage(), e);
|
|
|
|
@ -443,12 +486,13 @@ public class GroupManagerService extends AbstractManagerService {
|
|
|
|
|
return isAdded;
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
@Path("/groups/{groupId}/devices/{deviceType}/{deviceId}")
|
|
|
|
|
@Path("/group/id/{groupId}/device/assign")
|
|
|
|
|
@DELETE
|
|
|
|
|
@Consumes("application/json")
|
|
|
|
|
@Produces("application/json")
|
|
|
|
|
public boolean removeDevice(@PathParam("groupId") int groupId, @PathParam("deviceId") String deviceId,
|
|
|
|
|
@PathParam("deviceType") String deviceType) {
|
|
|
|
|
if (!isAuthorized(getCurrentUserName(), groupId, "/permission/device-mgt/admin/groups/remove_devices")){
|
|
|
|
|
public boolean removeDevice(@PathParam("groupId") int groupId, @FormParam("deviceId") String deviceId,
|
|
|
|
|
@FormParam("deviceType") String deviceType, @FormParam("username") String username) {
|
|
|
|
|
if (!isAuthorized(username, groupId, "/permission/device-mgt/admin/groups/remove_devices")){
|
|
|
|
|
response.setStatus(Response.Status.FORBIDDEN.getStatusCode());
|
|
|
|
|
return false;
|
|
|
|
|
}
|
|
|
|
@ -456,7 +500,7 @@ public class GroupManagerService extends AbstractManagerService {
|
|
|
|
|
try {
|
|
|
|
|
DeviceIdentifier deviceIdentifier = new DeviceIdentifier(deviceId, deviceType);
|
|
|
|
|
response.setStatus(Response.Status.OK.getStatusCode());
|
|
|
|
|
isRemoved = this.getServiceProvider(GroupManagementServiceProvider.class).removeDevice(deviceIdentifier, groupId);
|
|
|
|
|
isRemoved = this.getServiceProvider().removeDevice(deviceIdentifier, groupId);
|
|
|
|
|
} catch (GroupManagementException e) {
|
|
|
|
|
response.setStatus(Response.Status.INTERNAL_SERVER_ERROR.getStatusCode());
|
|
|
|
|
log.error(e.getErrorMessage(), e);
|
|
|
|
@ -466,14 +510,15 @@ public class GroupManagerService extends AbstractManagerService {
|
|
|
|
|
return isRemoved;
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
@Path("/groups/{groupId}/users/{userName}/permissions")
|
|
|
|
|
@Path("/group/id/{groupId}/user/{username}/permissions")
|
|
|
|
|
@GET
|
|
|
|
|
@Consumes("application/json")
|
|
|
|
|
@Produces("application/json")
|
|
|
|
|
public String[] getPermissions(@PathParam("userName") String userName, @PathParam("groupId") int groupId) {
|
|
|
|
|
public String[] getPermissions(@PathParam("username") String username, @PathParam("groupId") int groupId) {
|
|
|
|
|
String[] permissions = null;
|
|
|
|
|
try {
|
|
|
|
|
response.setStatus(Response.Status.OK.getStatusCode());
|
|
|
|
|
permissions = this.getServiceProvider(GroupManagementServiceProvider.class).getPermissions(userName, groupId);
|
|
|
|
|
permissions = this.getServiceProvider().getPermissions(username, groupId);
|
|
|
|
|
} catch (GroupManagementException e) {
|
|
|
|
|
response.setStatus(Response.Status.INTERNAL_SERVER_ERROR.getStatusCode());
|
|
|
|
|
log.error(e.getErrorMessage(), e);
|
|
|
|
@ -483,15 +528,16 @@ public class GroupManagerService extends AbstractManagerService {
|
|
|
|
|
return permissions;
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
@Path("/groups/{groupId}/users/{userName}/authorized")
|
|
|
|
|
@Path("/group/id/{groupId}/user/{username}/authorized")
|
|
|
|
|
@GET
|
|
|
|
|
@Consumes("application/json")
|
|
|
|
|
@Produces("application/json")
|
|
|
|
|
public boolean isAuthorized(@PathParam("userName") String userName, @PathParam("groupId") int groupId,
|
|
|
|
|
public boolean isAuthorized(@PathParam("username") String username, @PathParam("groupId") int groupId,
|
|
|
|
|
@QueryParam("permission") String permission){
|
|
|
|
|
boolean isAuthorized = false;
|
|
|
|
|
try {
|
|
|
|
|
response.setStatus(Response.Status.OK.getStatusCode());
|
|
|
|
|
isAuthorized = this.getServiceProvider(GroupManagementServiceProvider.class).isAuthorized(userName, groupId, permission);
|
|
|
|
|
isAuthorized = this.getServiceProvider().isAuthorized(username, groupId, permission);
|
|
|
|
|
} catch (GroupManagementException e) {
|
|
|
|
|
response.setStatus(Response.Status.INTERNAL_SERVER_ERROR.getStatusCode());
|
|
|
|
|
log.error(e.getErrorMessage(), e);
|
|
|
|
|