Revert "Fixing API returning Invalid Media Type & Refactoring RESTful API endpoints"

Ruwan 9 years ago
parent c1b2195021
commit 737b90ce40

@ -1,59 +0,0 @@
package org.wso2.carbon.device.mgt.iot;
import org.apache.commons.logging.Log;
import org.apache.commons.logging.LogFactory;
import org.wso2.carbon.context.CarbonContext;
import org.wso2.carbon.context.PrivilegedCarbonContext;
/**
* This class provides util methods for manager services
*/
public abstract class AbstractManagerService {
private static Log log = LogFactory.getLog(AbstractManagerService.class);
protected PrivilegedCarbonContext ctx;
// Returns current username
// this method assumes WebappAuthenticationValve is setting username, tenant
// upon successful authentication. Add context param doAuthentication to "true" on web.xml
/**
* Returns current username. this method assumes WebappAuthenticationValve is setting username,
* tenant_domain, tenant_id upon successful authentication.
* Add context param doAuthentication to "true" on web.xml.
*
* @return current username
*/
protected String getCurrentUserName(){
return CarbonContext.getThreadLocalCarbonContext().getUsername();
}
/**
* Returns OSGi service. Should invoke endTenantFlow() to end the tenant flow once osgi service
* is consumed.
* @param osgiServiceClass
* @param <T> OSGi service class
* @return OSGi service
*/
protected <T> T getServiceProvider(Class<T> osgiServiceClass) {
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 (T) ctx.getOSGiService(osgiServiceClass.getClass(), null);
}
/**
* Ends tenant flow.
*/
protected void endTenantFlow() {
PrivilegedCarbonContext.endTenantFlow();
ctx = null;
if (log.isDebugEnabled()) {
log.debug("Tenant flow ended");
}
}
}

@ -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);

Loading…
Cancel
Save