You are here

Implementation and services

The following key services are involved in access control:
  • PersonService
  • AuthorityService
  • PermissionService
  • OwnableService

The PersonService is responsible for obtaining a reference to the Person node for a given user name. It also creates, deletes and updates personal information. The AuthorityService are responsible for managing authorities. The PermissionService is responsible for managing ACLs and ACEs and for checking if a user has been assigned a permission for a particular node. The OwnableService manages object ownership and is used in evaluation the dynamic ROLE_OWNER authority.

The protection of public services methods is implemented using Spring method interceptors defined as part of the related ACEGI 0.8.2 security package. The SkyVault implementation adds new implementations of the ACEGI interfaces AccessDecisionVoter and AfterInvocationProvider, which support the configuration elements that have already been described (for example, ACL_NODE.<#>.<permission>). These extension classes make use of the key services.