我一直在实现谷歌日历API的一些功能。我有一个自定义日历,能够与谷歌日历同步。这意味着,您可以从我的仪表板到谷歌日历帐户创建和编辑日历和事件。我面临的主要问题是,如果我直接从谷歌日历更新事件。我已经实现了推送通知并得到如下响应:
{
"Google_channel_ID": "19835150 - 0057 - 11e6 - bc9c - 1735798 ca540",
"Google_channel_token": "calendar_id = 4e7 d5c20ht9lpfdtuukcsvgeq4 @group.calendar.google.com & user_id = 43e d7rxeqqce3fk09ahszc",
"Google_channel_expiration": "Tue,12 Apr 2016 12: 34: 36 GMT",
"Google_resource_id": "oLMEEhHAw5Xo3r2187CWykjAtm0",
"Google_resource_URI": "https: //www.googleapis.com/calendar/v3/calendars/4e7d5c20ht9lpfdtuukcsvgeq4@group.calendar.google.com/events?alt=json",
"Google_resource_state": "sync",
"Google_message_number": "1"
}
但是这个回应非常笼统。例如,如果我在此日历上有 1000 个事件,并更新完整的 1000 个事件。我将始终收到相同的通知 1000。我想知道是否可以获取哪个事件 id 已更改,以便我可以执行并更新到我的数据库。
我初始化 watch 的方式是这样的:
exports.watch = function(req, res){
var channel_id = uuid.v1();
var user_id = req.body.user_id;
var calendar_id = req.body.calendar_id;
authorize(user_id, function(oauth2Client){
var data = {
auth: oauth2Client,
calendarId: calendar_id,
resource: {
id: channel_id,
token: 'calendar_id='+ calendar_id + '&user_id=' + user_id,
address: 'https://api.medradr.com/google-watch',
type: 'web_hook',
params: {
ttl: '36000'
}
}
};
calendar.events.watch(data, function (err, response) {
if (err) {
console.error('The API returned an error: ' + err);
return;
}else{
res.send({ok: true, message: 'Listener created', result:response});
}
});
});
}
最佳答案
适合那些正在寻找一种好方法来获取网络 Hook 触发时哪些事件发生变化的人。当您的网络 Hook 被触发时,您将得到如下内容:
X-Goog-Channel-ID: channel-ID-value
X-Goog-Channel-Token: channel-token-value
X-Goog-Channel-Expiration: expiration-date-and-time // In human-readable format; present only if channel expires.
X-Goog-Resource-ID: identifier-for-the-watched-resource
X-Goog-Resource-URI: version-specific-URI-of-the-watched-resource
X-Goog-Resource-State: sync
X-Goog-Message-Number: 1
在X-Goog-Resource-URI上,您将得到如下内容:
https://www.googleapis.com/calendar/v3/calendars/4e7d5c20ht9lpfdtuukcsvgeq4@group.calendar.google.com/events?alt=json
通过 OAuth 身份验证,您可以向此 URL 发出 GET 请求以获取属于此日历的所有事件。现在知道哪些资源已更改的技巧非常简单。对于每个事件,您都会得到如下内容:
{
event_id: 335,
user_id: '43ed7rxeqqce3fk09ahszc',
kind: 'calendar#event',
etag: '"2921213870180000"',
google_id: 'cpbcesg966skprb3rh1p1ud668',
status: 'confirmed',
htmlLink: 'https://www.google.com/calendar/event?eid=Y3BiY2VzZzk2NnNrcHJiM3JoMXAxdWQ2NjggNGU3ZDVjMjBodDlscGZkdHV1a2NzdmdlcTRAZw',
created: Thu Apr 14 2016 00:00:00 GMT-0500 (CDT),
updated: Thu Apr 14 2016 00:00:00 GMT-0500 (CDT),
summary: 'Testing google notifications',
description: '',
creator: 'guizarkrg@gmail.com',
organizer: '4e7d5c20ht9lpfdtuukcsvgeq4@group.calendar.google.com',
start: Sat Apr 09 2016 00:00:00 GMT-0500 (CDT),
end: Sun Apr 10 2016 00:00:00 GMT-0500 (CDT),
iCalUID: 'cpbcesg966skprb3rh1p1ud668@google.com',
event_type_id: 0,
calendar_id: 0,
timezone_id: 0,
sequence: 0,
calendar_color_id: ''
}
正如你所看到的,这是一个序列:0,这是增量的。这意味着,每次您对事件进行一些更改(摘要、描述、开始日期、结束日期等)。该数字将增加+1。您可以将其保存在数据库中,因此每次 Web Hook 触发时,您只更新序列 > 已保存序列的事件。所以基本上,您更新事件并保存序列的新值。下次触发 Web Hook 时,它只会在您的数据库上更新此条件中包含的事件。
希望它能有所帮助,编码愉快。
关于node.js - 当 Google 日历事件更改时更新数据库,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/36562757/