User, Group and Access Rights Administration user-group-and-access-rights-administration
Enabling access to a CRX repository involves several topics:
-
Access Rights - the concepts of how they are defined and evaluated
-
User Administration - managing the individual accounts used for access
-
Group Administration - simplify user management by forming groups
-
Access Right Management - defining policies that control how these users and groups can access resources
The basic elements are:
User Accounts CRX authenticates access by identifying, and verifying, a user (by that a person, or another application) according to details held in the user account.
In CRX every user account is a node in the workspace. A CRX user account has the following properties:
-
It represents one user of CRX.
-
It holds a user name and password.
-
Is applicable for that workspace.
-
It cannot have sub-users. For hierarchical access rights you should use groups.
-
You can specify access rights for the user account.
However, to simplify management we recommend that (in the majority of cases) you assign access rights to group accounts. Assigning access rights for each individual user quickly becomes very difficult to manage (the exceptions are certain system users when only one or two instances exist).
Group Accounts Group accounts are collections of users and/or other groups. These are used to simplify management as a change in the access rights assigned to a group is automatically applied to all users in that group. A user does not have to belong to any group, but often belongs to several.
In CRX a group has the following properties:
-
It represents a group of users with common access rights. For example, authors or developers.
-
Is applicable for that workspace.
-
It can have members; these can be individual users or other groups.
-
Hierarchical grouping can be achieved with member relationships. You cannot place a group directly below another group in the repository.
-
You can define the access rights for all group members.
Access Rights CRX uses Access Rights to control access to specific areas of the repository.
This is done by assigning privileges to either allow or deny access to a resource (node or path) in the repository. As various privileges can be assigned, they must be evaluated to determine which combination is applicable for the current request.
CRX allows you to configure the access rights for both user and groups accounts. The same basic principles of evaluation are then applied to both.
How Access Rights are Evaluated how-access-rights-are-evaluated
Subjects and Principals subjects-and-principals
CRX uses two key concepts when evaluating access rights:
-
A principal is an entity that carries access rights. Principals include:
-
A user account.
-
A group account
If a user account belongs to one, or more, groups it is also associated with each of those group principals.
-
-
A subject is used to represent the source of a request.
It is used to consolidate the access rights applicable for that request. These are taken from:
-
The user principal
The rights that you assign directly to the user account.
-
All groups principals associated with that user
All rights assigned to any of the groups that the user belongs to.
The result is then used to allow or deny access to the resource requested.
-
Compiling the list of Access Rights for a Subject compiling-the-list-of-access-rights-for-a-subject
In CRX the subject is dependent on:
- the user principal
- all the group principals that are associated with that user
The list of access rights applicable for the subject is constructed from:
- the rights that you assign directly to the user account
- plus all rights assigned to any of the groups that the user belongs to
- CRX does not take any user hierarchy into account when it compiles the list.
- CRX uses a group hierarchy only when you include a group as a member of another group. There is no automatic inheritance of group permissions.
- The order in which you specify the groups does not affect the access rights.
Resolving Request and Access Rights resolving-request-and-access-rights
When CRX handles the request it compares the access request from the subject with the access control list on the repository node:
So if Linda requests to update the /features
node in the following repository structure:
Order of Precedence order-of-precedence
Access rights in CRX are evaluated as follows:
-
User principals always take precedence over group principals irrespective of:
- their order in the access control list
- their position in the node hierarchy
-
For a given principal there exists (at most) 1 deny and 1 allow entry on a given node. The implementation always clears redundant entries and makes sure that the same privilege is not listed in both the allow and deny entries.
Taking two examples where the user aUser
is member of the group aGroup
:
+ parentNode
+ acl
+ ace: aUser - deny - write
+ childNode
+ acl
+ ace: aGroup - allow - write
+ grandChildNode
In the above case:
aUser
is not granted write permission ongrandChildNode
.
+ parentNode
+ acl
+ ace: aUser - deny - write
+ childNode
+ acl
+ ace: aGroup - allow - write
+ ace: aUser - deny - write
+ grandChildNode
In this case:
-
aUser
is not granted write permission ongrandChildNode
. -
The second ACE for
aUser
is redundant.
Access rights from multiple group principals are evaluated based on their order, both within the hierarchy and within a single access control list.
Best Practices best-practices
The following table list some recommendations and best practices:
User Administration user-administration
A standard dialog is used for User Administration.
You must be logged into the appropriate workspace, then you can access the dialog from both:
- the User Administration link on the Main Console of CRX
- the Security menu of the CRX Explorer
Properties
-
UserID
Short name for the account, used when accessing CRX. -
Principal Name
A full text name for the account. -
Password
Needed when accessing CRX with this account. -
ntlmhash
Automatically assigned for each new account and updated when the password is changed. -
You can add new properties by defining a name, type and value. Click Save (green tick symbol) for each new property.
Group Membership This displays all groups that the account belongs to. The Inherited column indicates membership that has been inherited as a result of membership of another group.
Clicking on a GroupID (when available) will open the Group Administration for that group.
Impersonators With the Impersonate functionality a user can work on behalf of another user.
This means that a user account can specify other accounts (user or group) which can operate with their account. In other words, if user-B is allowed to impersonate user-A, then user-B can take actions using the full account details of user-A (including ID, name and access rights).
This allows the impersonator accounts to complete tasks as if they were using the account they are impersonating; for example, during an absence or to share an excessive load short-term.
If an account impersonates another it is very difficult to see. The log files hold no information about the fact that impersonation has occurred on the events. So if user-B is impersonating user-A all events will look as if they were performed by user-A personally.
Creating a User Account creating-a-user-account
-
Open the User Administration dialog.
-
Click Create User.
-
You can then enter the Properties:
- UserID used as the account name.
- Password needed when logging in.
- Principal Name to provide a full textual name.
- Intermediate Path which can be used to form a tree structure.
-
Click on the Save (green tick symbol).
-
The dialog will be expanded so that you can:
- Configure Properties.
- See Group Membership.
- Define Impersonators.
- users
- groups with many members
Updating a User Account updating-a-user-account
-
With the User Administration dialog open the list view of all accounts.
-
Navigate through the tree structure.
-
Click on the required account to open for edit.
-
Make a change then click on Save (green tick symbol) for that entry.
-
Click Close to finish, or … to return to the list of all user accounts.
Removing a User Account removing-a-user-account
-
With the User Administration dialog open the list view of all accounts.
-
Navigate through the tree structure.
-
Select the required account and click Remove User; the account will be deleted immediately.
Defining Properties defining-properties
You can define Properties for either new or existing accounts:
- Open the User Administration dialog for the appropriate account.
- Define a Property name.
- Select the Type from the drop-down list.
- Define the Value.
- Click Save (green click symbol) for the new property.
Existing properties can be deleted with the trash symbol.
With the exception of the Password, properties cannot be edited, they must be deleted and recreated.
Changing the Password changing-the-password
The Password is a special property that can be changed by clicking on the Change Password link.
You can also change the password to your own user account from the Security menu in the CRX Explorer.
Defining an Impersonator defining-an-impersonator
You can define Impersonators for either new or existing accounts:
-
Open the User Administration dialog for the appropriate account.
-
Specify the account to be allowed to impersonate that account.
You can use Ƿɲ… to select an existing account.
-
Click Save (green tick symbol) for the new property.
Group Administration group-administration
A standard dialog is used for Group Administration.
You must be logged into the appropriate workspace, then you can access the dialog from both:
- the Group Administration link on the Main Console of CRX
- the Security menu of the CRX Explorer
Properties
-
GroupID
Short name for the group account. -
Principal Name
A full text name for the group account. -
You can add new properties by defining a name, type and value. Click Save (green tick symbol) for each new property.
-
Members
You can add users, or other groups, as members of this group.
Group Membership This displays all groups that the current group account belongs to. The Inherited column indicates membership that has been inherited as a result of membership of another group.
Clicking on a GroupID will open the dialog for that group.
Members Lists all accounts (users and/or groups) that are members of the current group.
The Inherited column indicates membership that has been inherited as a result of membership of another group.
mac-default-<foldername>
for each folder on which the roles are defined.Creating a Group Account creating-a-group-account
-
Open the Group Administration dialog.
-
Click Create Group.
-
You can then enter the Properties:
- Principal Name to provide a full textual name.
- Intermediate Path which can be used to form a tree structure.
-
Click on the Save (green tick symbol).
-
The dialog will be expanded so that you can:
- Configure Properties.
- See Group Membership.
- Manage Members.
Updating a Group Account updating-a-group-account
-
With the Group Administration dialog open the list view of all accounts.
-
Navigate through the tree structure.
-
Click on the required account to open for edit.
-
Make a change then click on Save (green tick symbol) for that entry.
-
Click Close to finish, or … to return to the list of all group accounts.
Removing a Group Account removing-a-group-account
-
With the Group Administration dialog open the list view of all accounts.
-
Navigate through the tree structure.
-
Select the required account and click Remove Group; the account will be deleted immediately.
Defining Properties defining-properties-1
You can define Properties for either new or existing accounts:
- Open the Group Administration dialog for the appropriate account.
- Define a Property name.
- Select the Type from the drop-down list.
- Define the Value.
- Click Save (green tick symbol) for the new property.
Existing properties can be deleted with the trash symbol.
Members members
You can add members to the current group:
-
Open the Group Administration dialog for the appropriate account.
-
Either:
- Enter the name of the required member (user or group account).
- Or use Ƿɲ… to search for, and select, the principal (user or group account) that you want to add.
-
Click Save (green tick symbol) for the new property.
Or delete an existing member with the trash symbol.
Access Right Management access-right-management
With the Access Control tab of CRXDE Lite you can define the access control policies and assign the related privileges.
For example, for Current Path select the required resource in the left pane, the Access Control tab in the bottom right pane:
The policies are categorized according to:
-
Applicable Access Control Policies
These policies can be applied.These are policies that are available for creating a local policy. Once you select and add an applicable policy it becomes a local policy.
-
Local Access Control Policies
These are access control policies that you have applied. You can then update, order, or remove them.A local policy will override any policies inherited from the parent.
-
Effective Access Control Policies
These are the access control policies that are now in effect for any access requests. They show the aggregated policies derived from both the local policies and any inherited from the parent.
Policy Selection policy-selection
The policies can be selected for:
-
Current Path
As in the example above, select a resource within the repository. The policies for this “current path” will be shown. -
Repository
Selects repository level access control. For example, when setting thejcr:namespaceManagement
privilege, which is only relevant for the repository, not a node. -
Principal
A principal that is registered in the repository.You can either type in the Principal name or click the icon to the right of the field to open the Select Principal dialog.
This allows you to Search for a User or Group. Select the required principal from the resulting list, then click OK to carry the value back to the previous dialog.
Privileges privileges
The following privileges are available for selection when adding an access control entry (see the for full details):
Registering New Privileges registering-new-privileges
You can also register new privileges:
-
From the toolbar select Tools, then Privileges to display the privileges currently registered.
-
Use the Register Privilege icon (+) to open the dialog and define a new privilege:
-
Click OK to save. The privilege will now be available for selection.
Adding an Access Control Entry adding-an-access-control-entry
-
Select your resource and open the Access Control tab.
-
To add a new Local Access Control Policies, click the + icon at the right of the Applicable Access Control Policy list:
-
A new entry appears under Local Access Control Policies:
-
Click the + icon to add a new entry:
note note NOTE Currently a workaround is needed to specify an empty string. For this you need to use “”. -
Define your access control policy and click OK to save. Your new policy will:
- be listed under Local Access Control Policy
- the changes will be reflected in the Effective Access Control Policies.
CRX will validate your selection; for a given principal there exists (at most) 1 deny and 1 allow entry on a given node. The implementation always clears redundant entries and makes sure that the same privilege is not listed in both the allow and deny entries.
Ordering Local Access Control Policies ordering-local-access-control-policies
The order in the list indicates the order in which the policies are applied.
-
In the table of Local Access Control Policies select the required entry and drag it to the new position in the table.
-
The changes will be shown in both the tables for the Local and the Effective Access Control Policies.
Removing an Access Control Policy removing-an-access-control-policy
-
In the table of Local Access Control Policies click the red icon (-) at the right of the entry.
-
The entry will be removed from both the tables for the Local and the Effective Access Control Policies.
Testing an Access Control Policy testing-an-access-control-policy
-
From the CRXDE Lite toolbar select Tools, then Test Access Control….
-
A new dialog opens in the top right pane. Select the Path and/or Principal that you want to test.
-
Click Test to see the results for your selection: