Create evaluator with restrictions on one entity

Codeable evaluator is useful for restricting privileges on selected entity. For example, if you want one user to be able to see only other user (with defined username or uuid), or for restricting that user to see only a role (defined by code or uuid).

This tutorial describes how admin can create a new evaluator to achieve that.

This section describes how to create evaluator that restricts permission to see only one identity (user).

In first step we must get username of identity that will be restricted by this new evaluator.

For this step a role must exist so we can hook a new evaluator to this role. If you don't have such a role, please create one. Once you have a role, go to its submenu Permission and then add new evaluator by button Add.

On a modal window, select:

  • Entity type: IdmIdentity.
  • Evaluator type: CodeableEvaluator

Then, application will display an evaluator configuration dialog with one option marked identifier. Put UUID or username of an user (identiti) into this field.

Save the new evaluator. If the action was successful, you can verify new evaluator in the list of active evaluators.

Choose some other user (the user you want to give the permission to) and add him the role you configured. This user now obtains a new permission as defined in the evaluator.

Final result. We assigned a role to the richard.roe. This user now can see the john.doe identity in IdM.

This tutorial is similar to the first one. Instead of an identity, we grant user a permission to work with some certificate authority. For example, this restriction can be used for adding permissions to request certificates only from particular certificate authority authority. If you have multiple CAs defined, you can create one role for each of your CAs an then assign those roles to users as necessary.

Get the code of certification authority.

Code can be used in 1.3.0 (and later) version of crt module. If you use lower version of crt module, you have to use UUID as an identifier. UUID can be found in browser URL when you open the certificate authority detail page.

For this step you have to have a role created (if you do not have such a role, create it). We will now hook an evaluator to the role. For this, go to role's submenu Permission and then add new evaluator by clicking the Add button.

On modal window, select:

  • Entity type: CrtAuthority.
  • Evaluator type: CodeableEvaluator.

Application will display an evaluator configuration dialog with one option marked identifier. Fill in the identificator of certificate authority.

Save new evaluator. If everything is ok, you can see it in the list of existing evaluators.

Add a role to some user. This user will now obtain a permission to work with particular certificate authority (determined by CA identification in the evaluator).

Final result - user can see only the certification authority you want him to see.