-
Notifications
You must be signed in to change notification settings - Fork 7
/
README
103 lines (103 loc) · 4.06 KB
/
README
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
#=GCal4Ruby
#
#==Introduction
#GCal4Ruby is a full featured wrapper for the google calendar API. GCal4Ruby implements
#all of the functionality available through the Google Calnedar API, including permissions,
#attendees, reminders and event recurrence.
#
#==Author and Contact Information
#GCal4Ruby was created and is maintained by {Mike Reich}[mailto:[email protected]]
#and is licenses under the GPL v2. Feel free to use and update, but be sure to contribute your
#code back to the project and attribute as required by the license.
#
#This fork by {nachokb}[http://www.github.com/nachokb] brings some improvements related to recurring
#events handling (they always had 1970-01-01 as start_time), fixes some timezone issues and makes the
#parser a little more correct (there can be non-root elements with DTSTART without breaking the parser
#for a start) and flexible (in case Google slightly changes the format).
#
#===Website
#http://cookingandcoding.com/gcal4ruby/
#
#==Description
#GCal4Ruby has three major components: the service, calendar and event objects. Each service
#has many calendars, which in turn have many events. Each service is the representation of a
#google account, and thus must be successfully authenticated using valid Google Calendar
#account credentials.
#
#==Examples
#Below are some common usage examples. For more examples, check the documentation.
#===Service
#1. Authenticate
# service = Service.new
# service.authenticate("[email protected]", "password")
#
#2. Get Calendar List
# calendars = service.calendars
#
#===Calendar
#All usages assume a successfully authenticated Service.
#1. Create a new Calendar
# cal = Calendar.new(service)
#
#2. Find a calendar by ID
# cal = Calendar.find(service, {:id => cal_id})
#
#3. Get all calendar events
# cal = Calendar.find(service, {:id => cal_id})
# events = cal.events
#
#4. Find an existing calendar by title
# cal = Calendar.find(service, {:title => "New Calendar"})
#
#5. Find all calendars containing a search term
# cal = Calendar.find(service, "Soccer Team")
#===Event
#All usages assume a successfully authenticated Service and valid Calendar.
#1. Create a new Event
# event = Event.new(service, {:calendar => cal, :title => "Soccer Game", :start => Time.parse("12-06-2009 at 12:30 PM"), :end => Time.parse("12-06-2009 at 1:30 PM"), :where => "Merry Playfields"})
# event.save
#
#2. Find an existing Event by title
# event = Event.find(service, {:title => "Soccer Game"})
#
#3. Find an existing Event by ID
# event = Event.find(service, {:id => event.id})
#
#4. Find all events containing the search term
# event = Event.find(service, "Soccer Game")
#
#5. Find all events on a calendar containing the search term
# event = Event.find(service, "Soccer Game", {:calendar => cal.id})
#
#6. Find events within a date range
# event = Event.find(service, "Soccer Game", {'start-min' => Time.parse("01/01/2010").utc.xmlschema, 'start-max' => Time.parse("06/01/2010").utc.xmlschema})
#
#7. Create a recurring event for every saturday
# event = Event.new(service)
# event.title = "Baseball Game"
# event.calendar = cal
# event.where = "Municipal Stadium"
# event.recurrence = Recurrence.new
# event.recurrence.start_time = Time.parse("06/20/2009 at 4:30 PM")
# event.recurrence.end_time = Time.parse("06/20/2009 at 6:30 PM")
# event.recurrence.frequency = {"weekly" => ["SA"]}
# event.save
#
#8. Create an event with a 15 minute email reminder
# event = Event.new(service)
# event.calendar = cal
# event.title = "Dinner with Kate"
# event.start_time = Time.parse("06/20/2009 at 5 pm")
# event.end_time = Time.parse("06/20/2009 at 8 pm")
# event.where = "Luigi's"
# event.reminder = {:minutes => 15, :method => 'email'}
# event.save
#
#9. Create an event with attendees
# event = Event.new(service)
# event.calendar = cal
# event.title = "Dinner with Kate"
# event.start_time = Time.parse("06/20/2009 at 5 pm")
# event.end_time = Time.parse("06/20/2009 at 8 pm")
# event.attendees => {:name => "Kate", :email => "[email protected]"}
# event.save