Getting Started
There are different ways to get started with GmailProcessor in your Google Apps Script project:
- Use a library reference (recommended): Use this, if you just want to use the library, get easy updates and don't want to fiddle with the library code at all.
- Copy the library code (advanced): Use this if you want full control over what's being executed or use your own modified library.
Use a Library Reference (recommended)
To use the Gmail Processor library directly within Google Apps Script, you can choose from three available release channels with the associated script IDs - depending on your needs:
Follow these steps:
- Open Google Apps Script.
- Create an empty project and give it a name (e.g.
MyGmailProcessor
) or select an existing one. - Add the library in the Libraries section using the + icon and insert this Script ID:
1Qvk0v7ggfW-TJ84dlYPlDzJG8y-Dif-j9kdA1aWv4wzxE_IOkeV2juLB
- Press "Look up" and select the desired release number as version (recommended for stability) or "HEAD (Development Mode)" (recommended for automatically staying up-to-date with the potential risk of broken updates).
- See the Gmail Processor Release Notes for their corresponding Google Apps Script library version.
- Or use this URL to verify the release version of a Google Apps Script Library: https://script.google.com/macros/library/d/1Qvk0v7ggfW-TJ84dlYPlDzJG8y-Dif-j9kdA1aWv4wzxE_IOkeV2juLB/{libVersion} (replace
{libVersion}
with the number from the drop-down in Google Apps Script).
- Set the identifier to
GmailProcessorLib
(any name will do, but we will use this identifier as a reference in all examples and documentation) - Replace the contents of the initially created file
Code.gs
with the following code, take the config from the Simple Example and save the changes:
Expand example
function run() {
const config = {
description:
"Use this to get started with Gmail Processor. It stores an attachment to Google Drive.",
settings: {
markProcessedMethod: "mark-read",
},
global: {
thread: {
match: {
query:
"has:attachment -in:trash -in:drafts -in:spam after:{{date.now|formatDate('yyyy-MM-dd')}} is:unread subject:\"[GmailProcessor-Test] simple\"",
},
},
},
threads: [
{
match: {
query: "from:${user.email}",
},
messages: [
{
attachments: [
{
match: {
name: "^invoice\\.pdf$",
},
actions: [
{
name: "attachment.store",
args: {
location:
"/GmailProcessor-Tests/e2e/simple/{{message.date|formatDate('yyyy-MM-dd')}}/{{message.subject}}-{{attachment.name}}",
conflictStrategy: "keep",
},
},
],
},
],
},
],
},
],
}
return GmailProcessorLib.run(config, "dry-run")
}
- Perform an initial execution of the function
run
to grant all required permissions (see Required API Permissions for more details):- Select your account you want to grant access for
- When the message "Google did not verify the app" click on "Advanced" and "Go to ..." to proceed
- Grant access to all listed apps by clicking "Allow"
Adjust the configuration (see section Configuration Reference) to your needs. It's always recommended to test config changes using the run mode dry-run
(2nd parameter to the run()
function). That doesn't touch anything (GMail, GDrive, Google Sheets) but produces a log that shows what would have been done. This way any change in your configuration or an upgrade to a newer version of the library can be tested without any risk of data-loss.
If you're satisfied with the results change the run mode from dry-run
to safe-mode
to actually do the processing and execute the run
function again.
For automatic triggering you can create a time-based trigger that runs at certain intervals (e.g. once per day or every hour).
Should you run into any problems please create an issue and put the configuration as well as the log output there. Make sure to remove any sensitive information before doing so, since the issue contents will be publicly visible.
Copy the Library Code (advanced)
To use a copy of the library code in your project simply replace steps 3-5 from above with the following steps:
- Create a new file using the + icon at "Files" and selecting "Script"
- Give it a name (e.g.
GmailProcessorLib
resulting in the fileGmailProcessorLib.gs
to be created) - Replace the contents of the file with the library code of the release asset
GmailProcessorLib.js
from the latest release or your own built version frombuild/gas/lib/GmailProcessorLib.js
.
Follow the remaining steps from step 6 onwards from above.
Required API Permissions
To enable full processing of the emails the following OAuth Scopes for Google APIs are requested and need to be granted:
https://mail.google.com/
: Access Gmail API to process emailshttps://www.googleapis.com/auth/drive
: Access Google Drive API to store fileshttps://www.googleapis.com/auth/script.external_request
: Used for end-to-end tests to fetch example attachments via HTTPhttps://www.googleapis.com/auth/script.send_mail
: Used for end-to-end tests to send example emailshttps://www.googleapis.com/auth/spreadsheets
: Access Google Spreadsheets API to store logs of processed emailshttps://www.googleapis.com/auth/userinfo.email
: Get the user's email address to be used in the configuration