使用Google Calendar API v3手动验证我的用户帐户



我要做的事情:

允许在我的网站上经过身份验证和授权的用户使用一个表单,该表单允许他们使用Google calendar的API在我的日历上创建事件。

我能够通过Google Calendar API v2手动验证我的Google帐户来实现这一点:

calendar_service = gdata.calendar.service.CalendarService()
calendar_service.email = 'email@site.com'
calendar_service.password = 'password'
calendar_service.source = 'Calendar'
calendar_service.ProgrammaticLogin()

然后,我可以从我的站点表单中输入POST日期,并使用API创建一个事件,但我不知道如何使用API的V3来实现这一点。

我已经阅读了文档并尝试实现:

created_event = service.events().insert(calendarId='primary', body=event).execute()

但这需要创建一个service对象,这反过来又需要通过OAuth 2.0进行帐户身份验证,而这不是我想要实现的。我需要手动验证我自己的日历,而不是询问用户我的应用程序是否可以访问他们的日历。

我确信我遗漏了一些基本的逻辑或者做了一些错误的假设。如有任何正确方向的帮助,我们将不胜感激。

您必须使用OAuth授权您的代码访问自己的日历;一旦你做到了,你就会得到一个可以保留的代币。当您的代码再次运行时,它应该重用令牌来连接到您的日历。用户不会受到挑战,但令牌可能会不时刷新。

不能建议任何代码,因为我个人非常讨厌OAuth:(

@Ben-service对象可以使用密钥/机密组合创建,也可以使用服务帐户创建,其中您使用电子邮件/证书组合和prn参数来标识要操作的用户。这两种方法都需要在API控制台中注册。

使用服务帐户,您只需在prn参数中指定您的电子邮件地址,即可将事件插入您的日历中。insert语句保持不变,因为您使用此规范对帐户进行操作。

credentials = SignedJwtAssertionCredentials(SERVICE_ACCOUNT_EMAIL, key,
  scope='https://www.googleapis.com/auth/calendar', prn='you@domain.com')
...
created_event = service.events().insert(calendarId='primary', body=event).execute()

以下是一个例子:https://developers.google.com/drive/delegation

相关内容

  • 没有找到相关文章

最新更新