|
||||||||||
PREV CLASS NEXT CLASS | FRAMES NO FRAMES | |||||||||
SUMMARY: NESTED | FIELD | CONSTR | METHOD | DETAIL: FIELD | CONSTR | METHOD |
public interface PermissionService
This service provides operations for evaluating permissions and querying for permission data.
A permission is the ability to perform an action. All permissions have a permission template. Both permissions and permission templates are uniquely identified by a namespace code plus a name. The permission template defines the course-grained permission and specifies what additional permission details need to be collected on permissions that use that template. For example, a permission template might have a name of "Initiate Document" which requires a permission detail specifying the document type that can be initiated. A permission created from the "Initiate Document" template would define the name of the specific Document Type that can be initiated as a permission detail.
The isAuthorized and isAuthorizedByTemplateName operations on this service are used to execute authorization checks for a principal against a permission. Permissions are always assigned to roles (never directly to a principal or group). A particular principal will be authorized for a given permission if the permission evaluates to true (according to the permission evaluation logic and based on any supplied permission details) and that principal is assigned to a role which has been granted the permission.
The actual logic for how permission evaluation logic is defined and executed is dependent upon the permission service implementation. However, it will typically be associated with the permission template used on the permission.
This service provides read-only operations. For write operations, see
PermissionUpdateService
.
PermissionUpdateService
Method Summary | |
---|---|
List<PermissionTemplate> |
getAllTemplates()
Return all Permission Templates. |
List<Permission> |
getAuthorizedPermissions(String principalId,
String namespaceCode,
String permissionName,
AttributeSet permissionDetails,
AttributeSet qualification)
Returns permissions (with their details) that are granted to the principal given the passed qualification. |
List<Permission> |
getAuthorizedPermissionsByTemplateName(String principalId,
String namespaceCode,
String permissionTemplateName,
AttributeSet permissionDetails,
AttributeSet qualification)
Returns permissions (with their details) that are granted to the principal given the passed qualification. |
Permission |
getPermission(String permissionId)
Get the permission object with the given ID. |
List<PermissionAssigneeInfo> |
getPermissionAssignees(String namespaceCode,
String permissionName,
AttributeSet permissionDetails,
AttributeSet qualification)
Get the list of principals/groups who have a given permission. |
List<PermissionAssigneeInfo> |
getPermissionAssigneesForTemplateName(String namespaceCode,
String permissionTemplateName,
AttributeSet permissionDetails,
AttributeSet qualification)
Get the list of principals/groups who have a given permission that match the given permission template and permission details. |
String |
getPermissionDetailLabel(String permissionId,
String kimTypeId,
String attributeName)
Returns the label of the permission detail for the given permissionId, kimType and attributeName. |
List<Permission> |
getPermissionsByName(String namespaceCode,
String permissionName)
Return the permission object for the given unique combination of namespace, component and permission name. |
List<Permission> |
getPermissionsByNameIncludingInactive(String namespaceCode,
String permissionName)
Return the permission object for the given unique combination of namespace, component and permission name. |
List<Permission> |
getPermissionsByTemplateName(String namespaceCode,
String permissionTemplateName)
Return the permission object for the given unique combination of namespace, component and permission template name. |
PermissionTemplate |
getPermissionTemplate(String permissionTemplateId)
Return the Permission Template given the Template ID. |
PermissionTemplate |
getPermissionTemplateByName(String namespaceCode,
String permissionTemplateName)
Return the Permission Template given the Template Name and Namespace Code. |
List<String> |
getRoleIdsForPermission(String namespaceCode,
String permissionName,
AttributeSet permissionDetails)
Get the role IDs for the given permission. |
List<String> |
getRoleIdsForPermissionId(String permissionId)
Get the role IDs for the given permission. |
List<String> |
getRoleIdsForPermissions(List<KimPermissionInfo> permissions)
Get the role IDs for the given list of permissions. |
boolean |
hasPermission(String principalId,
String namespaceCode,
String permissionName,
AttributeSet permissionDetails)
Checks whether the principal has been granted a permission matching the given details without taking role qualifiers into account. |
boolean |
hasPermissionByTemplateName(String principalId,
String namespaceCode,
String permissionTemplateName,
AttributeSet permissionDetails)
Checks whether the principal has been granted a permission matching the given details without taking role qualifiers into account. |
boolean |
isAuthorized(String principalId,
String namespaceCode,
String permissionName,
AttributeSet permissionDetails,
AttributeSet qualification)
Checks whether the given qualified permission is granted to the principal given the passed roleQualification. |
boolean |
isAuthorizedByTemplateName(String principalId,
String namespaceCode,
String permissionTemplateName,
AttributeSet permissionDetails,
AttributeSet qualification)
Checks whether the given qualified permission is granted to the principal given the passed roleQualification. |
boolean |
isPermissionDefined(String namespaceCode,
String permissionName,
AttributeSet permissionDetails)
Returns true if the given permission is defined on any Roles. |
boolean |
isPermissionDefinedForTemplateName(String namespaceCode,
String permissionTemplateName,
AttributeSet permissionDetails)
Returns true if the given permission template is defined on any Roles. |
List<Permission> |
lookupPermissions(Map<String,String> searchCriteria,
boolean unbounded)
Search for permissions using arbitrary search criteria. |
Method Detail |
---|
boolean hasPermission(String principalId, String namespaceCode, String permissionName, AttributeSet permissionDetails)
boolean isAuthorized(String principalId, String namespaceCode, String permissionName, AttributeSet permissionDetails, AttributeSet qualification)
hasPermission(String, String, String, AttributeSet)
.
Each role assigned to the principal is checked for qualifications. If a qualifier
exists on the principal's membership in that role, that is checked first through
the role's type service. Once it is determined that the principal has the role
in the given context (qualification), the permissions are examined.
Each permission is checked against the permissionDetails. The PermissionTypeService
is called for each permission with the given permissionName to see if the
permissionDetails matches its details.
boolean hasPermissionByTemplateName(String principalId, String namespaceCode, String permissionTemplateName, AttributeSet permissionDetails)
boolean isAuthorizedByTemplateName(String principalId, String namespaceCode, String permissionTemplateName, AttributeSet permissionDetails, AttributeSet qualification)
hasPermission(String, String, String, AttributeSet)
.
Each role assigned to the principal is checked for qualifications. If a qualifier
exists on the principal's membership in that role, that is checked first through
the role's type service. Once it is determined that the principal has the role
in the given context (qualification), the permissions are examined.
Each permission is checked against the permissionDetails. The PermissionTypeService
is called for each permission with the given permissionName to see if the
permissionDetails matches its details.
List<PermissionAssigneeInfo> getPermissionAssignees(String namespaceCode, String permissionName, AttributeSet permissionDetails, AttributeSet qualification)
List<PermissionAssigneeInfo> getPermissionAssigneesForTemplateName(String namespaceCode, String permissionTemplateName, AttributeSet permissionDetails, AttributeSet qualification)
boolean isPermissionDefined(String namespaceCode, String permissionName, AttributeSet permissionDetails)
boolean isPermissionDefinedForTemplateName(String namespaceCode, String permissionTemplateName, AttributeSet permissionDetails)
List<Permission> getAuthorizedPermissions(String principalId, String namespaceCode, String permissionName, AttributeSet permissionDetails, AttributeSet qualification)
List<Permission> getAuthorizedPermissionsByTemplateName(String principalId, String namespaceCode, String permissionTemplateName, AttributeSet permissionDetails, AttributeSet qualification)
Permission getPermission(String permissionId)
List<Permission> getPermissionsByTemplateName(String namespaceCode, String permissionTemplateName)
List<Permission> getPermissionsByName(String namespaceCode, String permissionName)
PermissionTemplate getPermissionTemplate(String permissionTemplateId)
permissionTemplateId
-
PermissionTemplate getPermissionTemplateByName(String namespaceCode, String permissionTemplateName)
namespaceCode,
- permissionTemplateName
List<PermissionTemplate> getAllTemplates()
namespaceCode,
- permissionTemplateName
List<Permission> lookupPermissions(Map<String,String> searchCriteria, boolean unbounded)
List<String> getRoleIdsForPermission(String namespaceCode, String permissionName, AttributeSet permissionDetails)
List<String> getRoleIdsForPermissions(List<KimPermissionInfo> permissions)
String getPermissionDetailLabel(String permissionId, String kimTypeId, String attributeName)
List<String> getRoleIdsForPermissionId(String permissionId)
List<Permission> getPermissionsByNameIncludingInactive(String namespaceCode, String permissionName)
|
||||||||||
PREV CLASS NEXT CLASS | FRAMES NO FRAMES | |||||||||
SUMMARY: NESTED | FIELD | CONSTR | METHOD | DETAIL: FIELD | CONSTR | METHOD |