Skip to content

Role-Based Access Control - RBAC

The OctoSAM web interface implements a fine-grained authorization mechanism that allows to specify limited read and update rights for individual users. The authorization mechanism follows the RBAC de facto standard.

The classic OctoSAM Windows UI only has global read and global write rights, you cannot restrict access to parts of the data.

Using Active Directory for RBAC requires that the application is configured for Windows integrated authentication, using Entra ID required that Entra ID is configured as identity provider. You cannot configure both AD and Entra ID on the same instance of OctoWeb, however, you can install and configure two instances in parallel with different authentication settings.

OctoSAM RBAC concepts and definitions

Privileges

A privilege is the right to perform a low-level operation. For example, the privilege Machine.Fields.DirectoryCity.Read allows read access to the field DirectoryCity on the Machine object. OctoSAM defines and manages all privileges and makes them available to be assigned to roles.

Roles

A role is a combination of privileges that together grant permissions required to perform a specific function.

Predefined roles

Administrators

The predefined role Administrators grants a combination of privileges required for application administration.

ReadOnlyUsers

The predefined role ReadOnlyUsers grants read access to the whole OctoSAM application.

SoftwareItemOwners

This role allows to own a Software Item. Owners of Software Items can be assigned additional rights on their owned items.

Users

RBAC users are replicated from Microsoft Active Directory and/or Entra ID. Currently, OctoSAM RBAC requires users to be defined in Active Directory and/or Entra ID.

Groups

RBAC groups are replicated from Microsoft Active Directory and/or Entra ID Currently, OctoSAM RBAC requires groups to be defined in Active Directory and/or Entra ID.

Role to group relation

OctoSAM RBAC relates roles defined in OctoSAM to groups defined in Active Directory or Entra ID. A user who is a member in multiple groups/roles receives the cumulated privileges of all roles.

RBAC replication

All relevant objects from Entra ID and/or Active Directory are replicated to the OctoSAM database during RBAC housekeeping. The RBAC mechanism itself does not access Active Directory or Entra ID directly. This allows to verify an RBAC model without a live connection to AD or Entra ID.

New users and/or changed group memberships are reflected in OctoSAM only after the RBAC replication is complete. The default RBAC replication interval is 6 hours, but can be configured in appsettings.json.

You can trigger an RBAC replication at any time from the OctoWeb admin page or via OctoUtil.

Wildcard privileges

For example, OctoSAM defines the following privileges to access Modules in the OctoSAM web interface.

   Module.Admin.Execute
   Module.Inventory.Execute
   Module.Query.Execute
   Module.Monitor.Execute
   Module.License.Execute

You can assign the Privilege Module.ALL.Execute to a role to cover all of the Module Execute privileges. OctoSAM defines and manages all wildcard privileges. If a future release of OctoSAM defines a new module, execute privilege for this new module will automatically be included in the Role.

The ALL wildcard does not match the.

There is no hierarchy of privilege levels. The . is used only to delimit the Wildcard match. If you want to grant access to a subset of privileges instead of 'ALL' you have to specify each required privilege.

The ALL wildcard can be used on multiple parts such as ALL.ALL.ALL.Read

This would match

   Machine.Fields.Name.Read
   User.Fields.Domain.Read

List of privileges

Privilege names are intended to be self-explanatory. OctoSAM automatically manages the list of available privileges. Currently, there are approx. 3000 defined privileges. The web interface shows lists of granted and denied privileges per user. The denied privileges list helps you to find potentially missing privileges for a role.

Fields privileges

Field privileges control access to a specific object field. The names correspond to the names of the fields in the database. The fields are documented in the database Schema. Usually, the same names are used in the user interface, where possible. For objects that have multiple name components, the field PrintableName is usually used to display the object. So to display a Machine object, the user needs at least the Machine.Fields.PrintableName.Read privilege.

Annotation privileges

Annotations are site-specific object properties. One type of annotation are the Extended Attributes that can be defined via the Octopus2 UI. Other types of annotations are automatically created from inventoried systems that also allow site-specific annotations such as VMWare vCenter.

Relation privileges

A Relation privilege is used in the case where there is a relation to another object type. For example, a Software Package can be installed on multiple machines. To view Machines related to a SoftwarePackage a user needs the SoftwarePackage.Relations.Machine.Read privilege. To display the Machines, Machine.Fields.PrintableName.Read is also required.

Owner privileges

Some objects allow to set different permissions for 'Owned' objects. The meaning of 'owned' is specific to each object type. For Software Items, ownership can be defined explicitly in the application. For User objects it means the application users own User and RbacUser objects. For machine objects, ownership is computed from the user-to-device affinity.

Meta privileges

To update an object in the database, multiple permissions are sometimes needed. For example, to be able to update the Custom Field1 on Machine, required Permissions are

Machine.Fields.CustomField1.Write
Machine.Update

This is because an update to CustomField1 also implicitly updates some metadata on the machine (such as LastModification/LastModifiedBy)

Per object privileges

Some objects allow per-object privileges. The objects are identified by their object GUID. If that is the case, a role can have different privileges on each object. For example, Access to Queries can be defined by Query.

Organization privileges

Organization privileges are per-object privileges that can be used to configure per-organization read and write permissions in addition to object and field permissions.

Module privileges

OctoWeb consists of several modules that can be enabled or disabled globally using the appsettings.json file. In addition, these Modules can be managed per user using the Module.*.Execute privileges.

Note

Some modules require a corresponding license option, see the sample appsettings.json file on which modules require which license option. If a required license option is not set, the corresponding module cannot be activated, regardless of appsettings.json and/or granted privileges.

Privilege elevation in queries

If a role allows access to a query, it depends on the definition of the query, whether the query itself filters access to data via RBAC or not. A query can potentially show data that the user does not have a direct access privilege. This can be used by site-specific queries, to create reports that show or aggregate data that the user can not normally read.