-
Notifications
You must be signed in to change notification settings - Fork 88
Users Keep
- API documentation
- Notes
- Definitions
- Add Note
- Delete Note
- Display Notes
- Download Note Attachments
- Manage Notes permissions
- Examples
To use these commands you must add the 'Keep API' to your project and update your service account authorization.
gam update project
gam user [email protected] check serviceaccount
<StorageBucketName> ::= <String>
<StorageObjectName> ::= <String>
<StorageBucketObjectName> ::=
https://storage.cloud.google.com/<StorageBucketName>/<StorageObjectName>|
https://storage.googleapis.com/<StorageBucketName>/<StorageObjectName>|
gs://<StorageBucketName>/<StorageObjectName>|
<StorageBucketName>/<StorageObjectName>
<UserGoogleDoc> ::=
<EmailAddress> <DriveFileIDEntity>|<DriveFileNameEntity>|(<SharedDriveEntity> <SharedDriveFileNameEntity>)
<JSONData> ::=
(json [charset <Charset>] <String>) | (json file <FileName> [charset <Charset>]) |
<NoteContent> ::=
((text <String>)|
(textfile <FileName> [charset <Charset>])|
(gdoc <UserGoogleDoc>)|
(gcsdoc <StorageBucketObjectName>)|
<JSONData>)
<NotesName> ::= notes/<String>
<NotesNameList> ::= "<NotesName>(,<NotesName)*"
<NotesNameEntity> ::=
<NotesNameList> | <FileSelector> | <CSVFileSelector> | <CSVkmdSelector> | <CSVDataSelector>
See: https://github.com/taers232c/GAMADV-XTD3/wiki/Collections-of-Items
<NotesField> ::=
attachments|
body|
createtime|
name|
permissions|
title|
trashed|
trashtime|
updatetime
<NotesFieldList> ::= "<NotesField>(,<NotesField>)*"
<DriveFolderID> ::= <String>
<DriveFolderName> ::= <String>
<DriveFileParentAttribute> ::=
(parentid <DriveFolderID>)|
(parentname <DriveFolderName>)|
(anyownerparentname <DriveFolderName>)|
(teamdriveparentid <DriveFolderID>)|
(teamdriveparent <SharedDriveName>)|
(teamdriveparentid <SharedDriveID> teamdriveparentname <DriveFolderName>)|
(teamdriveparent <SharedDriveName> teamdriveparentname <DriveFolderName>)
Keep notes have an ID that is referred to by Google as its name
; this is the value
you will use wherever <NotesName>
is required.
gam <UserTypeEntity> create note [title <String>]
[missingtextvalue <String>]
<NoteContent>
[copyacls [copyowneraswriter]]
[compact|formatjson|nodetails]
<NoteContent>
is the note text, there are four ways to specify it:
-
message|textmessage|htmlmessage <String>
- Use<String>
as the note text -
file|htmlfile <FileName> [charset <Charset>]
- Read the note text from<FileName>
-
gdoc|ghtml <UserGoogleDoc>
- Read the note text from<UserGoogleDoc>
-
gcsdoc|gcshtml <StorageBucketObjectName>
- Read the note text from the Google Cloud Storage file<StorageBucketObjectName>
Use the <JSONData>
option to specify the title, text and list options.
Use the missingtextvalue <String>
option to have GAM supply a value for JSON list
and text
items that are missing text fields.
This option must appear before the <JSONData>
option. If not specified and a text field is missing, you'll get the following error:
Request contains an invalid argument.
The title <String>
option takes precedence over the JSON title.
If you specify options json
and copyacls
, the note is created and any ACLs
from the json data are added to the note. If you also specify copyowneraswriter
,
the original note owner is added as a writer to the created note.
By default, Gam displays the created note as an indented list of keys and values; the note text is displayed as individual lines.
-
compact
- Display the note text with escaped carriage returns as \r and newlines as \n -
formatjson
- Display the note in JSON format -
nodetails
- Display the note name only
gam <UserTypeEntity> delete note <NoteNameEntity>
Display selected notes
gam <UserTypeEntity> info note <NotesNameEntity>
[fields <NotesFieldList>]
[compact|formatjson]
By default, Gam displays the information as an indented list of keys and values; the note text is displayed as individual lines.
-
compact
- Display the note text with escaped carriage returns as \r and newlines as \n -
formatjson
- Display the note in JSON format
Display all notes
gam <UserTypeEntity> show notes
[fields <NotesFieldList>] [filter <String>]
[role owner|writer]
[countsonly]
[compact|formatjson]
By default, GAM displays all non-trashed notes:
-
filter trashed
- Display notes in the trash -
role owner|writer
- Display notes where the user has the specified role
When option countsonly
is specified, the number of notes a user owns, the number of notes of user can edit
and the total number of notes is displayed.
By default, Gam displays the information as an indented list of keys and values; the note text is displayed as individual lines.
-
compact
- Display the note text with escaped carriage returns as \r and newlines as \n -
formatjson
- Display the note in JSON format
gam <UserTypeEntity> print notes [todrive <ToDriveAttribute>*]
[fields <NotesFieldList>] [filter <String>]
[role owner|writer]
[countsonly]
[formatjson [quotechar <Character>]]
By default, GAM displays all non-trashed notes:
-
filter trashed
- Display notes in the trash -
role owner|writer
- Display notes where the user has the specified role
When option countsonly
is specified, the number of notes a user owns, the number of notes of user can edit
and the total number of notes is displayed.
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.
gam <UserTypeEntity> get noteattachments <NotesNameEntity>
[targetfolder <FilePath>] [targetname <FileName>] [overwrite [<Boolean>]]
[<DriveFileParentAttribute>]
By default, when getting an attachment, it is downloaded to the directory specified in gam.cfg/drive_dir
.
-
targetfolder <FilePath>
- Specify an alternate location for the downloaded file.
By default, when getting an attachment, the local name is the same as the Note title or attachment
if the Note doesn't have a title..
-
targetname <FileName>
- Specify an alternate name for the downloaded file.
The strings #email#
, #user#
and #username#
will be replaced by the the user's full emailaddress or just the name portion
in targetfolder <FilePath>
and targetname <FileName>
.
The final attachment local file name will have -<N>.<extension>
appended to the base name:
-
<N>
- The index of the attachment -
<extension>
- An extension based on the MIME type;gif, jpg, png, webp
By default, when getting an attachment, an existing local file will not be overwritten; a numeric prefix is added to the filename.
-
overwrite
- Overwite an existing file -
overwrite true
- Overwite an existing file -
overwrite false
- Do not overwite an existing file; add a numeric prefix and create a new file
If <DriveFileParentAttribute>
is specified, the dowloaded attachments will be uploaded to Google Drive.
- The owner of a note can not have it's role changed.
- The owner of a note can not be deleted.
- A new owner can not be added to a note.
gam <UserTypeEntity> create noteacl <NotesNameEntity>
(user|group <EmailAddress>)+
<JSONData>
[nodetails]
By default, Gam displays the user, note name, number of created permissions and the permission details
-
nodetails
- Do not display the permission details
gam <UserTypeEntity> delete noteacl <NotesNameEntity>
(user|group <EmailAddress>)+
<JSONData>
Use the user and
group`` options to specify email addresses.
Use the json
option to specify permissions.
{"permissions": [{"email": "[email protected]", "name": "notes/abc123xyz/permissions/def456uvw", "role": "WRITER", "user": {"email": "[email protected]"}}]}
gam redirect csv ./notes.csv user [email protected] print notes formatjson quotechar "'"
gam csv ./notes.csv quotechar "'" gam user [email protected] create note json "~JSON" copyacls
gam redirect stdout ./notes.json user [email protected] info note notes/abc123xyz permissions formatjson
gam user [email protected] delete notesacl notes/abc123xyz json file notes.json
gam redirect csv ./notes.csv user [email protected] print notes fields name filter trashed
gam user [email protected] delete notes csvfile notes.csv:name
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