出于某种原因,我很难访问Google日历。
我希望能够从我的Node.js服务器添加和删除日历中的事件。
我发现文件中存在真正矛盾的信息。
我跟着 - ,它提供了一个很好的指导如何获得一个acccess令牌,但最后它似乎只是为了访问Drive。
然后我跟着https://developers.google.com/identity/protocols/OAuth2ServiceAccount说明你只需要一个API密钥,但这看起来好像都是从客户端完成的,所以可能它有所不同?
我也查看了Google Calendar API v3 Access Not Configured,但这对于对日历进行简单的API调用似乎非常复杂。示例代码引用的文件不清楚它们来自何处或如何构造它们。例如。 var TOKEN_PATH = TOKEN_DIR + 'calendar-nodejs-quickstart.json';
关于如何实现这一目标的简单指南将非常受欢迎。
由于
答案 0 :(得分:15)
我和你的情况一样。 Google没有针对nodejs客户端API的server-to-server
身份验证的文档。荒谬。最后我找到了解决方案here。基本上,您需要服务帐户密钥(通常是JSON文件)和google.auth.JWT
server-to-server OAuth 2.0
客户端。
let google = require('googleapis');
let privatekey = require("./privatekey.json");
// configure a JWT auth client
let jwtClient = new google.auth.JWT(
privatekey.client_email,
null,
privatekey.private_key,
['https://www.googleapis.com/auth/calendar']);
//authenticate request
jwtClient.authorize(function (err, tokens) {
if (err) {
console.log(err);
return;
} else {
console.log("Successfully connected!");
}
});
现在只需调用日历API:
let calendar = google.calendar('v3');
calendar.events.list({
auth: jwtClient,
calendarId: 'primary'//whatever
}, function (err, response) {
});
答案 1 :(得分:3)
您想使用Node.js在日历中添加和删除事件。我的理解是否正确?如果我的理解有误,请告诉我。
关于quickstart.js
使用日历API,为了使用日历API,首先,用户必须检索具有客户端ID,客户端密钥等的client_secret.json
,并在API控制台上启用日历API 。
下一步,必须使用client_secret.json
从Google检索访问令牌和刷新令牌。 Quickstart中的大多数quickstart.js
用于检索它们。 var TOKEN_PATH = TOKEN_DIR + 'calendar-nodejs-quickstart.json';
包括使用client_secret.json
检索的访问令牌和刷新令牌。可以从没有到期时间的刷新令牌中检索具有到期时间的访问令牌。在quickstart.js
,每次使用刷新令牌运行脚本时都会检索访问令牌。
listEvents(auth)
中quickstart.js
以外的功能用于授权。在listEvents(auth)
,可以使用授权检索的访问令牌来使用日历API。
以下示例脚本用于添加和删除事件。这假设Quickstart中的步骤1和步骤2已经完成并且使用了quickstart.js
。
对于Node.js Quickstart sample,它修改了listEvents()
。使用此示例脚本时,请复制并粘贴 Node.js快速入门示例,然后按如下所示更改listEvents()
,并添加以下addEvents()
和removeEvents()
。
function listEvents(auth) {
var calendar = google.calendar('v3');
addEvents(auth, calendar); // Add events
removeEvents(auth, calendar); // Remove events
}
详情信息为https://developers.google.com/google-apps/calendar/v3/reference/events/insert。
function addEvents(auth, calendar){
calendar.events.insert({
auth: auth,
calendarId: 'primary',
resource: {
'summary': 'Sample Event',
'description': 'Sample description',
'start': {
'dateTime': '2017-01-01T00:00:00',
'timeZone': 'GMT',
},
'end': {
'dateTime': '2017-01-01T01:00:00',
'timeZone': 'GMT',
},
},
}, function(err, res) {
if (err) {
console.log('Error: ' + err);
return;
}
console.log(res);
});
}
详情信息为https://developers.google.com/google-apps/calendar/v3/reference/events/delete。
function removeEvents(auth, calendar){
calendar.events.delete({
auth: auth,
calendarId: 'primary',
eventId: "#####",
}, function(err) {
if (err) {
console.log('Error: ' + err);
return;
}
console.log("Removed");
});
}
对不起我的英语能力差。