Table: googleworkspace_gmail_draft - Query Google Workspace Gmail Drafts using SQL
Google Workspace's Gmail service offers a Drafts feature, where users can create, save, and manage draft emails before sending them. This feature provides a space for composing and editing emails, which can be saved for later completion and dispatch. The drafts can contain a variety of information, including recipients, subject lines, and body content.
Table Usage Guide
The googleworkspace_gmail_draft
table provides insights into draft emails within Google Workspace's Gmail service. As an IT administrator or security analyst, explore draft-specific details through this table, including metadata, message content, and associated user information. Utilize it to uncover information about unsent communications, such as those containing sensitive information, drafts saved by specific users, and the content of these saved but unsent messages.
Important Notes
- You must specify the
user_id
in thewhere
or join clause (where user_id=
,join googleworkspace_gmail_draft g on g.user_id=
) to query this table.
Examples
Basic info
Explore which drafts in your Google Workspace Gmail account have a specific user ID. This can help you manage your drafts more effectively by identifying which drafts belong to a specific user, especially useful in large organizations where multiple users may be using the same account.
select draft_id, message_id, message_thread_id, message_internal_date, message_size_estimate, message_snippetfrom googleworkspace_gmail_draftwhere user_id = 'user@domain.com';
select draft_id, message_id, message_thread_id, message_internal_date, message_size_estimate, message_snippetfrom googleworkspace_gmail_draftwhere user_id = 'user@domain.com';
List unread draft messages
Discover the segments that contain unread draft messages in your Gmail account. This can be especially useful for managing your email workflow and ensuring important drafts don't get overlooked.
select draft_id, message_id, message_thread_id, message_internal_date, message_size_estimate, message_snippetfrom googleworkspace_gmail_draftwhere user_id = 'user@domain.com' and query = 'is:unread';
select draft_id, message_id, message_thread_id, message_internal_date, message_size_estimate, message_snippetfrom googleworkspace_gmail_draftwhere user_id = 'user@domain.com' and query = 'is:unread';
List draft messages older than 30 days
Explore which draft messages have been left untouched for over 30 days. This could be useful for clearing out old drafts or identifying potential forgotten tasks.
select draft_id, message_id, message_thread_id, message_internal_date, message_size_estimate, message_snippetfrom googleworkspace_gmail_draftwhere user_id = 'user@domain.com' and message_internal_date <= (current_date - interval '30' day);
select draft_id, message_id, message_thread_id, message_internal_date, message_size_estimate, message_snippetfrom googleworkspace_gmail_draftwhere user_id = 'user@domain.com' and message_internal_date <= date('now', '-30 day');
List draft messages without a body
Discover the segments that consist of draft messages without any content. This can be useful for identifying and cleaning up unnecessary drafts, freeing up storage space and keeping your draft folder organized.
select draft_id, message_id, message_thread_id, message_internal_date, message_size_estimate, message_snippetfrom googleworkspace_gmail_draftwhere user_id = 'user@domain.com' and message_snippet is null;
select draft_id, message_id, message_thread_id, message_internal_date, message_size_estimate, message_snippetfrom googleworkspace_gmail_draftwhere user_id = 'user@domain.com' and message_snippet is null;
Schema for googleworkspace_gmail_draft
Name | Type | Operators | Description |
---|---|---|---|
_ctx | jsonb | Steampipe context in JSON form. | |
draft_id | text | = | The immutable ID of the draft. |
message_history_id | text | The ID of the last history record that modified this message. | |
message_id | text | The immutable ID of the message. | |
message_internal_date | timestamp with time zone | The internal message creation timestamp which determines ordering in the inbox. | |
message_label_ids | jsonb | A list of IDs of labels applied to this message. | |
message_payload | jsonb | The parsed email structure in the message parts. | |
message_raw | text | The entire email message in an RFC 2822 formatted and base64url encoded string. | |
message_size_estimate | bigint | Estimated size in bytes of the message. | |
message_snippet | text | A short part of the message text. | |
message_thread_id | text | The ID of the thread the message belongs to. | |
query | text | = | A string to filter messages matching the specified query. |
sp_connection_name | text | =, !=, ~~, ~~*, !~~, !~~* | Steampipe connection name. |
sp_ctx | jsonb | Steampipe context in JSON form. | |
user_id | text | = | User's email address. If not specified, indicates the current authenticated user. |
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)" -- googleworkspace
You can pass the configuration to the command with the --config
argument:
steampipe_export_googleworkspace --config '<your_config>' googleworkspace_gmail_draft