Privileges
Privileges define the actions a user may perform within the Nexus Repository. They grant access to resources, ensuring that users have the appropriate permissions based on their roles.
Understanding Privileges
Nexus Repository includes privileges for three primary purposes:
Access to the content inside repositories This includes tasks such as searching or browsing repositories, downloading artifacts from a repository, and adding or deleting artifacts.
Management of repositories This includes tasks such as creating and removing repositories
Access to functionality in the repository manager This includes tasks such as viewing elements in the user interface, managing access controls, running tasks, and general administration.
Review Privilege Types to learn more.
Restricting Downloads Before Release 3.76.0
Nexus Repository release 3.57.0 introduced a change that requires the nx-repository-view read
privilege when searching for content in repositories. This privilege includes access to download components which in some use cases is not desirable. As of release 3.76.0, this functionality has been restored to no longer require read permission when searching.
Use the nx-search-read
and nx-repository-view-*-*-browse
privileges for the use case of viewing content via search or browse, while not providing access to download it.
Assigning Privileges
In Nexus Repository, privileges are group together as a role. Roles are designed to accomplish a specific use case when accessing the repository. Typically, a user or a group of users may be assigned one or more role depending on their requirements. Service accounts may also have their own roles with limited access and minimize risk.
See Roles to learn more.
Combining Privileges
Privileges grant access but do not restrict access. Privileges provided by one role cannot be limited by another.
For example, a user with the "read" privilege can view and download artifacts from any repository, but they cannot modify or delete artifacts.
nexus:repository-view:maven2:maven-central:read
When also granted full access using the wild card '*
', they gain additional privileges and are not limited by the privilege only providing read access as demonstrated below.
nexus:repository-view:maven2:maven-central:read nexus:repository-view:maven2:maven-central:*
Privileges on Group Repositories
Group Repositories associate a mix of proxy and hosted repositories under a single endpoint. Privileges to a group repository provide access to the content of the repositories within the group as if they were a single repository. Privileges on a group repository do not provide permissions to access the members of the group directly.
For example, in the scenario where a user has read
and browse
privileges on a group repository but does not have the same permissions on a hosted repository within the group. The user may access content from the hosted repository when querying the group repository endpoint, however, they may not access the content of the hosted repository directly.
Custom Privileges
Nexus Repository provides default privileges to manage functionality in the repository manager. Some privileges such as access to specific repositories and repository formats are only available until those repositories are created.
Custom privileges are made using content selectors to target specific namespaces within a repository and provide more granular access controls to that content.
See Content Selectors for details.
Creating a Privilege
User access may be completely managed using the default privileges. Cu
Select the Create Privilege
button to view a list of privilege types. After selecting a type, fill in the required fields and save the privilege. When creating privileges based on content selectors, the selector must be created first.
Manage Selector Permissions
As part of your security setup, you can create user permissions to manage the filters you built in the Create Selector form. You do this by creating a privilege that controls operations for components matching that selector. The privilege may span multiple repositories.
To create a new content selector privilege, select Privileges in the Security section of the Administration panel.
Select the Create Privilege button.
Locate and select Repository Content Selector from the list of options in Select Privilege Type.
You will see a form that displays the following:
Name: Create a name for the content selector privilege.
Description: Add a brief description for the privilege.
Content Selector: Use this dropdown to select from a list of selectors you created.
Repository: Use this dropdown to select from either a range of all repository contents, all repository contents of an individual format, or repositories created by you.
Actions: Grant browse, read, edit, delete, create, update, or * (applies all other actions to the privilege)for user access control.
Save the new privilege by selecting Create privilege.
Privilege Actions
Privilege actions are the basic operations that can be performed on content in a repository. These include access to see the content, search through metadata, or modify the content. Actions may be assigned one at a time or in groups. You must assign at least one action when creating a privilege.
The privilege types have different actions ability to them. The following actions are the most commonly used with a repository:
*
(asterisk)This action is a wildcard grouping the available actions.
add
Action to add content to a repository.
browse
Action to view the contents of repositories in the user interface or a search. You may not download or open the content with the browse action.
create
Action to make a new 'item' in the repository manager configuration. Typically associated with the application privilege type. Note that this action does not provide the permissions to see the created items after creating them.
delete
Action to remove repository manager configurations, repository contents, and scripts.
edit
Action to modify repository content and change repository settings.
read
Action to download content from a repository. Note that this does not allow the user to browse the repository content.
This action is used to view application elements from the user interface and access content from the APIs.
update
Action to update repository manager configurations through the user interface and APIs.
Privilege Types
Application Built-in privileges that control access to features in the user interface. See the user interface for a complete list of features.
Actions: create, read, update, delete
nexus:{feature-name}:{actions}
Repository Admin Control the administration of configuration for specific repositories or repository formats.
Actions: browse, read, edit, add, delete
nexus:repository-admin:{format}:{repository}:{actions}
Repository Content Selector Repository Content Selector privileges provide fine-grained control over access to content within a repository by way of a content selector.
Actions: browse, read, edit, add, delete
nexus:repository-content-selector:{selector}:{format}:{repository}:{actions}
Repository View Repository View privileges control general access to all content contained within specific repositories or repository formats.
Actions: browse, read, edit, add, delete
nexus:repository-view:{format}:{repository}:{actions}
Script Script privileges control access to using the Groovy Script-related REST APIs as documented in REST and Integration API. These privileges do not control general REST API access.
Actions: browse, read, edit, add, delete, run
nexus:script:{script-name}:{actions}
Wildcard Wildcard privileges allow one to build a privilege string using a free-form series of segments. All other privilege types are more specific segment forms of a wildcard privilege. There is only one wildcard privilege included by default named
nx-all
that provides access to all functionality.nexus:*
Below are the list of default application privileges as of Nexus Repository release 3.76
Name | Description | Permission |
---|---|---|
nx-analytics-all | All permissions for Analytics | nexus:analytics:* |
nx-apikey-all | All permissions for APIKey | nexus:apikey:* |
nx-atlas-all | All permissions for Support Tools | nexus:atlas:* |
nx-blobstores-all | All permissions for Blobstores | nexus:blobstores:* |
nx-blobstores-create | Create permission for Blobstores | nexus:blobstores:create,read |
nx-blobstores-delete | Delete permission for Blobstores | nexus:blobstores:delete,read |
nx-blobstores-read | Read permission for Blobstores | nexus:blobstores:read |
nx-blobstores-update | Update permission for Blobstores | nexus:blobstores:update,read |
nx-bundles-all | All permissions for Bundles | nexus:bundles:* |
nx-bundles-read | Read permission for Bundles | nexus:bundles:read |
nx-capabilities-all | All permissions for Capabilities | nexus:capabilities:* |
nx-capabilities-create | Create permission for Capabilities | nexus:capabilities:create,read |
nx-capabilities-delete | Delete permission for Capabilities | nexus:capabilities:delete,read |
nx-capabilities-read | Read permission for Capabilities | nexus:capabilities:read |
nx-capabilities-update | Update permission for Capabilities | nexus:capabilities:update,read |
nx-component-upload | Upload component permission | nexus:component:create |
nx-crowd-all | All permissions for Crowd | nexus:crowd:* |
nx-crowd-read | Read permission for Crowd | nexus:crowd:* |
nx-crowd-update | Update permission for Crowd | nexus:crowd:* |
nx-datastores-all | All permissions for Datastores | nexus:datastores:* |
nx-datastores-create | Create permission for Datastores | nexus:datastores:create,read |
nx-datastores-delete | Delete permission for Datastores | nexus:datastores:delete,read |
nx-datastores-read | Read permission for Datastores | nexus:datastores:read |
nx-datastores-update | Update permission for Datastores | nexus:datastores:update,read |
nx-healthcheck-alerts-read | Read permission for Healthcheck alerts | nexus:healthcheckalerts:read |
nx-healthcheck-alerts-update | Update permission for Healthcheck alerts | nexus:healthcheckalerts:update |
nx-healthcheck-detail-read | Read permission for Healthcheck detail | nexus:healthcheckdetail:read |
nx-healthcheck-read | Read permission for Healthcheck | nexus:healthcheck:read |
nx-healthcheck-summary-read | Read permission for Healthcheck Summary | nexus:healthchecksummary:read |
nx-healthcheck-update | Update permission for Healthcheck | nexus:healthcheck:update |
nx-iq-violation-summary-read | Read permission for Audit and Quarantine summary | nexus:iq-violation-summary:read |
nx-ldap-all | All permissions for Ldap | nexus:ldap:* |
nx-ldap-create | Create permission for Ldap | nexus:ldap:create,read |
nx-ldap-delete | Delete permission for Ldap | nexus:ldap:delete,read |
nx-ldap-read | Read permission for Ldap | nexus:ldap:read |
nx-ldap-update | Update permission for Ldap | nexus:ldap:update,read |
nx-licensing-all | All permissions for Licensing | nexus:licensing:* |
nx-licensing-create | Create permission for Licensing | nexus:licensing:create,read |
nx-licensing-read | Read permission for Licensing | nexus:licensing:read |
nx-licensing-uninstall | Uninstall permission for Licensing | nexus:licensing:delete |
nx-logging-all | All permissions for Logging | nexus:logging:* |
nx-logging-mark | Mark permission for Logging | nexus:logging:create |
nx-logging-read | Read permission for Logging | nexus:logging:read |
nx-logging-update | Update permission for Logging | nexus:logging:update,read |
nx-metrics-all | All permissions for Metrics | nexus:metrics:* |
nx-metrics-read | Read permssions for Metrics | nexus:metrics:read |
nx-privileges-all | All permissions for Privileges | nexus:privileges:* |
nx-privileges-create | Create permission for Privileges | nexus:privileges:create,read |
nx-privileges-delete | Delete permission for Privileges | nexus:privileges:delete,read |
nx-privileges-read | Read permission for Privileges | nexus:privileges:read |
nx-privileges-update | Update permission for Privileges | nexus:privileges:update,read |
nx-ro-admin | Read Only for Nexus Admin | nexus:*:read,update |
nx-ro-admin-all | read only of all admin info | nexus:*:read |
nx-ro-sys-info | Read Only System Information | nexus:atlas:* |
nx-roles-all | All permissions for Roles | nexus:roles:* |
nx-roles-create | Create permission for Roles | nexus:roles:create,read |
nx-roles-delete | Delete permission for Roles | nexus:roles:delete,read |
nx-roles-read | Read permission for Roles | nexus:roles:read |
nx-roles-update | Update permission for Roles | nexus:roles:update,read |
nx-search-read | Read permission for Search | nexus:search:read |
nx-selectors-all | All permissions for Selectors | nexus:selectors:* |
nx-selectors-create | Create permission for Selectors | nexus:selectors:create,read |
nx-selectors-delete | Delete permission for Selectors | nexus:selectors:delete,read |
nx-selectors-read | Read permission for Selectors | nexus:selectors:read |
nx-selectors-update | Update permission for Selectors | nexus:selectors:update,read |
nx-settings-all | All permissions for Settings | nexus:settings:* |
nx-settings-read | Read permission for Settings | nexus:settings:read |
nx-settings-update | Update permission for Settings | nexus:settings:update,read |
nx-ssl-truststore-all | All permissions for Ssl-truststore | nexus:ssl-truststore:* |
nx-ssl-truststore-create | Create permission for Ssl-truststore | nexus:ssl-truststore:create,read |
nx-ssl-truststore-delete | Delete permission for Ssl-truststore | nexus:ssl-truststore:delete,read |
nx-ssl-truststore-read | Read permission for Ssl-truststore | nexus:ssl-truststore:read |
nx-ssl-truststore-update | Update permission for Ssl-truststore | nexus:ssl-truststore:update,read |
nx-tags-all | All permissions for Tags | nexus:tags:* |
nx-tags-associate | Associate permission for Tags | nexus:tags:associate,read |
nx-tags-create | Create permission for Tags | nexus:tags:create,read |
nx-tags-delete | Delete permission for Tags | nexus:tags:delete,read |
nx-tags-disassociate | Disassociate permission for Tags | nexus:tags:disassociate,read |
nx-tags-read | Read permission for Tags | nexus:tags:read |
nx-tags-update | Update permission for Tags | nexus:tags:update,read |
nx-tasks-all | All permissions for Tasks | nexus:tasks:* |
nx-tasks-create | Create permission for Tasks | nexus:tasks:create,read |
nx-tasks-delete | Delete permission for Tasks | nexus:tasks:delete,read |
nx-tasks-read | Read permission for Tasks | nexus:tasks:read |
nx-tasks-run | Run permission for Scheduled Tasks | nexus:tasks:start,stop |
nx-tasks-update | Update permission for Tasks | nexus:tasks:update,read |
nx-users-all | All permissions for Users | nexus:users:* |
nx-users-create | Create permission for Users | nexus:users:create,read |
nx-users-delete | Delete permission for Users | nexus:users:delete,read |
nx-users-read | Read permission for Users | nexus:users:read |
nx-users-update | Update permission for Users | nexus:users:update,read |
nx-userschangepw | Change password permission | nexus:userschangepw:create,read |
nx-usertoken-current | All permissions for Current User Token | nexus:usertoken-current:create,read,delete |
nx-usertoken-settings | Update permission for User Token settings | nexus:usertoken-settings:update,read |
nx-usertoken-user | Reset permission for User Token | nexus:usertoken-user:delete,read |
nx-usertoken-users | Reset permission for all User Tokens | nexus:usertoken-users:delete |
nx-wonderland-all | All permissions for Wonderland | nexus:wonderland:* |