Page Summary
-
Add-ons require user authorization and request specific permissions called OAuth scopes to access data or act on a user's behalf.
-
Scopes are declared in the add-on's manifest and can be viewed in the script project's overview section, with explicit scope definition recommended for better control and security.
-
Certain restricted scopes, particularly for Gmail and Editor add-ons, require careful consideration and adherence to specific guidelines for add-on review and publication.
-
Google Workspace add-ons have specific scopes tailored to each service, such as temporary access to document content for Editors, access to message metadata for Gmail, and event access for Calendar, requiring developers to choose the appropriate scope for the desired functionality.
-
Using sensitive or restricted scopes might necessitate OAuth client verification, and it is crucial to always use the least permissive scopes possible to minimize security risks and ensure user privacy.
Users must authorize add-ons and other applications that access their data or act on their behalf. When a user runs an add-on for the first time, the add-on UI presents an authorization prompt to start the authorization flow.
During this flow, the prompt tells the user what the application wants permission to do. For example, an add-on might want permission to read a user's email message or create events in their calendar. The add-on's script project defines these individual permissions as OAuth scopes .
You declare scopes in your manifest
using URL
strings. During the authorization flow, Apps Script presents a
human-readable description of the scope to the user. For example, your Google Workspace add-on
might use the "Read current message" scope, which is written in your manifest as https://www.googleapis.com/auth/gmail.addons.current.message.readonly
. During
the authorization flow, an add-on with this scope asks
the user to allow the add-on to: View your email
messages when the add-on is running.
The scopes Apps Script uses for its various services overlap with the scopes used by the related API. For example, Apps Script's Calendar service uses many of the same scopes as the Calendar API . You can look up the scopes that particular Apps Script service methods require in the Apps Script reference documentation .
View scopes
You can see the scopes your script project currently requires by doing the following:
- Open the script project.
- At the left, click Overview .
- View the scopes under "Project OAuth Scopes."
You can also view the script project's current scopes in the project manifest,
under the oauthScopes
field, but only if you have set those scopes explicitly
.
Set explicit scopes
Apps Script automatically determines what scopes a script needs by scanning its code for function calls that require them. For most scripts this is sufficient and saves you time, but for published add-ons you should exercise more direct control of the scopes.
For example, Apps Script might give an
add-on script project the very permissive scope https://mail.google.com
by default. When a user authorizes a script project
with this scope, the project is granted full access to the user's
Gmail account. For published add-ons, you mustreplace this scope with a more limited set that cover the
add-ons's needs and no more.
You can explicitly set the scopes your script project uses by editing
its manifest
file. The manifest field oauthScopes
is an array
of all scopes used by the add-on. To set your project's
scopes, do the following:
- View the scopes your add-on uses . Determine what changes need to be made, such as using a narrower scope.
- Open your add-on's manifest file .
- Locate the top-level field labeled
oauthScopes. If it is not present, you can add it. -
The
oauthScopesfield specifies an array of strings. To set the scopes your project uses, replace the contents of this array with the scopes you want it to use. For example, for a Google Workspace add-on that extends Gmail you might have the following:{ ... "oauthScopes" : [ "https://www.googleapis.com/auth/gmail.addons.current.message.metadata" , "https://www.googleapis.com/auth/userinfo.email" ], ... } -
Save the manifest file changes.
OAuth verification
Using certain sensitive OAuth scopes may require that your add-on go through OAuth client verification before you can publish it. For more information, see the following guides:
- OAuth client verification for Apps Script
- Unverified apps
- OAuth verification FAQ
- Google APIs Service: User Data Policy
Restricted scopes
Certain scopes are restricted and subject to additional rules that help protect user data. If you intend to publish a Gmail or Editor add-on that uses one or more restricted scopes, the add-on must comply with all the specified restrictions before it can be published.
Review the full list of restricted scopes before you attempt to publish. If your add-on uses any of them, you must comply with the Additional requirements for specific API scopes prior to publishing.
The Google Workspace Developer Tools extension for Visual Studio Code provides diagnostic information for all scopes including the scope's description and whether it is sensitive or restricted.
Choose scopes for Google Workspace add-ons
The following sections provide scopes that are commonly used for Google Workspace add-ons.
Editor scopes
The following frequently-used scopes for Google Workspace add-ons extend Google Docs, Google Sheets, and Google Slides.
https://www.googleapis.com/auth/documents.currentonly
Required if the add-on accesses the Google Apps Script Docs API. Grants temporary access to the open document's content.
https://www.googleapis.com/auth/spreadsheets.currentonly
Required if the add-on accesses the Apps Script Sheets API. Grants temporary access to the open spreadsheet's content.
https://www.googleapis.com/auth/presentations.currentonly
Required if the add-on accesses the Apps Script Slides API. Grants temporary access to the open presentation's content.
https://www.googleapis.com/auth/drive.file
Required for the add-on to use onFileScopeGrantedTrigger
and if the add-on accesses
Docs, Sheets,
Slides, or Drive API
.
Grants per-file access to files created or opened by the app using the
Apps Script Advanced Google Drive Service
. This doesn't allow similar
actions using the basic Drive service
.
File authorization is granted on a per-file basis and is revoked when
the user deauthorizes the app.
Gmail
There are scopes created specifically for Google Workspace add-ons to help protect user Gmail data. Add these scopes explicitly to your add-on manifest, along with any others required.
The following table lists frequently-used scopes for Google Workspace add-ons that extend Gmail. If your add-on extends Gmail, you must add any scopes labeled Requiredto your Google Workspace add-on manifest.
Replace the broad https://mail.google.com
scope with a narrower set of
scopes that allow the interactions your add-on needs.
https://www.googleapis.com/auth/gmail.addons.current.action.compose
Required if the add-on uses compose action triggers . Allows the add-on to temporarily create new drafts messages and replies. See Composing draft messages for details; this scope is often used with [compose actions] (/workspace/add-ons/gmail/extending-compose-ui). Requires an access token.
https://www.googleapis.com/auth/gmail.addons.current.message.metadata
Grants temporary access to the open message's metadata (such as the subject or recipients). Doesn't allow reading of message content and requires an access token.
Required if the add-on uses metadata in compose action triggers. For compose actions , this scope is required if a compose trigger needs access to metadata. In practice, this scope lets a compose trigger access recipient lists (to:, cc:, and bcc:) of a reply email draft.
https://www.googleapis.com/auth/gmail.addons.current.message.action
Grants access to the open message's content upon user interaction, such as when selecting an add-on menu item. Requires an access token.
https://www.googleapis.com/auth/gmail.addons.current.message.readonly
Grants temporary access to the open message's metadata and content. Also grants access to the content of other messages in the open thread. Requires an access token.
https://www.googleapis.com/auth/gmail.readonly
Read any email metadata and content, including the open message. Required if you need to read information about other messages, such as when conducting a search query or reading an entire mail thread.
Google Calendar scopes
The following table lists frequently-used scopes for Google Workspace add-ons that extend Google Calendar.
https://www.googleapis.com/auth/calendar.addons.execute
Required if the add-on accesses Calendar event metadata. Allows the add-on to access event metadata.
https://www.googleapis.com/auth/calendar.addons.current.event.read
Required if the add-on needs to read
user-generated event data.
Allows the
add-on to access user-generated event data.
This data is only available if the addOns.calendar.eventAccess
manifest field
is set to READ
or READ_WRITE
.
https://www.googleapis.com/auth/calendar.addons.current.event.write
Required if the add-on needs to write
user-generated event data.
Allows the
add-on to edit user-generated event data.
This data is only available if the addOns.calendar.eventAccess
manifest field
is set to WRITE
or READ_WRITE
.
Google Chat scopes
To call the Google Chat API, authenticate as the Google Chat user or as the Google Chat app . Each type of authentication requires different scopes, and not all Chat API methods support app authentication.
To learn more about Chat scopes and authentication types, see the Chat API Authentication and authorization overview
The following table shows frequently-used Chat API methods and scopes based on the supported authentication types:
-
chat.messages.create -
chat.messages -
chat.import
-
chat.bot
-
chat.spaces.create -
chat.spaces -
chat.import
-
chat.app.spaces.create -
chat.app.spaces
-
chat.memberships -
chat.memberships.app -
chat.import
-
chat.app.memberships
- For events about messages:
-
chat.messages -
chat.messages.readonly - For events about reactions:
-
chat.messages.reactions -
chat.messages.reactions.readonly -
chat.messages -
chat.messages.readonly - For events about memberships:
-
chat.memberships -
chat.memberships.readonly - For events about the space:
-
chat.spaces -
chat.spaces.readonly
Google Drive scopes
The following table lists frequently-used scopes for Google Workspace add-ons that extend Google Drive.
https://www.googleapis.com/auth/drive.addons.metadata.readonly
Required if the add-on implements a contextual interface triggered when the user selects items in Drive. Allows the add-on to read limited metadata about items a user has selected in Google Drive. The metadata is limited to the item's ID, title, MIME type, icon URL and whether the add-on has permission to access the item.
https://www.googleapis.com/auth/drive.file
Recommended if the add-on needs to access individual Drive files. Grants per-file access to files created or opened by the app using the Apps Script Advanced Drive Service . This doesn't allow similar actions using the basic Drive service . File authorization is granted on a per-file basis and is revoked when the user deauthorizes the app. See the Request file access for selected files example .
Access tokens
To protect user data, the Gmail scopes used in
Google Workspace add-ons grant temporary access to user data. To enable temporary
access, call GmailApp.setCurrentMessageAccessToken
using an access token from an action event object
.
The access token that enables Gmail scopes isn't the same as the
access token returned by ScriptApp.getOAuthToken
. Use the token provided in
the action event object.
The following shows an example of setting an access token to allow access to
a message's metadata. The only scope necessary for this example is https://www.googleapis.com/auth/gmail.addons.current.message.metadata
.
function
readSender
(
e
)
{
var
accessToken
=
e
.
gmail
.
accessToken
;
var
messageId
=
e
.
gmail
.
messageId
;
//
The
following
function
enables
short
-
lived
access
to
the
current
//
message
in
Gmail
.
Access
to
other
Gmail
messages
or
data
isn
't
//
permitted
.
GmailApp
.
setCurrentMessageAccessToken
(
accessToken
);
var
mailMessage
=
GmailApp
.
getMessageById
(
messageId
);
return
mailMessage
.
getFrom
();
}
Other Google Workspace scopes
Your add-on may require additional scopes if it uses other Google Workspace or Apps Script services. In most cases, Apps Script detects these scopes and updates the manifest automatically. When editing your manifest's scope list, don't remove any scopes unless you are replacing them with a narrower alternative.
The following table shows scopes that Google Workspace add-ons often use:
https://www.googleapis.com/auth/userinfo.email
Allows the project to read the current user's email address.
https://www.googleapis.com/auth/script.external_request
Allows the project to make UrlFetch
requests. This is also required if the project makes use of the OAuth2 for Apps Script
library.
https://www.googleapis.com/auth/script.locale
Allows the project to learn the current user's locale and timezone. See Accessing user locale and timezone for details.
https://www.googleapis.com/auth/script.scriptapp
Allows the project to create triggers .
https://www.googleapis.com/auth/workspace.linkpreview
Required if the add-on previews links from a third-party service. Allows the project to see a link within a Google Workspace application while the user is interacting with it. To learn more, see Preview links with smart chips .
https://www.googleapis.com/auth/workspace.linkcreate
Required if the add-on creates resources in a third-party service. Allows the project to read the information that users submit to the resource creation form and insert a link to the resource within a Google Workspace application. To learn more, see Create third-party resources from the @ menu .

