Table: servicenow_sys_group_has_role - Query ServiceNow Sys Group Roles using SQL
ServiceNow is a cloud-based platform designed to help manage digital workflows for enterprise operations. It provides a suite of applications and tools for IT service management (ITSM), IT operations management (ITOM), and IT business management (ITBM). Within the ServiceNow platform, Sys Group Roles represent the roles assigned to specific groups, which determine the access permissions and capabilities of the group members within the platform.
Table Usage Guide
The servicenow_sys_group_has_role
table provides insights into the roles assigned to groups within the ServiceNow platform. As a system administrator or IT manager, you can utilize this table to understand the access permissions and capabilities of different groups, aiding in effective access management and security compliance. It can also be used to identify any discrepancies in role assignments, ensuring that each group has the appropriate roles for their function.
Examples
What are the top 5 roles that are granted to groups?
Discover the most commonly assigned roles within a group to understand the distribution of responsibilities and privileges. This can be useful for auditing purposes or for optimizing group management strategies.
select r.name as role_name, count(*) as num_granted_to_groupsfrom servicenow_sys_group_has_role ghr left join servicenow_sys_user_role r on ghr.role ->> 'value' = r.sys_idwhere role is not nullgroup by role_nameorder by num_granted_to_groups desclimit 5;
select r.name as role_name, count(*) as num_granted_to_groupsfrom servicenow_sys_group_has_role ghr left join servicenow_sys_user_role r on json_extract(ghr.role, '$.value') = r.sys_idwhere role is not nullgroup by role_nameorder by num_granted_to_groups desclimit 5;
What are the top 10 groups that have the most roles granted to them?
Discover the segments that have the most roles assigned to them in an organization. This is useful for understanding which groups have the most responsibilities or privileges, aiding in access management and security planning.
select ug.name as group_name, count(*) as num_granted_rolesfrom servicenow_sys_group_has_role ghr left join servicenow_sys_user_group ug on ghr."group" ->> 'value' = ug.sys_idwhere "group" is not nullgroup by group_nameorder by num_granted_roles desclimit 10;
select ug.name as group_name, count(*) as num_granted_rolesfrom servicenow_sys_group_has_role ghr left join servicenow_sys_user_group ug on json_extract(ghr."group", '$.value') = ug.sys_idwhere "group" is not nullgroup by group_nameorder by num_granted_roles desclimit 10;
How many groups have roles that are inherited?
Determine the number of groups that have inherited roles in ServiceNow. This can be used to assess the extent of role inheritance within your organization's groups, which may be useful for managing permissions and access controls.
select count(distinct "group" ->> 'value') as num_groups_with_inherited_rolesfrom servicenow_sys_group_has_rolewhere inherits = true;
select count(distinct json_extract("group", '$.value')) as num_groups_with_inherited_rolesfrom servicenow_sys_group_has_rolewhere inherits = 1;
What are the groups that have a specific role granted to them?
Determine the areas in which certain groups have been granted a specific role. This is useful in managing access control and ensuring appropriate permissions are in place.
select ug.name as group_namefrom servicenow_sys_group_has_role ghr left join servicenow_sys_user_group ug on ghr."group" ->> 'value' = ug.sys_idwhere role ->> 'value' = '282bf1fac6112285017366cb5f867469';
select ug.name as group_namefrom servicenow_sys_group_has_role ghr left join servicenow_sys_user_group ug on json_extract(ghr."group", '$.value') = ug.sys_idwhere json_extract(role, '$.value') = '282bf1fac6112285017366cb5f867469';
How many groups have a specific role granted to them?
Determine the number of groups that have been assigned a particular role in your ServiceNow system. This can be useful for assessing access control and ensuring appropriate permissions are distributed.
select count(distinct "group" ->> 'value') as num_groups_with_rolefrom servicenow_sys_group_has_rolewhere role ->> 'value' = 'ec1816c3871323004caf66d107cb0b1e' and "group" is not null;
select count(distinct json_extract(` group `.value, '$.value')) as num_groups_with_rolefrom servicenow_sys_group_has_rolewhere json_extract(role.value, '$.value') = 'ec1816c3871323004caf66d107cb0b1e' and ` group ` is not null;
How many roles are granted to each group?
Determine the distribution of roles across different groups, identifying which groups have been assigned the most roles. This can help in understanding role allocation patterns and identifying any potential discrepancies or over-allocations.
select ug.name as group_name, count(*) as num_granted_rolesfrom servicenow_sys_group_has_role ghr left join servicenow_sys_user_group ug on ghr."group" ->> 'value' = ug.sys_idwhere "group" is not nullgroup by group_nameorder by num_granted_roles desc;
select ug.name as group_name, count(*) as num_granted_rolesfrom servicenow_sys_group_has_role ghr left join servicenow_sys_user_group ug on json_extract(ghr."group", '$.value') = ug.sys_idwhere "group" is not nullgroup by group_nameorder by num_granted_roles desc;
Schema for servicenow_sys_group_has_role
Name | Type | Operators | Description |
---|---|---|---|
_ctx | jsonb | Steampipe context in JSON form, e.g. connection_name. | |
granted_by | jsonb | User or group who granted the role to the group. | |
group | jsonb | User group to which the role is assigned. | |
inherits | boolean | Indicates whether the role is inherited. | |
role | jsonb | Role assigned to the group. | |
sys_created_by | text | User who created the record. | |
sys_created_on | timestamp with time zone | Date and time when the record was created. | |
sys_id | text | Unique system identifier for the record. | |
sys_mod_count | bigint | Number of times the record was modified. | |
sys_updated_by | text | User who last updated the record. | |
sys_updated_on | timestamp with time zone | Date and time when the record was last updated. |
Export
This table is available as a standalone Exporter CLI. Steampipe exporters are stand-alone binaries that allow you to extract data using Steampipe plugins without a database.
You can download the tarball for your platform from the Releases page, but it is simplest to install them with the steampipe_export_installer.sh
script:
/bin/sh -c "$(curl -fsSL https://steampipe.io/install/export.sh)" -- servicenow
You can pass the configuration to the command with the --config
argument:
steampipe_export_servicenow --config '<your_config>' servicenow_sys_group_has_role