mirror of
https://repository.entgra.net/community/device-mgt-core.git
synced 2025-10-06 02:01:45 +00:00
Merge branch 'master' into IoTS-1.0.0
# Conflicts: # components/device-mgt/org.wso2.carbon.device.mgt.api/src/main/java/org/wso2/carbon/device/mgt/jaxrs/service/api/GroupManagementService.java # components/device-mgt/org.wso2.carbon.device.mgt.api/src/main/java/org/wso2/carbon/device/mgt/jaxrs/service/api/admin/GroupManagementAdminService.java # components/device-mgt/org.wso2.carbon.device.mgt.api/src/main/java/org/wso2/carbon/device/mgt/jaxrs/service/impl/GroupManagementServiceImpl.java # components/device-mgt/org.wso2.carbon.device.mgt.api/src/main/java/org/wso2/carbon/device/mgt/jaxrs/service/impl/admin/GroupManagementAdminServiceImpl.java # components/device-mgt/org.wso2.carbon.device.mgt.api/src/main/webapp/WEB-INF/cxf-servlet.xml
This commit is contained in:
commit
5f68953b11
@ -0,0 +1,52 @@
|
|||||||
|
/*
|
||||||
|
* 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.
|
||||||
|
*
|
||||||
|
*/
|
||||||
|
package org.wso2.carbon.device.mgt.jaxrs.beans;
|
||||||
|
|
||||||
|
import com.fasterxml.jackson.annotation.JsonProperty;
|
||||||
|
import io.swagger.annotations.ApiModelProperty;
|
||||||
|
|
||||||
|
import java.util.ArrayList;
|
||||||
|
import java.util.List;
|
||||||
|
|
||||||
|
public class DeviceGroupList extends BasePaginatedResult {
|
||||||
|
|
||||||
|
@ApiModelProperty(value = "List of device groups returned")
|
||||||
|
@JsonProperty("groups")
|
||||||
|
private List<?> deviceGroups = new ArrayList<>();
|
||||||
|
|
||||||
|
public List<?> getList() {
|
||||||
|
return deviceGroups;
|
||||||
|
}
|
||||||
|
|
||||||
|
public void setList(List<?> deviceGroups) {
|
||||||
|
this.deviceGroups = deviceGroups;
|
||||||
|
}
|
||||||
|
|
||||||
|
@Override
|
||||||
|
public String toString() {
|
||||||
|
StringBuilder sb = new StringBuilder();
|
||||||
|
sb.append("{\n");
|
||||||
|
sb.append(" count: ").append(getCount()).append(",\n");
|
||||||
|
sb.append(" groups: [").append(deviceGroups).append("\n");
|
||||||
|
sb.append("]}\n");
|
||||||
|
return sb.toString();
|
||||||
|
}
|
||||||
|
|
||||||
|
}
|
||||||
|
|
||||||
@ -0,0 +1,58 @@
|
|||||||
|
/*
|
||||||
|
* 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.
|
||||||
|
*
|
||||||
|
*/
|
||||||
|
package org.wso2.carbon.device.mgt.jaxrs.beans;
|
||||||
|
|
||||||
|
import io.swagger.annotations.ApiModel;
|
||||||
|
import io.swagger.annotations.ApiModelProperty;
|
||||||
|
|
||||||
|
import java.io.Serializable;
|
||||||
|
import java.util.List;
|
||||||
|
|
||||||
|
|
||||||
|
/**
|
||||||
|
* This class holds Device Group user name and assigned roles of user for particular group. Exposed to external access.
|
||||||
|
*/
|
||||||
|
@ApiModel(value = "DeviceGroupShare", description = "This class carries roles assigned to a user of a managed device group.")
|
||||||
|
public class DeviceGroupShare implements Serializable {
|
||||||
|
|
||||||
|
private static final long serialVersionUID = 1998141711L;
|
||||||
|
|
||||||
|
@ApiModelProperty(name = "username", value = "Username of the user.", required = true)
|
||||||
|
private String username;
|
||||||
|
|
||||||
|
@ApiModelProperty(name = "roles", value = "List of roles assigned to user from the group.")
|
||||||
|
private List<String> groupRoles;
|
||||||
|
|
||||||
|
public String getUsername() {
|
||||||
|
return username;
|
||||||
|
}
|
||||||
|
|
||||||
|
public void setUsername(String username) {
|
||||||
|
this.username = username;
|
||||||
|
}
|
||||||
|
|
||||||
|
public List<String> getGroupRoles() {
|
||||||
|
return groupRoles;
|
||||||
|
}
|
||||||
|
|
||||||
|
public void setGroupRoles(List<String> groupRoles) {
|
||||||
|
this.groupRoles = groupRoles;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
@ -0,0 +1,54 @@
|
|||||||
|
/*
|
||||||
|
* 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.
|
||||||
|
*
|
||||||
|
*/
|
||||||
|
package org.wso2.carbon.device.mgt.jaxrs.beans;
|
||||||
|
|
||||||
|
import com.fasterxml.jackson.annotation.JsonProperty;
|
||||||
|
import io.swagger.annotations.ApiModelProperty;
|
||||||
|
import org.wso2.carbon.device.mgt.common.group.mgt.GroupUser;
|
||||||
|
|
||||||
|
import java.util.ArrayList;
|
||||||
|
import java.util.List;
|
||||||
|
|
||||||
|
public class DeviceGroupUsersList extends BasePaginatedResult {
|
||||||
|
|
||||||
|
@ApiModelProperty(value = "List of device group users returned")
|
||||||
|
@JsonProperty("users")
|
||||||
|
private List<GroupUser> users = new ArrayList<>();
|
||||||
|
|
||||||
|
public List<GroupUser> getList() {
|
||||||
|
return users;
|
||||||
|
}
|
||||||
|
|
||||||
|
public void setList(List<GroupUser> users) {
|
||||||
|
this.users = users;
|
||||||
|
}
|
||||||
|
|
||||||
|
@Override
|
||||||
|
public String toString() {
|
||||||
|
StringBuilder sb = new StringBuilder();
|
||||||
|
sb.append("{\n");
|
||||||
|
|
||||||
|
sb.append(" count: ").append(getCount()).append(",\n");
|
||||||
|
sb.append(" users: [").append(users).append("\n");
|
||||||
|
sb.append("]}\n");
|
||||||
|
return sb.toString();
|
||||||
|
}
|
||||||
|
|
||||||
|
}
|
||||||
|
|
||||||
@ -0,0 +1,674 @@
|
|||||||
|
/*
|
||||||
|
* 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.
|
||||||
|
*
|
||||||
|
*/
|
||||||
|
|
||||||
|
package org.wso2.carbon.device.mgt.jaxrs.service.api;
|
||||||
|
|
||||||
|
import io.swagger.annotations.Api;
|
||||||
|
import io.swagger.annotations.ApiOperation;
|
||||||
|
import io.swagger.annotations.ApiParam;
|
||||||
|
import io.swagger.annotations.ApiResponse;
|
||||||
|
import io.swagger.annotations.ApiResponses;
|
||||||
|
import io.swagger.annotations.ResponseHeader;
|
||||||
|
import org.apache.axis2.transport.http.HTTPConstants;
|
||||||
|
import org.wso2.carbon.apimgt.annotations.api.API;
|
||||||
|
import org.wso2.carbon.apimgt.annotations.api.Permission;
|
||||||
|
import org.wso2.carbon.device.mgt.common.DeviceIdentifier;
|
||||||
|
import org.wso2.carbon.device.mgt.common.group.mgt.DeviceGroup;
|
||||||
|
import org.wso2.carbon.device.mgt.jaxrs.beans.DeviceGroupList;
|
||||||
|
import org.wso2.carbon.device.mgt.jaxrs.beans.DeviceGroupShare;
|
||||||
|
import org.wso2.carbon.device.mgt.jaxrs.beans.DeviceGroupUsersList;
|
||||||
|
import org.wso2.carbon.device.mgt.jaxrs.beans.DeviceList;
|
||||||
|
import org.wso2.carbon.device.mgt.jaxrs.beans.ErrorResponse;
|
||||||
|
|
||||||
|
import javax.validation.Valid;
|
||||||
|
import javax.ws.rs.Consumes;
|
||||||
|
import javax.ws.rs.DELETE;
|
||||||
|
import javax.ws.rs.GET;
|
||||||
|
import javax.ws.rs.POST;
|
||||||
|
import javax.ws.rs.PUT;
|
||||||
|
import javax.ws.rs.Path;
|
||||||
|
import javax.ws.rs.PathParam;
|
||||||
|
import javax.ws.rs.Produces;
|
||||||
|
import javax.ws.rs.QueryParam;
|
||||||
|
import javax.ws.rs.core.MediaType;
|
||||||
|
import javax.ws.rs.core.Response;
|
||||||
|
import java.util.List;
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Device group related REST-API. This can be used to manipulated device group related details.
|
||||||
|
*/
|
||||||
|
@API(name = "GroupManagement", version = "1.0.0", context = "/api/device-mgt/v1.0/groups", tags = {"device_management"})
|
||||||
|
|
||||||
|
@Path("/groups")
|
||||||
|
@Api(value = "Device Group Management", description = "This API carries all device group management related operations " +
|
||||||
|
"such as get all the available groups, etc.")
|
||||||
|
@Produces(MediaType.APPLICATION_JSON)
|
||||||
|
@Consumes(MediaType.APPLICATION_JSON)
|
||||||
|
public interface GroupManagementService {
|
||||||
|
|
||||||
|
@GET
|
||||||
|
@ApiOperation(
|
||||||
|
produces = MediaType.APPLICATION_JSON,
|
||||||
|
httpMethod = HTTPConstants.HEADER_GET,
|
||||||
|
value = "Get the list of groups belongs to current user.",
|
||||||
|
notes = "Returns all permitted groups enrolled with the system.",
|
||||||
|
tags = "Device Group Management")
|
||||||
|
@ApiResponses(value = {
|
||||||
|
@ApiResponse(code = 200, message = "OK. \n Successfully fetched the list of device groups.",
|
||||||
|
response = DeviceGroupList.class,
|
||||||
|
responseHeaders = {
|
||||||
|
@ResponseHeader(
|
||||||
|
name = "Content-Type",
|
||||||
|
description = "The content type of the body"),
|
||||||
|
@ResponseHeader(
|
||||||
|
name = "ETag",
|
||||||
|
description = "Entity Tag of the response resource.\n" +
|
||||||
|
"Used by caches, or in conditional requests."),
|
||||||
|
@ResponseHeader(
|
||||||
|
name = "Last-Modified",
|
||||||
|
description = "Date and time the resource has been modified the last time.\n" +
|
||||||
|
"Used by caches, or in conditional requests."),
|
||||||
|
}),
|
||||||
|
@ApiResponse(
|
||||||
|
code = 304,
|
||||||
|
message = "Not Modified. \n Empty body because the client has already the latest version of " +
|
||||||
|
"the requested resource."),
|
||||||
|
@ApiResponse(
|
||||||
|
code = 404,
|
||||||
|
message = "No groups found.",
|
||||||
|
response = ErrorResponse.class),
|
||||||
|
@ApiResponse(
|
||||||
|
code = 406,
|
||||||
|
message = "Not Acceptable.\n The requested media type is not supported."),
|
||||||
|
@ApiResponse(
|
||||||
|
code = 500,
|
||||||
|
message = "Internal Server Error. \n Server error occurred while fetching the groups list.",
|
||||||
|
response = ErrorResponse.class)
|
||||||
|
})
|
||||||
|
@Permission(name = "View Groups", permission = "/device-mgt/groups/view")
|
||||||
|
Response getGroups(@ApiParam(
|
||||||
|
name = "name",
|
||||||
|
value = "Name of the group.")
|
||||||
|
@QueryParam("name") String name,
|
||||||
|
@ApiParam(
|
||||||
|
name = "owner",
|
||||||
|
value = "Owner of the group.")
|
||||||
|
@QueryParam("owner") String owner,
|
||||||
|
@ApiParam(
|
||||||
|
name = "offset",
|
||||||
|
value = "Starting point within the complete list of items qualified.")
|
||||||
|
@QueryParam("offset") int offset,
|
||||||
|
@ApiParam(
|
||||||
|
name = "limit",
|
||||||
|
value = "Maximum size of resource array to return.")
|
||||||
|
@QueryParam("limit") int limit);
|
||||||
|
|
||||||
|
@Path("/count")
|
||||||
|
@GET
|
||||||
|
@ApiOperation(
|
||||||
|
produces = MediaType.APPLICATION_JSON,
|
||||||
|
httpMethod = HTTPConstants.HEADER_GET,
|
||||||
|
value = "Get the count of groups belongs to current user.",
|
||||||
|
notes = "Returns count of all permitted groups enrolled with the system.",
|
||||||
|
tags = "Device Group Management")
|
||||||
|
@ApiResponses(value = {
|
||||||
|
@ApiResponse(code = 200, message = "OK. \n Successfully fetched the device group count.",
|
||||||
|
response = DeviceGroupList.class,
|
||||||
|
responseHeaders = {
|
||||||
|
@ResponseHeader(
|
||||||
|
name = "Content-Type",
|
||||||
|
description = "The content type of the body"),
|
||||||
|
@ResponseHeader(
|
||||||
|
name = "ETag",
|
||||||
|
description = "Entity Tag of the response resource.\n" +
|
||||||
|
"Used by caches, or in conditional requests."),
|
||||||
|
@ResponseHeader(
|
||||||
|
name = "Last-Modified",
|
||||||
|
description = "Date and time the resource has been modified the last time.\n" +
|
||||||
|
"Used by caches, or in conditional requests."),
|
||||||
|
}),
|
||||||
|
@ApiResponse(
|
||||||
|
code = 304,
|
||||||
|
message = "Not Modified. \n Empty body because the client has already the latest version of " +
|
||||||
|
"the requested resource."),
|
||||||
|
@ApiResponse(
|
||||||
|
code = 404,
|
||||||
|
message = "No groups found.",
|
||||||
|
response = ErrorResponse.class),
|
||||||
|
@ApiResponse(
|
||||||
|
code = 406,
|
||||||
|
message = "Not Acceptable.\n The requested media type is not supported."),
|
||||||
|
@ApiResponse(
|
||||||
|
code = 500,
|
||||||
|
message = "Internal Server Error. \n Server error occurred while fetching the group count.",
|
||||||
|
response = ErrorResponse.class)
|
||||||
|
})
|
||||||
|
@Permission(name = "View Groups", permission = "/device-mgt/groups/view")
|
||||||
|
Response getGroupCount();
|
||||||
|
|
||||||
|
@POST
|
||||||
|
@ApiOperation(
|
||||||
|
consumes = MediaType.APPLICATION_JSON,
|
||||||
|
httpMethod = HTTPConstants.HEADER_POST,
|
||||||
|
value = "Add new device group to the system.",
|
||||||
|
notes = "Add device group with current user as the owner.",
|
||||||
|
tags = "Device Group Management")
|
||||||
|
@ApiResponses(
|
||||||
|
value = {
|
||||||
|
@ApiResponse(
|
||||||
|
code = 201,
|
||||||
|
message = "Created. \n Device group has successfully been created",
|
||||||
|
responseHeaders = {
|
||||||
|
@ResponseHeader(
|
||||||
|
name = "Content-Location",
|
||||||
|
description = "The URL of the added group."),
|
||||||
|
@ResponseHeader(
|
||||||
|
name = "Content-Type",
|
||||||
|
description = "The content type of the body"),
|
||||||
|
@ResponseHeader(
|
||||||
|
name = "ETag",
|
||||||
|
description = "Entity Tag of the response resource.\n" +
|
||||||
|
"Used by caches, or in conditional requests."),
|
||||||
|
@ResponseHeader(
|
||||||
|
name = "Last-Modified",
|
||||||
|
description = "Date and time the resource has been modified the last time.\n" +
|
||||||
|
"Used by caches, or in conditional requests.")
|
||||||
|
}
|
||||||
|
),
|
||||||
|
@ApiResponse(
|
||||||
|
code = 303,
|
||||||
|
message = "See Other. \n Source can be retrieved from the URL specified at the Location header.",
|
||||||
|
responseHeaders = {
|
||||||
|
@ResponseHeader(
|
||||||
|
name = "Content-Location",
|
||||||
|
description = "The Source URL of the document.")}),
|
||||||
|
@ApiResponse(
|
||||||
|
code = 400,
|
||||||
|
message = "Bad Request. \n Invalid request or validation error.",
|
||||||
|
response = ErrorResponse.class),
|
||||||
|
@ApiResponse(
|
||||||
|
code = 401,
|
||||||
|
message = "Unauthorized. \n Current logged in user is not authorized to add device groups.",
|
||||||
|
response = ErrorResponse.class),
|
||||||
|
@ApiResponse(
|
||||||
|
code = 415,
|
||||||
|
message = "Unsupported media type. \n The entity of the request was in a not supported format."),
|
||||||
|
@ApiResponse(
|
||||||
|
code = 500,
|
||||||
|
message = "Internal Server Error. \n " +
|
||||||
|
"Server error occurred while adding a new device group.",
|
||||||
|
response = ErrorResponse.class)
|
||||||
|
})
|
||||||
|
@Permission(name = "Add Group", permission = "/device-mgt/groups/add")
|
||||||
|
Response createGroup(@ApiParam(
|
||||||
|
name = "group",
|
||||||
|
value = "Group object with data.",
|
||||||
|
required = true)
|
||||||
|
@Valid DeviceGroup group);
|
||||||
|
|
||||||
|
@Path("/id/{groupId}")
|
||||||
|
@GET
|
||||||
|
@ApiOperation(
|
||||||
|
produces = MediaType.APPLICATION_JSON,
|
||||||
|
httpMethod = HTTPConstants.HEADER_GET,
|
||||||
|
value = "View group specified.",
|
||||||
|
notes = "Returns details of group enrolled with the system.",
|
||||||
|
tags = "Device Group Management")
|
||||||
|
@ApiResponses(value = {
|
||||||
|
@ApiResponse(code = 200, message = "OK. \n Successfully fetched the device group.",
|
||||||
|
response = DeviceGroup.class,
|
||||||
|
responseHeaders = {
|
||||||
|
@ResponseHeader(
|
||||||
|
name = "Content-Type",
|
||||||
|
description = "The content type of the body"),
|
||||||
|
@ResponseHeader(
|
||||||
|
name = "ETag",
|
||||||
|
description = "Entity Tag of the response resource.\n" +
|
||||||
|
"Used by caches, or in conditional requests."),
|
||||||
|
@ResponseHeader(
|
||||||
|
name = "Last-Modified",
|
||||||
|
description = "Date and time the resource has been modified the last time.\n" +
|
||||||
|
"Used by caches, or in conditional requests."),
|
||||||
|
}),
|
||||||
|
@ApiResponse(
|
||||||
|
code = 304,
|
||||||
|
message = "Not Modified. \n Empty body because the client has already the latest version of " +
|
||||||
|
"the requested resource."),
|
||||||
|
@ApiResponse(
|
||||||
|
code = 404,
|
||||||
|
message = "No groups found.",
|
||||||
|
response = ErrorResponse.class),
|
||||||
|
@ApiResponse(
|
||||||
|
code = 406,
|
||||||
|
message = "Not Acceptable.\n The requested media type is not supported."),
|
||||||
|
@ApiResponse(
|
||||||
|
code = 500,
|
||||||
|
message = "Internal Server Error. \n Server error occurred while fetching the group details.",
|
||||||
|
response = ErrorResponse.class)
|
||||||
|
})
|
||||||
|
@Permission(name = "View Groups", permission = "/device-mgt/groups/view")
|
||||||
|
Response getGroup(@ApiParam(
|
||||||
|
name = "groupId",
|
||||||
|
value = "ID of the group to view.",
|
||||||
|
required = true)
|
||||||
|
@PathParam("groupId") int groupId);
|
||||||
|
|
||||||
|
@Path("/id/{groupId}")
|
||||||
|
@PUT
|
||||||
|
@ApiOperation(
|
||||||
|
produces = MediaType.APPLICATION_JSON,
|
||||||
|
httpMethod = HTTPConstants.HEADER_PUT,
|
||||||
|
value = "Update a group.",
|
||||||
|
notes = "If you wish to make changes to an existing group, that can be done by updating the group using " +
|
||||||
|
"this resource.",
|
||||||
|
tags = "Device Group Management")
|
||||||
|
@ApiResponses(value = {
|
||||||
|
@ApiResponse(code = 200, message = "OK. \n Group has been updated successfully.",
|
||||||
|
responseHeaders = {
|
||||||
|
@ResponseHeader(
|
||||||
|
name = "Content-Type",
|
||||||
|
description = "The content type of the body."),
|
||||||
|
@ResponseHeader(
|
||||||
|
name = "ETag",
|
||||||
|
description = "Entity Tag of the response resource.\n" +
|
||||||
|
"Used by caches, or in conditional requests."),
|
||||||
|
@ResponseHeader(
|
||||||
|
name = "Last-Modified",
|
||||||
|
description = "Date and time the resource has been modified the last time.\n" +
|
||||||
|
"Used by caches, or in conditional requests."),
|
||||||
|
}),
|
||||||
|
@ApiResponse(
|
||||||
|
code = 304,
|
||||||
|
message = "Not Modified. \n Empty body because the client has already the latest version of " +
|
||||||
|
"the requested resource."),
|
||||||
|
@ApiResponse(
|
||||||
|
code = 404,
|
||||||
|
message = "No groups found.",
|
||||||
|
response = ErrorResponse.class),
|
||||||
|
@ApiResponse(
|
||||||
|
code = 406,
|
||||||
|
message = "Not Acceptable.\n The requested media type is not supported."),
|
||||||
|
@ApiResponse(
|
||||||
|
code = 500,
|
||||||
|
message = "Internal Server Error. \n Server error occurred while updating the group.",
|
||||||
|
response = ErrorResponse.class)
|
||||||
|
})
|
||||||
|
@Permission(name = "Update Group", permission = "/device-mgt/groups/update")
|
||||||
|
Response updateGroup(@ApiParam(
|
||||||
|
name = "groupId",
|
||||||
|
value = "ID of the group to be updated.",
|
||||||
|
required = true)
|
||||||
|
@PathParam("groupId") int groupId,
|
||||||
|
@ApiParam(
|
||||||
|
name = "group",
|
||||||
|
value = "Group object with data.",
|
||||||
|
required = true)
|
||||||
|
@Valid DeviceGroup deviceGroup);
|
||||||
|
|
||||||
|
@Path("/id/{groupId}")
|
||||||
|
@DELETE
|
||||||
|
@ApiOperation(
|
||||||
|
produces = MediaType.APPLICATION_JSON,
|
||||||
|
httpMethod = HTTPConstants.HEADER_DELETE,
|
||||||
|
value = "Delete a group.",
|
||||||
|
notes = "If you wish to remove an existing group, that can be done by updating the group using " +
|
||||||
|
"this resource.",
|
||||||
|
tags = "Device Group Management")
|
||||||
|
@ApiResponses(value = {
|
||||||
|
@ApiResponse(code = 200, message = "OK. \n Group has been deleted successfully.",
|
||||||
|
responseHeaders = {
|
||||||
|
@ResponseHeader(
|
||||||
|
name = "Content-Type",
|
||||||
|
description = "The content type of the body."),
|
||||||
|
@ResponseHeader(
|
||||||
|
name = "ETag",
|
||||||
|
description = "Entity Tag of the response resource.\n" +
|
||||||
|
"Used by caches, or in conditional requests."),
|
||||||
|
@ResponseHeader(
|
||||||
|
name = "Last-Modified",
|
||||||
|
description = "Date and time the resource has been modified the last time.\n" +
|
||||||
|
"Used by caches, or in conditional requests."),
|
||||||
|
}),
|
||||||
|
@ApiResponse(
|
||||||
|
code = 304,
|
||||||
|
message = "Not Modified. \n Empty body because the client has already the latest version of " +
|
||||||
|
"the requested resource."),
|
||||||
|
@ApiResponse(
|
||||||
|
code = 404,
|
||||||
|
message = "No groups found.",
|
||||||
|
response = ErrorResponse.class),
|
||||||
|
@ApiResponse(
|
||||||
|
code = 406,
|
||||||
|
message = "Not Acceptable.\n The requested media type is not supported."),
|
||||||
|
@ApiResponse(
|
||||||
|
code = 500,
|
||||||
|
message = "Internal Server Error. \n Server error occurred while removing the group.",
|
||||||
|
response = ErrorResponse.class)
|
||||||
|
})
|
||||||
|
@Permission(name = "Remove Group", permission = "/device-mgt/groups/remove")
|
||||||
|
Response deleteGroup(@ApiParam(
|
||||||
|
name = "groupId",
|
||||||
|
value = "ID of the group to be deleted.",
|
||||||
|
required = true)
|
||||||
|
@PathParam("groupId") int groupId);
|
||||||
|
|
||||||
|
@Path("/id/{groupId}/share")
|
||||||
|
@POST
|
||||||
|
@ApiOperation(
|
||||||
|
produces = MediaType.APPLICATION_JSON,
|
||||||
|
httpMethod = HTTPConstants.HEADER_POST,
|
||||||
|
value = "Manage group sharing with a user.",
|
||||||
|
notes = "If you wish to share /un share an existing group with a user under defined sharing roles, " +
|
||||||
|
"that can be done using this resource.",
|
||||||
|
tags = "Device Group Management")
|
||||||
|
@ApiResponses(value = {
|
||||||
|
@ApiResponse(code = 200, message = "OK. \n Sharing has been updated successfully.",
|
||||||
|
responseHeaders = {
|
||||||
|
@ResponseHeader(
|
||||||
|
name = "Content-Type",
|
||||||
|
description = "The content type of the body."),
|
||||||
|
@ResponseHeader(
|
||||||
|
name = "ETag",
|
||||||
|
description = "Entity Tag of the response resource.\n" +
|
||||||
|
"Used by caches, or in conditional requests."),
|
||||||
|
@ResponseHeader(
|
||||||
|
name = "Last-Modified",
|
||||||
|
description = "Date and time the resource has been modified the last time.\n" +
|
||||||
|
"Used by caches, or in conditional requests."),
|
||||||
|
}),
|
||||||
|
@ApiResponse(
|
||||||
|
code = 304,
|
||||||
|
message = "Not Modified. \n Empty body because the client has already the latest version of " +
|
||||||
|
"the requested resource."),
|
||||||
|
@ApiResponse(
|
||||||
|
code = 404,
|
||||||
|
message = "No groups found.",
|
||||||
|
response = ErrorResponse.class),
|
||||||
|
@ApiResponse(
|
||||||
|
code = 406,
|
||||||
|
message = "Not Acceptable.\n The requested media type is not supported."),
|
||||||
|
@ApiResponse(
|
||||||
|
code = 500,
|
||||||
|
message = "Internal Server Error. \n Server error occurred while sharing the group.",
|
||||||
|
response = ErrorResponse.class)
|
||||||
|
})
|
||||||
|
@Permission(name = "Share Group", permission = "/device-mgt/groups/share")
|
||||||
|
Response manageGroupSharing(@ApiParam(
|
||||||
|
name = "groupName",
|
||||||
|
value = "Name of the group to be shared or unshared.",
|
||||||
|
required = true)
|
||||||
|
@PathParam("groupId") int groupId,
|
||||||
|
@ApiParam(
|
||||||
|
name = "deviceGroupShare",
|
||||||
|
value = "User name and the assigned roles for the share.",
|
||||||
|
required = true)
|
||||||
|
@Valid DeviceGroupShare deviceGroupShare);
|
||||||
|
|
||||||
|
@Path("/id/{groupId}/users")
|
||||||
|
@GET
|
||||||
|
@ApiOperation(
|
||||||
|
produces = MediaType.APPLICATION_JSON,
|
||||||
|
httpMethod = HTTPConstants.HEADER_GET,
|
||||||
|
value = "View list of users of a device group.",
|
||||||
|
notes = "Returns details of users which particular group has been shared with.",
|
||||||
|
tags = "Device Group Management")
|
||||||
|
@ApiResponses(value = {
|
||||||
|
@ApiResponse(code = 200, message = "OK. \n Successfully fetched the users.",
|
||||||
|
response = DeviceGroupUsersList.class,
|
||||||
|
responseHeaders = {
|
||||||
|
@ResponseHeader(
|
||||||
|
name = "Content-Type",
|
||||||
|
description = "The content type of the body"),
|
||||||
|
@ResponseHeader(
|
||||||
|
name = "ETag",
|
||||||
|
description = "Entity Tag of the response resource.\n" +
|
||||||
|
"Used by caches, or in conditional requests."),
|
||||||
|
@ResponseHeader(
|
||||||
|
name = "Last-Modified",
|
||||||
|
description = "Date and time the resource has been modified the last time.\n" +
|
||||||
|
"Used by caches, or in conditional requests."),
|
||||||
|
}),
|
||||||
|
@ApiResponse(
|
||||||
|
code = 304,
|
||||||
|
message = "Not Modified. \n Empty body because the client has already the latest version of " +
|
||||||
|
"the requested resource."),
|
||||||
|
@ApiResponse(
|
||||||
|
code = 404,
|
||||||
|
message = "No groups found.",
|
||||||
|
response = ErrorResponse.class),
|
||||||
|
@ApiResponse(
|
||||||
|
code = 406,
|
||||||
|
message = "Not Acceptable.\n The requested media type is not supported."),
|
||||||
|
@ApiResponse(
|
||||||
|
code = 500,
|
||||||
|
message = "Internal Server Error. \n Server error occurred while fetching the users.",
|
||||||
|
response = ErrorResponse.class)
|
||||||
|
})
|
||||||
|
@Permission(name = "View users", permission = "/device-mgt/groups/users/view")
|
||||||
|
Response getUsersOfGroup(@ApiParam(
|
||||||
|
name = "groupId",
|
||||||
|
value = "ID of the group.",
|
||||||
|
required = true)
|
||||||
|
@PathParam("groupId") int groupId);
|
||||||
|
|
||||||
|
@Path("/id/{groupId}/devices")
|
||||||
|
@GET
|
||||||
|
@ApiOperation(
|
||||||
|
produces = MediaType.APPLICATION_JSON,
|
||||||
|
httpMethod = HTTPConstants.HEADER_GET,
|
||||||
|
value = "View list of devices in the device group.",
|
||||||
|
notes = "Returns list of devices in the device group.",
|
||||||
|
tags = "Device Group Management")
|
||||||
|
@ApiResponses(value = {
|
||||||
|
@ApiResponse(code = 200, message = "OK. \n Successfully fetched the devices.",
|
||||||
|
response = DeviceList.class,
|
||||||
|
responseHeaders = {
|
||||||
|
@ResponseHeader(
|
||||||
|
name = "Content-Type",
|
||||||
|
description = "The content type of the body"),
|
||||||
|
@ResponseHeader(
|
||||||
|
name = "ETag",
|
||||||
|
description = "Entity Tag of the response resource.\n" +
|
||||||
|
"Used by caches, or in conditional requests."),
|
||||||
|
@ResponseHeader(
|
||||||
|
name = "Last-Modified",
|
||||||
|
description = "Date and time the resource has been modified the last time.\n" +
|
||||||
|
"Used by caches, or in conditional requests."),
|
||||||
|
}),
|
||||||
|
@ApiResponse(
|
||||||
|
code = 304,
|
||||||
|
message = "Not Modified. \n Empty body because the client has already the latest version of " +
|
||||||
|
"the requested resource."),
|
||||||
|
@ApiResponse(
|
||||||
|
code = 404,
|
||||||
|
message = "No groups found.",
|
||||||
|
response = ErrorResponse.class),
|
||||||
|
@ApiResponse(
|
||||||
|
code = 406,
|
||||||
|
message = "Not Acceptable.\n The requested media type is not supported."),
|
||||||
|
@ApiResponse(
|
||||||
|
code = 500,
|
||||||
|
message = "Internal Server Error. \n Server error occurred while fetching the devices.",
|
||||||
|
response = ErrorResponse.class)
|
||||||
|
})
|
||||||
|
@Permission(name = "View devices", permission = "/device-mgt/groups/devices/view")
|
||||||
|
Response getDevicesOfGroup(@ApiParam(
|
||||||
|
name = "groupId",
|
||||||
|
value = "ID of the group.",
|
||||||
|
required = true)
|
||||||
|
@PathParam("groupId") int groupId,
|
||||||
|
@ApiParam(
|
||||||
|
name = "offset",
|
||||||
|
value = "Starting point within the complete list of items qualified.")
|
||||||
|
@QueryParam("offset") int offset,
|
||||||
|
@ApiParam(
|
||||||
|
name = "limit",
|
||||||
|
value = "Maximum size of resource array to return.")
|
||||||
|
@QueryParam("limit") int limit);
|
||||||
|
|
||||||
|
@Path("/id/{groupId}/devices/count")
|
||||||
|
@GET
|
||||||
|
@ApiOperation(
|
||||||
|
produces = MediaType.APPLICATION_JSON,
|
||||||
|
httpMethod = HTTPConstants.HEADER_GET,
|
||||||
|
value = "View list of device count in the device group.",
|
||||||
|
notes = "Returns device count in the device group.",
|
||||||
|
tags = "Device Group Management")
|
||||||
|
@ApiResponses(value = {
|
||||||
|
@ApiResponse(code = 200, message = "OK. \n Successfully fetched the device count.",
|
||||||
|
response = DeviceList.class,
|
||||||
|
responseHeaders = {
|
||||||
|
@ResponseHeader(
|
||||||
|
name = "Content-Type",
|
||||||
|
description = "The content type of the body"),
|
||||||
|
@ResponseHeader(
|
||||||
|
name = "ETag",
|
||||||
|
description = "Entity Tag of the response resource.\n" +
|
||||||
|
"Used by caches, or in conditional requests."),
|
||||||
|
@ResponseHeader(
|
||||||
|
name = "Last-Modified",
|
||||||
|
description = "Date and time the resource has been modified the last time.\n" +
|
||||||
|
"Used by caches, or in conditional requests."),
|
||||||
|
}),
|
||||||
|
@ApiResponse(
|
||||||
|
code = 304,
|
||||||
|
message = "Not Modified. \n Empty body because the client has already the latest version of " +
|
||||||
|
"the requested resource."),
|
||||||
|
@ApiResponse(
|
||||||
|
code = 404,
|
||||||
|
message = "No groups found.",
|
||||||
|
response = ErrorResponse.class),
|
||||||
|
@ApiResponse(
|
||||||
|
code = 406,
|
||||||
|
message = "Not Acceptable.\n The requested media type is not supported."),
|
||||||
|
@ApiResponse(
|
||||||
|
code = 500,
|
||||||
|
message = "Internal Server Error. \n Server error occurred while fetching device count.",
|
||||||
|
response = ErrorResponse.class)
|
||||||
|
})
|
||||||
|
@Permission(name = "View devices", permission = "/device-mgt/groups/devices/view")
|
||||||
|
Response getDeviceCountOfGroup(@ApiParam(
|
||||||
|
name = "groupId",
|
||||||
|
value = "ID of the group.",
|
||||||
|
required = true)
|
||||||
|
@PathParam("groupId") int groupId);
|
||||||
|
|
||||||
|
@Path("/id/{groupId}/devices")
|
||||||
|
@POST
|
||||||
|
@ApiOperation(
|
||||||
|
produces = MediaType.APPLICATION_JSON,
|
||||||
|
httpMethod = HTTPConstants.HEADER_POST,
|
||||||
|
value = "Add devices to group.",
|
||||||
|
notes = "Add existing devices to the device group.",
|
||||||
|
tags = "Device Group Management")
|
||||||
|
@ApiResponses(value = {
|
||||||
|
@ApiResponse(code = 200, message = "OK. \n Successfully add devices to the group.",
|
||||||
|
responseHeaders = {
|
||||||
|
@ResponseHeader(
|
||||||
|
name = "Content-Type",
|
||||||
|
description = "The content type of the body"),
|
||||||
|
@ResponseHeader(
|
||||||
|
name = "ETag",
|
||||||
|
description = "Entity Tag of the response resource.\n" +
|
||||||
|
"Used by caches, or in conditional requests."),
|
||||||
|
@ResponseHeader(
|
||||||
|
name = "Last-Modified",
|
||||||
|
description = "Date and time the resource has been modified the last time.\n" +
|
||||||
|
"Used by caches, or in conditional requests."),
|
||||||
|
}),
|
||||||
|
@ApiResponse(
|
||||||
|
code = 304,
|
||||||
|
message = "Not Modified. \n Empty body because the client has already the latest version of " +
|
||||||
|
"the requested resource."),
|
||||||
|
@ApiResponse(
|
||||||
|
code = 404,
|
||||||
|
message = "No groups found.",
|
||||||
|
response = ErrorResponse.class),
|
||||||
|
@ApiResponse(
|
||||||
|
code = 406,
|
||||||
|
message = "Not Acceptable.\n The requested media type is not supported."),
|
||||||
|
@ApiResponse(
|
||||||
|
code = 500,
|
||||||
|
message = "Internal Server Error. \n Server error occurred while adding devices to the group.",
|
||||||
|
response = ErrorResponse.class)
|
||||||
|
})
|
||||||
|
@Permission(name = "Add devices", permission = "/device-mgt/groups/devices/add")
|
||||||
|
Response addDevicesToGroup(@ApiParam(
|
||||||
|
name = "groupId",
|
||||||
|
value = "ID of the group.",
|
||||||
|
required = true)
|
||||||
|
@PathParam("groupId") int groupId,
|
||||||
|
@ApiParam(
|
||||||
|
name = "deviceIdentifiers",
|
||||||
|
value = "Device identifiers of the devices which needed be added.",
|
||||||
|
required = true)
|
||||||
|
@Valid List<DeviceIdentifier> deviceIdentifiers);
|
||||||
|
|
||||||
|
@Path("/id/{groupId}/devices")
|
||||||
|
@DELETE
|
||||||
|
@ApiOperation(
|
||||||
|
produces = MediaType.APPLICATION_JSON,
|
||||||
|
httpMethod = HTTPConstants.HEADER_DELETE,
|
||||||
|
value = "Remove devices from group.",
|
||||||
|
notes = "Remove existing devices from the device group.",
|
||||||
|
tags = "Device Group Management")
|
||||||
|
@ApiResponses(value = {
|
||||||
|
@ApiResponse(code = 200, message = "OK. \n Successfully removed devices from the group.",
|
||||||
|
responseHeaders = {
|
||||||
|
@ResponseHeader(
|
||||||
|
name = "Content-Type",
|
||||||
|
description = "The content type of the body"),
|
||||||
|
@ResponseHeader(
|
||||||
|
name = "ETag",
|
||||||
|
description = "Entity Tag of the response resource.\n" +
|
||||||
|
"Used by caches, or in conditional requests."),
|
||||||
|
@ResponseHeader(
|
||||||
|
name = "Last-Modified",
|
||||||
|
description = "Date and time the resource has been modified the last time.\n" +
|
||||||
|
"Used by caches, or in conditional requests."),
|
||||||
|
}),
|
||||||
|
@ApiResponse(
|
||||||
|
code = 304,
|
||||||
|
message = "Not Modified. \n Empty body because the client has already the latest version of " +
|
||||||
|
"the requested resource."),
|
||||||
|
@ApiResponse(
|
||||||
|
code = 404,
|
||||||
|
message = "No groups found.",
|
||||||
|
response = ErrorResponse.class),
|
||||||
|
@ApiResponse(
|
||||||
|
code = 406,
|
||||||
|
message = "Not Acceptable.\n The requested media type is not supported."),
|
||||||
|
@ApiResponse(
|
||||||
|
code = 500,
|
||||||
|
message = "Internal Server Error. \n Server error occurred while removing devices from the group.",
|
||||||
|
response = ErrorResponse.class)
|
||||||
|
})
|
||||||
|
@Permission(name = "Remove devices", permission = "/device-mgt/groups/devices/remove")
|
||||||
|
Response removeDevicesFromGroup(@ApiParam(
|
||||||
|
name = "groupId",
|
||||||
|
value = "ID of the group.",
|
||||||
|
required = true)
|
||||||
|
@PathParam("groupId") int groupId,
|
||||||
|
@ApiParam(
|
||||||
|
name = "deviceIdentifiers",
|
||||||
|
value = "Device identifiers of the devices which needed to be removed.",
|
||||||
|
required = true)
|
||||||
|
@Valid List<DeviceIdentifier> deviceIdentifiers);
|
||||||
|
|
||||||
|
}
|
||||||
@ -0,0 +1,152 @@
|
|||||||
|
/*
|
||||||
|
* 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.
|
||||||
|
*
|
||||||
|
*/
|
||||||
|
|
||||||
|
package org.wso2.carbon.device.mgt.jaxrs.service.api.admin;
|
||||||
|
|
||||||
|
import io.swagger.annotations.Api;
|
||||||
|
import io.swagger.annotations.ApiOperation;
|
||||||
|
import io.swagger.annotations.ApiParam;
|
||||||
|
import io.swagger.annotations.ApiResponse;
|
||||||
|
import io.swagger.annotations.ApiResponses;
|
||||||
|
import io.swagger.annotations.ResponseHeader;
|
||||||
|
import org.apache.axis2.transport.http.HTTPConstants;
|
||||||
|
import org.wso2.carbon.apimgt.annotations.api.API;
|
||||||
|
import org.wso2.carbon.apimgt.annotations.api.Permission;
|
||||||
|
import org.wso2.carbon.device.mgt.jaxrs.beans.DeviceGroupList;
|
||||||
|
import org.wso2.carbon.device.mgt.jaxrs.beans.ErrorResponse;
|
||||||
|
|
||||||
|
import javax.ws.rs.Consumes;
|
||||||
|
import javax.ws.rs.GET;
|
||||||
|
import javax.ws.rs.Path;
|
||||||
|
import javax.ws.rs.Produces;
|
||||||
|
import javax.ws.rs.QueryParam;
|
||||||
|
import javax.ws.rs.core.MediaType;
|
||||||
|
import javax.ws.rs.core.Response;
|
||||||
|
|
||||||
|
@API(name = "GroupManagementAdmin", version = "1.0.0", context = "/api/device-mgt/v1.0/admin/groups", tags = {"device_management"})
|
||||||
|
|
||||||
|
@Path("/admin/groups")
|
||||||
|
@Produces(MediaType.APPLICATION_JSON)
|
||||||
|
@Consumes(MediaType.APPLICATION_JSON)
|
||||||
|
@Api(value = "Group Management Administrative Service", description = "This an API intended to be used by " +
|
||||||
|
"'internal' components to log in as an admin user and do a selected number of operations. " +
|
||||||
|
"Further, this is strictly restricted to admin users only ")
|
||||||
|
public interface GroupManagementAdminService {
|
||||||
|
|
||||||
|
@GET
|
||||||
|
@ApiOperation(
|
||||||
|
produces = MediaType.APPLICATION_JSON,
|
||||||
|
httpMethod = HTTPConstants.HEADER_GET,
|
||||||
|
value = "Get the list of groups.",
|
||||||
|
notes = "Returns all groups enrolled with the system.",
|
||||||
|
tags = "Device Group Management")
|
||||||
|
@ApiResponses(value = {
|
||||||
|
@ApiResponse(code = 200, message = "OK. \n Successfully fetched the list of device groups.",
|
||||||
|
response = DeviceGroupList.class,
|
||||||
|
responseHeaders = {
|
||||||
|
@ResponseHeader(
|
||||||
|
name = "Content-Type",
|
||||||
|
description = "The content type of the body"),
|
||||||
|
@ResponseHeader(
|
||||||
|
name = "ETag",
|
||||||
|
description = "Entity Tag of the response resource.\n" +
|
||||||
|
"Used by caches, or in conditional requests."),
|
||||||
|
@ResponseHeader(
|
||||||
|
name = "Last-Modified",
|
||||||
|
description = "Date and time the resource has been modified the last time.\n" +
|
||||||
|
"Used by caches, or in conditional requests."),
|
||||||
|
}),
|
||||||
|
@ApiResponse(
|
||||||
|
code = 304,
|
||||||
|
message = "Not Modified. \n Empty body because the client has already the latest version of " +
|
||||||
|
"the requested resource."),
|
||||||
|
@ApiResponse(
|
||||||
|
code = 404,
|
||||||
|
message = "No groups found.",
|
||||||
|
response = ErrorResponse.class),
|
||||||
|
@ApiResponse(
|
||||||
|
code = 406,
|
||||||
|
message = "Not Acceptable.\n The requested media type is not supported."),
|
||||||
|
@ApiResponse(
|
||||||
|
code = 500,
|
||||||
|
message = "Internal Server Error. \n Server error occurred while fetching the groups list.",
|
||||||
|
response = ErrorResponse.class)
|
||||||
|
})
|
||||||
|
@Permission(name = "View Groups", permission = "/device-mgt/admin/groups/view")
|
||||||
|
Response getGroups(@ApiParam(
|
||||||
|
name = "name",
|
||||||
|
value = "Name of the group.")
|
||||||
|
@QueryParam("name") String name,
|
||||||
|
@ApiParam(
|
||||||
|
name = "owner",
|
||||||
|
value = "Owner of the group.")
|
||||||
|
@QueryParam("owner") String owner,
|
||||||
|
@ApiParam(
|
||||||
|
name = "offset",
|
||||||
|
value = "Starting point within the complete list of items qualified.")
|
||||||
|
@QueryParam("offset") int offset,
|
||||||
|
@ApiParam(
|
||||||
|
name = "limit",
|
||||||
|
value = "Maximum size of resource array to return.")
|
||||||
|
@QueryParam("limit") int limit);
|
||||||
|
|
||||||
|
@Path("/count")
|
||||||
|
@GET
|
||||||
|
@ApiOperation(
|
||||||
|
produces = MediaType.APPLICATION_JSON,
|
||||||
|
httpMethod = HTTPConstants.HEADER_GET,
|
||||||
|
value = "Get the count of groups belongs to current user.",
|
||||||
|
notes = "Returns count of all permitted groups enrolled with the system.",
|
||||||
|
tags = "Device Group Management")
|
||||||
|
@ApiResponses(value = {
|
||||||
|
@ApiResponse(code = 200, message = "OK. \n Successfully fetched the device group count.",
|
||||||
|
response = DeviceGroupList.class,
|
||||||
|
responseHeaders = {
|
||||||
|
@ResponseHeader(
|
||||||
|
name = "Content-Type",
|
||||||
|
description = "The content type of the body"),
|
||||||
|
@ResponseHeader(
|
||||||
|
name = "ETag",
|
||||||
|
description = "Entity Tag of the response resource.\n" +
|
||||||
|
"Used by caches, or in conditional requests."),
|
||||||
|
@ResponseHeader(
|
||||||
|
name = "Last-Modified",
|
||||||
|
description = "Date and time the resource has been modified the last time.\n" +
|
||||||
|
"Used by caches, or in conditional requests."),
|
||||||
|
}),
|
||||||
|
@ApiResponse(
|
||||||
|
code = 304,
|
||||||
|
message = "Not Modified. \n Empty body because the client has already the latest version of " +
|
||||||
|
"the requested resource."),
|
||||||
|
@ApiResponse(
|
||||||
|
code = 404,
|
||||||
|
message = "No groups found.",
|
||||||
|
response = ErrorResponse.class),
|
||||||
|
@ApiResponse(
|
||||||
|
code = 406,
|
||||||
|
message = "Not Acceptable.\n The requested media type is not supported."),
|
||||||
|
@ApiResponse(
|
||||||
|
code = 500,
|
||||||
|
message = "Internal Server Error. \n Server error occurred while fetching the group count.",
|
||||||
|
response = ErrorResponse.class)
|
||||||
|
})
|
||||||
|
@Permission(name = "View Groups", permission = "/device-mgt/admin/groups/view")
|
||||||
|
Response getGroupCount();
|
||||||
|
|
||||||
|
}
|
||||||
@ -18,7 +18,6 @@
|
|||||||
*/
|
*/
|
||||||
package org.wso2.carbon.device.mgt.jaxrs.service.impl;
|
package org.wso2.carbon.device.mgt.jaxrs.service.impl;
|
||||||
|
|
||||||
import com.google.gson.JsonArray;
|
|
||||||
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;
|
||||||
|
|||||||
@ -0,0 +1,264 @@
|
|||||||
|
/*
|
||||||
|
* 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.
|
||||||
|
*
|
||||||
|
*/
|
||||||
|
|
||||||
|
package org.wso2.carbon.device.mgt.jaxrs.service.impl;
|
||||||
|
|
||||||
|
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.DeviceNotFoundException;
|
||||||
|
import org.wso2.carbon.device.mgt.common.GroupPaginationRequest;
|
||||||
|
import org.wso2.carbon.device.mgt.common.PaginationResult;
|
||||||
|
import org.wso2.carbon.device.mgt.common.group.mgt.DeviceGroup;
|
||||||
|
import org.wso2.carbon.device.mgt.common.group.mgt.GroupAlreadyExistException;
|
||||||
|
import org.wso2.carbon.device.mgt.common.group.mgt.GroupManagementException;
|
||||||
|
import org.wso2.carbon.device.mgt.common.group.mgt.GroupUser;
|
||||||
|
import org.wso2.carbon.device.mgt.common.group.mgt.RoleDoesNotExistException;
|
||||||
|
import org.wso2.carbon.device.mgt.core.service.GroupManagementProviderService;
|
||||||
|
import org.wso2.carbon.device.mgt.jaxrs.beans.DeviceGroupList;
|
||||||
|
import org.wso2.carbon.device.mgt.jaxrs.beans.DeviceGroupShare;
|
||||||
|
import org.wso2.carbon.device.mgt.jaxrs.beans.DeviceGroupUsersList;
|
||||||
|
import org.wso2.carbon.device.mgt.jaxrs.beans.DeviceList;
|
||||||
|
import org.wso2.carbon.device.mgt.jaxrs.service.api.GroupManagementService;
|
||||||
|
import org.wso2.carbon.device.mgt.jaxrs.service.impl.util.RequestValidationUtil;
|
||||||
|
import org.wso2.carbon.device.mgt.jaxrs.util.DeviceMgtAPIUtils;
|
||||||
|
import org.wso2.carbon.user.core.multiplecredentials.UserDoesNotExistException;
|
||||||
|
|
||||||
|
import javax.ws.rs.core.Response;
|
||||||
|
import java.util.Date;
|
||||||
|
import java.util.List;
|
||||||
|
|
||||||
|
public class GroupManagementServiceImpl implements GroupManagementService {
|
||||||
|
|
||||||
|
private static final Log log = LogFactory.getLog(GroupManagementServiceImpl.class);
|
||||||
|
|
||||||
|
private static final String DEFAULT_ADMIN_ROLE = "admin";
|
||||||
|
private static final String[] DEFAULT_ADMIN_PERMISSIONS = {"/permission/device-mgt/admin/groups",
|
||||||
|
"/permission/device-mgt/user/groups"};
|
||||||
|
|
||||||
|
@Override
|
||||||
|
public Response getGroups(String name, String owner, int offset, int limit) {
|
||||||
|
try {
|
||||||
|
RequestValidationUtil.validatePaginationParameters(offset, limit);
|
||||||
|
String currentUser = CarbonContext.getThreadLocalCarbonContext().getUsername();
|
||||||
|
GroupPaginationRequest request = new GroupPaginationRequest(offset, limit);
|
||||||
|
request.setGroupName(name);
|
||||||
|
request.setOwner(owner);
|
||||||
|
PaginationResult deviceGroupsResult = DeviceMgtAPIUtils.getGroupManagementProviderService()
|
||||||
|
.getGroups(currentUser, request);
|
||||||
|
if (deviceGroupsResult.getData() != null && deviceGroupsResult.getRecordsTotal() > 0) {
|
||||||
|
DeviceGroupList deviceGroupList = new DeviceGroupList();
|
||||||
|
deviceGroupList.setList(deviceGroupsResult.getData());
|
||||||
|
deviceGroupList.setCount(deviceGroupsResult.getRecordsTotal());
|
||||||
|
return Response.status(Response.Status.OK).entity(deviceGroupList).build();
|
||||||
|
} else {
|
||||||
|
return Response.status(Response.Status.NOT_FOUND).build();
|
||||||
|
}
|
||||||
|
} catch (GroupManagementException e) {
|
||||||
|
String error = "Error occurred while getting the groups.";
|
||||||
|
log.error(error, e);
|
||||||
|
return Response.status(Response.Status.INTERNAL_SERVER_ERROR).entity(error).build();
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
@Override
|
||||||
|
public Response getGroupCount() {
|
||||||
|
try {
|
||||||
|
String currentUser = CarbonContext.getThreadLocalCarbonContext().getUsername();
|
||||||
|
int count = DeviceMgtAPIUtils.getGroupManagementProviderService().getGroupCount(currentUser);
|
||||||
|
return Response.status(Response.Status.OK).entity(count).build();
|
||||||
|
} catch (GroupManagementException e) {
|
||||||
|
String msg = "Error occurred while retrieving group count.";
|
||||||
|
log.error(msg, e);
|
||||||
|
return Response.status(Response.Status.INTERNAL_SERVER_ERROR).entity(msg).build();
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
@Override
|
||||||
|
public Response createGroup(DeviceGroup group) {
|
||||||
|
String owner = PrivilegedCarbonContext.getThreadLocalCarbonContext().getUsername();
|
||||||
|
if (group == null) {
|
||||||
|
return Response.status(Response.Status.BAD_REQUEST).build();
|
||||||
|
}
|
||||||
|
group.setOwner(owner);
|
||||||
|
group.setDateOfCreation(new Date().getTime());
|
||||||
|
group.setDateOfLastUpdate(new Date().getTime());
|
||||||
|
try {
|
||||||
|
DeviceMgtAPIUtils.getGroupManagementProviderService().createGroup(group, DEFAULT_ADMIN_ROLE, DEFAULT_ADMIN_PERMISSIONS);
|
||||||
|
return Response.status(Response.Status.CREATED).build();
|
||||||
|
} catch (GroupManagementException e) {
|
||||||
|
String msg = "Error occurred while adding new group.";
|
||||||
|
log.error(msg, e);
|
||||||
|
return Response.status(Response.Status.INTERNAL_SERVER_ERROR).entity(msg).build();
|
||||||
|
} catch (GroupAlreadyExistException e) {
|
||||||
|
String msg = "Group already exists with name '" + group.getName() + "'.";
|
||||||
|
log.warn(msg);
|
||||||
|
return Response.status(Response.Status.CONFLICT).entity(msg).build();
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
@Override
|
||||||
|
public Response getGroup(int groupId) {
|
||||||
|
try {
|
||||||
|
GroupManagementProviderService service = DeviceMgtAPIUtils.getGroupManagementProviderService();
|
||||||
|
DeviceGroup deviceGroup = service.getGroup(groupId);
|
||||||
|
if (deviceGroup != null) {
|
||||||
|
return Response.status(Response.Status.OK).entity(deviceGroup).build();
|
||||||
|
} else {
|
||||||
|
return Response.status(Response.Status.NOT_FOUND).build();
|
||||||
|
}
|
||||||
|
} catch (GroupManagementException e) {
|
||||||
|
String error = "Error occurred while getting the group.";
|
||||||
|
log.error(error, e);
|
||||||
|
return Response.status(Response.Status.INTERNAL_SERVER_ERROR).entity(error).build();
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
@Override
|
||||||
|
public Response updateGroup(int groupId, DeviceGroup deviceGroup) {
|
||||||
|
if (deviceGroup == null) {
|
||||||
|
return Response.status(Response.Status.BAD_REQUEST).build();
|
||||||
|
}
|
||||||
|
try {
|
||||||
|
DeviceMgtAPIUtils.getGroupManagementProviderService().updateGroup(deviceGroup, groupId);
|
||||||
|
return Response.status(Response.Status.OK).build();
|
||||||
|
} catch (GroupManagementException e) {
|
||||||
|
String msg = "Error occurred while adding new group.";
|
||||||
|
log.error(msg, e);
|
||||||
|
return Response.status(Response.Status.INTERNAL_SERVER_ERROR).entity(msg).build();
|
||||||
|
} catch (GroupAlreadyExistException e) {
|
||||||
|
String msg = "There is another group already exists with name '" + deviceGroup.getName() + "'.";
|
||||||
|
log.warn(msg);
|
||||||
|
return Response.status(Response.Status.CONFLICT).entity(msg).build();
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
@Override
|
||||||
|
public Response deleteGroup(int groupId) {
|
||||||
|
try {
|
||||||
|
if (DeviceMgtAPIUtils.getGroupManagementProviderService().deleteGroup(groupId)) {
|
||||||
|
return Response.status(Response.Status.OK).build();
|
||||||
|
} else {
|
||||||
|
return Response.status(Response.Status.NOT_FOUND).entity("Group not found.").build();
|
||||||
|
}
|
||||||
|
} catch (GroupManagementException e) {
|
||||||
|
String msg = "Error occurred while deleting the group.";
|
||||||
|
log.error(msg, e);
|
||||||
|
return Response.status(Response.Status.INTERNAL_SERVER_ERROR).entity(msg).build();
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
@Override
|
||||||
|
public Response manageGroupSharing(int groupId, DeviceGroupShare deviceGroupShare) {
|
||||||
|
try {
|
||||||
|
DeviceMgtAPIUtils.getGroupManagementProviderService()
|
||||||
|
.manageGroupSharing(groupId, deviceGroupShare.getUsername(), deviceGroupShare.getGroupRoles());
|
||||||
|
return Response.status(Response.Status.OK).build();
|
||||||
|
} catch (GroupManagementException e) {
|
||||||
|
String msg = "Error occurred while managing group share.";
|
||||||
|
log.error(msg, e);
|
||||||
|
return Response.status(Response.Status.INTERNAL_SERVER_ERROR).entity(msg).build();
|
||||||
|
} catch (RoleDoesNotExistException | UserDoesNotExistException e) {
|
||||||
|
return Response.status(Response.Status.BAD_REQUEST).entity(e.getMessage()).build();
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
@Override
|
||||||
|
public Response getUsersOfGroup(int groupId) {
|
||||||
|
try {
|
||||||
|
List<GroupUser> groupUsers = DeviceMgtAPIUtils.getGroupManagementProviderService().getUsers(groupId);
|
||||||
|
if (groupUsers != null && groupUsers.size() > 0) {
|
||||||
|
DeviceGroupUsersList deviceGroupUsersList = new DeviceGroupUsersList();
|
||||||
|
deviceGroupUsersList.setList(groupUsers);
|
||||||
|
deviceGroupUsersList.setCount(groupUsers.size());
|
||||||
|
return Response.status(Response.Status.OK).entity(deviceGroupUsersList).build();
|
||||||
|
} else {
|
||||||
|
return Response.status(Response.Status.NOT_FOUND).build();
|
||||||
|
}
|
||||||
|
} catch (GroupManagementException e) {
|
||||||
|
String msg = "Error occurred while getting users of the group.";
|
||||||
|
log.error(msg, e);
|
||||||
|
return Response.status(Response.Status.INTERNAL_SERVER_ERROR).entity(msg).build();
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
@Override
|
||||||
|
public Response getDevicesOfGroup(int groupId, int offset, int limit) {
|
||||||
|
try {
|
||||||
|
GroupManagementProviderService service = DeviceMgtAPIUtils.getGroupManagementProviderService();
|
||||||
|
List<Device> deviceList = service.getDevices(groupId, offset, limit);
|
||||||
|
if (deviceList != null && deviceList.size() > 0) {
|
||||||
|
DeviceList deviceListWrapper = new DeviceList();
|
||||||
|
deviceListWrapper.setList(deviceList);
|
||||||
|
deviceListWrapper.setCount(service.getDeviceCount(groupId));
|
||||||
|
return Response.status(Response.Status.OK).entity(deviceListWrapper).build();
|
||||||
|
} else {
|
||||||
|
return Response.status(Response.Status.NOT_FOUND).build();
|
||||||
|
}
|
||||||
|
} catch (GroupManagementException e) {
|
||||||
|
String msg = "Error occurred while getting devices the group.";
|
||||||
|
log.error(msg, e);
|
||||||
|
return Response.status(Response.Status.INTERNAL_SERVER_ERROR).entity(msg).build();
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
@Override
|
||||||
|
public Response getDeviceCountOfGroup(int groupId) {
|
||||||
|
try {
|
||||||
|
int count = DeviceMgtAPIUtils.getGroupManagementProviderService().getDeviceCount(groupId);
|
||||||
|
return Response.status(Response.Status.OK).entity(count).build();
|
||||||
|
} catch (GroupManagementException e) {
|
||||||
|
String msg = "Error occurred while getting device count of the group.";
|
||||||
|
log.error(msg, e);
|
||||||
|
return Response.status(Response.Status.INTERNAL_SERVER_ERROR).entity(msg).build();
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
@Override
|
||||||
|
public Response addDevicesToGroup(int groupId, List<DeviceIdentifier> deviceIdentifiers) {
|
||||||
|
try {
|
||||||
|
DeviceMgtAPIUtils.getGroupManagementProviderService().addDevices(groupId, deviceIdentifiers);
|
||||||
|
return Response.status(Response.Status.OK).build();
|
||||||
|
} catch (GroupManagementException e) {
|
||||||
|
String msg = "Error occurred while adding devices to group.";
|
||||||
|
log.error(msg, e);
|
||||||
|
return Response.status(Response.Status.INTERNAL_SERVER_ERROR).entity(msg).build();
|
||||||
|
} catch (DeviceNotFoundException e) {
|
||||||
|
return Response.status(Response.Status.BAD_REQUEST).entity(e.getMessage()).build();
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
@Override
|
||||||
|
public Response removeDevicesFromGroup(int groupId, List<DeviceIdentifier> deviceIdentifiers) {
|
||||||
|
try {
|
||||||
|
DeviceMgtAPIUtils.getGroupManagementProviderService().removeDevice(groupId, deviceIdentifiers);
|
||||||
|
return Response.status(Response.Status.OK).build();
|
||||||
|
} catch (GroupManagementException e) {
|
||||||
|
String msg = "Error occurred while removing devices from group.";
|
||||||
|
log.error(msg, e);
|
||||||
|
return Response.status(Response.Status.INTERNAL_SERVER_ERROR).entity(msg).build();
|
||||||
|
} catch (DeviceNotFoundException e) {
|
||||||
|
return Response.status(Response.Status.BAD_REQUEST).entity(e.getMessage()).build();
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
}
|
||||||
@ -0,0 +1,76 @@
|
|||||||
|
/*
|
||||||
|
* 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.
|
||||||
|
*
|
||||||
|
*/
|
||||||
|
package org.wso2.carbon.device.mgt.jaxrs.service.impl.admin;
|
||||||
|
|
||||||
|
import org.apache.commons.logging.Log;
|
||||||
|
import org.apache.commons.logging.LogFactory;
|
||||||
|
import org.wso2.carbon.device.mgt.common.GroupPaginationRequest;
|
||||||
|
import org.wso2.carbon.device.mgt.common.PaginationRequest;
|
||||||
|
import org.wso2.carbon.device.mgt.common.PaginationResult;
|
||||||
|
import org.wso2.carbon.device.mgt.common.group.mgt.DeviceGroup;
|
||||||
|
import org.wso2.carbon.device.mgt.common.group.mgt.GroupManagementException;
|
||||||
|
import org.wso2.carbon.device.mgt.core.service.GroupManagementProviderService;
|
||||||
|
import org.wso2.carbon.device.mgt.jaxrs.beans.DeviceGroupList;
|
||||||
|
import org.wso2.carbon.device.mgt.jaxrs.service.api.admin.GroupManagementAdminService;
|
||||||
|
import org.wso2.carbon.device.mgt.jaxrs.service.impl.util.RequestValidationUtil;
|
||||||
|
import org.wso2.carbon.device.mgt.jaxrs.util.DeviceMgtAPIUtils;
|
||||||
|
|
||||||
|
import javax.ws.rs.core.Response;
|
||||||
|
import java.util.List;
|
||||||
|
|
||||||
|
public class GroupManagementAdminServiceImpl implements GroupManagementAdminService {
|
||||||
|
|
||||||
|
private static final Log log = LogFactory.getLog(GroupManagementAdminServiceImpl.class);
|
||||||
|
|
||||||
|
@Override
|
||||||
|
public Response getGroups(String name, String owner, int offset, int limit) {
|
||||||
|
try {
|
||||||
|
RequestValidationUtil.validatePaginationParameters(offset, limit);
|
||||||
|
GroupPaginationRequest request = new GroupPaginationRequest(offset, limit);
|
||||||
|
request.setGroupName(name);
|
||||||
|
request.setOwner(owner);
|
||||||
|
PaginationResult deviceGroupsResult = DeviceMgtAPIUtils.getGroupManagementProviderService()
|
||||||
|
.getGroups(request);
|
||||||
|
if (deviceGroupsResult.getData() != null && deviceGroupsResult.getRecordsTotal() > 0) {
|
||||||
|
DeviceGroupList deviceGroupList = new DeviceGroupList();
|
||||||
|
deviceGroupList.setList(deviceGroupsResult.getData());
|
||||||
|
deviceGroupList.setCount(deviceGroupsResult.getRecordsTotal());
|
||||||
|
return Response.status(Response.Status.OK).entity(deviceGroupList).build();
|
||||||
|
} else {
|
||||||
|
return Response.status(Response.Status.NOT_FOUND).build();
|
||||||
|
}
|
||||||
|
} catch (GroupManagementException e) {
|
||||||
|
String msg = "ErrorResponse occurred while retrieving all groups.";
|
||||||
|
log.error(msg, e);
|
||||||
|
return Response.status(Response.Status.INTERNAL_SERVER_ERROR).entity(msg).build();
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
@Override
|
||||||
|
public Response getGroupCount() {
|
||||||
|
try {
|
||||||
|
int count = DeviceMgtAPIUtils.getGroupManagementProviderService().getGroupCount();
|
||||||
|
return Response.status(Response.Status.OK).entity(count).build();
|
||||||
|
} catch (GroupManagementException e) {
|
||||||
|
String msg = "ErrorResponse occurred while retrieving group count.";
|
||||||
|
log.error(msg, e);
|
||||||
|
return Response.status(Response.Status.INTERNAL_SERVER_ERROR).entity(msg).build();
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
@ -34,8 +34,8 @@
|
|||||||
<ref bean="roleManagementService"/>
|
<ref bean="roleManagementService"/>
|
||||||
<ref bean="userManagementService"/>
|
<ref bean="userManagementService"/>
|
||||||
<ref bean="userManagementAdminService"/>
|
<ref bean="userManagementAdminService"/>
|
||||||
<!--<ref bean="groupManagementService"/>-->
|
<ref bean="groupManagementService"/>
|
||||||
<!--ref bean="groupManagementAdminService"/> -->
|
<ref bean="groupManagementAdminService"/>
|
||||||
<ref bean="applicationManagementAdminService"/>
|
<ref bean="applicationManagementAdminService"/>
|
||||||
<ref bean="deviceTypeManagementAdminService"/>
|
<ref bean="deviceTypeManagementAdminService"/>
|
||||||
<ref bean="dashboardServiceBean"/>
|
<ref bean="dashboardServiceBean"/>
|
||||||
@ -73,10 +73,10 @@
|
|||||||
<bean id="policyManagementService" class="org.wso2.carbon.device.mgt.jaxrs.service.impl.PolicyManagementServiceImpl"/>
|
<bean id="policyManagementService" class="org.wso2.carbon.device.mgt.jaxrs.service.impl.PolicyManagementServiceImpl"/>
|
||||||
<bean id="roleManagementService" class="org.wso2.carbon.device.mgt.jaxrs.service.impl.RoleManagementServiceImpl"/>
|
<bean id="roleManagementService" class="org.wso2.carbon.device.mgt.jaxrs.service.impl.RoleManagementServiceImpl"/>
|
||||||
<bean id="userManagementService" class="org.wso2.carbon.device.mgt.jaxrs.service.impl.UserManagementServiceImpl"/>
|
<bean id="userManagementService" class="org.wso2.carbon.device.mgt.jaxrs.service.impl.UserManagementServiceImpl"/>
|
||||||
<!--bean id="groupManagementService" class="org.wso2.carbon.device.mgt.jaxrs.service.impl.GroupManagementServiceImpl"/>-->
|
<bean id="groupManagementService" class="org.wso2.carbon.device.mgt.jaxrs.service.impl.GroupManagementServiceImpl"/>
|
||||||
<bean id="deviceManagementAdminService" class="org.wso2.carbon.device.mgt.jaxrs.service.impl.admin.DeviceManagementAdminServiceImpl"/>
|
<bean id="deviceManagementAdminService" class="org.wso2.carbon.device.mgt.jaxrs.service.impl.admin.DeviceManagementAdminServiceImpl"/>
|
||||||
<bean id="applicationManagementAdminService" class="org.wso2.carbon.device.mgt.jaxrs.service.impl.admin.ApplicationManagementAdminServiceImpl"/>
|
<bean id="applicationManagementAdminService" class="org.wso2.carbon.device.mgt.jaxrs.service.impl.admin.ApplicationManagementAdminServiceImpl"/>
|
||||||
<!--bean id="groupManagementAdminService" class="org.wso2.carbon.device.mgt.jaxrs.service.impl.admin.GroupManagementAdminServiceImpl"/>-->
|
<bean id="groupManagementAdminService" class="org.wso2.carbon.device.mgt.jaxrs.service.impl.admin.GroupManagementAdminServiceImpl"/>
|
||||||
<bean id="userManagementAdminService" class="org.wso2.carbon.device.mgt.jaxrs.service.impl.admin.UserManagementAdminServiceImpl"/>
|
<bean id="userManagementAdminService" class="org.wso2.carbon.device.mgt.jaxrs.service.impl.admin.UserManagementAdminServiceImpl"/>
|
||||||
<bean id="dashboardServiceBean" class="org.wso2.carbon.device.mgt.jaxrs.service.impl.DashboardImpl"/>
|
<bean id="dashboardServiceBean" class="org.wso2.carbon.device.mgt.jaxrs.service.impl.DashboardImpl"/>
|
||||||
<bean id="deviceTypeManagementAdminService" class="org.wso2.carbon.device.mgt.jaxrs.service.impl.DeviceTypeManagementServiceImpl"/>
|
<bean id="deviceTypeManagementAdminService" class="org.wso2.carbon.device.mgt.jaxrs.service.impl.DeviceTypeManagementServiceImpl"/>
|
||||||
|
|||||||
@ -0,0 +1,44 @@
|
|||||||
|
/*
|
||||||
|
* Copyright (c) 2014, 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.common;
|
||||||
|
|
||||||
|
public class DeviceNotFoundException extends Exception {
|
||||||
|
|
||||||
|
private static final long serialVersionUID = -3151279311996070297L;
|
||||||
|
|
||||||
|
public DeviceNotFoundException(String msg, Exception nestedEx) {
|
||||||
|
super(msg, nestedEx);
|
||||||
|
}
|
||||||
|
|
||||||
|
public DeviceNotFoundException(String message, Throwable cause) {
|
||||||
|
super(message, cause);
|
||||||
|
}
|
||||||
|
|
||||||
|
public DeviceNotFoundException(String msg) {
|
||||||
|
super(msg);
|
||||||
|
}
|
||||||
|
|
||||||
|
public DeviceNotFoundException() {
|
||||||
|
super();
|
||||||
|
}
|
||||||
|
|
||||||
|
public DeviceNotFoundException(Throwable cause) {
|
||||||
|
super(cause);
|
||||||
|
}
|
||||||
|
|
||||||
|
}
|
||||||
@ -0,0 +1,68 @@
|
|||||||
|
/*
|
||||||
|
* Copyright (c) 2015, 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.common;
|
||||||
|
|
||||||
|
/**
|
||||||
|
* This class holds required parameters for a querying a paginated device group response.
|
||||||
|
*/
|
||||||
|
public class GroupPaginationRequest {
|
||||||
|
|
||||||
|
private int startIndex;
|
||||||
|
private int rowCount;
|
||||||
|
private String owner;
|
||||||
|
private String groupName;
|
||||||
|
|
||||||
|
public GroupPaginationRequest(int start, int rowCount) {
|
||||||
|
this.startIndex = start;
|
||||||
|
this.rowCount = rowCount;
|
||||||
|
}
|
||||||
|
|
||||||
|
public int getStartIndex() {
|
||||||
|
return startIndex;
|
||||||
|
}
|
||||||
|
|
||||||
|
public void setStartIndex(int startIndex) {
|
||||||
|
this.startIndex = startIndex;
|
||||||
|
}
|
||||||
|
|
||||||
|
public int getRowCount() {
|
||||||
|
return rowCount;
|
||||||
|
}
|
||||||
|
|
||||||
|
public void setRowCount(int rowCount) {
|
||||||
|
this.rowCount = rowCount;
|
||||||
|
}
|
||||||
|
|
||||||
|
public String getOwner() {
|
||||||
|
return owner;
|
||||||
|
}
|
||||||
|
|
||||||
|
public void setOwner(String owner) {
|
||||||
|
this.owner = owner;
|
||||||
|
}
|
||||||
|
|
||||||
|
public String getGroupName() {
|
||||||
|
return groupName;
|
||||||
|
}
|
||||||
|
|
||||||
|
public void setGroupName(String groupName) {
|
||||||
|
this.groupName = groupName;
|
||||||
|
}
|
||||||
|
|
||||||
|
}
|
||||||
@ -21,12 +21,13 @@ package org.wso2.carbon.device.mgt.common;
|
|||||||
import java.util.Date;
|
import java.util.Date;
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* This class holds required parameters for a querying a paginated response.
|
* This class holds required parameters for a querying a paginated device response.
|
||||||
*/
|
*/
|
||||||
public class PaginationRequest {
|
public class PaginationRequest {
|
||||||
|
|
||||||
private int startIndex;
|
private int startIndex;
|
||||||
private int rowCount;
|
private int rowCount;
|
||||||
|
private int groupId;
|
||||||
private String owner;
|
private String owner;
|
||||||
private String status;
|
private String status;
|
||||||
private String deviceType;
|
private String deviceType;
|
||||||
@ -55,6 +56,14 @@ public class PaginationRequest {
|
|||||||
this.rowCount = rowCount;
|
this.rowCount = rowCount;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
public int getGroupId() {
|
||||||
|
return groupId;
|
||||||
|
}
|
||||||
|
|
||||||
|
public void setGroupId(int groupId) {
|
||||||
|
this.groupId = groupId;
|
||||||
|
}
|
||||||
|
|
||||||
public String getOwner() {
|
public String getOwner() {
|
||||||
return owner;
|
return owner;
|
||||||
}
|
}
|
||||||
|
|||||||
@ -17,6 +17,9 @@
|
|||||||
*/
|
*/
|
||||||
package org.wso2.carbon.device.mgt.common.group.mgt;
|
package org.wso2.carbon.device.mgt.common.group.mgt;
|
||||||
|
|
||||||
|
import io.swagger.annotations.ApiModel;
|
||||||
|
import io.swagger.annotations.ApiModelProperty;
|
||||||
|
|
||||||
import javax.xml.bind.annotation.XmlElement;
|
import javax.xml.bind.annotation.XmlElement;
|
||||||
import javax.xml.bind.annotation.XmlRootElement;
|
import javax.xml.bind.annotation.XmlRootElement;
|
||||||
import java.io.Serializable;
|
import java.io.Serializable;
|
||||||
@ -25,28 +28,36 @@ import java.util.List;
|
|||||||
/**
|
/**
|
||||||
* Holds Device Group details and expose to external access
|
* Holds Device Group details and expose to external access
|
||||||
*/
|
*/
|
||||||
@XmlRootElement
|
@ApiModel(value = "DeviceGroup", description = "This class carries all information related to a managed device group.")
|
||||||
public class DeviceGroup implements Serializable {
|
public class DeviceGroup implements Serializable {
|
||||||
|
|
||||||
|
private static final long serialVersionUID = 1998121711L;
|
||||||
|
|
||||||
|
@ApiModelProperty(name = "id", value = "ID of the device group in the device group information database.")
|
||||||
private int id;
|
private int id;
|
||||||
|
|
||||||
|
@ApiModelProperty(name = "description", value = "The device group description that can be set on the device group by the user.",
|
||||||
|
required = true)
|
||||||
private String description;
|
private String description;
|
||||||
|
|
||||||
|
@ApiModelProperty(name = "name", value = "The device group name that can be set on the device group by the user.",
|
||||||
|
required = true)
|
||||||
private String name;
|
private String name;
|
||||||
|
|
||||||
private Long dateOfCreation;
|
private Long dateOfCreation;
|
||||||
private Long dateOfLastUpdate;
|
private Long dateOfLastUpdate;
|
||||||
private String owner;
|
private String owner;
|
||||||
private List<GroupUser> users;
|
private List<GroupUser> users;
|
||||||
private List<String> roles;
|
private List<String> roles;
|
||||||
|
|
||||||
@XmlElement
|
public int getGroupId() {
|
||||||
public int getId() {
|
|
||||||
return id;
|
return id;
|
||||||
}
|
}
|
||||||
|
|
||||||
public void setId(int id) {
|
public void setGroupId(int id) {
|
||||||
this.id = id;
|
this.id = id;
|
||||||
}
|
}
|
||||||
|
|
||||||
@XmlElement
|
|
||||||
public String getDescription() {
|
public String getDescription() {
|
||||||
return description;
|
return description;
|
||||||
}
|
}
|
||||||
@ -55,7 +66,6 @@ public class DeviceGroup implements Serializable {
|
|||||||
this.description = description;
|
this.description = description;
|
||||||
}
|
}
|
||||||
|
|
||||||
@XmlElement
|
|
||||||
public String getName() {
|
public String getName() {
|
||||||
return name;
|
return name;
|
||||||
}
|
}
|
||||||
@ -64,7 +74,6 @@ public class DeviceGroup implements Serializable {
|
|||||||
this.name = name;
|
this.name = name;
|
||||||
}
|
}
|
||||||
|
|
||||||
@XmlElement
|
|
||||||
public Long getDateOfCreation() {
|
public Long getDateOfCreation() {
|
||||||
return dateOfCreation;
|
return dateOfCreation;
|
||||||
}
|
}
|
||||||
@ -73,7 +82,6 @@ public class DeviceGroup implements Serializable {
|
|||||||
this.dateOfCreation = dateOfCreation;
|
this.dateOfCreation = dateOfCreation;
|
||||||
}
|
}
|
||||||
|
|
||||||
@XmlElement
|
|
||||||
public Long getDateOfLastUpdate() {
|
public Long getDateOfLastUpdate() {
|
||||||
return dateOfLastUpdate;
|
return dateOfLastUpdate;
|
||||||
}
|
}
|
||||||
@ -82,7 +90,6 @@ public class DeviceGroup implements Serializable {
|
|||||||
this.dateOfLastUpdate = dateOfLastUpdate;
|
this.dateOfLastUpdate = dateOfLastUpdate;
|
||||||
}
|
}
|
||||||
|
|
||||||
@XmlElement
|
|
||||||
public String getOwner() {
|
public String getOwner() {
|
||||||
return owner;
|
return owner;
|
||||||
}
|
}
|
||||||
@ -91,35 +98,20 @@ public class DeviceGroup implements Serializable {
|
|||||||
this.owner = owner;
|
this.owner = owner;
|
||||||
}
|
}
|
||||||
|
|
||||||
@XmlElement
|
|
||||||
public List<GroupUser> getUsers() {
|
public List<GroupUser> getUsers() {
|
||||||
return users;
|
return users;
|
||||||
}
|
}
|
||||||
|
|
||||||
protected void setUsers(List<GroupUser> users) {
|
public void setUsers(List<GroupUser> users) {
|
||||||
this.users = users;
|
this.users = users;
|
||||||
}
|
}
|
||||||
|
|
||||||
@XmlElement
|
|
||||||
public List<String> getRoles() {
|
public List<String> getRoles() {
|
||||||
return roles;
|
return roles;
|
||||||
}
|
}
|
||||||
|
|
||||||
protected void setRoles(List<String> roles) {
|
public void setRoles(List<String> roles) {
|
||||||
this.roles = roles;
|
this.roles = roles;
|
||||||
}
|
}
|
||||||
|
|
||||||
protected DeviceGroup getGroup() {
|
|
||||||
DeviceGroup deviceGroup = new DeviceGroup();
|
|
||||||
deviceGroup.setId(getId());
|
|
||||||
deviceGroup.setDescription(getDescription());
|
|
||||||
deviceGroup.setName(getName());
|
|
||||||
deviceGroup.setDateOfCreation(getDateOfCreation());
|
|
||||||
deviceGroup.setDateOfLastUpdate(getDateOfLastUpdate());
|
|
||||||
deviceGroup.setOwner(getOwner());
|
|
||||||
deviceGroup.setUsers(getUsers());
|
|
||||||
deviceGroup.setRoles(getRoles());
|
|
||||||
return deviceGroup;
|
|
||||||
}
|
|
||||||
|
|
||||||
}
|
}
|
||||||
|
|||||||
@ -18,6 +18,9 @@
|
|||||||
*/
|
*/
|
||||||
package org.wso2.carbon.device.mgt.common.group.mgt;
|
package org.wso2.carbon.device.mgt.common.group.mgt;
|
||||||
|
|
||||||
|
import io.swagger.annotations.ApiModel;
|
||||||
|
import io.swagger.annotations.ApiModelProperty;
|
||||||
|
|
||||||
import javax.xml.bind.annotation.XmlElement;
|
import javax.xml.bind.annotation.XmlElement;
|
||||||
import javax.xml.bind.annotation.XmlRootElement;
|
import javax.xml.bind.annotation.XmlRootElement;
|
||||||
import java.io.Serializable;
|
import java.io.Serializable;
|
||||||
@ -26,12 +29,17 @@ import java.util.List;
|
|||||||
/**
|
/**
|
||||||
* This class holds Device Group user name and assigned group roles of user. Exposed to external access
|
* This class holds Device Group user name and assigned group roles of user. Exposed to external access
|
||||||
*/
|
*/
|
||||||
@XmlRootElement
|
@ApiModel(value = "GroupUser", description = "This class carries all information related to a user of a managed device group.")
|
||||||
public class GroupUser implements Serializable {
|
public class GroupUser implements Serializable {
|
||||||
|
|
||||||
|
private static final long serialVersionUID = 1998131711L;
|
||||||
|
|
||||||
|
@ApiModelProperty(name = "username", value = "Username of the user.", required = true)
|
||||||
private String username;
|
private String username;
|
||||||
|
|
||||||
|
@ApiModelProperty(name = "roles", value = "List of roles assigned to the user.")
|
||||||
private List<String> groupRoles;
|
private List<String> groupRoles;
|
||||||
|
|
||||||
@XmlElement
|
|
||||||
public String getUsername() {
|
public String getUsername() {
|
||||||
return username;
|
return username;
|
||||||
}
|
}
|
||||||
@ -40,7 +48,6 @@ public class GroupUser implements Serializable {
|
|||||||
this.username = username;
|
this.username = username;
|
||||||
}
|
}
|
||||||
|
|
||||||
@XmlElement
|
|
||||||
public List<String> getGroupRoles() {
|
public List<String> getGroupRoles() {
|
||||||
return groupRoles;
|
return groupRoles;
|
||||||
}
|
}
|
||||||
|
|||||||
@ -0,0 +1,60 @@
|
|||||||
|
/*
|
||||||
|
* 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.
|
||||||
|
*/
|
||||||
|
|
||||||
|
package org.wso2.carbon.device.mgt.common.group.mgt;
|
||||||
|
|
||||||
|
/**
|
||||||
|
* This class represents a custom exception specified for group management
|
||||||
|
*/
|
||||||
|
public class RoleDoesNotExistException extends Exception {
|
||||||
|
|
||||||
|
private static final long serialVersionUID = -312678379574556874L;
|
||||||
|
private String errorMessage;
|
||||||
|
|
||||||
|
public RoleDoesNotExistException(String msg, Exception nestedEx) {
|
||||||
|
super(msg, nestedEx);
|
||||||
|
setErrorMessage(msg);
|
||||||
|
}
|
||||||
|
|
||||||
|
public RoleDoesNotExistException(String message, Throwable cause) {
|
||||||
|
super(message, cause);
|
||||||
|
setErrorMessage(message);
|
||||||
|
}
|
||||||
|
|
||||||
|
public RoleDoesNotExistException(String msg) {
|
||||||
|
super(msg);
|
||||||
|
setErrorMessage(msg);
|
||||||
|
}
|
||||||
|
|
||||||
|
public RoleDoesNotExistException() {
|
||||||
|
super();
|
||||||
|
}
|
||||||
|
|
||||||
|
public RoleDoesNotExistException(Throwable cause) {
|
||||||
|
super(cause);
|
||||||
|
}
|
||||||
|
|
||||||
|
public String getErrorMessage() {
|
||||||
|
return errorMessage;
|
||||||
|
}
|
||||||
|
|
||||||
|
public void setErrorMessage(String errorMessage) {
|
||||||
|
this.errorMessage = errorMessage;
|
||||||
|
}
|
||||||
|
|
||||||
|
}
|
||||||
@ -203,7 +203,7 @@ public class DeviceAccessAuthorizationServiceImpl implements DeviceAccessAuthori
|
|||||||
Iterator<DeviceGroup> groupsWithDeviceIterator = groupsWithDevice.iterator();
|
Iterator<DeviceGroup> groupsWithDeviceIterator = groupsWithDevice.iterator();
|
||||||
while (groupsWithDeviceIterator.hasNext()) {
|
while (groupsWithDeviceIterator.hasNext()) {
|
||||||
DeviceGroup deviceGroup = groupsWithDeviceIterator.next();
|
DeviceGroup deviceGroup = groupsWithDeviceIterator.next();
|
||||||
if (deviceGroup.getId() == group.getId()) {
|
if (deviceGroup.getGroupId() == group.getGroupId()) {
|
||||||
return true;
|
return true;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|||||||
@ -28,6 +28,7 @@ import javax.xml.bind.annotation.XmlRootElement;
|
|||||||
public class PaginationConfiguration {
|
public class PaginationConfiguration {
|
||||||
|
|
||||||
private int deviceListPageSize;
|
private int deviceListPageSize;
|
||||||
|
private int groupListPageSize;
|
||||||
private int operationListPageSize;
|
private int operationListPageSize;
|
||||||
private int notificationListPageSize;
|
private int notificationListPageSize;
|
||||||
private int activityListPageSize;
|
private int activityListPageSize;
|
||||||
@ -41,6 +42,15 @@ public class PaginationConfiguration {
|
|||||||
this.deviceListPageSize = deviceListPageSize;
|
this.deviceListPageSize = deviceListPageSize;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
public int getGroupListPageSize() {
|
||||||
|
return groupListPageSize;
|
||||||
|
}
|
||||||
|
|
||||||
|
@XmlElement(name = "GroupListPageSize", required = true)
|
||||||
|
public void setGroupListPageSize(int groupListPageSize) {
|
||||||
|
this.groupListPageSize = groupListPageSize;
|
||||||
|
}
|
||||||
|
|
||||||
public int getOperationListPageSize() {
|
public int getOperationListPageSize() {
|
||||||
return operationListPageSize;
|
return operationListPageSize;
|
||||||
}
|
}
|
||||||
|
|||||||
@ -28,7 +28,6 @@ import org.wso2.carbon.device.mgt.core.dao.DeviceManagementDAOException;
|
|||||||
import org.wso2.carbon.device.mgt.core.dao.DeviceManagementDAOFactory;
|
import org.wso2.carbon.device.mgt.core.dao.DeviceManagementDAOFactory;
|
||||||
import org.wso2.carbon.device.mgt.core.dao.util.DeviceManagementDAOUtil;
|
import org.wso2.carbon.device.mgt.core.dao.util.DeviceManagementDAOUtil;
|
||||||
import org.wso2.carbon.device.mgt.core.dto.DeviceType;
|
import org.wso2.carbon.device.mgt.core.dto.DeviceType;
|
||||||
import org.wso2.carbon.utils.xml.StringUtils;
|
|
||||||
|
|
||||||
import java.sql.Connection;
|
import java.sql.Connection;
|
||||||
import java.sql.PreparedStatement;
|
import java.sql.PreparedStatement;
|
||||||
|
|||||||
@ -1,71 +0,0 @@
|
|||||||
/*
|
|
||||||
* 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.
|
|
||||||
*/
|
|
||||||
|
|
||||||
package org.wso2.carbon.device.mgt.core.group.mgt;
|
|
||||||
|
|
||||||
import org.wso2.carbon.device.mgt.common.group.mgt.DeviceGroup;
|
|
||||||
import org.wso2.carbon.device.mgt.common.group.mgt.GroupUser;
|
|
||||||
|
|
||||||
import java.util.List;
|
|
||||||
|
|
||||||
/**
|
|
||||||
* This class is used to expose protected methods to the core. Use with internal access only.
|
|
||||||
*/
|
|
||||||
public class DeviceGroupBuilder extends DeviceGroup {
|
|
||||||
|
|
||||||
private int groupId;
|
|
||||||
|
|
||||||
/**
|
|
||||||
* Set device group to be decorated with the builder
|
|
||||||
*
|
|
||||||
* @param deviceGroup to decorate
|
|
||||||
*/
|
|
||||||
public DeviceGroupBuilder(DeviceGroup deviceGroup) {
|
|
||||||
this.setId(deviceGroup.getId());
|
|
||||||
this.setDescription(deviceGroup.getDescription());
|
|
||||||
this.setName(deviceGroup.getName());
|
|
||||||
this.setDateOfCreation(deviceGroup.getDateOfCreation());
|
|
||||||
this.setDateOfLastUpdate(deviceGroup.getDateOfLastUpdate());
|
|
||||||
this.setOwner(deviceGroup.getOwner());
|
|
||||||
this.setUsers(deviceGroup.getUsers());
|
|
||||||
this.setRoles(deviceGroup.getRoles());
|
|
||||||
}
|
|
||||||
|
|
||||||
@Override
|
|
||||||
public void setUsers(List<GroupUser> users) {
|
|
||||||
super.setUsers(users);
|
|
||||||
}
|
|
||||||
|
|
||||||
@Override
|
|
||||||
public void setRoles(List<String> roles) {
|
|
||||||
super.setRoles(roles);
|
|
||||||
}
|
|
||||||
|
|
||||||
@Override
|
|
||||||
public DeviceGroup getGroup() {
|
|
||||||
return super.getGroup();
|
|
||||||
}
|
|
||||||
|
|
||||||
public int getGroupId() {
|
|
||||||
return groupId;
|
|
||||||
}
|
|
||||||
|
|
||||||
public void setGroupId(int groupId) {
|
|
||||||
this.groupId = groupId;
|
|
||||||
}
|
|
||||||
}
|
|
||||||
@ -19,8 +19,8 @@
|
|||||||
package org.wso2.carbon.device.mgt.core.group.mgt.dao;
|
package org.wso2.carbon.device.mgt.core.group.mgt.dao;
|
||||||
|
|
||||||
import org.wso2.carbon.device.mgt.common.Device;
|
import org.wso2.carbon.device.mgt.common.Device;
|
||||||
|
import org.wso2.carbon.device.mgt.common.GroupPaginationRequest;
|
||||||
import org.wso2.carbon.device.mgt.common.group.mgt.DeviceGroup;
|
import org.wso2.carbon.device.mgt.common.group.mgt.DeviceGroup;
|
||||||
import org.wso2.carbon.device.mgt.core.group.mgt.DeviceGroupBuilder;
|
|
||||||
|
|
||||||
import java.util.List;
|
import java.util.List;
|
||||||
|
|
||||||
@ -41,24 +41,22 @@ public interface GroupDAO {
|
|||||||
/**
|
/**
|
||||||
* Update an existing Device Group.
|
* Update an existing Device Group.
|
||||||
*
|
*
|
||||||
* @param deviceGroup group to update.
|
* @param deviceGroup group to update.
|
||||||
* @param oldGroupName of the group.
|
* @param groupId of Device Group.
|
||||||
* @param oldOwner of the group.
|
* @param tenantId of the group.
|
||||||
* @param tenantId of the group.
|
|
||||||
* @throws GroupManagementDAOException
|
* @throws GroupManagementDAOException
|
||||||
*/
|
*/
|
||||||
void updateGroup(DeviceGroup deviceGroup, String oldGroupName, String oldOwner, int tenantId)
|
void updateGroup(DeviceGroup deviceGroup, int groupId, int tenantId)
|
||||||
throws GroupManagementDAOException;
|
throws GroupManagementDAOException;
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* Delete an existing Device Group.
|
* Delete an existing Device Group.
|
||||||
*
|
*
|
||||||
* @param groupName to be deleted.
|
* @param groupId of Device Group.
|
||||||
* @param owner of the group.
|
|
||||||
* @param tenantId of the group.
|
* @param tenantId of the group.
|
||||||
* @throws GroupManagementDAOException
|
* @throws GroupManagementDAOException
|
||||||
*/
|
*/
|
||||||
void deleteGroup(String groupName, String owner, int tenantId) throws GroupManagementDAOException;
|
void deleteGroup(int groupId, int tenantId) throws GroupManagementDAOException;
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* Get device group by id.
|
* Get device group by id.
|
||||||
@ -68,39 +66,34 @@ public interface GroupDAO {
|
|||||||
* @return Device Group in tenant with specified name.
|
* @return Device Group in tenant with specified name.
|
||||||
* @throws GroupManagementDAOException
|
* @throws GroupManagementDAOException
|
||||||
*/
|
*/
|
||||||
DeviceGroupBuilder getGroup(int groupId, int tenantId) throws GroupManagementDAOException;
|
DeviceGroup getGroup(int groupId, int tenantId) throws GroupManagementDAOException;
|
||||||
|
|
||||||
|
|
||||||
/**
|
|
||||||
* Get device group by name.
|
|
||||||
*
|
|
||||||
* @param groupName of Device Group.
|
|
||||||
* @param owner of the group.
|
|
||||||
* @param tenantId of the group.
|
|
||||||
* @return Device Group in tenant with specified name.
|
|
||||||
* @throws GroupManagementDAOException
|
|
||||||
*/
|
|
||||||
DeviceGroupBuilder getGroup(String groupName, String owner, int tenantId) throws GroupManagementDAOException;
|
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* Get the groups of device with device id provided
|
* Get the groups of device with device id provided
|
||||||
* @param deviceId
|
* @param deviceId
|
||||||
* @return
|
* @return groups which has the device.
|
||||||
* @throws GroupManagementDAOException
|
* @throws GroupManagementDAOException
|
||||||
*/
|
*/
|
||||||
List<DeviceGroupBuilder> getGroups(int deviceId, int tenantId) throws GroupManagementDAOException;
|
List<DeviceGroup> getGroups(int deviceId, int tenantId) throws GroupManagementDAOException;
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* Get the list of Device Groups in tenant.
|
* Get paginated list of Device Groups in tenant.
|
||||||
*
|
*
|
||||||
* @param startIndex for pagination.
|
* @param paginationRequest to filter results.
|
||||||
* @param rowCount for pagination.
|
|
||||||
* @param tenantId of user's tenant.
|
* @param tenantId of user's tenant.
|
||||||
* @return List of all Device Groups in tenant.
|
* @return List of all Device Groups in tenant.
|
||||||
* @throws GroupManagementDAOException
|
* @throws GroupManagementDAOException
|
||||||
*/
|
*/
|
||||||
List<DeviceGroupBuilder> getGroups(int startIndex, int rowCount, int tenantId) throws GroupManagementDAOException;
|
List<DeviceGroup> getGroups(GroupPaginationRequest paginationRequest, int tenantId) throws GroupManagementDAOException;
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Get the list of Device Groups in tenant.
|
||||||
|
*
|
||||||
|
* @param tenantId of user's tenant.
|
||||||
|
* @return List of all Device Groups in tenant.
|
||||||
|
* @throws GroupManagementDAOException
|
||||||
|
*/
|
||||||
|
List<DeviceGroup> getGroups(int tenantId) throws GroupManagementDAOException;
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* Get count of Device Groups in tenant.
|
* Get count of Device Groups in tenant.
|
||||||
@ -112,94 +105,77 @@ public interface GroupDAO {
|
|||||||
int getGroupCount(int tenantId) throws GroupManagementDAOException;
|
int getGroupCount(int tenantId) throws GroupManagementDAOException;
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* Get the list of Groups that matches with the given DeviceGroup name.
|
* Get paginated count of Device Groups in tenant.
|
||||||
*
|
*
|
||||||
* @param groupName of the Device Group.
|
* @param paginationRequest to filter results.
|
||||||
* @param tenantId of user's tenant.
|
* @param tenantId of user's tenant.
|
||||||
* @return List of DeviceGroup that matches with the given DeviceGroup name.
|
* @return List of all Device Groups in tenant.
|
||||||
* @throws GroupManagementDAOException
|
* @throws GroupManagementDAOException
|
||||||
*/
|
*/
|
||||||
List<DeviceGroupBuilder> findInGroups(String groupName, int tenantId) throws GroupManagementDAOException;
|
int getGroupCount(GroupPaginationRequest paginationRequest, int tenantId) throws GroupManagementDAOException;
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* Check group already existed with given name.
|
* Check group already existed with given name.
|
||||||
*
|
*
|
||||||
* @param groupName of the Device Group.
|
* @param groupName of the Device Group.
|
||||||
* @param owner of the Device Group.
|
|
||||||
* @param tenantId of user's tenant.
|
* @param tenantId of user's tenant.
|
||||||
* @return existence of group with name
|
* @return existence of group with name
|
||||||
* @throws GroupManagementDAOException
|
* @throws GroupManagementDAOException
|
||||||
*/
|
*/
|
||||||
boolean isGroupExist(String groupName, String owner, int tenantId) throws GroupManagementDAOException;
|
DeviceGroup getGroup(String groupName, int tenantId) throws GroupManagementDAOException;
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* Add device to a given Device Group.
|
* Add device to a given Device Group.
|
||||||
*
|
*
|
||||||
* @param groupName of the Device Group.
|
* @param groupId of Device Group.
|
||||||
* @param owner of the Device Group.
|
|
||||||
* @param deviceId of the device.
|
* @param deviceId of the device.
|
||||||
* @param tenantId of user's tenant.
|
* @param tenantId of user's tenant.
|
||||||
* @throws GroupManagementDAOException
|
* @throws GroupManagementDAOException
|
||||||
*/
|
*/
|
||||||
void addDevice(String groupName, String owner, int deviceId, int tenantId) throws GroupManagementDAOException;
|
void addDevice(int groupId, int deviceId, int tenantId) throws GroupManagementDAOException;
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* Remove device from the Device Group.
|
* Remove device from the Device Group.
|
||||||
*
|
*
|
||||||
* @param groupName of the Device Group.
|
* @param groupId of Device Group.
|
||||||
* @param owner of the Device Group.
|
|
||||||
* @param deviceId of the device.
|
* @param deviceId of the device.
|
||||||
* @param tenantId of user's tenant.
|
* @param tenantId of user's tenant.
|
||||||
* @throws GroupManagementDAOException
|
* @throws GroupManagementDAOException
|
||||||
*/
|
*/
|
||||||
void removeDevice(String groupName, String owner, int deviceId, int tenantId) throws GroupManagementDAOException;
|
void removeDevice(int groupId, int deviceId, int tenantId) throws GroupManagementDAOException;
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* Check device is belonging to a Device Group.
|
* Check device is belonging to a Device Group.
|
||||||
*
|
*
|
||||||
* @param groupName of the Device Group.
|
* @param groupId of Device Group.
|
||||||
* @param owner of the Device Group.
|
|
||||||
* @param deviceId of the device.
|
* @param deviceId of the device.
|
||||||
* @param tenantId of user's tenant.
|
* @param tenantId of user's tenant.
|
||||||
* @throws GroupManagementDAOException
|
* @throws GroupManagementDAOException
|
||||||
*/
|
*/
|
||||||
boolean isDeviceMappedToGroup(String groupName, String owner, int deviceId, int tenantId)
|
boolean isDeviceMappedToGroup(int groupId, int deviceId, int tenantId)
|
||||||
throws GroupManagementDAOException;
|
throws GroupManagementDAOException;
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* Get count of devices in a Device Group.
|
* Get count of devices in a Device Group.
|
||||||
*
|
*
|
||||||
* @param groupName of the Device Group.
|
* @param groupId of Device Group.
|
||||||
* @param owner of the Device Group.
|
|
||||||
* @param tenantId of user's tenant.
|
* @param tenantId of user's tenant.
|
||||||
* @return device count.
|
* @return device count.
|
||||||
* @throws GroupManagementDAOException
|
* @throws GroupManagementDAOException
|
||||||
*/
|
*/
|
||||||
int getDeviceCount(String groupName, String owner, int tenantId) throws GroupManagementDAOException;
|
int getDeviceCount(int groupId, int tenantId) throws GroupManagementDAOException;
|
||||||
|
|
||||||
/**
|
|
||||||
* Get all devices of a given tenant and device group.
|
|
||||||
*
|
|
||||||
* @param groupName of the group.
|
|
||||||
* @param owner of the Device Group.
|
|
||||||
* @param tenantId of user's tenant.
|
|
||||||
* @return list of device in group
|
|
||||||
* @throws GroupManagementDAOException
|
|
||||||
*/
|
|
||||||
List<Device> getDevices(String groupName, String owner, int tenantId) throws GroupManagementDAOException;
|
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* Get paginated result of devices of a given tenant and device group.
|
* Get paginated result of devices of a given tenant and device group.
|
||||||
*
|
*
|
||||||
* @param groupName of the group.
|
* @param groupId of Device Group.
|
||||||
* @param owner of the Device Group.
|
|
||||||
* @param startIndex for pagination.
|
* @param startIndex for pagination.
|
||||||
* @param rowCount for pagination.
|
* @param rowCount for pagination.
|
||||||
* @param tenantId of user's tenant.
|
* @param tenantId of user's tenant.
|
||||||
* @return list of device in group
|
* @return list of device in group
|
||||||
* @throws GroupManagementDAOException
|
* @throws GroupManagementDAOException
|
||||||
*/
|
*/
|
||||||
List<Device> getDevices(String groupName, String owner, int startIndex, int rowCount, int tenantId)
|
List<Device> getDevices(int groupId, int startIndex, int rowCount, int tenantId)
|
||||||
throws GroupManagementDAOException;
|
throws GroupManagementDAOException;
|
||||||
|
|
||||||
}
|
}
|
||||||
|
|||||||
@ -19,9 +19,9 @@
|
|||||||
package org.wso2.carbon.device.mgt.core.group.mgt.dao;
|
package org.wso2.carbon.device.mgt.core.group.mgt.dao;
|
||||||
|
|
||||||
import org.wso2.carbon.device.mgt.common.Device;
|
import org.wso2.carbon.device.mgt.common.Device;
|
||||||
|
import org.wso2.carbon.device.mgt.common.GroupPaginationRequest;
|
||||||
import org.wso2.carbon.device.mgt.common.group.mgt.DeviceGroup;
|
import org.wso2.carbon.device.mgt.common.group.mgt.DeviceGroup;
|
||||||
import org.wso2.carbon.device.mgt.core.dao.util.DeviceManagementDAOUtil;
|
import org.wso2.carbon.device.mgt.core.dao.util.DeviceManagementDAOUtil;
|
||||||
import org.wso2.carbon.device.mgt.core.group.mgt.DeviceGroupBuilder;
|
|
||||||
|
|
||||||
import java.sql.Connection;
|
import java.sql.Connection;
|
||||||
import java.sql.PreparedStatement;
|
import java.sql.PreparedStatement;
|
||||||
@ -67,21 +67,20 @@ public class GroupDAOImpl implements GroupDAO {
|
|||||||
}
|
}
|
||||||
|
|
||||||
@Override
|
@Override
|
||||||
public void updateGroup(DeviceGroup deviceGroup, String oldGroupName, String oldOwner, int tenantId)
|
public void updateGroup(DeviceGroup deviceGroup, int groupId, int tenantId)
|
||||||
throws GroupManagementDAOException {
|
throws GroupManagementDAOException {
|
||||||
PreparedStatement stmt = null;
|
PreparedStatement stmt = null;
|
||||||
try {
|
try {
|
||||||
Connection conn = GroupManagementDAOFactory.getConnection();
|
Connection conn = GroupManagementDAOFactory.getConnection();
|
||||||
String sql = "UPDATE DM_GROUP SET DESCRIPTION = ?, GROUP_NAME = ?, DATE_OF_LAST_UPDATE = ?, OWNER = ? "
|
String sql = "UPDATE DM_GROUP SET DESCRIPTION = ?, GROUP_NAME = ?, DATE_OF_LAST_UPDATE = ?, OWNER = ? "
|
||||||
+ "WHERE GROUP_NAME = ? AND OWNER = ? AND TENANT_ID = ?";
|
+ "WHERE ID = ? AND TENANT_ID = ?";
|
||||||
stmt = conn.prepareStatement(sql);
|
stmt = conn.prepareStatement(sql);
|
||||||
stmt.setString(1, deviceGroup.getDescription());
|
stmt.setString(1, deviceGroup.getDescription());
|
||||||
stmt.setString(2, deviceGroup.getName());
|
stmt.setString(2, deviceGroup.getName());
|
||||||
stmt.setLong(3, deviceGroup.getDateOfLastUpdate());
|
stmt.setLong(3, deviceGroup.getDateOfLastUpdate());
|
||||||
stmt.setString(4, deviceGroup.getOwner());
|
stmt.setString(4, deviceGroup.getOwner());
|
||||||
stmt.setString(5, oldGroupName);
|
stmt.setInt(5, groupId);
|
||||||
stmt.setString(6, oldOwner);
|
stmt.setInt(6, tenantId);
|
||||||
stmt.setInt(7, tenantId);
|
|
||||||
stmt.executeUpdate();
|
stmt.executeUpdate();
|
||||||
} catch (SQLException e) {
|
} catch (SQLException e) {
|
||||||
throw new GroupManagementDAOException("Error occurred while updating deviceGroup '" +
|
throw new GroupManagementDAOException("Error occurred while updating deviceGroup '" +
|
||||||
@ -92,42 +91,38 @@ public class GroupDAOImpl implements GroupDAO {
|
|||||||
}
|
}
|
||||||
|
|
||||||
@Override
|
@Override
|
||||||
public void deleteGroup(String groupName, String owner, int tenantId) throws GroupManagementDAOException {
|
public void deleteGroup(int groupId, int tenantId) throws GroupManagementDAOException {
|
||||||
Connection conn;
|
Connection conn;
|
||||||
PreparedStatement stmt = null;
|
PreparedStatement stmt = null;
|
||||||
try {
|
try {
|
||||||
conn = GroupManagementDAOFactory.getConnection();
|
conn = GroupManagementDAOFactory.getConnection();
|
||||||
String sql = "DELETE FROM DM_DEVICE_GROUP_MAP WHERE GROUP_ID = (SELECT ID AS GROUP_ID FROM DM_GROUP WHERE GROUP_NAME = ? AND OWNER = ? AND TENANT_ID = ?) AND TENANT_ID = ?";
|
String sql = "DELETE FROM DM_DEVICE_GROUP_MAP WHERE GROUP_ID = ? AND TENANT_ID = ?";
|
||||||
stmt = conn.prepareStatement(sql);
|
stmt = conn.prepareStatement(sql);
|
||||||
stmt.setString(1, groupName);
|
stmt.setInt(1, groupId);
|
||||||
stmt.setString(2, owner);
|
stmt.setInt(2, tenantId);
|
||||||
stmt.setInt(3, tenantId);
|
|
||||||
stmt.setInt(4, tenantId);
|
|
||||||
stmt.executeUpdate();
|
stmt.executeUpdate();
|
||||||
} catch (SQLException e) {
|
} catch (SQLException e) {
|
||||||
throw new GroupManagementDAOException("Error occurred while removing mappings for group '" + groupName +
|
throw new GroupManagementDAOException("Error occurred while removing mappings for group.'", e);
|
||||||
"'", e);
|
|
||||||
} finally {
|
} finally {
|
||||||
GroupManagementDAOUtil.cleanupResources(stmt, null);
|
GroupManagementDAOUtil.cleanupResources(stmt, null);
|
||||||
}
|
}
|
||||||
|
|
||||||
try {
|
try {
|
||||||
conn = GroupManagementDAOFactory.getConnection();
|
conn = GroupManagementDAOFactory.getConnection();
|
||||||
String sql = "DELETE FROM DM_GROUP WHERE GROUP_NAME = ? AND OWNER = ? AND TENANT_ID = ?";
|
String sql = "DELETE FROM DM_GROUP WHERE ID = ? AND TENANT_ID = ?";
|
||||||
stmt = conn.prepareStatement(sql);
|
stmt = conn.prepareStatement(sql);
|
||||||
stmt.setString(1, groupName);
|
stmt.setInt(1, groupId);
|
||||||
stmt.setString(2, owner);
|
stmt.setInt(2, tenantId);
|
||||||
stmt.setInt(3, tenantId);
|
|
||||||
stmt.executeUpdate();
|
stmt.executeUpdate();
|
||||||
} catch (SQLException e) {
|
} catch (SQLException e) {
|
||||||
throw new GroupManagementDAOException("Error occurred while deleting group '" + groupName + "'", e);
|
throw new GroupManagementDAOException("Error occurred while deleting group.'", e);
|
||||||
} finally {
|
} finally {
|
||||||
GroupManagementDAOUtil.cleanupResources(stmt, null);
|
GroupManagementDAOUtil.cleanupResources(stmt, null);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
@Override
|
@Override
|
||||||
public DeviceGroupBuilder getGroup(int groupId, int tenantId) throws GroupManagementDAOException {
|
public DeviceGroup getGroup(int groupId, int tenantId) throws GroupManagementDAOException {
|
||||||
PreparedStatement stmt = null;
|
PreparedStatement stmt = null;
|
||||||
ResultSet resultSet = null;
|
ResultSet resultSet = null;
|
||||||
try {
|
try {
|
||||||
@ -152,38 +147,10 @@ public class GroupDAOImpl implements GroupDAO {
|
|||||||
}
|
}
|
||||||
|
|
||||||
@Override
|
@Override
|
||||||
public DeviceGroupBuilder getGroup(String groupName, String owner, int tenantId)
|
public List<DeviceGroup> getGroups(int deviceId, int tenantId) throws GroupManagementDAOException {
|
||||||
throws GroupManagementDAOException {
|
|
||||||
PreparedStatement stmt = null;
|
PreparedStatement stmt = null;
|
||||||
ResultSet resultSet = null;
|
ResultSet resultSet = null;
|
||||||
try {
|
List<DeviceGroup> deviceGroupBuilders = new ArrayList<>();
|
||||||
Connection conn = GroupManagementDAOFactory.getConnection();
|
|
||||||
String sql = "SELECT ID, DESCRIPTION, GROUP_NAME, DATE_OF_CREATE, DATE_OF_LAST_UPDATE, OWNER "
|
|
||||||
+ "FROM DM_GROUP WHERE GROUP_NAME = ? AND OWNER = ? AND TENANT_ID = ?";
|
|
||||||
stmt = conn.prepareStatement(sql);
|
|
||||||
stmt.setString(1, groupName);
|
|
||||||
stmt.setString(2, owner);
|
|
||||||
stmt.setInt(3, tenantId);
|
|
||||||
resultSet = stmt.executeQuery();
|
|
||||||
if (resultSet.next()) {
|
|
||||||
return GroupManagementDAOUtil.loadGroup(resultSet);
|
|
||||||
} else {
|
|
||||||
return null;
|
|
||||||
}
|
|
||||||
} catch (SQLException e) {
|
|
||||||
throw new GroupManagementDAOException("Error occurred while obtaining information of Device Group '" +
|
|
||||||
groupName + "'", e);
|
|
||||||
} finally {
|
|
||||||
GroupManagementDAOUtil.cleanupResources(stmt, resultSet);
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
@Override
|
|
||||||
public List<DeviceGroupBuilder> getGroups(int deviceId, int tenantId) throws GroupManagementDAOException {
|
|
||||||
|
|
||||||
PreparedStatement stmt = null;
|
|
||||||
ResultSet resultSet = null;
|
|
||||||
List<DeviceGroupBuilder> deviceGroupBuilders = new ArrayList<>();
|
|
||||||
try {
|
try {
|
||||||
Connection conn = GroupManagementDAOFactory.getConnection();
|
Connection conn = GroupManagementDAOFactory.getConnection();
|
||||||
String sql = "SELECT G.ID, G.GROUP_NAME, G.DESCRIPTION, G.DATE_OF_CREATE, G.DATE_OF_LAST_UPDATE, \n" +
|
String sql = "SELECT G.ID, G.GROUP_NAME, G.DESCRIPTION, G.DATE_OF_CREATE, G.DATE_OF_LAST_UPDATE, \n" +
|
||||||
@ -205,21 +172,71 @@ public class GroupDAOImpl implements GroupDAO {
|
|||||||
}
|
}
|
||||||
|
|
||||||
@Override
|
@Override
|
||||||
public List<DeviceGroupBuilder> getGroups(int startIndex, int rowCount, int tenantId)
|
public List<DeviceGroup> getGroups(GroupPaginationRequest request, int tenantId)
|
||||||
throws GroupManagementDAOException {
|
throws GroupManagementDAOException {
|
||||||
PreparedStatement stmt = null;
|
PreparedStatement stmt = null;
|
||||||
ResultSet resultSet = null;
|
ResultSet resultSet = null;
|
||||||
List<DeviceGroupBuilder> deviceGroupList = null;
|
List<DeviceGroup> deviceGroupList = null;
|
||||||
|
|
||||||
|
String groupName = request.getGroupName();
|
||||||
|
boolean hasGroupName = false;
|
||||||
|
String owner = request.getOwner();
|
||||||
|
boolean hasOwner = false;
|
||||||
|
boolean hasLimit = request.getRowCount() != 0;
|
||||||
|
|
||||||
try {
|
try {
|
||||||
Connection conn = GroupManagementDAOFactory.getConnection();
|
Connection conn = GroupManagementDAOFactory.getConnection();
|
||||||
String sql = "SELECT ID, DESCRIPTION, GROUP_NAME, DATE_OF_CREATE, DATE_OF_LAST_UPDATE, OWNER "
|
String sql = "SELECT ID, DESCRIPTION, GROUP_NAME, DATE_OF_CREATE, DATE_OF_LAST_UPDATE, OWNER "
|
||||||
+ "FROM DM_GROUP WHERE TENANT_ID = ? LIMIT ?, ?";
|
+ "FROM DM_GROUP WHERE TENANT_ID = ?";
|
||||||
|
if (groupName != null && !groupName.isEmpty()) {
|
||||||
|
sql += " AND GROUP_NAME LIKE ?";
|
||||||
|
hasGroupName = true;
|
||||||
|
}
|
||||||
|
if (owner != null && !owner.isEmpty()) {
|
||||||
|
sql += " AND OWNER LIKE ?";
|
||||||
|
hasOwner = true;
|
||||||
|
}
|
||||||
|
if (hasLimit) {
|
||||||
|
sql += " LIMIT ?, ?";
|
||||||
|
}
|
||||||
|
|
||||||
|
int paramIndex = 1;
|
||||||
|
stmt = conn.prepareStatement(sql);
|
||||||
|
stmt.setInt(paramIndex++, tenantId);
|
||||||
|
if (hasGroupName) {
|
||||||
|
stmt.setString(paramIndex++, groupName + "%");
|
||||||
|
}
|
||||||
|
if (hasOwner) {
|
||||||
|
stmt.setString(paramIndex++, owner + "%");
|
||||||
|
}
|
||||||
|
if (hasLimit) {
|
||||||
|
stmt.setInt(paramIndex++, request.getStartIndex());
|
||||||
|
stmt.setInt(paramIndex, request.getRowCount());
|
||||||
|
}
|
||||||
|
resultSet = stmt.executeQuery();
|
||||||
|
deviceGroupList = new ArrayList<>();
|
||||||
|
while (resultSet.next()) {
|
||||||
|
deviceGroupList.add(GroupManagementDAOUtil.loadGroup(resultSet));
|
||||||
|
}
|
||||||
|
} catch (SQLException e) {
|
||||||
|
throw new GroupManagementDAOException("Error occurred while listing all groups in tenant: " + tenantId, e);
|
||||||
|
} finally {
|
||||||
|
GroupManagementDAOUtil.cleanupResources(stmt, resultSet);
|
||||||
|
}
|
||||||
|
return deviceGroupList;
|
||||||
|
}
|
||||||
|
|
||||||
|
@Override
|
||||||
|
public List<DeviceGroup> getGroups(int tenantId) throws GroupManagementDAOException {
|
||||||
|
PreparedStatement stmt = null;
|
||||||
|
ResultSet resultSet = null;
|
||||||
|
List<DeviceGroup> deviceGroupList = null;
|
||||||
|
try {
|
||||||
|
Connection conn = GroupManagementDAOFactory.getConnection();
|
||||||
|
String sql = "SELECT ID, DESCRIPTION, GROUP_NAME, DATE_OF_CREATE, DATE_OF_LAST_UPDATE, OWNER "
|
||||||
|
+ "FROM DM_GROUP WHERE TENANT_ID = ?";
|
||||||
stmt = conn.prepareStatement(sql);
|
stmt = conn.prepareStatement(sql);
|
||||||
stmt.setInt(1, tenantId);
|
stmt.setInt(1, tenantId);
|
||||||
//noinspection JpaQueryApiInspection
|
|
||||||
stmt.setInt(2, startIndex);
|
|
||||||
//noinspection JpaQueryApiInspection
|
|
||||||
stmt.setInt(3, rowCount);
|
|
||||||
resultSet = stmt.executeQuery();
|
resultSet = stmt.executeQuery();
|
||||||
deviceGroupList = new ArrayList<>();
|
deviceGroupList = new ArrayList<>();
|
||||||
while (resultSet.next()) {
|
while (resultSet.next()) {
|
||||||
@ -256,140 +273,144 @@ public class GroupDAOImpl implements GroupDAO {
|
|||||||
}
|
}
|
||||||
|
|
||||||
@Override
|
@Override
|
||||||
public List<DeviceGroupBuilder> findInGroups(String groupName, int tenantId)
|
public int getGroupCount(GroupPaginationRequest request, int tenantId)
|
||||||
throws GroupManagementDAOException {
|
throws GroupManagementDAOException {
|
||||||
PreparedStatement stmt = null;
|
PreparedStatement stmt = null;
|
||||||
ResultSet resultSet = null;
|
ResultSet resultSet = null;
|
||||||
List<DeviceGroupBuilder> deviceGroups = new ArrayList<>();
|
|
||||||
|
String groupName = request.getGroupName();
|
||||||
|
boolean hasGroupName = false;
|
||||||
|
String owner = request.getOwner();
|
||||||
|
boolean hasOwner = false;
|
||||||
|
|
||||||
try {
|
try {
|
||||||
Connection conn = GroupManagementDAOFactory.getConnection();
|
Connection conn = GroupManagementDAOFactory.getConnection();
|
||||||
String sql = "SELECT ID, DESCRIPTION, GROUP_NAME, DATE_OF_CREATE, DATE_OF_LAST_UPDATE, OWNER "
|
String sql = "SELECT COUNT(ID) AS GROUP_COUNT FROM DM_GROUP WHERE TENANT_ID = ?";
|
||||||
+ "FROM DM_GROUP WHERE GROUP_NAME LIKE ? AND TENANT_ID = ?";
|
if (groupName != null && !groupName.isEmpty()) {
|
||||||
|
sql += " AND GROUP_NAME LIKE ?";
|
||||||
|
hasGroupName = true;
|
||||||
|
}
|
||||||
|
if (owner != null && !owner.isEmpty()) {
|
||||||
|
sql += " AND OWNER LIKE ?";
|
||||||
|
hasOwner = true;
|
||||||
|
}
|
||||||
|
|
||||||
|
int paramIndex = 1;
|
||||||
stmt = conn.prepareStatement(sql);
|
stmt = conn.prepareStatement(sql);
|
||||||
stmt.setString(1, "%" + groupName + "%");
|
stmt.setInt(paramIndex++, tenantId);
|
||||||
stmt.setInt(2, tenantId);
|
if (hasGroupName) {
|
||||||
|
stmt.setString(paramIndex++, groupName + "%");
|
||||||
|
}
|
||||||
|
if (hasOwner) {
|
||||||
|
stmt.setString(paramIndex, owner + "%");
|
||||||
|
}
|
||||||
resultSet = stmt.executeQuery();
|
resultSet = stmt.executeQuery();
|
||||||
while (resultSet.next()) {
|
if (resultSet.next()) {
|
||||||
deviceGroups.add(GroupManagementDAOUtil.loadGroup(resultSet));
|
return resultSet.getInt("GROUP_COUNT");
|
||||||
|
} else {
|
||||||
|
return 0;
|
||||||
}
|
}
|
||||||
} catch (SQLException e) {
|
} catch (SQLException e) {
|
||||||
throw new GroupManagementDAOException("Error occurred while listing Device Groups by name '" +
|
throw new GroupManagementDAOException("Error occurred while listing all groups in tenant: " + tenantId, e);
|
||||||
groupName + "' in tenant '" + tenantId + "'", e);
|
|
||||||
} finally {
|
} finally {
|
||||||
GroupManagementDAOUtil.cleanupResources(stmt, resultSet);
|
GroupManagementDAOUtil.cleanupResources(stmt, resultSet);
|
||||||
}
|
}
|
||||||
return deviceGroups;
|
|
||||||
}
|
}
|
||||||
|
|
||||||
@Override
|
@Override
|
||||||
public boolean isGroupExist(String groupName, String owner, int tenantId) throws GroupManagementDAOException {
|
public DeviceGroup getGroup(String groupName, int tenantId) throws GroupManagementDAOException {
|
||||||
PreparedStatement stmt = null;
|
PreparedStatement stmt = null;
|
||||||
ResultSet resultSet = null;
|
ResultSet resultSet = null;
|
||||||
try {
|
try {
|
||||||
Connection conn = GroupManagementDAOFactory.getConnection();
|
Connection conn = GroupManagementDAOFactory.getConnection();
|
||||||
String sql = "SELECT GROUP_NAME FROM DM_GROUP WHERE GROUP_NAME = ? AND OWNER = ? AND TENANT_ID = ?";
|
String sql = "SELECT ID, DESCRIPTION, GROUP_NAME, DATE_OF_CREATE, DATE_OF_LAST_UPDATE, OWNER " +
|
||||||
|
"FROM DM_GROUP WHERE GROUP_NAME = ? AND TENANT_ID = ?";
|
||||||
stmt = conn.prepareStatement(sql);
|
stmt = conn.prepareStatement(sql);
|
||||||
stmt.setString(1, groupName);
|
stmt.setString(1, groupName);
|
||||||
stmt.setString(2, owner);
|
stmt.setInt(2, tenantId);
|
||||||
stmt.setInt(3, tenantId);
|
|
||||||
resultSet = stmt.executeQuery();
|
resultSet = stmt.executeQuery();
|
||||||
return resultSet.next();
|
if (resultSet.next()) {
|
||||||
|
return GroupManagementDAOUtil.loadGroup(resultSet);
|
||||||
|
}
|
||||||
|
return null;
|
||||||
} catch (SQLException e) {
|
} catch (SQLException e) {
|
||||||
throw new GroupManagementDAOException("Error occurred while group Id listing by group name '" +
|
throw new GroupManagementDAOException("Error occurred while group Id listing by group name.'", e);
|
||||||
groupName + "'", e);
|
|
||||||
} finally {
|
} finally {
|
||||||
GroupManagementDAOUtil.cleanupResources(stmt, resultSet);
|
GroupManagementDAOUtil.cleanupResources(stmt, resultSet);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
@Override
|
@Override
|
||||||
public void addDevice(String groupName, String owner, int deviceId, int tenantId)
|
public void addDevice(int groupId, int deviceId, int tenantId)
|
||||||
throws GroupManagementDAOException {
|
throws GroupManagementDAOException {
|
||||||
PreparedStatement stmt = null;
|
PreparedStatement stmt = null;
|
||||||
try {
|
try {
|
||||||
Connection conn = GroupManagementDAOFactory.getConnection();
|
Connection conn = GroupManagementDAOFactory.getConnection();
|
||||||
String sql = "INSERT INTO DM_DEVICE_GROUP_MAP(DEVICE_ID, GROUP_ID, TENANT_ID) " +
|
String sql = "INSERT INTO DM_DEVICE_GROUP_MAP(DEVICE_ID, GROUP_ID, TENANT_ID) VALUES (?, ?, ?)";
|
||||||
"VALUES (?, (SELECT ID as GROUP_ID FROM DM_GROUP " +
|
|
||||||
"WHERE GROUP_NAME = ? AND OWNER = ? AND TENANT_ID = ?), ?)";
|
|
||||||
stmt = conn.prepareStatement(sql);
|
stmt = conn.prepareStatement(sql);
|
||||||
stmt.setInt(1, deviceId);
|
stmt.setInt(1, deviceId);
|
||||||
stmt.setString(2, groupName);
|
stmt.setInt(2, groupId);
|
||||||
stmt.setString(3, owner);
|
stmt.setInt(3, tenantId);
|
||||||
stmt.setInt(4, tenantId);
|
|
||||||
stmt.setInt(5, tenantId);
|
|
||||||
stmt.executeUpdate();
|
stmt.executeUpdate();
|
||||||
stmt.getGeneratedKeys();
|
stmt.getGeneratedKeys();
|
||||||
} catch (SQLException e) {
|
} catch (SQLException e) {
|
||||||
throw new GroupManagementDAOException("Error occurred while adding device to Group '" + groupName + "'", e);
|
throw new GroupManagementDAOException("Error occurred while adding device to Group.", e);
|
||||||
} finally {
|
} finally {
|
||||||
GroupManagementDAOUtil.cleanupResources(stmt, null);
|
GroupManagementDAOUtil.cleanupResources(stmt, null);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
@Override
|
@Override
|
||||||
public void removeDevice(String groupName, String owner, int deviceId, int tenantId)
|
public void removeDevice(int groupId, int deviceId, int tenantId)
|
||||||
throws GroupManagementDAOException {
|
throws GroupManagementDAOException {
|
||||||
PreparedStatement stmt = null;
|
PreparedStatement stmt = null;
|
||||||
try {
|
try {
|
||||||
Connection conn = GroupManagementDAOFactory.getConnection();
|
Connection conn = GroupManagementDAOFactory.getConnection();
|
||||||
String sql = "DELETE FROM DM_DEVICE_GROUP_MAP WHERE DEVICE_ID = ? AND GROUP_ID = (SELECT ID as GROUP_ID " +
|
String sql = "DELETE FROM DM_DEVICE_GROUP_MAP WHERE DEVICE_ID = ? AND GROUP_ID = ? AND TENANT_ID = ?";
|
||||||
"FROM DM_GROUP WHERE GROUP_NAME = ? AND OWNER = ? AND TENANT_ID = ?) AND TENANT_ID = ?";
|
|
||||||
stmt = conn.prepareStatement(sql);
|
stmt = conn.prepareStatement(sql);
|
||||||
stmt.setInt(1, deviceId);
|
stmt.setInt(1, deviceId);
|
||||||
stmt.setString(2, groupName);
|
stmt.setInt(2, groupId);
|
||||||
stmt.setString(3, owner);
|
stmt.setInt(3, tenantId);
|
||||||
stmt.setInt(4, tenantId);
|
|
||||||
stmt.setInt(5, tenantId);
|
|
||||||
stmt.executeUpdate();
|
stmt.executeUpdate();
|
||||||
stmt.getGeneratedKeys();
|
stmt.getGeneratedKeys();
|
||||||
} catch (SQLException e) {
|
} catch (SQLException e) {
|
||||||
throw new GroupManagementDAOException("Error occurred while removing device from Group '" +
|
throw new GroupManagementDAOException("Error occurred while removing device from Group.", e);
|
||||||
groupName + "'", e);
|
|
||||||
} finally {
|
} finally {
|
||||||
GroupManagementDAOUtil.cleanupResources(stmt, null);
|
GroupManagementDAOUtil.cleanupResources(stmt, null);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
@Override
|
@Override
|
||||||
public boolean isDeviceMappedToGroup(String groupName, String owner, int deviceId, int tenantId)
|
public boolean isDeviceMappedToGroup(int groupId, int deviceId, int tenantId)
|
||||||
throws GroupManagementDAOException {
|
throws GroupManagementDAOException {
|
||||||
PreparedStatement stmt = null;
|
PreparedStatement stmt = null;
|
||||||
ResultSet resultSet = null;
|
ResultSet resultSet = null;
|
||||||
try {
|
try {
|
||||||
Connection conn = GroupManagementDAOFactory.getConnection();
|
Connection conn = GroupManagementDAOFactory.getConnection();
|
||||||
String sql = "SELECT dm.ID FROM DM_DEVICE_GROUP_MAP dm, (SELECT ID as GROUP_ID FROM DM_GROUP " +
|
String sql = "SELECT ID FROM DM_DEVICE_GROUP_MAP WHERE GROUP_ID = ? AND DEVICE_ID = ? AND TENANT_ID = ?";
|
||||||
"WHERE GROUP_NAME = ? AND OWNER = ? AND TENANT_ID = ?) dg " +
|
|
||||||
"WHERE dm.GROUP_ID = dg.GROUP_ID AND dm.ID = ? AND dm.TENANT_ID = ?";
|
|
||||||
stmt = conn.prepareStatement(sql);
|
stmt = conn.prepareStatement(sql);
|
||||||
stmt.setString(1, groupName);
|
stmt.setInt(1, groupId);
|
||||||
stmt.setString(2, owner);
|
stmt.setInt(2, deviceId);
|
||||||
stmt.setInt(3, tenantId);
|
stmt.setInt(3, tenantId);
|
||||||
stmt.setInt(4, deviceId);
|
|
||||||
stmt.setInt(5, tenantId);
|
|
||||||
resultSet = stmt.executeQuery();
|
resultSet = stmt.executeQuery();
|
||||||
return resultSet.next();
|
return resultSet.next();
|
||||||
} catch (SQLException e) {
|
} catch (SQLException e) {
|
||||||
throw new GroupManagementDAOException("Error occurred while group Id listing by group name '" +
|
throw new GroupManagementDAOException("Error occurred while checking device mapping with group.", e);
|
||||||
groupName + "'", e);
|
|
||||||
} finally {
|
} finally {
|
||||||
GroupManagementDAOUtil.cleanupResources(stmt, resultSet);
|
GroupManagementDAOUtil.cleanupResources(stmt, resultSet);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
@Override
|
@Override
|
||||||
public int getDeviceCount(String groupName, String owner, int tenantId) throws GroupManagementDAOException {
|
public int getDeviceCount(int groupId, int tenantId) throws GroupManagementDAOException {
|
||||||
PreparedStatement stmt = null;
|
PreparedStatement stmt = null;
|
||||||
ResultSet resultSet = null;
|
ResultSet resultSet = null;
|
||||||
try {
|
try {
|
||||||
Connection conn = GroupManagementDAOFactory.getConnection();
|
Connection conn = GroupManagementDAOFactory.getConnection();
|
||||||
String sql = "SELECT COUNT(gm.ID) AS DEVICE_COUNT FROM DM_DEVICE_GROUP_MAP gm, (SELECT ID " +
|
String sql = "SELECT COUNT(ID) AS DEVICE_COUNT FROM DM_DEVICE_GROUP_MAP WHERE GROUP_ID = ? AND TENANT_ID = ?";
|
||||||
"FROM DM_GROUP WHERE GROUP_NAME = ? AND OWNER = ? AND TENANT_ID = ?) dg " +
|
|
||||||
"WHERE gm.GROUP_ID = dg.ID AND gm.TENANT_ID = ?";
|
|
||||||
stmt = conn.prepareStatement(sql);
|
stmt = conn.prepareStatement(sql);
|
||||||
stmt.setString(1, groupName);
|
stmt.setInt(1, groupId);
|
||||||
stmt.setString(2, owner);
|
stmt.setInt(2, tenantId);
|
||||||
stmt.setInt(3, tenantId);
|
|
||||||
stmt.setInt(4, tenantId);
|
|
||||||
resultSet = stmt.executeQuery();
|
resultSet = stmt.executeQuery();
|
||||||
if (resultSet.next()) {
|
if (resultSet.next()) {
|
||||||
return resultSet.getInt("DEVICE_COUNT");
|
return resultSet.getInt("DEVICE_COUNT");
|
||||||
@ -397,54 +418,15 @@ public class GroupDAOImpl implements GroupDAO {
|
|||||||
return 0;
|
return 0;
|
||||||
}
|
}
|
||||||
} catch (SQLException e) {
|
} catch (SQLException e) {
|
||||||
throw new GroupManagementDAOException("Error occurred while group Id listing by group name '" +
|
throw new GroupManagementDAOException("Error occurred while getting device count from the group.", e);
|
||||||
groupName + "'", e);
|
|
||||||
} finally {
|
} finally {
|
||||||
GroupManagementDAOUtil.cleanupResources(stmt, resultSet);
|
GroupManagementDAOUtil.cleanupResources(stmt, resultSet);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
//TODO: Move this to device mgt
|
||||||
@Override
|
@Override
|
||||||
public List<Device> getDevices(String groupName, String owner, int tenantId) throws GroupManagementDAOException {
|
public List<Device> getDevices(int groupId, int startIndex, int rowCount, int tenantId)
|
||||||
Connection conn;
|
|
||||||
PreparedStatement stmt = null;
|
|
||||||
ResultSet rs = null;
|
|
||||||
List<Device> devices = null;
|
|
||||||
try {
|
|
||||||
conn = GroupManagementDAOFactory.getConnection();
|
|
||||||
String sql = "SELECT d1.DEVICE_ID, d1.DESCRIPTION, d1.NAME AS DEVICE_NAME, d1.DEVICE_TYPE, " +
|
|
||||||
"d1.DEVICE_IDENTIFICATION, e.OWNER, e.OWNERSHIP, e.STATUS, e.DATE_OF_LAST_UPDATE, " +
|
|
||||||
"e.DATE_OF_ENROLMENT, e.ID AS ENROLMENT_ID FROM DM_ENROLMENT e, " +
|
|
||||||
"(SELECT gd.DEVICE_ID, gd.DESCRIPTION, gd.NAME, gd.DEVICE_IDENTIFICATION, " +
|
|
||||||
"t.NAME AS DEVICE_TYPE FROM (SELECT d.ID AS DEVICE_ID, d.DESCRIPTION, d.NAME, " +
|
|
||||||
"d.DEVICE_IDENTIFICATION, d.DEVICE_TYPE_ID FROM DM_DEVICE d, (SELECT dgm.DEVICE_ID " +
|
|
||||||
"FROM DM_DEVICE_GROUP_MAP dgm, DM_GROUP dg WHERE dgm.GROUP_ID = dg.ID AND dg.GROUP_NAME = ? " +
|
|
||||||
"AND dg.OWNER = ? AND dg.TENANT_ID = ?) dgm1 WHERE d.ID = dgm1.DEVICE_ID " +
|
|
||||||
"AND d.TENANT_ID = ?) gd, DM_DEVICE_TYPE t WHERE gd.DEVICE_TYPE_ID = t.ID) d1 " +
|
|
||||||
"WHERE d1.DEVICE_ID = e.DEVICE_ID AND TENANT_ID = ?";
|
|
||||||
stmt = conn.prepareStatement(sql);
|
|
||||||
stmt.setString(1, groupName);
|
|
||||||
stmt.setString(2, owner);
|
|
||||||
stmt.setInt(3, tenantId);
|
|
||||||
stmt.setInt(4, tenantId);
|
|
||||||
stmt.setInt(5, tenantId);
|
|
||||||
rs = stmt.executeQuery();
|
|
||||||
devices = new ArrayList<>();
|
|
||||||
while (rs.next()) {
|
|
||||||
Device device = DeviceManagementDAOUtil.loadDevice(rs);
|
|
||||||
devices.add(device);
|
|
||||||
}
|
|
||||||
} catch (SQLException e) {
|
|
||||||
throw new GroupManagementDAOException("Error occurred while retrieving information of all " +
|
|
||||||
"registered devices", e);
|
|
||||||
} finally {
|
|
||||||
DeviceManagementDAOUtil.cleanupResources(stmt, rs);
|
|
||||||
}
|
|
||||||
return devices;
|
|
||||||
}
|
|
||||||
|
|
||||||
@Override
|
|
||||||
public List<Device> getDevices(String groupName, String owner, int startIndex, int rowCount, int tenantId)
|
|
||||||
throws GroupManagementDAOException {
|
throws GroupManagementDAOException {
|
||||||
Connection conn;
|
Connection conn;
|
||||||
PreparedStatement stmt = null;
|
PreparedStatement stmt = null;
|
||||||
@ -455,24 +437,20 @@ public class GroupDAOImpl implements GroupDAO {
|
|||||||
String sql = "SELECT d1.DEVICE_ID, d1.DESCRIPTION, d1.NAME AS DEVICE_NAME, d1.DEVICE_TYPE, " +
|
String sql = "SELECT d1.DEVICE_ID, d1.DESCRIPTION, d1.NAME AS DEVICE_NAME, d1.DEVICE_TYPE, " +
|
||||||
"d1.DEVICE_IDENTIFICATION, e.OWNER, e.OWNERSHIP, e.STATUS, e.DATE_OF_LAST_UPDATE, " +
|
"d1.DEVICE_IDENTIFICATION, e.OWNER, e.OWNERSHIP, e.STATUS, e.DATE_OF_LAST_UPDATE, " +
|
||||||
"e.DATE_OF_ENROLMENT, e.ID AS ENROLMENT_ID FROM DM_ENROLMENT e, " +
|
"e.DATE_OF_ENROLMENT, e.ID AS ENROLMENT_ID FROM DM_ENROLMENT e, " +
|
||||||
"(SELECT gd.DEVICE_ID, gd.DESCRIPTION, gd.NAME, gd.DEVICE_IDENTIFICATION, " +
|
"(SELECT gd.DEVICE_ID, gd.DESCRIPTION, gd.NAME, gd.DEVICE_IDENTIFICATION, t.NAME AS DEVICE_TYPE FROM " +
|
||||||
"t.NAME AS DEVICE_TYPE FROM (SELECT d.ID AS DEVICE_ID, d.DESCRIPTION, d.NAME, " +
|
"(SELECT d.ID AS DEVICE_ID, d.DESCRIPTION, d.NAME, d.DEVICE_IDENTIFICATION, d.DEVICE_TYPE_ID FROM DM_DEVICE d, (" +
|
||||||
"d.DEVICE_IDENTIFICATION, d.DEVICE_TYPE_ID FROM DM_DEVICE d, (SELECT dgm.DEVICE_ID " +
|
"SELECT dgm.DEVICE_ID FROM DM_DEVICE_GROUP_MAP dgm WHERE dgm.GROUP_ID = ?) dgm1 " +
|
||||||
"FROM DM_DEVICE_GROUP_MAP dgm, DM_GROUP dg WHERE dgm.GROUP_ID = dg.ID AND dg.GROUP_NAME = ? " +
|
"WHERE d.ID = dgm1.DEVICE_ID AND d.TENANT_ID = ?) gd, DM_DEVICE_TYPE t " +
|
||||||
"AND dg.OWNER = ? AND dg.TENANT_ID = ?) dgm1 WHERE d.ID = dgm1.DEVICE_ID " +
|
"WHERE gd.DEVICE_TYPE_ID = t.ID) d1 WHERE d1.DEVICE_ID = e.DEVICE_ID AND TENANT_ID = ? LIMIT ? , ?";
|
||||||
"AND d.TENANT_ID = ?) gd, DM_DEVICE_TYPE t WHERE gd.DEVICE_TYPE_ID = t.ID) d1 " +
|
|
||||||
"WHERE d1.DEVICE_ID = e.DEVICE_ID AND TENANT_ID = ? LIMIT ?, ?";
|
|
||||||
|
|
||||||
stmt = conn.prepareStatement(sql);
|
stmt = conn.prepareStatement(sql);
|
||||||
stmt.setString(1, groupName);
|
stmt.setInt(1, groupId);
|
||||||
stmt.setString(2, owner);
|
stmt.setInt(2, tenantId);
|
||||||
stmt.setInt(3, tenantId);
|
stmt.setInt(3, tenantId);
|
||||||
stmt.setInt(4, tenantId);
|
|
||||||
stmt.setInt(5, tenantId);
|
|
||||||
//noinspection JpaQueryApiInspection
|
//noinspection JpaQueryApiInspection
|
||||||
stmt.setInt(6, startIndex);
|
stmt.setInt(4, startIndex);
|
||||||
//noinspection JpaQueryApiInspection
|
//noinspection JpaQueryApiInspection
|
||||||
stmt.setInt(7, rowCount);
|
stmt.setInt(5, rowCount);
|
||||||
rs = stmt.executeQuery();
|
rs = stmt.executeQuery();
|
||||||
devices = new ArrayList<>();
|
devices = new ArrayList<>();
|
||||||
while (rs.next()) {
|
while (rs.next()) {
|
||||||
|
|||||||
@ -21,7 +21,6 @@ package org.wso2.carbon.device.mgt.core.group.mgt.dao;
|
|||||||
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.device.mgt.common.group.mgt.DeviceGroup;
|
import org.wso2.carbon.device.mgt.common.group.mgt.DeviceGroup;
|
||||||
import org.wso2.carbon.device.mgt.core.group.mgt.DeviceGroupBuilder;
|
|
||||||
|
|
||||||
import javax.naming.InitialContext;
|
import javax.naming.InitialContext;
|
||||||
import javax.sql.DataSource;
|
import javax.sql.DataSource;
|
||||||
@ -80,8 +79,8 @@ public final class GroupManagementDAOUtil {
|
|||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
public static DeviceGroupBuilder loadGroup(ResultSet resultSet) throws SQLException {
|
public static DeviceGroup loadGroup(ResultSet resultSet) throws SQLException {
|
||||||
DeviceGroupBuilder group = new DeviceGroupBuilder(new DeviceGroup());
|
DeviceGroup group = new DeviceGroup();
|
||||||
group.setGroupId(resultSet.getInt("ID"));
|
group.setGroupId(resultSet.getInt("ID"));
|
||||||
group.setDescription(resultSet.getString("DESCRIPTION"));
|
group.setDescription(resultSet.getString("DESCRIPTION"));
|
||||||
group.setName(resultSet.getString("GROUP_NAME"));
|
group.setName(resultSet.getString("GROUP_NAME"));
|
||||||
|
|||||||
@ -19,7 +19,6 @@
|
|||||||
package org.wso2.carbon.device.mgt.core.notification.mgt.dao;
|
package org.wso2.carbon.device.mgt.core.notification.mgt.dao;
|
||||||
|
|
||||||
import org.wso2.carbon.device.mgt.common.PaginationRequest;
|
import org.wso2.carbon.device.mgt.common.PaginationRequest;
|
||||||
import org.wso2.carbon.device.mgt.common.PaginationResult;
|
|
||||||
import org.wso2.carbon.device.mgt.common.notification.mgt.Notification;
|
import org.wso2.carbon.device.mgt.common.notification.mgt.Notification;
|
||||||
import org.wso2.carbon.device.mgt.common.notification.mgt.NotificationManagementException;
|
import org.wso2.carbon.device.mgt.common.notification.mgt.NotificationManagementException;
|
||||||
|
|
||||||
|
|||||||
@ -20,7 +20,6 @@ package org.wso2.carbon.device.mgt.core.operation.mgt.dao;
|
|||||||
|
|
||||||
import org.wso2.carbon.device.mgt.common.PaginationRequest;
|
import org.wso2.carbon.device.mgt.common.PaginationRequest;
|
||||||
import org.wso2.carbon.device.mgt.common.operation.mgt.Activity;
|
import org.wso2.carbon.device.mgt.common.operation.mgt.Activity;
|
||||||
import org.wso2.carbon.device.mgt.common.operation.mgt.ActivityStatus;
|
|
||||||
import org.wso2.carbon.device.mgt.common.operation.mgt.OperationResponse;
|
import org.wso2.carbon.device.mgt.common.operation.mgt.OperationResponse;
|
||||||
import org.wso2.carbon.device.mgt.core.dto.operation.mgt.Operation;
|
import org.wso2.carbon.device.mgt.core.dto.operation.mgt.Operation;
|
||||||
|
|
||||||
|
|||||||
@ -17,7 +17,6 @@
|
|||||||
*/
|
*/
|
||||||
package org.wso2.carbon.device.mgt.core.operation.mgt.dao.impl;
|
package org.wso2.carbon.device.mgt.core.operation.mgt.dao.impl;
|
||||||
|
|
||||||
import org.apache.axis2.databinding.types.soapencoding.Integer;
|
|
||||||
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.PrivilegedCarbonContext;
|
import org.wso2.carbon.context.PrivilegedCarbonContext;
|
||||||
@ -26,7 +25,6 @@ import org.wso2.carbon.device.mgt.common.PaginationRequest;
|
|||||||
import org.wso2.carbon.device.mgt.common.operation.mgt.Activity;
|
import org.wso2.carbon.device.mgt.common.operation.mgt.Activity;
|
||||||
import org.wso2.carbon.device.mgt.common.operation.mgt.ActivityStatus;
|
import org.wso2.carbon.device.mgt.common.operation.mgt.ActivityStatus;
|
||||||
import org.wso2.carbon.device.mgt.common.operation.mgt.OperationResponse;
|
import org.wso2.carbon.device.mgt.common.operation.mgt.OperationResponse;
|
||||||
import org.wso2.carbon.device.mgt.core.DeviceManagementConstants;
|
|
||||||
import org.wso2.carbon.device.mgt.core.dto.operation.mgt.Operation;
|
import org.wso2.carbon.device.mgt.core.dto.operation.mgt.Operation;
|
||||||
import org.wso2.carbon.device.mgt.core.operation.mgt.dao.OperationDAO;
|
import org.wso2.carbon.device.mgt.core.operation.mgt.dao.OperationDAO;
|
||||||
import org.wso2.carbon.device.mgt.core.operation.mgt.dao.OperationManagementDAOException;
|
import org.wso2.carbon.device.mgt.core.operation.mgt.dao.OperationManagementDAOException;
|
||||||
|
|||||||
@ -90,7 +90,7 @@ public class OracleOperationDAOImpl extends GenericOperationDAOImpl {
|
|||||||
|
|
||||||
@Override
|
@Override
|
||||||
public List<? extends Operation> getOperationsByDeviceAndStatus(int enrolmentId,
|
public List<? extends Operation> getOperationsByDeviceAndStatus(int enrolmentId,
|
||||||
PaginationRequest request, Operation.Status status) throws OperationManagementDAOException {
|
PaginationRequest request, Operation.Status status) throws OperationManagementDAOException {
|
||||||
PreparedStatement stmt = null;
|
PreparedStatement stmt = null;
|
||||||
ResultSet rs = null;
|
ResultSet rs = null;
|
||||||
Operation operation;
|
Operation operation;
|
||||||
|
|||||||
@ -20,11 +20,15 @@ package org.wso2.carbon.device.mgt.core.service;
|
|||||||
|
|
||||||
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.DeviceNotFoundException;
|
||||||
|
import org.wso2.carbon.device.mgt.common.GroupPaginationRequest;
|
||||||
|
import org.wso2.carbon.device.mgt.common.PaginationRequest;
|
||||||
import org.wso2.carbon.device.mgt.common.PaginationResult;
|
import org.wso2.carbon.device.mgt.common.PaginationResult;
|
||||||
import org.wso2.carbon.device.mgt.common.group.mgt.DeviceGroup;
|
import org.wso2.carbon.device.mgt.common.group.mgt.DeviceGroup;
|
||||||
import org.wso2.carbon.device.mgt.common.group.mgt.GroupAlreadyExistException;
|
import org.wso2.carbon.device.mgt.common.group.mgt.GroupAlreadyExistException;
|
||||||
import org.wso2.carbon.device.mgt.common.group.mgt.GroupManagementException;
|
import org.wso2.carbon.device.mgt.common.group.mgt.GroupManagementException;
|
||||||
import org.wso2.carbon.device.mgt.common.group.mgt.GroupUser;
|
import org.wso2.carbon.device.mgt.common.group.mgt.GroupUser;
|
||||||
|
import org.wso2.carbon.device.mgt.common.group.mgt.RoleDoesNotExistException;
|
||||||
import org.wso2.carbon.user.core.multiplecredentials.UserDoesNotExistException;
|
import org.wso2.carbon.user.core.multiplecredentials.UserDoesNotExistException;
|
||||||
|
|
||||||
import java.util.List;
|
import java.util.List;
|
||||||
@ -49,71 +53,64 @@ public interface GroupManagementProviderService {
|
|||||||
* Update existing device group.
|
* Update existing device group.
|
||||||
*
|
*
|
||||||
* @param deviceGroup to update.
|
* @param deviceGroup to update.
|
||||||
* @param oldGroupName of the group.
|
* @param groupId of the group.
|
||||||
* @param oldOwner of the group.
|
|
||||||
* @throws GroupManagementException
|
* @throws GroupManagementException
|
||||||
*/
|
*/
|
||||||
void updateGroup(DeviceGroup deviceGroup, String oldGroupName, String oldOwner) throws GroupManagementException;
|
void updateGroup(DeviceGroup deviceGroup, int groupId) throws GroupManagementException, GroupAlreadyExistException;
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* Delete existing device group.
|
* Delete existing device group.
|
||||||
*
|
*
|
||||||
* @param groupName to be deleted.
|
* @param groupId to be deleted.
|
||||||
* @param owner of the group.
|
* @return status of the delete operation.
|
||||||
* @throws GroupManagementException
|
* @throws GroupManagementException
|
||||||
*/
|
*/
|
||||||
boolean deleteGroup(String groupName, String owner) throws GroupManagementException;
|
boolean deleteGroup(int groupId) throws GroupManagementException;
|
||||||
|
|
||||||
/**
|
|
||||||
* Get device group specified by group name.
|
|
||||||
*
|
|
||||||
* @param groupName of the group.
|
|
||||||
* @param owner of the group.
|
|
||||||
* @return group
|
|
||||||
* @throws GroupManagementException
|
|
||||||
*/
|
|
||||||
DeviceGroup getGroup(String groupName, String owner) throws GroupManagementException;
|
|
||||||
|
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* Get the device group provided the device group id.
|
* Get the device group provided the device group id.
|
||||||
*
|
*
|
||||||
* @param groupId
|
* @param groupId of the group.
|
||||||
* @return
|
* @return group with details.
|
||||||
* @throws GroupManagementException
|
* @throws GroupManagementException
|
||||||
*/
|
*/
|
||||||
DeviceGroup getGroup(int groupId) throws GroupManagementException;
|
DeviceGroup getGroup(int groupId) throws GroupManagementException;
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* Get list of device groups matched with %groupName%
|
* Get all device groups in tenant.
|
||||||
*
|
*
|
||||||
* @param groupName of the groups.
|
* @return list of groups.
|
||||||
* @param username of user
|
|
||||||
* @return List of Groups that matches with the given DeviceGroup name.
|
|
||||||
* @throws GroupManagementException
|
* @throws GroupManagementException
|
||||||
*/
|
*/
|
||||||
List<DeviceGroup> findInGroups(String groupName, String username) throws GroupManagementException;
|
List<DeviceGroup> getGroups() throws GroupManagementException;
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* Get paginated device groups in tenant
|
* Get all device groups for user.
|
||||||
*
|
*
|
||||||
* @param startIndex for pagination.
|
* @param username of the user.
|
||||||
* @param rowCount for pagination.
|
* @return list of groups
|
||||||
* @return paginated list of groups
|
|
||||||
* @throws GroupManagementException
|
* @throws GroupManagementException
|
||||||
*/
|
*/
|
||||||
PaginationResult getGroups(int startIndex, int rowCount) throws GroupManagementException;
|
List<DeviceGroup> getGroups(String username) throws GroupManagementException;
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* Get paginated device groups in tenant
|
* Get device groups with pagination.
|
||||||
*
|
*
|
||||||
* @param username of user.
|
* @param paginationRequest to filter results
|
||||||
* @param startIndex for pagination.
|
* @return list of groups.
|
||||||
* @param rowCount for pagination.
|
|
||||||
* @return paginated list of groups
|
|
||||||
* @throws GroupManagementException
|
* @throws GroupManagementException
|
||||||
*/
|
*/
|
||||||
PaginationResult getGroups(String username, int startIndex, int rowCount) throws GroupManagementException;
|
PaginationResult getGroups(GroupPaginationRequest paginationRequest) throws GroupManagementException;
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Get device groups with pagination.
|
||||||
|
*
|
||||||
|
* @param username of the user.
|
||||||
|
* @param paginationRequest to filter results
|
||||||
|
* @return list of groups.
|
||||||
|
* @throws GroupManagementException
|
||||||
|
*/
|
||||||
|
PaginationResult getGroups(String username, GroupPaginationRequest paginationRequest) throws GroupManagementException;
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* Get all device group count in tenant
|
* Get all device group count in tenant
|
||||||
@ -123,15 +120,6 @@ public interface GroupManagementProviderService {
|
|||||||
*/
|
*/
|
||||||
int getGroupCount() throws GroupManagementException;
|
int getGroupCount() throws GroupManagementException;
|
||||||
|
|
||||||
/**
|
|
||||||
* Get device groups of user
|
|
||||||
*
|
|
||||||
* @param username of the user
|
|
||||||
* @return list of groups
|
|
||||||
* @throws GroupManagementException
|
|
||||||
*/
|
|
||||||
List<DeviceGroup> getGroups(String username) throws GroupManagementException;
|
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* Get device group count of user
|
* Get device group count of user
|
||||||
*
|
*
|
||||||
@ -142,154 +130,116 @@ public interface GroupManagementProviderService {
|
|||||||
int getGroupCount(String username) throws GroupManagementException;
|
int getGroupCount(String username) throws GroupManagementException;
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* Share device group with user specified by role
|
* Manage device group sharing with user with list of roles.
|
||||||
*
|
*
|
||||||
* @param username of the user
|
* @param username of the user
|
||||||
* @param groupName of the group
|
* @param groupId of the group
|
||||||
* @param owner of the group
|
* @param newRoles to be shared
|
||||||
* @param sharingRole to be shared
|
|
||||||
* @return is group shared
|
|
||||||
* @throws GroupManagementException UserDoesNotExistException
|
* @throws GroupManagementException UserDoesNotExistException
|
||||||
*/
|
*/
|
||||||
boolean shareGroup(String username, String groupName, String owner, String sharingRole)
|
void manageGroupSharing(int groupId, String username, List<String> newRoles)
|
||||||
throws GroupManagementException, UserDoesNotExistException;
|
throws GroupManagementException, UserDoesNotExistException, RoleDoesNotExistException;
|
||||||
|
|
||||||
/**
|
|
||||||
* Un share existing group sharing with user specified by role
|
|
||||||
*
|
|
||||||
* @param userName of the user
|
|
||||||
* @param groupName of the group
|
|
||||||
* @param owner of the group
|
|
||||||
* @param sharingRole to be un shared
|
|
||||||
* @return is group un shared
|
|
||||||
* @throws GroupManagementException UserDoesNotExistException
|
|
||||||
*/
|
|
||||||
boolean unshareGroup(String userName, String groupName, String owner, String sharingRole)
|
|
||||||
throws GroupManagementException, UserDoesNotExistException;
|
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* Add new sharing role for device group
|
* Add new sharing role for device group
|
||||||
*
|
*
|
||||||
* @param userName of the user
|
* @param userName of the user
|
||||||
* @param groupName of the group
|
* @param groupId of the group
|
||||||
* @param owner of the group
|
|
||||||
* @param roleName to add
|
* @param roleName to add
|
||||||
* @param permissions to bind with role
|
* @param permissions to bind with role
|
||||||
* @return is role added
|
* @return is role added
|
||||||
* @throws GroupManagementException
|
* @throws GroupManagementException
|
||||||
*/
|
*/
|
||||||
boolean addGroupSharingRole(String userName, String groupName, String owner, String roleName, String[] permissions)
|
boolean addGroupSharingRole(String userName, int groupId, String roleName, String[] permissions)
|
||||||
throws GroupManagementException;
|
throws GroupManagementException;
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* Remove existing sharing role for device group
|
* Remove existing sharing role for device group
|
||||||
*
|
*
|
||||||
* @param groupName of the group
|
* @param groupId of the group
|
||||||
* @param owner of the group
|
|
||||||
* @param roleName to remove
|
* @param roleName to remove
|
||||||
* @return is role removed
|
* @return is role removed
|
||||||
* @throws GroupManagementException
|
* @throws GroupManagementException
|
||||||
*/
|
*/
|
||||||
boolean removeGroupSharingRole(String groupName, String owner, String roleName) throws GroupManagementException;
|
boolean removeGroupSharingRole(int groupId, String roleName) throws GroupManagementException;
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* Get all sharing roles for device group
|
* Get all sharing roles for device group
|
||||||
*
|
*
|
||||||
* @param groupName of the group
|
* @param groupId of the group
|
||||||
* @param owner of the group
|
|
||||||
* @return list of roles
|
* @return list of roles
|
||||||
* @throws GroupManagementException
|
* @throws GroupManagementException
|
||||||
*/
|
*/
|
||||||
List<String> getRoles(String groupName, String owner) throws GroupManagementException;
|
List<String> getRoles(int groupId) throws GroupManagementException;
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* Get specific device group sharing roles for user
|
* Get specific device group sharing roles for user
|
||||||
*
|
*
|
||||||
* @param userName of the user
|
* @param userName of the user
|
||||||
* @param groupName of the group
|
* @param groupId of the group
|
||||||
* @param owner of the group
|
|
||||||
* @return list of roles
|
* @return list of roles
|
||||||
* @throws GroupManagementException UserDoesNotExistException
|
* @throws GroupManagementException UserDoesNotExistException
|
||||||
*/
|
*/
|
||||||
List<String> getRoles(String userName, String groupName, String owner)
|
List<String> getRoles(String userName, int groupId) throws GroupManagementException, UserDoesNotExistException;
|
||||||
throws GroupManagementException, UserDoesNotExistException;
|
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* Get device group users
|
* Get device group users
|
||||||
*
|
*
|
||||||
* @param groupName of the group
|
* @param groupId of the group
|
||||||
* @param owner of the group
|
|
||||||
* @return list of group users
|
* @return list of group users
|
||||||
* @throws GroupManagementException
|
* @throws GroupManagementException
|
||||||
*/
|
*/
|
||||||
List<GroupUser> getUsers(String groupName, String owner) throws GroupManagementException;
|
List<GroupUser> getUsers(int groupId) throws GroupManagementException;
|
||||||
|
|
||||||
/**
|
|
||||||
* Get all devices in device group.
|
|
||||||
*
|
|
||||||
* @param groupName of the group.
|
|
||||||
* @param owner of the group.
|
|
||||||
* @return list of group devices.
|
|
||||||
* @throws GroupManagementException
|
|
||||||
*/
|
|
||||||
List<Device> getDevices(String groupName, String owner) throws GroupManagementException;
|
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* Get all devices in device group as paginated result.
|
* Get all devices in device group as paginated result.
|
||||||
*
|
*
|
||||||
* @param groupName of the group.
|
* @param groupId of the group
|
||||||
* @param owner of the group.
|
|
||||||
* @param startIndex for pagination.
|
* @param startIndex for pagination.
|
||||||
* @param rowCount for pagination.
|
* @param rowCount for pagination.
|
||||||
* @return Paginated list of devices.
|
* @return list of devices in group.
|
||||||
* @throws GroupManagementException
|
* @throws GroupManagementException
|
||||||
*/
|
*/
|
||||||
PaginationResult getDevices(String groupName, String owner, int startIndex, int rowCount)
|
List<Device> getDevices(int groupId, int startIndex, int rowCount) throws GroupManagementException;
|
||||||
throws GroupManagementException;
|
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* This method is used to retrieve the device count of a given group.
|
* This method is used to retrieve the device count of a given group.
|
||||||
*
|
*
|
||||||
* @param groupName of the group.
|
* @param groupId of the group
|
||||||
* @param owner of the group.
|
|
||||||
* @return returns the device count.
|
* @return returns the device count.
|
||||||
* @throws GroupManagementException
|
* @throws GroupManagementException
|
||||||
*/
|
*/
|
||||||
int getDeviceCount(String groupName, String owner) throws GroupManagementException;
|
int getDeviceCount(int groupId) throws GroupManagementException;
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* Add device to device group.
|
* Add device to device group.
|
||||||
*
|
*
|
||||||
* @param deviceId of the device.
|
* @param groupId of the group.
|
||||||
* @param groupName of the group.
|
* @param deviceIdentifiers of devices.
|
||||||
* @param owner of the group.
|
|
||||||
* @return is device added.
|
|
||||||
* @throws GroupManagementException
|
* @throws GroupManagementException
|
||||||
*/
|
*/
|
||||||
boolean addDevice(DeviceIdentifier deviceId, String groupName, String owner) throws GroupManagementException;
|
void addDevices(int groupId, List<DeviceIdentifier> deviceIdentifiers) throws GroupManagementException,
|
||||||
|
DeviceNotFoundException;
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* Remove device from device group.
|
* Remove device from device group.
|
||||||
*
|
*
|
||||||
* @param deviceId of the device.
|
* @param groupId of the group.
|
||||||
* @param groupName of the group.
|
* @param deviceIdentifiers of devices.
|
||||||
* @param owner of the group.
|
|
||||||
* @return is device removed.
|
|
||||||
* @throws GroupManagementException
|
* @throws GroupManagementException
|
||||||
*/
|
*/
|
||||||
boolean removeDevice(DeviceIdentifier deviceId, String groupName, String owner) throws GroupManagementException;
|
void removeDevice(int groupId, List<DeviceIdentifier> deviceIdentifiers) throws GroupManagementException,
|
||||||
|
DeviceNotFoundException;
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* Get device group permissions of user.
|
* Get device group permissions of user.
|
||||||
*
|
*
|
||||||
* @param username of the user.
|
* @param username of the user.
|
||||||
* @param groupName of the group.
|
* @param groupId of the group
|
||||||
* @param owner of the group.
|
|
||||||
* @return array of permissions.
|
* @return array of permissions.
|
||||||
* @throws GroupManagementException UserDoesNotExistException
|
* @throws GroupManagementException UserDoesNotExistException
|
||||||
*/
|
*/
|
||||||
String[] getPermissions(String username, String groupName, String owner)
|
String[] getPermissions(String username, int groupId) throws GroupManagementException, UserDoesNotExistException;
|
||||||
throws GroupManagementException, UserDoesNotExistException;
|
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* Get device groups of user with permission.
|
* Get device groups of user with permission.
|
||||||
|
|||||||
@ -23,16 +23,23 @@ import org.apache.commons.logging.LogFactory;
|
|||||||
import org.wso2.carbon.CarbonConstants;
|
import org.wso2.carbon.CarbonConstants;
|
||||||
import org.wso2.carbon.context.CarbonContext;
|
import org.wso2.carbon.context.CarbonContext;
|
||||||
import org.wso2.carbon.context.PrivilegedCarbonContext;
|
import org.wso2.carbon.context.PrivilegedCarbonContext;
|
||||||
import org.wso2.carbon.device.mgt.common.*;
|
import org.wso2.carbon.device.mgt.common.Device;
|
||||||
|
import org.wso2.carbon.device.mgt.common.DeviceIdentifier;
|
||||||
|
import org.wso2.carbon.device.mgt.common.DeviceManagementException;
|
||||||
|
import org.wso2.carbon.device.mgt.common.DeviceNotFoundException;
|
||||||
|
import org.wso2.carbon.device.mgt.common.GroupPaginationRequest;
|
||||||
|
import org.wso2.carbon.device.mgt.common.PaginationResult;
|
||||||
|
import org.wso2.carbon.device.mgt.common.TransactionManagementException;
|
||||||
import org.wso2.carbon.device.mgt.common.group.mgt.DeviceGroup;
|
import org.wso2.carbon.device.mgt.common.group.mgt.DeviceGroup;
|
||||||
import org.wso2.carbon.device.mgt.common.group.mgt.GroupAlreadyExistException;
|
import org.wso2.carbon.device.mgt.common.group.mgt.GroupAlreadyExistException;
|
||||||
import org.wso2.carbon.device.mgt.common.group.mgt.GroupManagementException;
|
import org.wso2.carbon.device.mgt.common.group.mgt.GroupManagementException;
|
||||||
import org.wso2.carbon.device.mgt.common.group.mgt.GroupUser;
|
import org.wso2.carbon.device.mgt.common.group.mgt.GroupUser;
|
||||||
import org.wso2.carbon.device.mgt.core.group.mgt.DeviceGroupBuilder;
|
import org.wso2.carbon.device.mgt.common.group.mgt.RoleDoesNotExistException;
|
||||||
import org.wso2.carbon.device.mgt.core.group.mgt.dao.GroupDAO;
|
import org.wso2.carbon.device.mgt.core.group.mgt.dao.GroupDAO;
|
||||||
import org.wso2.carbon.device.mgt.core.group.mgt.dao.GroupManagementDAOException;
|
import org.wso2.carbon.device.mgt.core.group.mgt.dao.GroupManagementDAOException;
|
||||||
import org.wso2.carbon.device.mgt.core.group.mgt.dao.GroupManagementDAOFactory;
|
import org.wso2.carbon.device.mgt.core.group.mgt.dao.GroupManagementDAOFactory;
|
||||||
import org.wso2.carbon.device.mgt.core.internal.DeviceManagementDataHolder;
|
import org.wso2.carbon.device.mgt.core.internal.DeviceManagementDataHolder;
|
||||||
|
import org.wso2.carbon.device.mgt.core.util.DeviceManagerUtil;
|
||||||
import org.wso2.carbon.user.api.Permission;
|
import org.wso2.carbon.user.api.Permission;
|
||||||
import org.wso2.carbon.user.api.UserRealm;
|
import org.wso2.carbon.user.api.UserRealm;
|
||||||
import org.wso2.carbon.user.api.UserStoreException;
|
import org.wso2.carbon.user.api.UserStoreException;
|
||||||
@ -41,7 +48,11 @@ import org.wso2.carbon.user.core.multiplecredentials.UserDoesNotExistException;
|
|||||||
import org.wso2.carbon.user.core.util.UserCoreUtil;
|
import org.wso2.carbon.user.core.util.UserCoreUtil;
|
||||||
|
|
||||||
import java.sql.SQLException;
|
import java.sql.SQLException;
|
||||||
import java.util.*;
|
import java.util.ArrayList;
|
||||||
|
import java.util.Date;
|
||||||
|
import java.util.HashMap;
|
||||||
|
import java.util.List;
|
||||||
|
import java.util.Map;
|
||||||
|
|
||||||
public class GroupManagementProviderServiceImpl implements GroupManagementProviderService {
|
public class GroupManagementProviderServiceImpl implements GroupManagementProviderService {
|
||||||
|
|
||||||
@ -65,14 +76,13 @@ public class GroupManagementProviderServiceImpl implements GroupManagementProvid
|
|||||||
if (deviceGroup == null) {
|
if (deviceGroup == null) {
|
||||||
throw new GroupManagementException("DeviceGroup cannot be null.", new NullPointerException());
|
throw new GroupManagementException("DeviceGroup cannot be null.", new NullPointerException());
|
||||||
}
|
}
|
||||||
DeviceGroupBuilder groupBroker = new DeviceGroupBuilder(deviceGroup);
|
|
||||||
int tenantId = CarbonContext.getThreadLocalCarbonContext().getTenantId();
|
int tenantId = CarbonContext.getThreadLocalCarbonContext().getTenantId();
|
||||||
int groupId = -1;
|
int groupId = -1;
|
||||||
try {
|
try {
|
||||||
GroupManagementDAOFactory.beginTransaction();
|
GroupManagementDAOFactory.beginTransaction();
|
||||||
boolean nameIsExists = this.groupDAO.isGroupExist(deviceGroup.getName(), deviceGroup.getOwner(), tenantId);
|
DeviceGroup existingGroup = this.groupDAO.getGroup(deviceGroup.getName(), tenantId);
|
||||||
if (!nameIsExists) {
|
if (existingGroup == null) {
|
||||||
groupId = this.groupDAO.addGroup(groupBroker, tenantId);
|
groupId = this.groupDAO.addGroup(deviceGroup, tenantId);
|
||||||
GroupManagementDAOFactory.commitTransaction();
|
GroupManagementDAOFactory.commitTransaction();
|
||||||
} else {
|
} else {
|
||||||
throw new GroupAlreadyExistException("Group exist with name " + deviceGroup.getName());
|
throw new GroupAlreadyExistException("Group exist with name " + deviceGroup.getName());
|
||||||
@ -87,9 +97,9 @@ public class GroupManagementProviderServiceImpl implements GroupManagementProvid
|
|||||||
GroupManagementDAOFactory.closeConnection();
|
GroupManagementDAOFactory.closeConnection();
|
||||||
}
|
}
|
||||||
|
|
||||||
addGroupSharingRole(groupBroker.getOwner(), groupId, defaultRole, defaultPermissions);
|
addGroupSharingRole(deviceGroup.getOwner(), groupId, defaultRole, defaultPermissions);
|
||||||
if (log.isDebugEnabled()) {
|
if (log.isDebugEnabled()) {
|
||||||
log.debug("DeviceGroup added: " + groupBroker.getName());
|
log.debug("DeviceGroup added: " + deviceGroup.getName());
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -97,17 +107,22 @@ public class GroupManagementProviderServiceImpl implements GroupManagementProvid
|
|||||||
* {@inheritDoc}
|
* {@inheritDoc}
|
||||||
*/
|
*/
|
||||||
@Override
|
@Override
|
||||||
public void updateGroup(DeviceGroup deviceGroup, String oldGroupName, String oldOwner)
|
public void updateGroup(DeviceGroup deviceGroup, int groupId)
|
||||||
throws GroupManagementException {
|
throws GroupManagementException, GroupAlreadyExistException {
|
||||||
if (deviceGroup == null) {
|
if (deviceGroup == null) {
|
||||||
throw new GroupManagementException("DeviceGroup cannot be null.", new NullPointerException());
|
throw new GroupManagementException("DeviceGroup cannot be null.", new NullPointerException());
|
||||||
}
|
}
|
||||||
try {
|
try {
|
||||||
int tenantId = CarbonContext.getThreadLocalCarbonContext().getTenantId();
|
int tenantId = CarbonContext.getThreadLocalCarbonContext().getTenantId();
|
||||||
GroupManagementDAOFactory.beginTransaction();
|
GroupManagementDAOFactory.beginTransaction();
|
||||||
deviceGroup.setDateOfLastUpdate(new Date().getTime());
|
DeviceGroup existingGroup = this.groupDAO.getGroup(deviceGroup.getName(), tenantId);
|
||||||
this.groupDAO.updateGroup(deviceGroup, oldGroupName, oldOwner, tenantId);
|
if (existingGroup == null || existingGroup.getGroupId() == groupId) {
|
||||||
GroupManagementDAOFactory.commitTransaction();
|
deviceGroup.setDateOfLastUpdate(new Date().getTime());
|
||||||
|
this.groupDAO.updateGroup(deviceGroup, groupId, tenantId);
|
||||||
|
GroupManagementDAOFactory.commitTransaction();
|
||||||
|
} else {
|
||||||
|
throw new GroupAlreadyExistException("Group exist with name " + deviceGroup.getName());
|
||||||
|
}
|
||||||
} catch (GroupManagementDAOException e) {
|
} catch (GroupManagementDAOException e) {
|
||||||
GroupManagementDAOFactory.rollbackTransaction();
|
GroupManagementDAOFactory.rollbackTransaction();
|
||||||
throw new GroupManagementException("Error occurred while modifying deviceGroup " +
|
throw new GroupManagementException("Error occurred while modifying deviceGroup " +
|
||||||
@ -123,13 +138,13 @@ public class GroupManagementProviderServiceImpl implements GroupManagementProvid
|
|||||||
* {@inheritDoc}
|
* {@inheritDoc}
|
||||||
*/
|
*/
|
||||||
@Override
|
@Override
|
||||||
public boolean deleteGroup(String groupName, String owner) throws GroupManagementException {
|
public boolean deleteGroup(int groupId) throws GroupManagementException {
|
||||||
String roleName;
|
String roleName;
|
||||||
DeviceGroupBuilder deviceGroup = getGroupBuilder(groupName, owner);
|
DeviceGroup deviceGroup = getGroup(groupId);
|
||||||
if (deviceGroup == null) {
|
if (deviceGroup == null) {
|
||||||
return false;
|
return false;
|
||||||
}
|
}
|
||||||
List<String> groupRoles = getRoles(groupName, owner);
|
List<String> groupRoles = getRoles(groupId);
|
||||||
for (String role : groupRoles) {
|
for (String role : groupRoles) {
|
||||||
if (role != null) {
|
if (role != null) {
|
||||||
roleName = role.replace("Internal/group-" + deviceGroup.getGroupId() + "-", "");
|
roleName = role.replace("Internal/group-" + deviceGroup.getGroupId() + "-", "");
|
||||||
@ -138,7 +153,7 @@ public class GroupManagementProviderServiceImpl implements GroupManagementProvid
|
|||||||
}
|
}
|
||||||
try {
|
try {
|
||||||
GroupManagementDAOFactory.beginTransaction();
|
GroupManagementDAOFactory.beginTransaction();
|
||||||
this.groupDAO.deleteGroup(groupName, owner, CarbonContext.getThreadLocalCarbonContext().getTenantId());
|
this.groupDAO.deleteGroup(groupId, CarbonContext.getThreadLocalCarbonContext().getTenantId());
|
||||||
GroupManagementDAOFactory.commitTransaction();
|
GroupManagementDAOFactory.commitTransaction();
|
||||||
if (log.isDebugEnabled()) {
|
if (log.isDebugEnabled()) {
|
||||||
log.debug("DeviceGroup " + deviceGroup.getName() + " removed.");
|
log.debug("DeviceGroup " + deviceGroup.getName() + " removed.");
|
||||||
@ -146,8 +161,7 @@ public class GroupManagementProviderServiceImpl implements GroupManagementProvid
|
|||||||
return true;
|
return true;
|
||||||
} catch (GroupManagementDAOException e) {
|
} catch (GroupManagementDAOException e) {
|
||||||
GroupManagementDAOFactory.rollbackTransaction();
|
GroupManagementDAOFactory.rollbackTransaction();
|
||||||
throw new GroupManagementException("Error occurred while removing group " +
|
throw new GroupManagementException("Error occurred while removing group data.", e);
|
||||||
"'" + groupName + "' data.", e);
|
|
||||||
} catch (TransactionManagementException e) {
|
} catch (TransactionManagementException e) {
|
||||||
throw new GroupManagementException("Error occurred while initiating transaction.", e);
|
throw new GroupManagementException("Error occurred while initiating transaction.", e);
|
||||||
} finally {
|
} finally {
|
||||||
@ -159,37 +173,11 @@ public class GroupManagementProviderServiceImpl implements GroupManagementProvid
|
|||||||
* {@inheritDoc}
|
* {@inheritDoc}
|
||||||
*/
|
*/
|
||||||
@Override
|
@Override
|
||||||
public DeviceGroup getGroup(String groupName, String owner) throws GroupManagementException {
|
public DeviceGroup getGroup(int groupId) throws GroupManagementException {
|
||||||
return getGroupBuilder(groupName, owner).getGroup();
|
DeviceGroup deviceGroup;
|
||||||
}
|
|
||||||
|
|
||||||
@SuppressWarnings("Duplicates")
|
|
||||||
private DeviceGroupBuilder getGroupBuilder(String groupName, String owner) throws GroupManagementException {
|
|
||||||
DeviceGroupBuilder deviceGroupBuilder;
|
|
||||||
try {
|
try {
|
||||||
GroupManagementDAOFactory.openConnection();
|
GroupManagementDAOFactory.openConnection();
|
||||||
int tenantId = CarbonContext.getThreadLocalCarbonContext().getTenantId();
|
deviceGroup = this.groupDAO.getGroup(groupId, CarbonContext.getThreadLocalCarbonContext().getTenantId());
|
||||||
deviceGroupBuilder = this.groupDAO.getGroup(groupName, owner, tenantId);
|
|
||||||
} catch (GroupManagementDAOException e) {
|
|
||||||
throw new GroupManagementException("Error occurred while obtaining group '" + groupName + "'", e);
|
|
||||||
} catch (SQLException e) {
|
|
||||||
throw new GroupManagementException("Error occurred while opening a connection to the data source.", e);
|
|
||||||
} finally {
|
|
||||||
GroupManagementDAOFactory.closeConnection();
|
|
||||||
}
|
|
||||||
if (deviceGroupBuilder != null) {
|
|
||||||
deviceGroupBuilder.setUsers(this.getUsers(deviceGroupBuilder.getGroupId()));
|
|
||||||
deviceGroupBuilder.setRoles(this.getRoles(deviceGroupBuilder.getGroupId()));
|
|
||||||
}
|
|
||||||
return deviceGroupBuilder;
|
|
||||||
}
|
|
||||||
|
|
||||||
|
|
||||||
private DeviceGroupBuilder getGroupBuilder(int groupId) throws GroupManagementException {
|
|
||||||
DeviceGroupBuilder groupBroker;
|
|
||||||
try {
|
|
||||||
GroupManagementDAOFactory.openConnection();
|
|
||||||
groupBroker = this.groupDAO.getGroup(groupId, CarbonContext.getThreadLocalCarbonContext().getTenantId());
|
|
||||||
} catch (GroupManagementDAOException e) {
|
} catch (GroupManagementDAOException e) {
|
||||||
throw new GroupManagementException("Error occurred while obtaining group '" + groupId + "'", e);
|
throw new GroupManagementException("Error occurred while obtaining group '" + groupId + "'", e);
|
||||||
} catch (SQLException e) {
|
} catch (SQLException e) {
|
||||||
@ -197,59 +185,20 @@ public class GroupManagementProviderServiceImpl implements GroupManagementProvid
|
|||||||
} finally {
|
} finally {
|
||||||
GroupManagementDAOFactory.closeConnection();
|
GroupManagementDAOFactory.closeConnection();
|
||||||
}
|
}
|
||||||
if (groupBroker != null) {
|
if (deviceGroup != null) {
|
||||||
groupBroker.setUsers(this.getUsers(groupBroker.getGroupId()));
|
deviceGroup.setUsers(this.getUsers(groupId));
|
||||||
groupBroker.setRoles(this.getRoles(groupBroker.getGroupId()));
|
deviceGroup.setRoles(this.getRoles(groupId));
|
||||||
}
|
}
|
||||||
return groupBroker;
|
return deviceGroup;
|
||||||
}
|
}
|
||||||
|
|
||||||
/**
|
|
||||||
* {@inheritDoc}
|
|
||||||
*/
|
|
||||||
@Override
|
@Override
|
||||||
public DeviceGroup getGroup(int groupId) throws GroupManagementException {
|
public List<DeviceGroup> getGroups() throws GroupManagementException {
|
||||||
DeviceGroupBuilder groupBroker = this.getGroupBuilder(groupId);
|
List<DeviceGroup> deviceGroups = new ArrayList<>();
|
||||||
if (groupBroker != null) {
|
|
||||||
groupBroker.setUsers(this.getUsers(groupBroker.getGroupId()));
|
|
||||||
groupBroker.setRoles(this.getRoles(groupBroker.getGroupId()));
|
|
||||||
}
|
|
||||||
return groupBroker.getGroup();
|
|
||||||
}
|
|
||||||
|
|
||||||
/**
|
|
||||||
* {@inheritDoc}
|
|
||||||
*/
|
|
||||||
@Override
|
|
||||||
public List<DeviceGroup> findInGroups(String groupName, String owner) throws GroupManagementException {
|
|
||||||
List<DeviceGroupBuilder> deviceGroups = new ArrayList<>();
|
|
||||||
try {
|
try {
|
||||||
int tenantId = CarbonContext.getThreadLocalCarbonContext().getTenantId();
|
int tenantId = CarbonContext.getThreadLocalCarbonContext().getTenantId();
|
||||||
GroupManagementDAOFactory.openConnection();
|
GroupManagementDAOFactory.openConnection();
|
||||||
deviceGroups = this.groupDAO.findInGroups(groupName, tenantId);
|
deviceGroups = this.groupDAO.getGroups(tenantId);
|
||||||
} catch (GroupManagementDAOException e) {
|
|
||||||
throw new GroupManagementException("Error occurred while finding group " + groupName, e);
|
|
||||||
} catch (SQLException e) {
|
|
||||||
throw new GroupManagementException("Error occurred while opening a connection to the data source.", e);
|
|
||||||
} finally {
|
|
||||||
GroupManagementDAOFactory.closeConnection();
|
|
||||||
}
|
|
||||||
List<DeviceGroup> groupsWithData = new ArrayList<>();
|
|
||||||
for (DeviceGroupBuilder groupBroker : deviceGroups) {
|
|
||||||
groupBroker.setUsers(this.getUsers(groupBroker.getGroupId()));
|
|
||||||
groupBroker.setRoles(this.getRoles(groupBroker.getGroupId()));
|
|
||||||
groupsWithData.add(groupBroker.getGroup());
|
|
||||||
}
|
|
||||||
return groupsWithData;
|
|
||||||
}
|
|
||||||
|
|
||||||
@Override
|
|
||||||
public PaginationResult getGroups(int startIndex, int rowCount) throws GroupManagementException {
|
|
||||||
List<DeviceGroupBuilder> deviceGroups = new ArrayList<>();
|
|
||||||
try {
|
|
||||||
int tenantId = CarbonContext.getThreadLocalCarbonContext().getTenantId();
|
|
||||||
GroupManagementDAOFactory.openConnection();
|
|
||||||
deviceGroups = this.groupDAO.getGroups(startIndex, rowCount, tenantId);
|
|
||||||
} catch (GroupManagementDAOException e) {
|
} catch (GroupManagementDAOException e) {
|
||||||
throw new GroupManagementException("Error occurred while retrieving all groups in tenant", e);
|
throw new GroupManagementException("Error occurred while retrieving all groups in tenant", e);
|
||||||
} catch (SQLException e) {
|
} catch (SQLException e) {
|
||||||
@ -257,21 +206,45 @@ public class GroupManagementProviderServiceImpl implements GroupManagementProvid
|
|||||||
} finally {
|
} finally {
|
||||||
GroupManagementDAOFactory.closeConnection();
|
GroupManagementDAOFactory.closeConnection();
|
||||||
}
|
}
|
||||||
List<DeviceGroup> groupsWithData = new ArrayList<>();
|
for (DeviceGroup group : deviceGroups) {
|
||||||
for (DeviceGroupBuilder groupBroker : deviceGroups) {
|
group.setUsers(this.getUsers(group.getGroupId()));
|
||||||
groupBroker.setUsers(this.getUsers(groupBroker.getGroupId()));
|
group.setRoles(this.getRoles(group.getGroupId()));
|
||||||
groupBroker.setRoles(this.getRoles(groupBroker.getGroupId()));
|
|
||||||
groupsWithData.add(groupBroker.getGroup());
|
|
||||||
}
|
}
|
||||||
PaginationResult paginationResult = new PaginationResult();
|
return deviceGroups;
|
||||||
paginationResult.setRecordsTotal(getGroupCount());
|
|
||||||
paginationResult.setData(groupsWithData);
|
|
||||||
paginationResult.setRecordsFiltered(groupsWithData.size());
|
|
||||||
return paginationResult;
|
|
||||||
}
|
}
|
||||||
|
|
||||||
@Override
|
@Override
|
||||||
public PaginationResult getGroups(String username, int startIndex, int rowCount) throws GroupManagementException {
|
public PaginationResult getGroups(GroupPaginationRequest request) throws GroupManagementException {
|
||||||
|
request = DeviceManagerUtil.validateGroupListPageSize(request);
|
||||||
|
List<DeviceGroup> deviceGroups = getPlainDeviceGroups(request);
|
||||||
|
for (DeviceGroup group : deviceGroups) {
|
||||||
|
group.setUsers(this.getUsers(group.getGroupId()));
|
||||||
|
group.setRoles(this.getRoles(group.getGroupId()));
|
||||||
|
}
|
||||||
|
PaginationResult groupResult = new PaginationResult();
|
||||||
|
groupResult.setData(deviceGroups);
|
||||||
|
groupResult.setRecordsTotal(getGroupCount(request));
|
||||||
|
return groupResult;
|
||||||
|
}
|
||||||
|
|
||||||
|
private List<DeviceGroup> getPlainDeviceGroups(GroupPaginationRequest request) throws GroupManagementException {
|
||||||
|
List<DeviceGroup> deviceGroups = new ArrayList<>();
|
||||||
|
try {
|
||||||
|
int tenantId = CarbonContext.getThreadLocalCarbonContext().getTenantId();
|
||||||
|
GroupManagementDAOFactory.openConnection();
|
||||||
|
deviceGroups = this.groupDAO.getGroups(request, tenantId);
|
||||||
|
} catch (GroupManagementDAOException e) {
|
||||||
|
throw new GroupManagementException("Error occurred while retrieving all groups in tenant", e);
|
||||||
|
} catch (SQLException e) {
|
||||||
|
throw new GroupManagementException("Error occurred while opening a connection to the data source.", e);
|
||||||
|
} finally {
|
||||||
|
GroupManagementDAOFactory.closeConnection();
|
||||||
|
}
|
||||||
|
return deviceGroups;
|
||||||
|
}
|
||||||
|
|
||||||
|
@Override
|
||||||
|
public List<DeviceGroup> getGroups(String username) throws GroupManagementException {
|
||||||
Map<Integer, DeviceGroup> groups = new HashMap<>();
|
Map<Integer, DeviceGroup> groups = new HashMap<>();
|
||||||
UserStoreManager userStoreManager;
|
UserStoreManager userStoreManager;
|
||||||
try {
|
try {
|
||||||
@ -279,23 +252,60 @@ public class GroupManagementProviderServiceImpl implements GroupManagementProvid
|
|||||||
userStoreManager = DeviceManagementDataHolder.getInstance().getRealmService().getTenantUserRealm(tenantId)
|
userStoreManager = DeviceManagementDataHolder.getInstance().getRealmService().getTenantUserRealm(tenantId)
|
||||||
.getUserStoreManager();
|
.getUserStoreManager();
|
||||||
String[] roleList = userStoreManager.getRoleListOfUser(username);
|
String[] roleList = userStoreManager.getRoleListOfUser(username);
|
||||||
int index = 0;
|
|
||||||
for (String role : roleList) {
|
for (String role : roleList) {
|
||||||
if (role != null && role.contains("Internal/group-")) {
|
if (role != null && role.contains("Internal/group-")) {
|
||||||
DeviceGroupBuilder deviceGroupBuilder = extractNewGroupFromRole(groups, role);
|
DeviceGroup deviceGroup = checkAndExtractNonExistingGroup(groups, role);
|
||||||
if (deviceGroupBuilder != null && startIndex <= index++ && index <= rowCount) {
|
if (deviceGroup != null) {
|
||||||
groups.put(deviceGroupBuilder.getGroupId(), deviceGroupBuilder.getGroup());
|
groups.put(deviceGroup.getGroupId(), deviceGroup);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
} catch (UserStoreException e) {
|
} catch (UserStoreException e) {
|
||||||
throw new GroupManagementException("Error occurred while getting user store manager.", e);
|
throw new GroupManagementException("Error occurred while getting user store manager.", e);
|
||||||
}
|
}
|
||||||
PaginationResult paginationResult = new PaginationResult();
|
return new ArrayList<>(groups.values());
|
||||||
paginationResult.setRecordsTotal(getGroupCount());
|
}
|
||||||
paginationResult.setData(new ArrayList<>(groups.values()));
|
|
||||||
paginationResult.setRecordsFiltered(groups.size());
|
public PaginationResult getGroups(String currentUser, GroupPaginationRequest request) throws GroupManagementException {
|
||||||
return paginationResult;
|
request = DeviceManagerUtil.validateGroupListPageSize(request);
|
||||||
|
int startIndex = request.getStartIndex();
|
||||||
|
int count = request.getRowCount();
|
||||||
|
int index = 0;
|
||||||
|
request.setRowCount(0);
|
||||||
|
List<DeviceGroup> allMatchingGroups = this.getPlainDeviceGroups(request);
|
||||||
|
List<DeviceGroup> deviceGroups = new ArrayList<>();
|
||||||
|
try {
|
||||||
|
int tenantId = CarbonContext.getThreadLocalCarbonContext().getTenantId();
|
||||||
|
UserStoreManager userStoreManager = DeviceManagementDataHolder.getInstance().getRealmService().getTenantUserRealm(tenantId)
|
||||||
|
.getUserStoreManager();
|
||||||
|
String[] roleList = userStoreManager.getRoleListOfUser(currentUser);
|
||||||
|
List<Integer> groupIds = new ArrayList<>();
|
||||||
|
for (String role : roleList) {
|
||||||
|
if (role != null && role.contains("Internal/group-")) {
|
||||||
|
int groupId = Integer.parseInt(role.split("-")[1]);
|
||||||
|
if (!groupIds.contains(groupId)) {
|
||||||
|
groupIds.add(groupId);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
for (DeviceGroup group : allMatchingGroups) {
|
||||||
|
int groupId = group.getGroupId();
|
||||||
|
if (groupIds.contains(groupId)) {
|
||||||
|
if (startIndex <= index && index < count) {
|
||||||
|
group.setUsers(this.getUsers(groupId));
|
||||||
|
group.setRoles(this.getRoles(groupId));
|
||||||
|
deviceGroups.add(group);
|
||||||
|
}
|
||||||
|
index++;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
} catch (UserStoreException e) {
|
||||||
|
throw new GroupManagementException("Error occurred while getting user store manager.", e);
|
||||||
|
}
|
||||||
|
PaginationResult groupResult = new PaginationResult();
|
||||||
|
groupResult.setData(deviceGroups);
|
||||||
|
groupResult.setRecordsTotal(index);
|
||||||
|
return groupResult;
|
||||||
}
|
}
|
||||||
|
|
||||||
@Override
|
@Override
|
||||||
@ -313,29 +323,17 @@ public class GroupManagementProviderServiceImpl implements GroupManagementProvid
|
|||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
/**
|
private int getGroupCount(GroupPaginationRequest request) throws GroupManagementException {
|
||||||
* {@inheritDoc}
|
|
||||||
*/
|
|
||||||
@Override
|
|
||||||
public List<DeviceGroup> getGroups(String username) throws GroupManagementException {
|
|
||||||
UserStoreManager userStoreManager;
|
|
||||||
try {
|
try {
|
||||||
int tenantId = CarbonContext.getThreadLocalCarbonContext().getTenantId();
|
int tenantId = CarbonContext.getThreadLocalCarbonContext().getTenantId();
|
||||||
userStoreManager = DeviceManagementDataHolder.getInstance().getRealmService().getTenantUserRealm(tenantId)
|
GroupManagementDAOFactory.openConnection();
|
||||||
.getUserStoreManager();
|
return groupDAO.getGroupCount(request, tenantId);
|
||||||
String[] roleList = userStoreManager.getRoleListOfUser(username);
|
} catch (GroupManagementDAOException e) {
|
||||||
Map<Integer, DeviceGroup> groups = new HashMap<>();
|
throw new GroupManagementException("Error occurred while retrieving all groups in tenant", e);
|
||||||
for (String role : roleList) {
|
} catch (SQLException e) {
|
||||||
if (role != null && role.contains("Internal/group-")) {
|
throw new GroupManagementException("Error occurred while opening a connection to the data source.", e);
|
||||||
DeviceGroupBuilder deviceGroupBuilder = extractNewGroupFromRole(groups, role);
|
} finally {
|
||||||
if (deviceGroupBuilder != null) {
|
GroupManagementDAOFactory.closeConnection();
|
||||||
groups.put(deviceGroupBuilder.getGroupId(), deviceGroupBuilder.getGroup());
|
|
||||||
}
|
|
||||||
}
|
|
||||||
}
|
|
||||||
return new ArrayList<>(groups.values());
|
|
||||||
} catch (UserStoreException e) {
|
|
||||||
throw new GroupManagementException("Error occurred while getting user store manager.", e);
|
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -371,75 +369,57 @@ public class GroupManagementProviderServiceImpl implements GroupManagementProvid
|
|||||||
* {@inheritDoc}
|
* {@inheritDoc}
|
||||||
*/
|
*/
|
||||||
@Override
|
@Override
|
||||||
public boolean shareGroup(String username, String groupName, String owner, String sharingRole)
|
@SuppressWarnings("Duplicates")
|
||||||
throws GroupManagementException, UserDoesNotExistException {
|
public void manageGroupSharing(int groupId, String username, List<String> newRoles)
|
||||||
int groupId = getGroupId(groupName, owner);
|
throws GroupManagementException, UserDoesNotExistException, RoleDoesNotExistException {
|
||||||
return modifyGroupShare(username, groupId, sharingRole, true);
|
int tenantId = CarbonContext.getThreadLocalCarbonContext().getTenantId();
|
||||||
}
|
|
||||||
|
|
||||||
/**
|
|
||||||
* {@inheritDoc}
|
|
||||||
*/
|
|
||||||
@Override
|
|
||||||
public boolean unshareGroup(String username, String groupName, String owner, String sharingRole)
|
|
||||||
throws GroupManagementException, UserDoesNotExistException {
|
|
||||||
int groupId = getGroupId(groupName, owner);
|
|
||||||
return modifyGroupShare(username, groupId, sharingRole, false);
|
|
||||||
}
|
|
||||||
|
|
||||||
private boolean modifyGroupShare(String username, int groupId, String sharingRole,
|
|
||||||
boolean isAddNew)
|
|
||||||
throws GroupManagementException, UserDoesNotExistException {
|
|
||||||
if (groupId == -1) {
|
|
||||||
return false;
|
|
||||||
}
|
|
||||||
UserStoreManager userStoreManager;
|
UserStoreManager userStoreManager;
|
||||||
String[] roles = new String[1];
|
|
||||||
try {
|
try {
|
||||||
int tenantId = CarbonContext.getThreadLocalCarbonContext().getTenantId();
|
|
||||||
userStoreManager =
|
userStoreManager =
|
||||||
DeviceManagementDataHolder.getInstance().getRealmService().getTenantUserRealm(
|
DeviceManagementDataHolder.getInstance().getRealmService().getTenantUserRealm(
|
||||||
tenantId).getUserStoreManager();
|
tenantId).getUserStoreManager();
|
||||||
if (!userStoreManager.isExistingUser(username)) {
|
if (!userStoreManager.isExistingUser(username)) {
|
||||||
throw new UserDoesNotExistException("User not exists with name " + username);
|
throw new UserDoesNotExistException("User not exists with name " + username);
|
||||||
}
|
}
|
||||||
roles[0] = "Internal/group-" + groupId + "-" + sharingRole;
|
List<String> currentGroupRoles = getRoles(groupId);
|
||||||
List<String> currentRoles = getRoles(username, groupId);
|
List<String> currentUserRoles = getRoles(username, groupId);
|
||||||
if (isAddNew && !currentRoles.contains(sharingRole)) {
|
List<String> rolesToAdd = new ArrayList<>();
|
||||||
userStoreManager.updateRoleListOfUser(username, null, roles);
|
List<String> rolesToRemove = new ArrayList<>();
|
||||||
} else if (!isAddNew && currentRoles.contains(sharingRole)) {
|
String roleNamePrefix = "Internal/group-" + groupId + "-";
|
||||||
userStoreManager.updateRoleListOfUser(username, roles, null);
|
for (String role : newRoles) {
|
||||||
|
if (currentGroupRoles.contains(role)) {
|
||||||
|
if (!currentUserRoles.contains(role)) {
|
||||||
|
rolesToAdd.add(roleNamePrefix + role);
|
||||||
|
}
|
||||||
|
} else {
|
||||||
|
throw new RoleDoesNotExistException("Role '" + role + "' is not exists in requested group.");
|
||||||
|
}
|
||||||
}
|
}
|
||||||
return true;
|
for (String role : currentUserRoles) {
|
||||||
|
if (currentGroupRoles.contains(role)) {
|
||||||
|
if (!newRoles.contains(role)) {
|
||||||
|
rolesToRemove.add(roleNamePrefix + role);
|
||||||
|
}
|
||||||
|
} else {
|
||||||
|
throw new RoleDoesNotExistException("Role '" + role + "' is not exists in requested group.");
|
||||||
|
}
|
||||||
|
}
|
||||||
|
userStoreManager.updateRoleListOfUser(username,
|
||||||
|
rolesToRemove.toArray(new String[rolesToRemove.size()]),
|
||||||
|
rolesToAdd.toArray(new String[rolesToAdd.size()]));
|
||||||
} catch (UserStoreException e) {
|
} catch (UserStoreException e) {
|
||||||
if (e instanceof UserDoesNotExistException) {
|
if (e instanceof UserDoesNotExistException) {
|
||||||
throw (UserDoesNotExistException) e;
|
throw (UserDoesNotExistException) e;
|
||||||
}
|
}
|
||||||
throw new GroupManagementException("User store error in adding user " + username + " to group name:" +
|
throw new GroupManagementException("User store error in updating sharing roles.", e);
|
||||||
groupId, e);
|
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
private int getGroupId(String groupName, String owner) throws GroupManagementException {
|
|
||||||
DeviceGroupBuilder deviceGroupBuilder = getGroupBuilder(groupName, owner);
|
|
||||||
if (deviceGroupBuilder == null) {
|
|
||||||
return -1;
|
|
||||||
}
|
|
||||||
return deviceGroupBuilder.getGroupId();
|
|
||||||
}
|
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* {@inheritDoc}
|
* {@inheritDoc}
|
||||||
*/
|
*/
|
||||||
@Override
|
@Override
|
||||||
public boolean addGroupSharingRole(String userName, String groupName, String owner, String roleName,
|
public boolean addGroupSharingRole(String username, int groupId, String roleName, String[] permissions)
|
||||||
String[] permissions) throws GroupManagementException {
|
|
||||||
int groupId = getGroupId(groupName, owner);
|
|
||||||
return addGroupSharingRole(userName, groupId, roleName, permissions);
|
|
||||||
}
|
|
||||||
|
|
||||||
private boolean addGroupSharingRole(String username, int groupId, String roleName,
|
|
||||||
String[] permissions)
|
|
||||||
throws GroupManagementException {
|
throws GroupManagementException {
|
||||||
if (groupId == -1) {
|
if (groupId == -1) {
|
||||||
return false;
|
return false;
|
||||||
@ -469,14 +449,7 @@ public class GroupManagementProviderServiceImpl implements GroupManagementProvid
|
|||||||
* {@inheritDoc}
|
* {@inheritDoc}
|
||||||
*/
|
*/
|
||||||
@Override
|
@Override
|
||||||
public boolean removeGroupSharingRole(String groupName, String owner, String roleName)
|
public boolean removeGroupSharingRole(int groupId, String roleName) throws GroupManagementException {
|
||||||
throws GroupManagementException {
|
|
||||||
int groupId = getGroupId(groupName, owner);
|
|
||||||
return removeGroupSharingRole(groupId, roleName);
|
|
||||||
}
|
|
||||||
|
|
||||||
private boolean removeGroupSharingRole(int groupId, String roleName)
|
|
||||||
throws GroupManagementException {
|
|
||||||
if (groupId == -1) {
|
if (groupId == -1) {
|
||||||
return false;
|
return false;
|
||||||
}
|
}
|
||||||
@ -500,12 +473,7 @@ public class GroupManagementProviderServiceImpl implements GroupManagementProvid
|
|||||||
* {@inheritDoc}
|
* {@inheritDoc}
|
||||||
*/
|
*/
|
||||||
@Override
|
@Override
|
||||||
public List<String> getRoles(String groupName, String owner) throws GroupManagementException {
|
public List<String> getRoles(int groupId) throws GroupManagementException {
|
||||||
int groupId = getGroupId(groupName, owner);
|
|
||||||
return getRoles(groupId);
|
|
||||||
}
|
|
||||||
|
|
||||||
private List<String> getRoles(int groupId) throws GroupManagementException {
|
|
||||||
UserStoreManager userStoreManager;
|
UserStoreManager userStoreManager;
|
||||||
String[] roles;
|
String[] roles;
|
||||||
List<String> groupRoles;
|
List<String> groupRoles;
|
||||||
@ -532,13 +500,7 @@ public class GroupManagementProviderServiceImpl implements GroupManagementProvid
|
|||||||
* {@inheritDoc}
|
* {@inheritDoc}
|
||||||
*/
|
*/
|
||||||
@Override
|
@Override
|
||||||
public List<String> getRoles(String username, String groupName, String owner)
|
public List<String> getRoles(String username, int groupId)
|
||||||
throws GroupManagementException, UserDoesNotExistException {
|
|
||||||
int groupId = getGroupId(groupName, owner);
|
|
||||||
return getRoles(username, groupId);
|
|
||||||
}
|
|
||||||
|
|
||||||
private List<String> getRoles(String username, int groupId)
|
|
||||||
throws GroupManagementException, UserDoesNotExistException {
|
throws GroupManagementException, UserDoesNotExistException {
|
||||||
UserStoreManager userStoreManager;
|
UserStoreManager userStoreManager;
|
||||||
List<String> groupRoleList = new ArrayList<>();
|
List<String> groupRoleList = new ArrayList<>();
|
||||||
@ -569,11 +531,6 @@ public class GroupManagementProviderServiceImpl implements GroupManagementProvid
|
|||||||
* {@inheritDoc}
|
* {@inheritDoc}
|
||||||
*/
|
*/
|
||||||
@Override
|
@Override
|
||||||
public List<GroupUser> getUsers(String groupName, String owner) throws GroupManagementException {
|
|
||||||
int groupId = getGroupId(groupName, owner);
|
|
||||||
return getUsers(groupId);
|
|
||||||
}
|
|
||||||
|
|
||||||
public List<GroupUser> getUsers(int groupId) throws GroupManagementException {
|
public List<GroupUser> getUsers(int groupId) throws GroupManagementException {
|
||||||
UserStoreManager userStoreManager;
|
UserStoreManager userStoreManager;
|
||||||
Map<String, GroupUser> groupUserHashMap = new HashMap<>();
|
Map<String, GroupUser> groupUserHashMap = new HashMap<>();
|
||||||
@ -610,31 +567,13 @@ public class GroupManagementProviderServiceImpl implements GroupManagementProvid
|
|||||||
* {@inheritDoc}
|
* {@inheritDoc}
|
||||||
*/
|
*/
|
||||||
@Override
|
@Override
|
||||||
public List<Device> getDevices(String groupName, String owner) throws GroupManagementException {
|
public List<Device> getDevices(int groupId, int startIndex, int rowCount)
|
||||||
try {
|
|
||||||
int tenantId = CarbonContext.getThreadLocalCarbonContext().getTenantId();
|
|
||||||
GroupManagementDAOFactory.openConnection();
|
|
||||||
return this.groupDAO.getDevices(groupName, owner, tenantId);
|
|
||||||
} catch (GroupManagementDAOException e) {
|
|
||||||
throw new GroupManagementException("Error occurred while getting devices in group.", e);
|
|
||||||
} catch (SQLException e) {
|
|
||||||
throw new GroupManagementException("Error occurred while opening a connection to the data source.", e);
|
|
||||||
} finally {
|
|
||||||
GroupManagementDAOFactory.closeConnection();
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
/**
|
|
||||||
* {@inheritDoc}
|
|
||||||
*/
|
|
||||||
@Override
|
|
||||||
public PaginationResult getDevices(String groupName, String owner, int startIndex, int rowCount)
|
|
||||||
throws GroupManagementException {
|
throws GroupManagementException {
|
||||||
int tenantId = CarbonContext.getThreadLocalCarbonContext().getTenantId();
|
int tenantId = CarbonContext.getThreadLocalCarbonContext().getTenantId();
|
||||||
List<Device> devices;
|
List<Device> devices;
|
||||||
try {
|
try {
|
||||||
GroupManagementDAOFactory.openConnection();
|
GroupManagementDAOFactory.openConnection();
|
||||||
devices = this.groupDAO.getDevices(groupName, owner, startIndex, rowCount, tenantId);
|
devices = this.groupDAO.getDevices(groupId, startIndex, rowCount, tenantId);
|
||||||
} catch (GroupManagementDAOException e) {
|
} catch (GroupManagementDAOException e) {
|
||||||
throw new GroupManagementException("Error occurred while getting devices in group.", e);
|
throw new GroupManagementException("Error occurred while getting devices in group.", e);
|
||||||
} catch (SQLException e) {
|
} catch (SQLException e) {
|
||||||
@ -642,24 +581,17 @@ public class GroupManagementProviderServiceImpl implements GroupManagementProvid
|
|||||||
} finally {
|
} finally {
|
||||||
GroupManagementDAOFactory.closeConnection();
|
GroupManagementDAOFactory.closeConnection();
|
||||||
}
|
}
|
||||||
PaginationResult paginationResult = new PaginationResult();
|
return devices;
|
||||||
paginationResult.setRecordsTotal(getDeviceCount(groupName, owner));
|
|
||||||
paginationResult.setData(devices);
|
|
||||||
paginationResult.setRecordsFiltered(devices.size());
|
|
||||||
return paginationResult;
|
|
||||||
}
|
}
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* {@inheritDoc}
|
* {@inheritDoc}
|
||||||
*/
|
*/
|
||||||
@Override
|
@Override
|
||||||
public int getDeviceCount(String groupName, String owner) throws GroupManagementException {
|
public int getDeviceCount(int groupId) throws GroupManagementException {
|
||||||
try {
|
try {
|
||||||
int count;
|
|
||||||
GroupManagementDAOFactory.openConnection();
|
GroupManagementDAOFactory.openConnection();
|
||||||
count = groupDAO.getDeviceCount(groupName, owner,
|
return groupDAO.getDeviceCount(groupId, CarbonContext.getThreadLocalCarbonContext().getTenantId());
|
||||||
CarbonContext.getThreadLocalCarbonContext().getTenantId());
|
|
||||||
return count;
|
|
||||||
} catch (GroupManagementDAOException e) {
|
} catch (GroupManagementDAOException e) {
|
||||||
throw new GroupManagementException("Error occurred while retrieving all groups in tenant", e);
|
throw new GroupManagementException("Error occurred while retrieving all groups in tenant", e);
|
||||||
} catch (SQLException e) {
|
} catch (SQLException e) {
|
||||||
@ -673,46 +605,51 @@ public class GroupManagementProviderServiceImpl implements GroupManagementProvid
|
|||||||
* {@inheritDoc}
|
* {@inheritDoc}
|
||||||
*/
|
*/
|
||||||
@Override
|
@Override
|
||||||
public boolean addDevice(DeviceIdentifier deviceIdentifier, String groupName, String owner)
|
public void addDevices(int groupId, List<DeviceIdentifier> deviceIdentifiers)
|
||||||
throws GroupManagementException {
|
throws GroupManagementException, DeviceNotFoundException {
|
||||||
Device device;
|
Device device;
|
||||||
try {
|
try {
|
||||||
device = DeviceManagementDataHolder.getInstance().getDeviceManagementProvider().getDevice(deviceIdentifier);
|
|
||||||
if (device == null) {
|
|
||||||
return false;
|
|
||||||
}
|
|
||||||
int tenantId = CarbonContext.getThreadLocalCarbonContext().getTenantId();
|
int tenantId = CarbonContext.getThreadLocalCarbonContext().getTenantId();
|
||||||
GroupManagementDAOFactory.beginTransaction();
|
GroupManagementDAOFactory.beginTransaction();
|
||||||
this.groupDAO.addDevice(groupName, owner, device.getId(), tenantId);
|
for (DeviceIdentifier deviceIdentifier : deviceIdentifiers){
|
||||||
|
device = DeviceManagementDataHolder.getInstance().getDeviceManagementProvider().getDevice(deviceIdentifier);
|
||||||
|
if (device == null) {
|
||||||
|
throw new DeviceNotFoundException("Device not found for id '" + deviceIdentifier.getId() + "'");
|
||||||
|
}
|
||||||
|
if (!this.groupDAO.isDeviceMappedToGroup(groupId, device.getId(), tenantId)){
|
||||||
|
this.groupDAO.addDevice(groupId, device.getId(), tenantId);
|
||||||
|
}
|
||||||
|
}
|
||||||
GroupManagementDAOFactory.commitTransaction();
|
GroupManagementDAOFactory.commitTransaction();
|
||||||
} catch (DeviceManagementException e) {
|
} catch (DeviceManagementException e) {
|
||||||
throw new GroupManagementException("Error occurred while retrieving device.", e);
|
throw new GroupManagementException("Error occurred while retrieving device.", e);
|
||||||
} catch (GroupManagementDAOException e) {
|
} catch (GroupManagementDAOException e) {
|
||||||
GroupManagementDAOFactory.rollbackTransaction();
|
GroupManagementDAOFactory.rollbackTransaction();
|
||||||
throw new GroupManagementException("Error occurred while adding device to group '" + groupName + "'.", e);
|
throw new GroupManagementException("Error occurred while adding device to group.", e);
|
||||||
} catch (TransactionManagementException e) {
|
} catch (TransactionManagementException e) {
|
||||||
throw new GroupManagementException("Error occurred while initiating transaction.", e);
|
throw new GroupManagementException("Error occurred while initiating transaction.", e);
|
||||||
} finally {
|
} finally {
|
||||||
GroupManagementDAOFactory.closeConnection();
|
GroupManagementDAOFactory.closeConnection();
|
||||||
}
|
}
|
||||||
return true;
|
|
||||||
}
|
}
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* {@inheritDoc}
|
* {@inheritDoc}
|
||||||
*/
|
*/
|
||||||
@Override
|
@Override
|
||||||
public boolean removeDevice(DeviceIdentifier deviceIdentifier, String groupName, String owner)
|
public void removeDevice(int groupId, List<DeviceIdentifier> deviceIdentifiers)
|
||||||
throws GroupManagementException {
|
throws GroupManagementException, DeviceNotFoundException {
|
||||||
Device device;
|
Device device;
|
||||||
try {
|
try {
|
||||||
device = DeviceManagementDataHolder.getInstance().getDeviceManagementProvider().getDevice(deviceIdentifier);
|
|
||||||
if (device == null) {
|
|
||||||
return false;
|
|
||||||
}
|
|
||||||
int tenantId = CarbonContext.getThreadLocalCarbonContext().getTenantId();
|
int tenantId = CarbonContext.getThreadLocalCarbonContext().getTenantId();
|
||||||
GroupManagementDAOFactory.beginTransaction();
|
GroupManagementDAOFactory.beginTransaction();
|
||||||
this.groupDAO.removeDevice(groupName, owner, device.getId(), tenantId);
|
for (DeviceIdentifier deviceIdentifier : deviceIdentifiers){
|
||||||
|
device = DeviceManagementDataHolder.getInstance().getDeviceManagementProvider().getDevice(deviceIdentifier);
|
||||||
|
if (device == null) {
|
||||||
|
throw new DeviceNotFoundException("Device not found for id '" + deviceIdentifier.getId() + "'");
|
||||||
|
}
|
||||||
|
this.groupDAO.removeDevice(groupId, device.getId(), tenantId);
|
||||||
|
}
|
||||||
GroupManagementDAOFactory.commitTransaction();
|
GroupManagementDAOFactory.commitTransaction();
|
||||||
} catch (DeviceManagementException e) {
|
} catch (DeviceManagementException e) {
|
||||||
throw new GroupManagementException("Error occurred while retrieving device.", e);
|
throw new GroupManagementException("Error occurred while retrieving device.", e);
|
||||||
@ -720,21 +657,19 @@ public class GroupManagementProviderServiceImpl implements GroupManagementProvid
|
|||||||
throw new GroupManagementException("Error occurred while initiating transaction.", e);
|
throw new GroupManagementException("Error occurred while initiating transaction.", e);
|
||||||
} catch (GroupManagementDAOException e) {
|
} catch (GroupManagementDAOException e) {
|
||||||
GroupManagementDAOFactory.rollbackTransaction();
|
GroupManagementDAOFactory.rollbackTransaction();
|
||||||
throw new GroupManagementException("Error occurred while adding device to group '" + groupName + "'.", e);
|
throw new GroupManagementException("Error occurred while adding device to group.", e);
|
||||||
} finally {
|
} finally {
|
||||||
GroupManagementDAOFactory.closeConnection();
|
GroupManagementDAOFactory.closeConnection();
|
||||||
}
|
}
|
||||||
return true;
|
|
||||||
}
|
}
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* {@inheritDoc}
|
* {@inheritDoc}
|
||||||
*/
|
*/
|
||||||
@Override
|
@Override
|
||||||
public String[] getPermissions(String username, String groupName, String owner)
|
public String[] getPermissions(String username, int groupId)
|
||||||
throws GroupManagementException, UserDoesNotExistException {
|
throws GroupManagementException, UserDoesNotExistException {
|
||||||
UserRealm userRealm;
|
UserRealm userRealm;
|
||||||
int groupId = getGroupId(groupName, owner);
|
|
||||||
List<String> roles = getRoles(username, groupId);
|
List<String> roles = getRoles(username, groupId);
|
||||||
int tenantId = CarbonContext.getThreadLocalCarbonContext().getTenantId();
|
int tenantId = CarbonContext.getThreadLocalCarbonContext().getTenantId();
|
||||||
try {
|
try {
|
||||||
@ -774,9 +709,9 @@ public class GroupManagementProviderServiceImpl implements GroupManagementProvid
|
|||||||
for (String role : roles) {
|
for (String role : roles) {
|
||||||
if (role != null && role.contains("Internal/group-") && userRealm.getAuthorizationManager()
|
if (role != null && role.contains("Internal/group-") && userRealm.getAuthorizationManager()
|
||||||
.isRoleAuthorized(role, permission, CarbonConstants.UI_PERMISSION_ACTION)) {
|
.isRoleAuthorized(role, permission, CarbonConstants.UI_PERMISSION_ACTION)) {
|
||||||
DeviceGroupBuilder deviceGroupBuilder = extractNewGroupFromRole(groups, role);
|
DeviceGroup group = checkAndExtractNonExistingGroup(groups, role);
|
||||||
if (deviceGroupBuilder != null) {
|
if (group != null) {
|
||||||
groups.put(deviceGroupBuilder.getGroupId(), deviceGroupBuilder.getGroup());
|
groups.put(group.getGroupId(), group);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
@ -789,15 +724,11 @@ public class GroupManagementProviderServiceImpl implements GroupManagementProvid
|
|||||||
@Override
|
@Override
|
||||||
public List<DeviceGroup> getGroups(DeviceIdentifier deviceIdentifier) throws GroupManagementException {
|
public List<DeviceGroup> getGroups(DeviceIdentifier deviceIdentifier) throws GroupManagementException {
|
||||||
DeviceManagementProviderService managementProviderService = new DeviceManagementProviderServiceImpl();
|
DeviceManagementProviderService managementProviderService = new DeviceManagementProviderServiceImpl();
|
||||||
List<DeviceGroup> deviceGroups = new ArrayList<>();
|
|
||||||
try {
|
try {
|
||||||
Device device = managementProviderService.getDevice(deviceIdentifier);
|
Device device = managementProviderService.getDevice(deviceIdentifier);
|
||||||
GroupManagementDAOFactory.openConnection();
|
GroupManagementDAOFactory.openConnection();
|
||||||
List<DeviceGroupBuilder> builders = groupDAO.getGroups(device.getId(),
|
return groupDAO.getGroups(device.getId(),
|
||||||
PrivilegedCarbonContext.getThreadLocalCarbonContext().getTenantId());
|
PrivilegedCarbonContext.getThreadLocalCarbonContext().getTenantId());
|
||||||
for (DeviceGroupBuilder d : builders){
|
|
||||||
deviceGroups.add(d.getGroup());
|
|
||||||
}
|
|
||||||
} catch (DeviceManagementException e) {
|
} catch (DeviceManagementException e) {
|
||||||
throw new GroupManagementException("Error occurred while retrieving the device details.", e);
|
throw new GroupManagementException("Error occurred while retrieving the device details.", e);
|
||||||
} catch (GroupManagementDAOException e) {
|
} catch (GroupManagementDAOException e) {
|
||||||
@ -807,15 +738,22 @@ public class GroupManagementProviderServiceImpl implements GroupManagementProvid
|
|||||||
} finally {
|
} finally {
|
||||||
GroupManagementDAOFactory.closeConnection();
|
GroupManagementDAOFactory.closeConnection();
|
||||||
}
|
}
|
||||||
return deviceGroups;
|
|
||||||
}
|
}
|
||||||
|
|
||||||
private DeviceGroupBuilder extractNewGroupFromRole(Map<Integer, DeviceGroup> groups, String role)
|
/**
|
||||||
|
* This method returns group belongs to particular role, if it is not existed in groups map.
|
||||||
|
*
|
||||||
|
* @param groups existing groups map.
|
||||||
|
* @param role group related role which needs to evaluate.
|
||||||
|
* @return device group if it is not existing in the groups map.
|
||||||
|
* @throws GroupManagementException
|
||||||
|
*/
|
||||||
|
private DeviceGroup checkAndExtractNonExistingGroup(Map<Integer, DeviceGroup> groups, String role)
|
||||||
throws GroupManagementException {
|
throws GroupManagementException {
|
||||||
try {
|
try {
|
||||||
int groupId = Integer.parseInt(role.split("-")[1]);
|
int groupId = Integer.parseInt(role.split("-")[1]);
|
||||||
if (!groups.containsKey(groupId)) {
|
if (!groups.containsKey(groupId)) {
|
||||||
return getGroupBuilder(groupId);
|
return getGroup(groupId);
|
||||||
}
|
}
|
||||||
} catch (NumberFormatException e) {
|
} catch (NumberFormatException e) {
|
||||||
log.error("Unable to extract groupId from role " + role, e);
|
log.error("Unable to extract groupId from role " + role, e);
|
||||||
|
|||||||
@ -22,6 +22,7 @@ import org.apache.commons.logging.LogFactory;
|
|||||||
import org.w3c.dom.Document;
|
import org.w3c.dom.Document;
|
||||||
import org.wso2.carbon.base.MultitenantConstants;
|
import org.wso2.carbon.base.MultitenantConstants;
|
||||||
import org.wso2.carbon.device.mgt.common.*;
|
import org.wso2.carbon.device.mgt.common.*;
|
||||||
|
import org.wso2.carbon.device.mgt.common.group.mgt.GroupManagementException;
|
||||||
import org.wso2.carbon.device.mgt.common.notification.mgt.NotificationManagementException;
|
import org.wso2.carbon.device.mgt.common.notification.mgt.NotificationManagementException;
|
||||||
import org.wso2.carbon.device.mgt.common.operation.mgt.OperationManagementException;
|
import org.wso2.carbon.device.mgt.common.operation.mgt.OperationManagementException;
|
||||||
import org.wso2.carbon.device.mgt.core.config.DeviceConfigurationManager;
|
import org.wso2.carbon.device.mgt.core.config.DeviceConfigurationManager;
|
||||||
@ -327,6 +328,22 @@ public final class DeviceManagerUtil {
|
|||||||
return paginationRequest;
|
return paginationRequest;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
public static GroupPaginationRequest validateGroupListPageSize(GroupPaginationRequest paginationRequest) throws
|
||||||
|
GroupManagementException {
|
||||||
|
if (paginationRequest.getRowCount() == 0) {
|
||||||
|
DeviceManagementConfig deviceManagementConfig = DeviceConfigurationManager.getInstance()
|
||||||
|
.getDeviceManagementConfig();
|
||||||
|
if (deviceManagementConfig != null) {
|
||||||
|
paginationRequest.setRowCount(deviceManagementConfig.getPaginationConfiguration()
|
||||||
|
.getDeviceListPageSize());
|
||||||
|
} else {
|
||||||
|
throw new GroupManagementException("Device-Mgt configuration has not initialized. Please check the " +
|
||||||
|
"cdm-config.xml file.");
|
||||||
|
}
|
||||||
|
}
|
||||||
|
return paginationRequest;
|
||||||
|
}
|
||||||
|
|
||||||
public static int validateDeviceListPageSize(int limit) throws DeviceManagementException {
|
public static int validateDeviceListPageSize(int limit) throws DeviceManagementException {
|
||||||
if (limit == 0) {
|
if (limit == 0) {
|
||||||
DeviceManagementConfig deviceManagementConfig = DeviceConfigurationManager.getInstance().
|
DeviceManagementConfig deviceManagementConfig = DeviceConfigurationManager.getInstance().
|
||||||
|
|||||||
@ -20,7 +20,6 @@ import org.wso2.carbon.device.mgt.common.EnrolmentInfo;
|
|||||||
import org.wso2.carbon.device.mgt.common.app.mgt.Application;
|
import org.wso2.carbon.device.mgt.common.app.mgt.Application;
|
||||||
import org.wso2.carbon.device.mgt.common.group.mgt.DeviceGroup;
|
import org.wso2.carbon.device.mgt.common.group.mgt.DeviceGroup;
|
||||||
import org.wso2.carbon.device.mgt.core.dto.DeviceType;
|
import org.wso2.carbon.device.mgt.core.dto.DeviceType;
|
||||||
import org.wso2.carbon.device.mgt.core.group.mgt.DeviceGroupBuilder;
|
|
||||||
|
|
||||||
import java.util.Date;
|
import java.util.Date;
|
||||||
import java.util.Properties;
|
import java.util.Properties;
|
||||||
@ -82,7 +81,6 @@ public class TestDataHolder {
|
|||||||
deviceGroup.setDateOfCreation(new Date().getTime());
|
deviceGroup.setDateOfCreation(new Date().getTime());
|
||||||
deviceGroup.setDateOfLastUpdate(new Date().getTime());
|
deviceGroup.setDateOfLastUpdate(new Date().getTime());
|
||||||
deviceGroup.setOwner(OWNER);
|
deviceGroup.setOwner(OWNER);
|
||||||
DeviceGroupBuilder broker = new DeviceGroupBuilder(deviceGroup);
|
return deviceGroup;
|
||||||
return broker.getGroup();
|
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|||||||
@ -24,11 +24,11 @@ import org.testng.Assert;
|
|||||||
import org.testng.annotations.BeforeClass;
|
import org.testng.annotations.BeforeClass;
|
||||||
import org.testng.annotations.Test;
|
import org.testng.annotations.Test;
|
||||||
import org.wso2.carbon.device.mgt.common.Device;
|
import org.wso2.carbon.device.mgt.common.Device;
|
||||||
|
import org.wso2.carbon.device.mgt.common.GroupPaginationRequest;
|
||||||
import org.wso2.carbon.device.mgt.common.TransactionManagementException;
|
import org.wso2.carbon.device.mgt.common.TransactionManagementException;
|
||||||
import org.wso2.carbon.device.mgt.common.group.mgt.DeviceGroup;
|
import org.wso2.carbon.device.mgt.common.group.mgt.DeviceGroup;
|
||||||
import org.wso2.carbon.device.mgt.core.common.BaseDeviceManagementTest;
|
import org.wso2.carbon.device.mgt.core.common.BaseDeviceManagementTest;
|
||||||
import org.wso2.carbon.device.mgt.core.common.TestDataHolder;
|
import org.wso2.carbon.device.mgt.core.common.TestDataHolder;
|
||||||
import org.wso2.carbon.device.mgt.core.group.mgt.DeviceGroupBuilder;
|
|
||||||
import org.wso2.carbon.device.mgt.core.group.mgt.dao.GroupDAO;
|
import org.wso2.carbon.device.mgt.core.group.mgt.dao.GroupDAO;
|
||||||
import org.wso2.carbon.device.mgt.core.group.mgt.dao.GroupManagementDAOException;
|
import org.wso2.carbon.device.mgt.core.group.mgt.dao.GroupManagementDAOException;
|
||||||
import org.wso2.carbon.device.mgt.core.group.mgt.dao.GroupManagementDAOFactory;
|
import org.wso2.carbon.device.mgt.core.group.mgt.dao.GroupManagementDAOFactory;
|
||||||
@ -40,7 +40,7 @@ import java.util.List;
|
|||||||
public class GroupPersistTests extends BaseDeviceManagementTest {
|
public class GroupPersistTests extends BaseDeviceManagementTest {
|
||||||
|
|
||||||
private static final Log log = LogFactory.getLog(GroupPersistTests.class);
|
private static final Log log = LogFactory.getLog(GroupPersistTests.class);
|
||||||
int groupId = -1;
|
private int groupId = -1;
|
||||||
private GroupDAO groupDAO;
|
private GroupDAO groupDAO;
|
||||||
|
|
||||||
@BeforeClass
|
@BeforeClass
|
||||||
@ -57,7 +57,7 @@ public class GroupPersistTests extends BaseDeviceManagementTest {
|
|||||||
GroupManagementDAOFactory.beginTransaction();
|
GroupManagementDAOFactory.beginTransaction();
|
||||||
groupId = groupDAO.addGroup(deviceGroup, TestDataHolder.SUPER_TENANT_ID);
|
groupId = groupDAO.addGroup(deviceGroup, TestDataHolder.SUPER_TENANT_ID);
|
||||||
GroupManagementDAOFactory.commitTransaction();
|
GroupManagementDAOFactory.commitTransaction();
|
||||||
log.debug("Group added to database.");
|
log.debug("Group added to database. ID: " + groupId);
|
||||||
} catch (GroupManagementDAOException e) {
|
} catch (GroupManagementDAOException e) {
|
||||||
GroupManagementDAOFactory.rollbackTransaction();
|
GroupManagementDAOFactory.rollbackTransaction();
|
||||||
String msg = "Error occurred while adding device type '" + deviceGroup.getName() + "'.";
|
String msg = "Error occurred while adding device type '" + deviceGroup.getName() + "'.";
|
||||||
@ -76,32 +76,14 @@ public class GroupPersistTests extends BaseDeviceManagementTest {
|
|||||||
log.debug("Group name: " + group.getName());
|
log.debug("Group name: " + group.getName());
|
||||||
}
|
}
|
||||||
|
|
||||||
@Test(dependsOnMethods = {"testAddGroupTest"})
|
|
||||||
public void findGroupTest() {
|
|
||||||
try {
|
|
||||||
GroupManagementDAOFactory.openConnection();
|
|
||||||
List<DeviceGroupBuilder> groups = groupDAO.findInGroups("Test", TestDataHolder.SUPER_TENANT_ID);
|
|
||||||
Assert.assertNotEquals(groups.size(), 0, "No groups found");
|
|
||||||
Assert.assertNotNull(groups.get(0), "Group is null");
|
|
||||||
log.debug("Group found: " + groups.get(0).getName());
|
|
||||||
} catch (GroupManagementDAOException e) {
|
|
||||||
String msg = "Error occurred while find group by name.";
|
|
||||||
log.error(msg, e);
|
|
||||||
Assert.fail(msg, e);
|
|
||||||
} catch (SQLException e) {
|
|
||||||
String msg = "Error occurred while opening a connection to the data source.";
|
|
||||||
log.error(msg, e);
|
|
||||||
Assert.fail(msg, e);
|
|
||||||
} finally {
|
|
||||||
GroupManagementDAOFactory.closeConnection();
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
@Test(dependsOnMethods = {"testAddGroupTest"})
|
@Test(dependsOnMethods = {"testAddGroupTest"})
|
||||||
public void getGroupTest() {
|
public void getGroupTest() {
|
||||||
try {
|
try {
|
||||||
GroupManagementDAOFactory.openConnection();
|
GroupManagementDAOFactory.openConnection();
|
||||||
List<DeviceGroupBuilder> groups = groupDAO.getGroups(0, 100, TestDataHolder.SUPER_TENANT_ID);
|
GroupPaginationRequest request = new GroupPaginationRequest(0, 10);
|
||||||
|
request.setGroupName(null);
|
||||||
|
request.setOwner(null);
|
||||||
|
List<DeviceGroup> groups = groupDAO.getGroups(request, TestDataHolder.SUPER_TENANT_ID);
|
||||||
Assert.assertNotEquals(groups.size(), 0, "No groups found");
|
Assert.assertNotEquals(groups.size(), 0, "No groups found");
|
||||||
Assert.assertNotNull(groups.get(0), "Group is null");
|
Assert.assertNotNull(groups.get(0), "Group is null");
|
||||||
log.debug("No of Groups found: " + groups.size());
|
log.debug("No of Groups found: " + groups.size());
|
||||||
@ -122,10 +104,10 @@ public class GroupPersistTests extends BaseDeviceManagementTest {
|
|||||||
public void addDeviceToGroupTest() {
|
public void addDeviceToGroupTest() {
|
||||||
Device initialTestDevice = TestDataHolder.initialTestDevice;
|
Device initialTestDevice = TestDataHolder.initialTestDevice;
|
||||||
DeviceGroup deviceGroup = getGroupById(groupId);
|
DeviceGroup deviceGroup = getGroupById(groupId);
|
||||||
|
Assert.assertNotNull(deviceGroup, "Group is null");
|
||||||
try {
|
try {
|
||||||
GroupManagementDAOFactory.beginTransaction();
|
GroupManagementDAOFactory.beginTransaction();
|
||||||
groupDAO.addDevice(deviceGroup.getName(), deviceGroup.getOwner(), initialTestDevice.getId(),
|
groupDAO.addDevice(deviceGroup.getGroupId(), initialTestDevice.getId(), TestDataHolder.SUPER_TENANT_ID);
|
||||||
TestDataHolder.SUPER_TENANT_ID);
|
|
||||||
GroupManagementDAOFactory.commitTransaction();
|
GroupManagementDAOFactory.commitTransaction();
|
||||||
log.debug("Device added to group.");
|
log.debug("Device added to group.");
|
||||||
} catch (GroupManagementDAOException e) {
|
} catch (GroupManagementDAOException e) {
|
||||||
@ -143,8 +125,7 @@ public class GroupPersistTests extends BaseDeviceManagementTest {
|
|||||||
|
|
||||||
try {
|
try {
|
||||||
GroupManagementDAOFactory.openConnection();
|
GroupManagementDAOFactory.openConnection();
|
||||||
List<Device> groupedDevices = groupDAO.getDevices(deviceGroup.getName(), deviceGroup.getOwner(),
|
List<Device> groupedDevices = groupDAO.getDevices(deviceGroup.getGroupId(), 0, 10, TestDataHolder.SUPER_TENANT_ID);
|
||||||
TestDataHolder.SUPER_TENANT_ID);
|
|
||||||
Assert.assertNotEquals(groupedDevices.size(), 0, "No device found");
|
Assert.assertNotEquals(groupedDevices.size(), 0, "No device found");
|
||||||
Assert.assertNotNull(groupedDevices.get(0), "Device is null");
|
Assert.assertNotNull(groupedDevices.get(0), "Device is null");
|
||||||
Assert.assertEquals(groupedDevices.get(0).getId(), initialTestDevice.getId(), "Device ids not matched");
|
Assert.assertEquals(groupedDevices.get(0).getId(), initialTestDevice.getId(), "Device ids not matched");
|
||||||
@ -165,9 +146,10 @@ public class GroupPersistTests extends BaseDeviceManagementTest {
|
|||||||
public void removeDeviceFromGroupTest() {
|
public void removeDeviceFromGroupTest() {
|
||||||
Device initialTestDevice = TestDataHolder.initialTestDevice;
|
Device initialTestDevice = TestDataHolder.initialTestDevice;
|
||||||
DeviceGroup deviceGroup = getGroupById(groupId);
|
DeviceGroup deviceGroup = getGroupById(groupId);
|
||||||
|
Assert.assertNotNull(deviceGroup, "Group is null");
|
||||||
try {
|
try {
|
||||||
GroupManagementDAOFactory.beginTransaction();
|
GroupManagementDAOFactory.beginTransaction();
|
||||||
groupDAO.removeDevice(deviceGroup.getName(), deviceGroup.getOwner(), initialTestDevice.getId(), TestDataHolder.SUPER_TENANT_ID);
|
groupDAO.removeDevice(deviceGroup.getGroupId(), initialTestDevice.getId(), TestDataHolder.SUPER_TENANT_ID);
|
||||||
GroupManagementDAOFactory.commitTransaction();
|
GroupManagementDAOFactory.commitTransaction();
|
||||||
log.debug("Device added to group.");
|
log.debug("Device added to group.");
|
||||||
} catch (GroupManagementDAOException e) {
|
} catch (GroupManagementDAOException e) {
|
||||||
@ -196,8 +178,7 @@ public class GroupPersistTests extends BaseDeviceManagementTest {
|
|||||||
group.setDescription(desc);
|
group.setDescription(desc);
|
||||||
try {
|
try {
|
||||||
GroupManagementDAOFactory.beginTransaction();
|
GroupManagementDAOFactory.beginTransaction();
|
||||||
groupDAO.updateGroup(group, TestDataHolder.generateDummyGroupData().getName(),
|
groupDAO.updateGroup(group, groupId, TestDataHolder.SUPER_TENANT_ID);
|
||||||
TestDataHolder.generateDummyGroupData().getOwner(), TestDataHolder.SUPER_TENANT_ID);
|
|
||||||
GroupManagementDAOFactory.commitTransaction();
|
GroupManagementDAOFactory.commitTransaction();
|
||||||
log.debug("Group updated");
|
log.debug("Group updated");
|
||||||
} catch (GroupManagementDAOException e) {
|
} catch (GroupManagementDAOException e) {
|
||||||
@ -226,7 +207,7 @@ public class GroupPersistTests extends BaseDeviceManagementTest {
|
|||||||
try {
|
try {
|
||||||
Assert.assertNotNull(group, "Group is null");
|
Assert.assertNotNull(group, "Group is null");
|
||||||
GroupManagementDAOFactory.beginTransaction();
|
GroupManagementDAOFactory.beginTransaction();
|
||||||
groupDAO.deleteGroup(group.getName(), group.getOwner(), TestDataHolder.SUPER_TENANT_ID);
|
groupDAO.deleteGroup(group.getGroupId(), TestDataHolder.SUPER_TENANT_ID);
|
||||||
GroupManagementDAOFactory.commitTransaction();
|
GroupManagementDAOFactory.commitTransaction();
|
||||||
log.debug("Group deleted");
|
log.debug("Group deleted");
|
||||||
} catch (GroupManagementDAOException e) {
|
} catch (GroupManagementDAOException e) {
|
||||||
@ -245,7 +226,7 @@ public class GroupPersistTests extends BaseDeviceManagementTest {
|
|||||||
Assert.assertNull(group, "Group is not deleted");
|
Assert.assertNull(group, "Group is not deleted");
|
||||||
}
|
}
|
||||||
|
|
||||||
public DeviceGroup getGroupById(int groupId) {
|
private DeviceGroup getGroupById(int groupId) {
|
||||||
try {
|
try {
|
||||||
GroupManagementDAOFactory.openConnection();
|
GroupManagementDAOFactory.openConnection();
|
||||||
return groupDAO.getGroup(groupId, TestDataHolder.SUPER_TENANT_ID);
|
return groupDAO.getGroup(groupId, TestDataHolder.SUPER_TENANT_ID);
|
||||||
|
|||||||
@ -26,8 +26,7 @@ var groupModule = {};
|
|||||||
var utility = require("/app/modules/utility.js").utility;
|
var utility = require("/app/modules/utility.js").utility;
|
||||||
var serviceInvokers = require("/app/modules/oauth/token-protected-service-invokers.js")["invokers"];
|
var serviceInvokers = require("/app/modules/oauth/token-protected-service-invokers.js")["invokers"];
|
||||||
|
|
||||||
var groupServiceEndpoint = devicemgtProps["httpsURL"] +
|
var deviceServiceEndpoint = devicemgtProps["httpsURL"] + "/api/device-mgt/v1.0";
|
||||||
devicemgtProps["backendRestEndpoints"]["deviceMgt"] + "/groups";
|
|
||||||
|
|
||||||
var user = session.get(constants.USER_SESSION_KEY);
|
var user = session.get(constants.USER_SESSION_KEY);
|
||||||
|
|
||||||
@ -36,26 +35,26 @@ var groupModule = {};
|
|||||||
groupModule.getGroupCount = function () {
|
groupModule.getGroupCount = function () {
|
||||||
var permissions = userModule.getUIPermissions();
|
var permissions = userModule.getUIPermissions();
|
||||||
if (permissions.LIST_ALL_GROUPS) {
|
if (permissions.LIST_ALL_GROUPS) {
|
||||||
endPoint = groupServiceEndpoint + "/count";
|
endPoint = deviceServiceEndpoint + "/admin/groups/count";
|
||||||
} else if (permissions.LIST_GROUPS) {
|
} else if (permissions.LIST_GROUPS) {
|
||||||
endPoint = groupServiceEndpoint + "/user/" + user.username + "/count";
|
endPoint = deviceServiceEndpoint + "/groups/count";
|
||||||
} else {
|
} else {
|
||||||
log.error("Access denied for user: " + carbonUser.username);
|
log.error("Access denied for user: " + carbonUser.username);
|
||||||
return -1;
|
return -1;
|
||||||
}
|
}
|
||||||
return serviceInvokers.XMLHttp.get(
|
return serviceInvokers.XMLHttp.get(
|
||||||
endPoint, function (responsePayload) {
|
endPoint, function (responsePayload) {
|
||||||
return responsePayload;
|
return responsePayload["responseText"];
|
||||||
},
|
},
|
||||||
function (responsePayload) {
|
function (responsePayload) {
|
||||||
log.error(responsePayload);
|
log.error(responsePayload["responseText"]);
|
||||||
return -1;
|
return -1;
|
||||||
}
|
}
|
||||||
);
|
);
|
||||||
};
|
};
|
||||||
|
|
||||||
groupModule.getGroupDeviceCount = function (groupName, owner) {
|
groupModule.getGroupDeviceCount = function (groupName, owner) {
|
||||||
endPoint = groupServiceEndpoint + "/owner/" + owner + "/name/" + groupName + "/devices/count";
|
endPoint = deviceServiceEndpoint + "/owner/" + owner + "/name/" + groupName + "/devices/count";
|
||||||
return serviceInvokers.XMLHttp.get(
|
return serviceInvokers.XMLHttp.get(
|
||||||
endPoint, function (responsePayload) {
|
endPoint, function (responsePayload) {
|
||||||
return responsePayload;
|
return responsePayload;
|
||||||
@ -68,7 +67,7 @@ var groupModule = {};
|
|||||||
};
|
};
|
||||||
|
|
||||||
groupModule.getGroupDevices = function (groupName, owner) {
|
groupModule.getGroupDevices = function (groupName, owner) {
|
||||||
endPoint = groupServiceEndpoint + "/owner/" + owner + "/name/" + groupName + "/devices";
|
endPoint = deviceServiceEndpoint + "/owner/" + owner + "/name/" + groupName + "/devices";
|
||||||
return serviceInvokers.XMLHttp.get(
|
return serviceInvokers.XMLHttp.get(
|
||||||
endPoint, function (responsePayload) {
|
endPoint, function (responsePayload) {
|
||||||
return responsePayload;
|
return responsePayload;
|
||||||
|
|||||||
@ -485,10 +485,10 @@ var userModule = function () {
|
|||||||
if (publicMethods.isAuthorized("/permission/admin/device-mgt/user/devices/list")) {
|
if (publicMethods.isAuthorized("/permission/admin/device-mgt/user/devices/list")) {
|
||||||
permissions["LIST_OWN_DEVICES"] = true;
|
permissions["LIST_OWN_DEVICES"] = true;
|
||||||
}
|
}
|
||||||
if (publicMethods.isAuthorized("/permission/admin/device-mgt/groups/list")) {
|
if (publicMethods.isAuthorized("/permission/admin/device-mgt/admin/groups/view")) {
|
||||||
permissions["LIST_ALL_GROUPS"] = true;
|
permissions["LIST_ALL_GROUPS"] = true;
|
||||||
}
|
}
|
||||||
if (publicMethods.isAuthorized("/permission/admin/device-mgt/user/groups/list")) {
|
if (publicMethods.isAuthorized("/permission/admin/device-mgt/groups/view")) {
|
||||||
permissions["LIST_GROUPS"] = true;
|
permissions["LIST_GROUPS"] = true;
|
||||||
}
|
}
|
||||||
if (publicMethods.isAuthorized("/permission/admin/device-mgt/users/list")) {
|
if (publicMethods.isAuthorized("/permission/admin/device-mgt/users/list")) {
|
||||||
|
|||||||
@ -36,9 +36,7 @@ function onRequest() {
|
|||||||
viewModel.permissions = permissions;
|
viewModel.permissions = permissions;
|
||||||
viewModel.enrollmentURL = devicemgtProps.enrollmentURL;
|
viewModel.enrollmentURL = devicemgtProps.enrollmentURL;
|
||||||
viewModel.deviceCount = deviceModule.getDevicesCount();
|
viewModel.deviceCount = deviceModule.getDevicesCount();
|
||||||
//TODO: Enable Group Management Service API on CDMF
|
viewModel.groupCount = groupModule.getGroupCount();
|
||||||
//page.group_count = groupModule.getGroupCount();
|
|
||||||
viewModel.groupCount = -1;
|
|
||||||
viewModel.userCount = userModule.getUsersCount();
|
viewModel.userCount = userModule.getUsersCount();
|
||||||
viewModel.policyCount = policyModule.getPoliciesCount();
|
viewModel.policyCount = policyModule.getPoliciesCount();
|
||||||
viewModel.roleCount = userModule.getRolesCount();
|
viewModel.roleCount = userModule.getRolesCount();
|
||||||
|
|||||||
@ -22,7 +22,7 @@ package org.wso2.carbon.policy.mgt.common;
|
|||||||
import io.swagger.annotations.ApiModel;
|
import io.swagger.annotations.ApiModel;
|
||||||
import io.swagger.annotations.ApiModelProperty;
|
import io.swagger.annotations.ApiModelProperty;
|
||||||
|
|
||||||
@ApiModel(value = "DeviceGroupWrapper", description = "This class carries all information related to device groups")
|
@ApiModel(value = "DeviceGroupWrapper", description = "This class carries information related to device groups expect users and devices.")
|
||||||
public class DeviceGroupWrapper {
|
public class DeviceGroupWrapper {
|
||||||
|
|
||||||
@ApiModelProperty(name = "id", value = "Id of the group", required = true)
|
@ApiModelProperty(name = "id", value = "Id of the group", required = true)
|
||||||
|
|||||||
@ -231,7 +231,7 @@ public class PolicyManagerUtil {
|
|||||||
public static Map<Integer, DeviceGroup> convertDeviceGroupMap(List<DeviceGroup> deviceGroups) {
|
public static Map<Integer, DeviceGroup> convertDeviceGroupMap(List<DeviceGroup> deviceGroups) {
|
||||||
Map<Integer, DeviceGroup> groupMap = new HashMap<>();
|
Map<Integer, DeviceGroup> groupMap = new HashMap<>();
|
||||||
for (DeviceGroup dg: deviceGroups){
|
for (DeviceGroup dg: deviceGroups){
|
||||||
groupMap.put(dg.getId(), dg);
|
groupMap.put(dg.getGroupId(), dg);
|
||||||
}
|
}
|
||||||
return groupMap;
|
return groupMap;
|
||||||
}
|
}
|
||||||
|
|||||||
@ -82,6 +82,7 @@
|
|||||||
<!-- Default Page size configuration for paginated DM APIs-->
|
<!-- Default Page size configuration for paginated DM APIs-->
|
||||||
<PaginationConfiguration>
|
<PaginationConfiguration>
|
||||||
<DeviceListPageSize>20</DeviceListPageSize>
|
<DeviceListPageSize>20</DeviceListPageSize>
|
||||||
|
<GroupListPageSize>20</GroupListPageSize>
|
||||||
<NotificationListPageSize>20</NotificationListPageSize>
|
<NotificationListPageSize>20</NotificationListPageSize>
|
||||||
<ActivityListPageSize>20</ActivityListPageSize>
|
<ActivityListPageSize>20</ActivityListPageSize>
|
||||||
<OperationListPageSize>20</OperationListPageSize>
|
<OperationListPageSize>20</OperationListPageSize>
|
||||||
|
|||||||
Loading…
Reference in New Issue
Block a user