turbot/googledirectory
steampipe plugin install googledirectory

Table: googledirectory_group - Query Google Directory Groups using SQL

Google Directory is a service within Google Workspace that allows you to manage, create, and view groups and their members. It provides a centralized way to set up and manage groups for various Google Workspace resources, including users, emails, and more. Google Directory helps you stay informed about the organization and membership of your Google Workspace resources.

Table Usage Guide

The googledirectory_group table provides insights into groups within Google Workspace. As a system administrator, explore group-specific details through this table, including group names, emails, and associated metadata. Utilize it to uncover information about groups, such as those with certain members, the hierarchy of groups, and the verification of group properties.

Examples

Basic info

Explore the basic information of Google Directory groups to gain insights into group names, IDs, associated emails, and creation details. This can be useful for managing and auditing group settings and memberships.

select
name,
id,
email,
admin_created
from
googledirectory_group;
select
name,
id,
email,
admin_created
from
googledirectory_group;

Get group by ID

Discover the details of a specific group in your Google Directory by using its unique ID. This can be useful for gaining insights into group information such as its name, email, and administrative creation data.

select
name,
id,
email,
admin_created
from
googledirectory_group
where
id = '02ce457p6conzyd';
select
name,
id,
email,
admin_created
from
googledirectory_group
where
id = '02ce457p6conzyd';

Get group by email

Determine the areas in which a specific email address is associated with a group, allowing you to understand the context and scope of that group's administration. This can be particularly useful for managing and auditing access permissions in a large organization.

select
name,
id,
email,
admin_created
from
googledirectory_group
where
email = 'scranton@dundermifflin.com';
select
name,
id,
email,
admin_created
from
googledirectory_group
where
email = 'scranton@dundermifflin.com';

List top 5 groups by member count

Explore the five most populated groups within your Google Directory. This could be useful for understanding which groups are most active or require the most resources.

select
name,
direct_members_count
from
googledirectory_group
order by
direct_members_count desc
limit
5;
select
name,
direct_members_count
from
googledirectory_group
order by
direct_members_count desc
limit
5;

List all groups and their members

Explore which members belong to specific groups within your Google Directory. This allows you to assess the composition of each group, aiding in tasks like group management and access control.

select
g.id as group_id,
g.name as group_name,
m.email as member_email
from
googledirectory_group as g,
googledirectory_group_member as m
where
g.id = m.group_id
order by
g.name,
m.email;
select
g.id as group_id,
g.name as group_name,
m.email as member_email
from
googledirectory_group as g
join googledirectory_group_member as m on g.id = m.group_id
order by
g.name,
m.email;

List groups using the query filter

Explore which groups have been created by admins within the Google Directory, specifically focusing on those associated with an email containing 'steampipe'. This can be beneficial in understanding the extent of 'steampipe' usage across different groups.

select
name,
id,
email,
admin_created
from
googledirectory_group
where
query = 'email:steampipe*';
select
name,
id,
email,
admin_created
from
googledirectory_group
where
query = 'email:steampipe*';

Schema for googledirectory_group

NameTypeOperatorsDescription
_ctxjsonbSteampipe context in JSON form.
admin_createdbooleanIndicates whether the group is created by an administrator, or by an user.
aliasesjsonbA list of the group's alias email addresses.
customer_idtext=The customer ID to retrieve all account groups.
descriptiontextAn extended description to help users determine the purpose of a group.
direct_members_countbigintThe number of users that are direct members of the group.
emailtext=Specifies the group's email address.
etagtextA hash of the metadata, used to ensure there were no concurrent modifications to the resource when attempting an update.
idtext=The unique ID of a group.
kindtextThe type of the API resource.
nametext=The group's display name.
non_editable_aliasesjsonbA list of the group's non-editable alias email addresses that are outside of the account's primary domain or subdomains.
querytext=Filter string to [filter](https://developers.google.com/admin-sdk/directory/v1/guides/search-groups) groups.
sp_connection_nametext=, !=, ~~, ~~*, !~~, !~~*Steampipe connection name.
sp_ctxjsonbSteampipe context in JSON form.

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)" -- googledirectory

You can pass the configuration to the command with the --config argument:

steampipe_export_googledirectory --config '<your_config>' googledirectory_group