-
Notifications
You must be signed in to change notification settings - Fork 0
/
Copy pathREADME.txt
305 lines (239 loc) · 15.5 KB
/
README.txt
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
124
125
126
127
128
129
130
131
132
133
134
135
136
137
138
139
140
141
142
143
144
145
146
147
148
149
150
151
152
153
154
155
156
157
158
159
160
161
162
163
164
165
166
167
168
169
170
171
172
173
174
175
176
177
178
179
180
181
182
183
184
185
186
187
188
189
190
191
192
193
194
195
196
197
198
199
200
201
202
203
204
205
206
207
208
209
210
211
212
213
214
215
216
217
218
219
220
221
222
223
224
225
226
227
228
229
230
231
232
233
234
235
236
237
238
239
240
241
242
243
244
245
246
247
248
249
250
251
252
253
254
255
256
257
258
259
260
261
262
263
264
265
266
267
268
269
270
271
272
273
274
275
276
277
278
279
280
281
282
283
284
285
286
287
288
289
290
291
292
293
294
295
296
297
298
299
300
301
302
303
304
Copyright (C) 2010 Google Inc.
Licensed under the Apache License, Version 2.0 (the "License");
you may not use this file except in compliance with the License.
You may obtain a copy of the License at
http://www.apache.org/licenses/LICENSE-2.0
Unless required by applicable law or agreed to in writing, software
distributed under the License is distributed on an "AS IS" BASIS,
WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
See the License for the specific language governing permissions and
limitations under the License.
Contents:
---------
1. Introduction
1.1 Other files
1.2 README style
2. Commands
2.1 Services
2.1.1 Blogger
2.1.2 Calendar
2.1.3 Contacts
2.1.4 Docs
2.1.5 Picasa
2.1.6 Sites
2.1.7 YouTube
2.2 The 'list' task
3. Options
3.1 Tags
3.2 Date
1. Introduction
Welcome to the README. If you're reading this after checking out the svn repository, this should have the most up-to-date information on the capabilities and usage of the code in svn HEAD. Otherwise, it should more or less match the Manual on the GoogleCL project wiki (http://code.google.com/p/googlecl/wiki/Manual)
If you have no idea what this project is or is about, poke around on our home page at http://code.google.com/p/googlecl.
1.1 Other files
For installation instructions, see INSTALL.txt
For help with the configuration file, see README.config
README.new-usage contains a crash-course in the usage changes from the previous version.
1.2 README style
Wiki markup is used occasionally in this document:
* The '`' character marks example commands.
* '*' denotes an entry in a list (such as this one).
2. Commands
Some terminology:
* service - The Google service being used (Picasa, Blogger, etc.)
* task - The task that the service will be doing (tag, post, delete, etc.)
You can also access help by typing `$ google help` or help on a specific service with `$ google help <service>`. For help with available options and what they mean, use `$ google --help`
2.1 Services
Each sub-section corresponds to a service, which lists the available tasks and some options commonly used with that service. Each task follows the format "task: description. `example`". Note that the `example` omits the initial `$ google <service>`
You can access a list of available tasks and their options with the "help" command as described above.
2.1.1 Blogger
Common options:
* blog: If you have multiple blogs, you can indicate which one to use. The value you give here the is saved in your config file for future use, if your config file does not already contain an entry for "blog". See ConfigurationOptions.
Tasks:
* delete: Delete posts. `delete --title "Silly post number [0-9]*"`
* list: List posts. `list title,url-site`
* post: Upload posts. `post --tags "GoogleCL, awesome" "Here's a really short post. The next posts will be much longer!" ~/blog/2010/may/*`
* tag: Label posts `tag --title "Dev post" --tags "Python, software"`
Note: You can use `--owner` to specify another user's blog when listing posts, but you have to provide a Blogger ID (the number in http://www.blogger.com/profile/NUMBER), not the Google account name.
2.1.2 Calendar
Common options:
* cal: Specify the name of the calendar. This can be a regular expression. If this option is not given, the primary calendar is used.
* date: Specify a date, or date range. For the add task, this DISABLES the Quick Add text parsing feature, but allows you to specify when the event occurs. For listing and deleting events, `--date` will only return events that fall on or within the given date(s). Dates are inclusive, so `--date 2010-06-23,2010-06-25` will include the 23rd, 24th, and 25th of June 2010. See the detailed description of the `--date` option below.
* reminder: (for add task only) Add a reminder to the events being added, one per default reminder type in your calendar settings. Default is in minutes, though you can say something like "2h" for one hour, "1d" for one day, etc.
Tasks:
* add: Add event to calendar. `add "Dinner party with George tomorrow at 6pm" --reminder 1h`
* delete: Delete an event. `delete --cal "GoogleCL dev cal" --title "Release.*"`
* list: List events. `list --date 2010-06-01,2010-06-30`
* today: List events for today only. `today`
*Note:* The add task uses the 'Quick Add' feature unless you specify `--date`. You you can read about Quick Add here: http://www.google.com/support/calendar/bin/answer.py?answer=36604#text
*Warning*: Because the add task uses 'Quick Add', it will not work for non-English calendars. See Issue 211. If you have a non-English calendar, use the `--date` option to add events to your calendar.
2.1.3 Contacts
Tasks:
* add: Add contacts. `add "Jim Raynor, [email protected]" contacts.csv`
* delete: Delete contacts. `delete --title Jerkface`
* list: List contacts. `list name,email --title ".*bob.*" > the_bobs.csv`
* add-groups: Add contact groups. `add-groups "Work" "Friends"`
* delete-groups: Delete contact groups. `delete-groups "Friends"`
* list-groups: List contact groups. `list-groups "my group"`
2.1.4 Docs
Common options:
* format: Force docs to use the extension you provide.
* folder: Specify a folder on Docs to search in or upload to.
Tasks:
* delete: Delete docs. `delete --title "Evidence"`
* edit: Edit or view a document. `edit --title "Shopping list" --editor vim`
* get: Download docs. `get --title "Homework [0-9]*"`
* list: List documents. `list title,url-direct --delimiter ": "`
* upload: Upload documents. `upload the_bobs.csv ~/work/docs_to_share`
Note: Uploading arbitrary files is only possible for Apps Premier customers, using the --no-convert option. See the FAQ.
2.1.5 Picasa
Common options:
* owner: Owner of the albums you want to deal with. This will work with all tasks but create and delete. For example, to download bob's album, add `--owner bob` to the "get" task. To post to your friend's album that she shared with you, add `--owner your_friend` to the "post" task.
Tasks:
* create: Create an album. `create --title "Summer Vacation 2009" --tags Vermont ~/photos/vacation2009/*`
* delete: Delete photos or albums. `delete --title "Stupid album"`
* get: Download photos. `get --title "My Album" /path/to/download/folder`
* list: List photos or albums. `list title,url-direct --query "A tag"`
* post: Add photos to an album. `post --title "Summer Vacation 2008" ~/old_photos/*.jpg`
* tag: Tag photos. `tag --title "Album I forgot to tag" --tags oops`
2.1.6 Sites
All sites pages have a contentEntryID, a value that uniquely identifies it. Some commands use this value.
Common options:
* domain: If your site has a domain, either specify it in config or with this option
* site: This is a particular site out of all the sites that you can access. Also can be in config.
Tasks:
* sites: show all the sites that you can see/access (site feed).
* list: List site pages for the site (content feed). By default, lists 'first page' of results: option/config parameter max_queries can increase this. `list --site=mysite --max_results=50`. The --query option does a full text search, returning pages that match: `list --site=mysite --query="some text"`. Finally, other queries (path, kind, parent, ancestor) can be specified: `list --site=mysite path=/path/to/page`, `list --site=mysite parent=contentEntryID`, `list --site=mysite kind=webpage`.
* upload: Upload a page to sites, optionally as a subpage: `upload --site=mysite --src=file --title=page_name --folder=parent_path --format=webpage`. Default format is webpage, see https://developers.google.com/google-apps/sites/docs/1.0/reference#feed_Content for more. folder is the path to the parent; default is top-level of site.
* delete: delete a page from a site: `delete site=mysite --title=/path/to/page`.
2.1.7 YouTube
Common options:
* category: YouTube category to assign to the video. This is required, and a little tricky. Here's the mapping for YouTube categories to `--category` values (and capitalization counts!)
|| *YouTube category* || *Value for* `--category` ||
|| Autos & Vehicles || Autos ||
|| Comedy || Comedy ||
|| Education || Education ||
|| Entertainment || Entertainment ||
|| Film & Animation || Film ||
|| Gaming || Games ||
|| Howto & Style || Howto ||
|| Music || Music ||
|| News & Politics || News ||
|| Nonprofits & Activism || Nonprofit ||
|| People & Blogs || People ||
|| Pets & Animals || Animals ||
|| Science & Technology || Tech ||
|| Sports || Sports ||
|| Travel & Events || Travel ||
Tasks:
* delete: Delete videos. `delete --title ".*"`
* list: List your videos. `list`
* post: Post a video. `post --category Education --devtags GoogleCL killer_robots.avi`
* tag: Tag videos. `tag -n ".*robot.*" --tags robot`
2.2. The List task
The list task can be given additional arguments to specify what exactly is being listed. For example,
`$ google <service> list field1,field2,field3 --delimiter ": "`
will output those fields, in that order, with ": " as a delimiter. Valid values for `<`field1`>` etc. are dependent on the service being used.
Common (all services):
*Note:* These are enabled for all services, but the service may not have a definition for it. For example, Docs does not support summaries.
* 'summary' - summary text. Includes Picasa captions.
* 'title', 'name' - displayed title or name.
* 'url' - treated as 'url-direct' or 'url-site' depending on setting in preferences file. See the note at the end of this section.
* 'url-site' - url of the site associated with the resource.
* 'url-direct' - url directly to the resource.
* 'xml' - dump the XML representation of the result.
Blogger:
* 'access' - access level of the post (either 'public' or 'draft')
* 'author' - author of the post
* 'tags', 'labels', - tags or labels on the post.
Calendar:
* 'when' - when an event takes place.
* 'where' - where the event takes place.
Contacts:
* 'address', 'where' - postal addresses.
* 'birthday', 'bday' - birthday.
* 'email' - email address(es).
* 'event', 'dates', 'when' - events such as birthdays, anniversaries, etc.
* 'im' - instant messanger handles.
* 'name' - full name.
* 'nickname' - nickname.
* 'notes' - notes on a contact.
* 'organization', 'company' - company or organization.
* 'phone_number', 'phone' - phone numbers.
* 'relation' - names of relations, such as manager, spouse, etc.
* 'title', 'org_title' - job title.
* 'user_defined', 'other' - custom labels.
* 'website', 'links' - websites and links.
Picasa:
* Photos (picasa list)
** 'caption', 'summary' - photo caption
** 'distance' - distance between camera and target.
** 'ev' - exposure value.
** 'exposure' - exposure time.
** 'flash' - if flash was used.
** 'focallength'- focal length used.
** 'fstop' - focal length divided by "effective" aperture diameter (aka f-number, focal ratio, or relative aperture)
** 'imageUniqueID', 'id' - EXIF identifier assigned uniquely to each image.
** 'iso' - iso equivalent value used.
** 'make' - make of the camera used.
** 'model' - model of the camera used.
** 'tags' - tags on the photo.
** 'time', 'when' - time the photo was taken (as millisecond timestamp).
** 'url-download' - link directly to download an image.
* Albums (picasa list-albums)
** 'access', 'visibility' - visibility setting on the album.
** 'location', 'where' - location text of the album properties.
** 'published', 'when' - when the album was uploaded
YouTube:
* 'author', 'owner' - username of video uploader.
* 'minutes', 'time', 'length', 'duration' - length of the video, in MM:SS format. (Note that if you specify ':' as a delimiter, it will be MM SS).
* 'seconds' - length of the video in seconds.
* 'status' - status of the video. This is still an uncertain feature.
* 'tags' - tags on the video.
The difference between 'url-site' and 'url-direct' is best exemplified by a picasa photo: 'url-site' gives a link to the photo in the user's album, 'url-direct' gives a link to the image url. If 'url-direct' is specified but is not applicable, 'url-site' is placed in its stead, and vice-versa.
3. Options
GoogleCL will fill in options in what it hopes is a natural way. If you do not specify any options explicitly with `-<letter>` or `--<option>`, the program will suck in values from the command line to replace the missing required options. For example,
`$ google help contacts`
...
`list: List contacts`
` Requires: fields AND title AND delimiter`
says that `--fields --title --delimiter` are all required. If you haven't changed your basic configuration, there should be a line under the config header `[CONTACTS]` that says `fields = name,email`, so that required option is fulfilled. (Note that there is a `fields` entry under `[GENERAL]` so you never need to supply a value for `fields`, and shouldn't, unless you specify it with `--fields=<my new fields>`)
Next up is `title`, so if you issue the contacts list command with any free-floating arguments, the first one will be set to `title`.
Finally, `delimiter` is always set to "," by default, so that's satisfied as well.
This means that
`$ google contacts list Huey Dewey Louie`
`$ google contacts list Huey Dewey Louie --fields name,email`
`$ google contacts list --fields name,email --title Huey Dewey Louie`
all give the same output.
Some tasks have a conditional requirement, such as (title OR query). In this case, `title` is filled first, and GoogleCL assumes you do not want to specify a query. Of course, if you filled `query` explicitly and not `title`, `title` is not filled in with any command line arguments.
Here are some more details on the trickier options you can specify.
3.1 Tags
The tags option will let you both add and remove tags / labels. Here are some examples:
* 'tag1, tag2, tag3': Add tag1, tag2, and tag3 to the item's tags
* '-tag1, tag4': Remove tag1, add tag4
* '-- tag5': Remove all tags, then add tag5
3.2 Date
The behavior given here is applicable to the calendar service.
* '[datetime]': Specify date/time.
* '[datetime],': On and after given date/time.
* '[starting datetime],[ending datetime]': Between the two dates/times, inclusive
* ',[datetime]': On or before date/time.
The contents of [datetime] can follow several formats. You can specify a date with any of the following:
* today/tomorrow
* YYYY-M-D ("2010-9-25")
* M/D[/YY or /YYYY] (e.g. "9/2", "9/2/10", "9/2/2010")
* Month/mo. D [YYYY] (e.g. "January 1", "Feb 20", "Dec 31 1999")
You can specify a time in most typical formats:
* hour [am or pm] (e.g. "3pm", but NOT just "23")
* hour:minute [am or pm] (e.g. "10:30am" "11:45", "23:00")
but note that if you specify a time without specifying am or pm, it will be converted the same way Google Calendar Quick Add does. 1-6 are interpreted as "pm", 7-12 are "am". So "6" will be interpreted as "18:00".
Finally, you can combine a date and time with "at" or "@"
* 11/3 @ 5:30pm
* Feb 5 at 16:00
* tomorrow @ 3:33am
In case those weren't enough options for you, you can specify an offset by prefixing a number with "+", which is interpreted based on where it appears in the date expression. Appearing by itself, it translates to an offset from the current time. After a datetime and comma, it translates to an offset from the previous datetime.
* '+3': A time of "three hours from now"
* '1/1/11 at 4pm,+2': A range of "1/1/11 at 4pm" to "1/1/11 at 6pm"
* '+4,+1': A range of "four hours from now" to "five hours from now"
See the example scripts for examples on how to use this option.
*Note:* the calendar delete task will interpret 'datetime,' and ',datetime' identically.
*Note:* picasa create will only accept the "date" portion of possibilities for `--date`