Skip to content
Scalekit Docs
Talk to an Engineer Dashboard

Gmail connector

OAuth 2.0 Communication

Gmail is Google's cloud based email service that allows you to access your messages from any computer or device with just a web browser.

Gmail connector

  1. Terminal window
    npm install @scalekit-sdk/node

    Full SDK reference: Node.js | Python

  2. Add your Scalekit credentials to your .env file. Find values in app.scalekit.com > Developers > API Credentials.

    .env
    SCALEKIT_ENVIRONMENT_URL=<your-environment-url>
    SCALEKIT_CLIENT_ID=<your-client-id>
    SCALEKIT_CLIENT_SECRET=<your-client-secret>
  3. Register your Gmail credentials with Scalekit so it handles the token lifecycle. You do this once per environment.

    Dashboard setup steps

    Register your Scalekit environment with the Gmail connector so Scalekit handles the authentication flow and token lifecycle for you. The connection name you create will be used to identify and invoke the connection programmatically. Then complete the configuration in your application as follows:

    1. Set up auth redirects

      • In Scalekit dashboard, go to AgentKit > Connections > Create Connection. Find Gmail and click Create.

      • Click Use your own credentials and copy the redirect URI. It looks like https://<SCALEKIT_ENVIRONMENT_URL>/sso/v1/oauth/<CONNECTION_ID>/callback.

        Copy redirect URI from Scalekit dashboard

      • Navigate to Google Cloud ConsoleAPIs & ServicesCredentials. Click + Create Credentials, then OAuth client ID. Choose Web application as the application type.

        Select Web application in Google Cloud Console

      • Under Authorized redirect URIs, click + Add URI, paste the redirect URI, and click Create.

        Add authorized redirect URI in Google Cloud Console

    2. Enable Gmail API

      • In Google Cloud Console, go to APIs & ServicesLibrary. Search for “Gmail API” and click Enable.

        Enable Gmail API in Google Cloud Console

    3. Get client credentials

      Google provides your Client ID and Client Secret after you create the OAuth client ID in step 1.

    4. Add credentials in Scalekit

      • In Scalekit dashboard, go to AgentKit > Connections and open the connection you created.

      • Enter your credentials:

        Add credentials for Gmail in Scalekit dashboard

      • Click Save.

  4. quickstart.ts
    import { ScalekitClient } from '@scalekit-sdk/node'
    import 'dotenv/config'
    const scalekit = new ScalekitClient(
    process.env.SCALEKIT_ENV_URL,
    process.env.SCALEKIT_CLIENT_ID,
    process.env.SCALEKIT_CLIENT_SECRET,
    )
    const actions = scalekit.actions
    const connector = 'gmail'
    const identifier = 'user_123'
    // Generate an authorization link for the user
    const { link } = await actions.getAuthorizationLink({ connectionName: connector, identifier })
    console.log('Authorize Gmail:', link)
    process.stdout.write('Press Enter after authorizing...')
    await new Promise(r => process.stdin.once('data', r))
    // Make your first call
    const result = await actions.executeTool({
    connector,
    identifier,
    toolName: 'gmail_fetch_mails',
    toolInput: {},
    })
    console.log(result)

Connect this agent connector to let your agent:

  • Read emails — fetch messages, threads, and attachments from any label or inbox
  • Send and reply — compose new emails and reply to existing threads on behalf of your users
  • Search messages — query Gmail with full search syntax to find emails by sender, subject, or content
  • Manage labels — apply, remove, and list labels to organize messages
  • Access contacts — look up contacts and people from the user’s address book
Use Gmail response fields as returned

Response fields from Gmail tools use camelCase, such as threadId, messageId, and internalDate. Tool input parameters use the snake_case names shown in the Tool list, such as thread_id and message_id. Extract values with camelCase, then pass them with snake_case.

const fetchResponse = await actions.executeTool({
connector: 'gmail',
identifier: 'user_123',
toolName: 'gmail_fetch_mails',
toolInput: {
query: 'is:unread',
max_results: 5,
},
});
const messages = Array.isArray(fetchResponse.data?.messages)
? fetchResponse.data.messages
: [];
const threadId = typeof messages[0]?.threadId === 'string' ? messages[0].threadId : '';
if (threadId) {
const threadResponse = await actions.executeTool({
connector: 'gmail',
identifier: 'user_123',
toolName: 'gmail_get_thread_by_id',
toolInput: {
thread_id: threadId,
},
});
console.log(threadResponse.data);
}
Proxy API call
const result = await actions.request({
connectionName: 'gmail',
identifier: 'user_123',
path: '/gmail/v1/users/me/profile',
method: 'GET',
});
console.log(result);

Use the exact tool names from the Tool list below when you call execute_tool. If you’re not sure which name to use, list the tools available for the current user first.

gmail_create_draft # Create a new draft email in Gmail for the authenticated user. Constructs a MIME message and saves it as a draft. Supports plain text and HTML content types, CC, BCC, and threading. Uses OAuth credentials. 9 params

Create a new draft email in Gmail for the authenticated user. Constructs a MIME message and saves it as a draft. Supports plain text and HTML content types, CC, BCC, and threading. Uses OAuth credentials.

Name Type Required Description
body string required The body content of the draft email. Provide plain text or HTML depending on the content_type field. Example: 'Hello, this is my draft message.'
subject string required The subject line of the draft email. Example: 'Meeting Follow-up'.
to string required The recipient email address(es) for the draft. Provide a single address or comma-separated list. Example: 'recipient@example.com' or 'a@example.com,b@example.com'.
bcc string optional BCC recipients for the draft email. Provide a comma-separated list of email addresses, e.g., bcc1@example.com,bcc2@example.com. Optional.
cc string optional CC recipients for the draft email. Provide a comma-separated list of email addresses, e.g., cc1@example.com,cc2@example.com. Optional.
content_type string optional The MIME content type for the email body. Use 'text/plain' for plain text or 'text/html' for HTML content. Defaults to 'text/plain'.
schema_version string optional Optional schema version to use for tool execution
thread_id string optional The Gmail thread ID to associate this draft with an existing conversation. If provided, the draft will be part of that thread. Example: '17a1b2c3d4e5f6g7'.
tool_version string optional Optional tool version to use for execution
gmail_create_filter # Create a new email filter for the authenticated Gmail account. Specify criteria (sender, recipient, subject, query, or attachment) and actions (apply labels, forward, archive, star, trash, mark as read, etc.). At least one criteria field should be provided. Uses OAuth credentials. 17 params

Create a new email filter for the authenticated Gmail account. Specify criteria (sender, recipient, subject, query, or attachment) and actions (apply labels, forward, archive, star, trash, mark as read, etc.). At least one criteria field should be provided. Uses OAuth credentials.

Name Type Required Description
add_label_ids array optional List of Gmail label IDs to apply to matching messages (e.g., ['Label_123', 'STARRED']). Use the List Labels tool to find valid label IDs.
forward string optional Email address to forward matching messages to. The address must already be configured as a forwarding address in the Gmail account.
from string optional Sender email address or domain to match in the filter criteria (e.g., 'alerts@github.com' or '@newsletter.com').
has_attachment boolean optional If true, only match messages that have at least one attachment.
query string optional Gmail search query string to match messages using Gmail's search syntax (e.g., 'larger:10M', 'is:important').
remove_label_ids array optional List of Gmail label IDs to remove from matching messages (e.g., ['INBOX'] to archive, ['UNREAD'] to mark as read).
schema_version string optional Optional schema version to use for tool execution
should_always_mark_important boolean optional If true, always mark matching messages as important regardless of Gmail's automatic importance detection.
should_archive boolean optional If true, skip the inbox for matching messages (equivalent to adding the 'Archive' action).
should_mark_read boolean optional If true, automatically mark matching messages as read.
should_never_mark_important boolean optional If true, never mark matching messages as important, overriding Gmail's automatic importance detection.
should_never_spam boolean optional If true, never send matching messages to the Spam folder.
should_star boolean optional If true, automatically star matching messages.
should_trash boolean optional If true, automatically move matching messages to the Trash.
subject string optional Subject line text to match in the filter criteria (e.g., '[GitHub]' or 'Invoice').
to string optional Recipient email address to match in the filter criteria (e.g., 'team@example.com').
tool_version string optional Optional tool version to use for execution
gmail_fetch_mails # Fetch emails from a connected Gmail account using search filters. Requires a valid Gmail OAuth2 connection. 8 params

Fetch emails from a connected Gmail account using search filters. Requires a valid Gmail OAuth2 connection.

Name Type Required Description
format string optional Format of the returned message.
include_spam_trash boolean optional Whether to fetch emails from spam and trash folders
label_ids array optional Gmail label IDs to filter messages
max_results integer optional Maximum number of emails to fetch
page_token string optional Page token for pagination
query string optional Search query string using Gmail's search syntax (e.g., 'is:unread from:user@example.com')
schema_version string optional Optional schema version to use for tool execution
tool_version string optional Optional tool version to use for execution
gmail_get_attachment_by_id # Retrieve a specific attachment from a Gmail message using the message ID and attachment ID. 5 params

Retrieve a specific attachment from a Gmail message using the message ID and attachment ID.

Name Type Required Description
attachment_id string required Unique Gmail attachment ID
message_id string required Unique Gmail message ID that contains the attachment
file_name string optional Preferred filename to use when saving/returning the attachment
schema_version string optional Optional schema version to use for tool execution
tool_version string optional Optional tool version to use for execution
gmail_get_contacts # Fetch a list of contacts from the connected Gmail account. Supports pagination and field filtering. 5 params

Fetch a list of contacts from the connected Gmail account. Supports pagination and field filtering.

Name Type Required Description
max_results integer optional Maximum number of contacts to fetch
page_token string optional Token to retrieve the next page of results
person_fields array optional Fields to include for each person
schema_version string optional Optional schema version to use for tool execution
tool_version string optional Optional tool version to use for execution
gmail_get_message_by_id # Retrieve a specific Gmail message using its message ID. Optionally control the format of the returned data. 4 params

Retrieve a specific Gmail message using its message ID. Optionally control the format of the returned data.

Name Type Required Description
message_id string required Unique Gmail message ID
format string optional Format of the returned message.
schema_version string optional Optional schema version to use for tool execution
tool_version string optional Optional tool version to use for execution
gmail_get_send_as # Get send-as alias settings including email signature for the authenticated Gmail account. Use the user's own email address to retrieve the default send-as settings and signature. Uses OAuth credentials. 3 params

Get send-as alias settings including email signature for the authenticated Gmail account. Use the user's own email address to retrieve the default send-as settings and signature. Uses OAuth credentials.

Name Type Required Description
send_as_email string required The send-as alias email address to retrieve settings for. Use the user's own email address (e.g., 'user@example.com') to get their default signature and send-as settings.
schema_version string optional Optional schema version to use for tool execution
tool_version string optional Optional tool version to use for execution
gmail_get_thread_by_id # Retrieve a specific Gmail thread by thread ID. Optionally control message format and metadata headers. Requires a valid Gmail OAuth2 connection with read access. 5 params

Retrieve a specific Gmail thread by thread ID. Optionally control message format and metadata headers. Requires a valid Gmail OAuth2 connection with read access.

Name Type Required Description
thread_id string required Unique Gmail thread ID
format string optional Format of messages in the returned thread.
metadata_headers array optional Specific email headers to include when format is metadata
schema_version string optional Optional schema version to use for tool execution
tool_version string optional Optional tool version to use for execution
gmail_get_vacation_settings # Get the vacation auto-reply settings for the authenticated Gmail account. Uses OAuth credentials. 2 params

Get the vacation auto-reply settings for the authenticated Gmail account. Uses OAuth credentials.

Name Type Required Description
schema_version string optional Optional schema version to use for tool execution
tool_version string optional Optional tool version to use for execution
gmail_list_drafts # List draft emails from a connected Gmail account. Requires a valid Gmail OAuth2 connection. 4 params

List draft emails from a connected Gmail account. Requires a valid Gmail OAuth2 connection.

Name Type Required Description
max_results integer optional Maximum number of drafts to fetch
page_token string optional Page token for pagination
schema_version string optional Optional schema version to use for tool execution
tool_version string optional Optional tool version to use for execution
gmail_list_filters # List all email filters for the authenticated Gmail account. Returns filter criteria and actions such as label assignment, forwarding, and archiving rules. Uses OAuth credentials. 2 params

List all email filters for the authenticated Gmail account. Returns filter criteria and actions such as label assignment, forwarding, and archiving rules. Uses OAuth credentials.

Name Type Required Description
schema_version string optional Optional schema version to use for tool execution
tool_version string optional Optional tool version to use for execution
gmail_list_threads # List threads in a connected Gmail account using optional search and label filters. Requires a valid Gmail OAuth2 connection with read access. 7 params

List threads in a connected Gmail account using optional search and label filters. Requires a valid Gmail OAuth2 connection with read access.

Name Type Required Description
include_spam_trash boolean optional Whether to include threads from Spam and Trash
label_ids array optional Gmail label IDs to filter threads (threads must match all labels)
max_results integer optional Maximum number of threads to return
page_token string optional Page token for pagination
query string optional Search query string using Gmail search syntax (for example, 'is:unread from:user@example.com')
schema_version string optional Optional schema version to use for tool execution
tool_version string optional Optional tool version to use for execution
gmail_modify_message_labels # Add or remove labels on a Gmail message. Use label IDs such as 'INBOX', 'UNREAD', 'STARRED', 'IMPORTANT', 'TRASH', 'SPAM', or custom label IDs. At least one of add_label_ids or remove_label_ids should be provided. Uses OAuth credentials. 5 params

Add or remove labels on a Gmail message. Use label IDs such as 'INBOX', 'UNREAD', 'STARRED', 'IMPORTANT', 'TRASH', 'SPAM', or custom label IDs. At least one of add_label_ids or remove_label_ids should be provided. Uses OAuth credentials.

Name Type Required Description
message_id string required The Gmail message ID whose labels will be modified. Obtain this from a list or search messages operation. Example: '17a1b2c3d4e5f6g7'.
add_label_ids array optional List of label IDs to add to the message. Use system labels such as 'INBOX', 'UNREAD', 'STARRED', 'IMPORTANT', or custom label IDs retrieved from the Labels API. Example: ["STARRED", "INBOX"].
remove_label_ids array optional List of label IDs to remove from the message. Use system labels such as 'UNREAD', 'STARRED', 'INBOX', or custom label IDs. Example: ["UNREAD"].
schema_version string optional Optional schema version to use for tool execution
tool_version string optional Optional tool version to use for execution
gmail_search_people # Search people or contacts in the connected Google account using a query. Requires a valid Google OAuth2 connection with People API scopes. 6 params

Search people or contacts in the connected Google account using a query. Requires a valid Google OAuth2 connection with People API scopes.

Name Type Required Description
query string required Text query to search people (e.g., name, email address).
other_contacts boolean optional Whether to include people not in the user's contacts (from 'Other Contacts').
page_size integer optional Maximum number of people to return.
person_fields array optional Fields to retrieve for each person.
schema_version string optional Optional schema version to use for tool execution
tool_version string optional Optional tool version to use for execution
gmail_trash_message # Move a Gmail message to the Trash. The message is not permanently deleted and can be recovered from Trash within 30 days. This operation is idempotent — trashing an already-trashed message is a no-op. Uses OAuth credentials. 3 params

Move a Gmail message to the Trash. The message is not permanently deleted and can be recovered from Trash within 30 days. This operation is idempotent — trashing an already-trashed message is a no-op. Uses OAuth credentials.

Name Type Required Description
message_id string required The Gmail message ID to move to Trash. Obtain this from a list or search messages operation. Example: '17a1b2c3d4e5f6g7'.
schema_version string optional Optional schema version to use for tool execution
tool_version string optional Optional tool version to use for execution
gmail_update_send_as # Update send-as alias settings such as the email signature, display name, or reply-to address for the authenticated Gmail account. Use the user's own email address to update their default signature. Uses OAuth credentials. 7 params

Update send-as alias settings such as the email signature, display name, or reply-to address for the authenticated Gmail account. Use the user's own email address to update their default signature. Uses OAuth credentials.

Name Type Required Description
send_as_email string required The send-as alias email address to update. Use the user's own email address (e.g., 'user@example.com') to update their default signature and settings.
display_name string optional The display name shown as the sender name for this alias (e.g., 'Jane Smith').
is_default boolean optional If true, sets this send-as alias as the default address used when composing new messages.
reply_to_address string optional An optional email address that appears in the Reply-To header for messages sent from this alias (e.g., 'replies@example.com').
schema_version string optional Optional schema version to use for tool execution
signature string optional HTML email signature to set for this alias. Supports full HTML markup (e.g., '<b>Jane Smith</b><br>Senior Engineer').
tool_version string optional Optional tool version to use for execution
gmail_update_vacation_settings # Update the vacation auto-reply settings for the authenticated Gmail account. Set enableAutoReply to true to activate out-of-office responses. Uses OAuth credentials. 10 params

Update the vacation auto-reply settings for the authenticated Gmail account. Set enableAutoReply to true to activate out-of-office responses. Uses OAuth credentials.

Name Type Required Description
enable_auto_reply boolean required Whether to enable the vacation auto-reply. Set to true to turn on out-of-office responses, false to disable.
end_time string optional End time for the vacation auto-reply as epoch milliseconds in string format (e.g., '1754006400000'). After this time, auto-reply stops.
response_body_html string optional HTML body of the vacation auto-reply message. If both plain text and HTML are provided, HTML takes precedence for clients that support it.
response_body_plain_text string optional Plain text body of the vacation auto-reply message.
response_subject string optional Subject line of the vacation auto-reply email (e.g., 'Out of Office: Back on Monday').
restrict_to_contacts boolean optional If true, only contacts in the user's Google Contacts will receive the auto-reply. Default is false.
restrict_to_domain boolean optional If true, only users in the same Google Workspace domain will receive the auto-reply. Default is false.
schema_version string optional Optional schema version to use for tool execution
start_time string optional Start time for the vacation auto-reply as epoch milliseconds in string format (e.g., '1753401600000'). Auto-reply activates from this time.
tool_version string optional Optional tool version to use for execution