-
Notifications
You must be signed in to change notification settings - Fork 88
Users Gmail Filters
- API documentation
- Definitions
- Create filters
- Delete filters
- Display information about individual filters
- Display information about multiple filters
- Examples
<ByteCount> ::= <Number>[m|k|b]
<DomainName> ::= <String>(.<String>)+
<EmailAddress> ::= <String>@<DomainName>
<LabelID> ::= <String>
<LabelName> ::= <String>
<FilterID> ::= <String>
<FilterIDList> ::= "<FilterID>(,<FilterID>)*"
<FilterIDEntity> ::=
<FilterIDList> | <FileSelector> | <CSVkmdSelector> | <CSVDataSelector>
See: https://github.com/taers232c/GAMADV-XTD3/wiki/Collections-of-Items
<GmailCategory> ::=
forums|
personal|
promotions|
social|
updates
<FilterCriteria> ::=
excludechats|
(from <String>)|
(haswords|query <String>)|
(musthaveattachment|hasattachment)|
(nowords|negatedquery <String>)|
(size larger|smaller <ByteCount>)|
(subject <String>)|
(to <String>)
<FilterAction> ::=
archive|
(category <GmailCategory>)|
(forward <EmailAddress>)|
(important|notimportant)|
(label <LabelName>)|
markread|
neverspam|
star|
trash
You create filters by defining criteria for selecting messages and actions to perform on them.
gam <UserTypeEntity> [create|add] filter
(<FilterCriteria>+ <FilterAction>+) |
((json [charset <Charset>] <String>) |
(json file <FileName> [charset <Charset>]))
[buildpath [<Boolean>]]
You specify criteria by selecting individual <FilterCriteria>
or by selecting JSON data created by
gam <UserTypeEntity> print filters formatjson
.
The excludechats
criteria is not typically used as it will never apply to incoming messages.
It can be used in filters that are used to identify messages that have already been received.
All <FilterAction>s
except forward <EmailAddress>
involve adding/removing labels from a message.
-
archive
- Remove the label INBOX -
category <GmailCategory>
- Add a CATEGORY label; only one CATEGORY label can be specified -
important
- Add the label IMPORTANT -
notimportant
- Remove the label IMPORTANT -
markread
- Remove the label UNREAD -
neverspam
- Remove the label SPAM -
star
- Add the label STARRED -
trash
- Add the label TRASH -
label <LabelName>
- Add the user label<LabelName>
; only one user label can be specified. It will be created if necessary.
In Gmail, you can have a multi-level label like Top/Middle/Bottom
; you can also have a single-level label like Top/Middle/Bottom
,
- If
buildpath
is omitted or<Boolean>
is set to False, acontaining
/` will be created as single-level. - If
buildpath
is present and<Boolean>
is omitted or set to True, acontaining
/` will be created as multi-level; all parent labels are created as necessary.
If forward <EmailAddress>
is specified, the filter creation will fail if the user has not defined <EmailAddress>
as a forwarding address.
gam <UserTypeEntity> delete filters <FilterIDEntity>
When you get a filter from Google, all labels mentioned in the filter are specified with their internal Id, not the label name the user sees.
Gam has to make an extra API call to get the labels so it can map from id to name so the output reflects the label names that are familiar to the user.
If you don't need to see the label names, you can eliminate the extra API call by specifying labelidsonly
.
gam <UserTypeEntity> info filters <FilterIDEntity> [labelidsonly] [formatjson]
By default, Gam displays the information as an indented list of keys and values.
-
formatjson
- Display the fields in JSON format.
When you get a filter from Google, all labels mentioned in the filter are specified with their internal Id, not the label name the user sees.
Gam has to make an extra API call to get the labels so it can map from id to name so the output reflects the label names that are familiar to the user.
If you don't need to see the label names, you can eliminate the extra API call by specifying labelidsonly
.
gam <UserTypeEntity> show filters [labelidsonly] [formatjson]
By default, Gam displays the information as an indented list of keys and values.
-
formatjson
- Display the fields in JSON format.
gam <UserTypeEntity> print filters [labelidsonly] [todrive <ToDriveAttribute>*]
[formatjson [quotechar <Character>]]
By default, Gam displays the filters as columns of fields; the following option adds a column displaying the filter in JSON format.
-
formatjson
- Display the fields in JSON format. The columns of fields are for looking at filter characteristics, but are basically unusable as input tocreate filter
; the JSON data can be used bycreate filter
.
By default, when writing CSV files, Gam uses a quote character of double quote "
. The quote character is used to enclose columns that contain
the quote character itself, the column delimiter (comma by default) and new-line characters. Any quote characters within the column are doubled.
When using the formatjson
option, double quotes are used extensively in the data resulting in hard to read/process output.
The quotechar <Character>
option allows you to choose an alternate quote character, single quote for instance, that makes for readable/processable output.
quotechar
defaults to gam.cfg/csv_output_quote_char
. When uploading CSV files to Google, double quote "
should be used.
When copying filters from one user to another user, you will typically use the buildpath
option so that
labels like Top/Middle/Bottom
get created as multi-level.
Generate a CSV file of the source user's Gmail filters; include JSON data, only save the JSON column.
gam config csv_output_header_filter JSON redirect csv filterjson.csv user sourceuser@domain.com print filters formatjson quotechar "'"
Create those filters for the target user. Use a single thread as Google has issues occasionally when multiple filters are being created simultaneously.
gam config num_threads 1 csv filterjson.csv quotechar "'" gam user targetuser@domain.com create filter json "~JSON" buildpath
Generate a CSV file of the source user's Gmail filters; include JSON data, only save the JSON column.
gam config csv_output_header_filter JSON redirect csv filterjson.csv user sourceuser@domain.com print filters formatjson quotechar "'"
Create those filters for the target users. Make a file CopyFilters.bat containing a line like the following for each user. Use a single thread as Google has issues occasionally when multiple filters are being created simultaneously.
gam config num_threads 1 csv filterjson.csv quotechar "'" gam user targetuser@domain.com create filter json "~JSON" buildpath
Execute the batch.
gam tbatch CopyFilters.bat
Find the desired Filder ID from all the source user's filters to use in the next command.
gam redirect stdout ./filter.json user sourceuser@domain.com info filter <FilterID> formatjson
Create the filter for the target user.
gam user targetuser@domain.com create filter json file ./filter.json buildpath
Generate a CSV file of all of the source user's Gmail filters; include JSON data, save all columns for selection during creation.
gam redirect csv filterjson.csv user sourceuser@domain.com print filters formatjson quotechar "'"
Create filters that have the label Staff for the target user. Use a single thread as Google has issues occasionally when multiple filters are being created simultaneously.
gam config num_threads 1 csv_input_row_filter "'label:regex:^label Staff$'" csv filterjson.csv quotechar "'" gam user targetuser@domain.com create filter json "~JSON"
This can be done in one of two ways; select the filters during print filters
or during delete filter
.
Generate a CSV file of the user's Gmail filters that reference label Staff; delete them.
gam config csv_output_row_filter "'label:regex:^label Staff$'" redirect csv filter.csv user user@domain.com print filters
gam csv filter.csv gam user "~User" delete filter "~id"
Generate a CSV file of all of the user's Gmail filters; delete filters that reference label Staff.
gam redirect csv filter.csv user user@domain.com print filters
gam config csv_input_row_filter "'label:regex:^label Staff$'" csv filter.csv gam user "~User" delete filter "~id"
Need more help? Ask on the GAM Discussion Group
Update History
Installation
- How to Install GAM7
- How to Uograde GAMADV-XTD3 to GAM7
- How to Upgrade Legacy GAM to GAM7
- How to Update GAM7
- Install GAM as Python Library
- GAM7 on Chrome OS Devices
- GAM7 on Android Devices
- Google Network Addresses
- HTTPS Proxy
- SSL Root CA Certificates
- How to Uninstall GAM7
Configuration
- Authorization
- GAM Configuration
- Running GAM7 securely on a Google Compute Engine
- Using GAM7 with a delegated admin service account
- Using GAM7 with a YubiKey
Notes and Information
- Upgrade Benefits
- Questions? Visit the GAM Discussion Forum
- GAM Public Chat Room
- Scripts
- Other Resources
- Drive REST API v3
- BNF Syntax
- GAM Return Codes
- Python Regular Expressions
- Rclone
Definitions
Command Processing
- Bulk Processing
- Command Line Parsing
- Command Logging and Progress
- Command data from Google Docs/Sheets/Storage
- CSV Special Characters
- CSV Input Filtering
- CSV Output Filtering
- Meta Commands and File Redirection
- Permission matches
- Tag Replace
- Todrive
Collections
Client Access
- Addresses
- Administrators
- Alert Center
- Aliases
- Calendars
- Calendars - Access
- Calendars - Events
- Chrome Auto Update Expiration Counts
- Chrome Browser Cloud Management
- Chrome Device Needs Attention Counts
- Chrome Installed Apps
- Chrome Policies
- Chrome Printers
- Chrome Profile Management
- Chrome Version Counts
- Chrome Version History
- ChromeOS Devices
- Classroom - Courses
- Classroom - Guardians
- Classroom - Invitations
- Classroom - Membership
- Cloud Channel
- Cloud Identity Devices
- Cloud Identity Groups
- Cloud Identity Groups - Membership
- Cloud Identity Policies
- Cloud Storage
- Context Aware Access Levels
- Customer
- Domains
- Domains - Verification
- Domain People - Contacts & Profiles
- Domain Shared Contacts - Global Address List
- Email Audit Monitor
- Find File Owner
- Google Data Transfers
- Groups
- Groups - Membership
- Inbound SSO
- Licenses
- Mobile Devices
- Organizational Units
- Reports
- Reseller
- Resources
- Send Email
- Schemas
- Shared Drives
- Sites
- Users
- Unmanaged Accounts
- Users - Signout and Turn off 2-Step Verification
- Vault - Takeout
- Version and Help
Special Service Account Access
Service Account Access
- Users - Analytics Admin
- Users - Application Specific Passwords
- Users - Backup Verification Codes
- Users - Calendars
- Users - Calendars - Access
- Users - Calendars - Events
- Users - Chat
- Users - Classification Labels
- Users - Classroom - Profile
- Users - Deprovision
- Users - Contacts
- Users - Contacts - Delegates
- Users - Drive - File Selection
- Users - Drive - Activity/Settings
- Users - Drive - Cleanup
- Users - Drive - Comments
- Users - Drive - Copy/Move
- Users - Drive - Files-Display
- Users - Drive - Files-Manage
- Users - Drive - Orphans
- Users - Drive - Ownership
- Users - Drive - Permissions
- Users - Drive - Query
- Users - Drive - Revisions
- Users - Drive - Shortcuts
- Users - Drive - Transfer
- Users - Forms
- Users - Gmail - Client Side Encryption
- Users - Gmail - Delegates
- Users - Gmail - Filters
- Users - Gmail - Forwarding
- Users - Gmail - Labels
- Users - Gmail - Messages/Threads
- Users - Gmail - Profile
- Users - Gmail - S/MIME
- Users - Gmail - SendAs/Signature/Vacation
- Users - Gmail - Settings
- Users - Group Membership
- Users - Keep
- Users - Looker Studio
- Users - Meet
- Users - Classroom - Profile
- Users - People - Contacts & Profiles
- Users - Photo
- Users - Profile Sharing
- Users - Shared Drives
- Users - Spreadsheets
- Users - Tasks
- Users - Tokens
- Users - YouTube