Explore Access Control Lists
Summarize
Summary of Explore Access Control Lists
Access Control Lists (ACLs) in ServiceNow govern who can access specific objects and operations based on defined conditions. Each ACL consists of a decision type, object, operation, and conditions that determine access eligibility. Understanding ACL components is crucial for managing data security effectively.
Show less
Key Features
- Decision Types: Specify whether access is allowed or denied based on conditions:
- Deny-Unless: Denies access unless conditions are met.
- Allow-If: Grants access if conditions are satisfied.
- Objects: The target elements secured by ACLs, such as tables and fields, identified by type and name.
- Operations: Actions permitted on the secured object, including create, read, write, and execute.
- Conditions: Criteria that must be satisfied for access, including user roles, security attributes, data conditions, and scripts.
Key Outcomes
By configuring ACLs effectively, ServiceNow customers can:
- Ensure only authorized users can access sensitive data, enhancing security.
- Gain granular control over data visibility and modification based on user roles and conditions.
- Utilize both pre-query and post-query checks to refine data access based on user permissions.
- Understand the implications of failing ACL rules, which can prevent users from viewing or interacting with specific data.
Overall, mastering ACLs allows organizations to maintain robust security protocols while enabling necessary access for users based on their roles and the context of their requests.
Explore Access Control Lists (ACLs).
- The decision type, rule type and operation which defines the ACL
- The object being secured
- The conditions required to access the object
Components of ACL
The decision type defines whether users are allowed to access the object if conditions are met or denies access the object unless conditions are met.
| Decision type | Description |
|---|---|
| Deny-Unless | Restrict access to resource by explicitly denying access unless conditions are passed. See acl-denial-behavior.html#acl-denial-behavior__section_qnd_snl_zbc for more information. |
| Allow-If | Allow access to resource if conditions are passed. |
The object is the target to which access needs to be controlled. Each object consists of a type and name that uniquely identifies a particular table, field, or record. With the Applies-to field users have granular control over which specific records this ACL will apply to.
For example, all these entries specify an object:
| Type | Name | Object secured |
|---|---|---|
| record | [incident].[--None--] | The Incident table. |
| record | [incident].[active] | The Active field in the Incident table. |
| record | [incident] Applies-To: Priority = P1 |
Only Priority 1 incidents in the incident table. |
| REST_Endpoint | user_role_inheritance | The record for the user_role_inheritance Scripted REST API. |
Each operation describes a valid action the system can take on the specified object. Some objects, such as records, support multiple operations, while other objects, such as a REST_Endpoint, only support one operation.
For example, all these entries specify an operation:
| Type | Name | Operation | Operation secured |
|---|---|---|---|
| record | [incident].[-- None --] | create | Creating records in the Incident table. |
| record | [incident].[active] | write | Updating the Active field in the Incident table. |
| REST_Endpoint | user_role_inheritance | execute | Running the user_role_inheritance scripted REST API. |
- One or more user roles to the Requires role list.
- One or more security attributes need to be evaluated to be true.
- One or more data conditions.
- A script that evaluates to true or false or sets the
answervariable to true or false.
To gain access to an object and operation, a user must pass all conditions listed in an access control. For example, this access control restricts access to view operations on the incident table.
To update a record in the incident table, a user must have the listed roles and the record must meet the condition.
| Condition type | Requirement | Description |
|---|---|---|
| Requires role | Requires role:itil | Only allow users with the itil role to update incidents. |
| Security Attributes | UserIsAuthenticated | Only authenticated users to update incidents. |
| Data Condition | [Incident state] [is not] [Closed] | Only allow updates to active incident records. |
Applies-to behavior
The Applies-to field determines whether an ACL applies to records, whereas data condition evaluates an ACL that's already applied. Applies-to specifies whether the ACL affects a specific record; if it's empty, the ACL applies to all records. Applies-to can be used for granular ACL enforcement whereas "Data Condition" is an evaluation criteria.
Deny by default behavior
- Defined role
- Security attribute
- Data condition
- Script
- ACLs with roles that do not exist (e.g. have no row in the database)
- ACLs with Security Attributes that do not exist (e.g. have no row in the database)
- ACLs with a script that contains "answer=true" or "true"
If the system detects the user creating an ACL it will prompt the user to select a role or an existing security attribute.
ACL evaluation process
An ACL rule only grants a user access to an object if the user meets all conditions required by the matching ACL rule.
- The condition must evaluate to true.
- The script must evaluate to true or return an answer variable with the value of true.
- The user must have one of the roles in the required roles list. If the list is empty, this condition evaluates to true.
- [Record ACL rules only] The matching table-level and field-level ACL rules must both evaluate to true.
Whenever a session requests data, the system searches for access control rules that match the requested object and operation. If there’s a matching access control rule, then the system evaluates if the user has the conditions required to access the object and operation. If an access control rule specifies more than one condition, then the user must meet all conditions to gain access to the object and operation. Failing any one condition check prevents the user from accessing the matching object and operation.
The effects of being denied access to an object depend on the ACL rule that the user failed. For example, failing a read operation ACL rule prevents the user from seeing the object. Depending on the object secured, the ACL rule hides a field on a form, hides rows from a list, or prevents a user from accessing a UI page. The following table contains a complete list of results of failing an ACL rule for a given operation and object type.
Pre and post query ACL checks
- Pre-query ACL check
-
Before your instance runs a database query, it checks the ACL rules for each field in the queried table to determine which fields a user may access. This check only looks at the user's roles, and checks to see if these roles allow access to fields. Because this check runs before the query, the ACL doesn't have access to the records on the table, so it can’t take that data into account. Scripts and conditions that rely on knowing the contents of a record aren’t evaluated.
If the user doesn't have read access at this point, the value for the field isn’t shown to the user.
- Post-query ACL check
-
After the query, your instance checks each record returned by the query. During this check, there’s context for the ACL, so the role, condition, and script portions of the ACL are evaluated. If the user doesn't have read access at this point, the value for the field isn’t shown to the user, however the user sees the field label if their roles allow access to the field.
| Operation | Results of failing an ACL rule on object |
|---|---|
| execute | User can’t execute scripts on a record or UI page. |
| create | User can’t see the New UI action from forms. The user also cannot insert records into a table using API protocols such as web services. A create ACL with a condition requiring that a field contain a specific value may evaluate as false. Fields on new records are considered empty until the record is saved. |
| read | User can’t see the object in forms or lists. The user also can’t retrieve records using API protocols such as web services. |
| write | User sees a read-only field in forms and lists, and the user can’t update records using API protocols such as web services. |
| delete | User cannot see the Delete UI action from forms. The user also can’t remove records from a table using API protocols such as web services. |
| edit_task_relations | User cannot define relationships between task tables. |
| edit_ci_relations | User cannot define relationships between Configuration Item [cmdb_ci] tables. |
| save_as_template | Used to control the fields that should be saved when a template is created. |
| add_to_list | User can’t view or personalize specific columns in the list mechanic. |
| list_edit | User can’t update records (rows) from a list. |
| report_on | User can’t create a report on the ACL table. For more information, see Restrict report creation with an ACL rule. |
| report_view | User can’t view the content of a report on the ACL table or on the ACL field. For more information, see Reporting. |
| personalize_choices | User can’t right-click a list field and select Configure Choices. |
ACL matching requirements for objects
| Object Type | Matching ACL Rules Required to Access Object | Existing wild-card ACL Rules |
|---|---|---|
| Client-callable script includes | Users must meet the conditions of two ACL rules:
|
By default, there are no wild-card (*) rules for these object types. If you create a wild-card ACL rule for one of these objects, then the ACL rule applies to all objects of this type. |
| Processors | ||
| UI pages | Users must meet the conditions of two ACL rules:
|
By default, there are wild-card table rules (*) for the create, read, write, and delete operations and wild-card field rules (*.*) for the personalize_choices, create, and save_as_template operations. When you create a table, create ACL rules for the table unless you want to use the provided wild-card ACL rules. |
| Record |
Multiple ACL rules at the same point in the processing order
If two or more rules match at the same point in the processing order, the user must pass any one of the ACL rules conditions to access the object. For example, if you create two field ACL rules for incident.number, then a user who passes one rule has access to the number field regardless of whether the user failed any other field ACL rule at the same point in the processing order.
Required role
Normal admin users can view and debug access control rules. However, to create or update existing access control rules, administrators must elevate privileges to the security_admin role. See Elevate to a privileged role for instructions.
ACL rules in scoped applications
You can create ACL rules for objects in the same scope as the ACL rule. You can also create ACL rules for tables with at least one field that is in the same scope as the ACL rule.
- You can create an ACL rule for any table, UI page, or other object that is in the same scope as the ACL rule.
- You can create an ACL for a field that is in the same scope as the ACL rule.
- If the table is in the same scope, you can use a script to evaluate conditions.
- If the table is in a different scope, you can’t use a script to evaluate conditions.
- You can’t create or modify ACL rules for objects that are in a different scope than the application you’ve selected in the application picker, including adding a role to an ACL in a different scope.
- You can create wild-card table rules (*) only in the global scope.
- You can create wild-card field rules (*) only for tables in the same scope as the ACL rule.