我正在尝试通过服务账户连接我们G Suite域上的所有日历。
我创建了一个新项目,并在API和服务页面中启用了Google日历API。
我创建了一个Google服务账户,其中包括:
- 名称 - 适用的角色 - 生成的JSON密钥文件 - 启用了整个域的G Suite 在服务账户管理页面中,我获取了我的ID(AAA@BBB.iam.gserviceaccount.com)。
我进入了G Suite安全模块,并转到ManageOauthClients页面,在该页面输入了我的ID并选择了Google日历API(https://www.googleapis.com/auth/calendar)。
它正确地识别了我的ID,并添加了:
1234567890 日历(读写)https://www.googleapis.com/auth/calendar 其中,1234567890是Google从我的AAA@BBB.iam.gserviceaccount.com输入中获取的ID。
现在,我添加了Google和日历API的nuget包,并在C#命令行应用程序中编写了以下代码:
我确认了我所请求的日历确实存在。它是我用来执行以上所有步骤的帐户中的日历。
但我仍然收到404错误,这意味着很可能我没有权限访问(我的)日历。
这可能与角色有关吗?我不确定在创建服务帐户时应选择哪些角色。
此外,当尝试获取所有日历列表时,它是一个空列表。
我创建了一个新项目,并在API和服务页面中启用了Google日历API。
我创建了一个Google服务账户,其中包括:
- 名称 - 适用的角色 - 生成的JSON密钥文件 - 启用了整个域的G Suite 在服务账户管理页面中,我获取了我的ID(AAA@BBB.iam.gserviceaccount.com)。
我进入了G Suite安全模块,并转到ManageOauthClients页面,在该页面输入了我的ID并选择了Google日历API(https://www.googleapis.com/auth/calendar)。
它正确地识别了我的ID,并添加了:
1234567890 日历(读写)https://www.googleapis.com/auth/calendar 其中,1234567890是Google从我的AAA@BBB.iam.gserviceaccount.com输入中获取的ID。
现在,我添加了Google和日历API的nuget包,并在C#命令行应用程序中编写了以下代码:
var scopes = new[] { CalendarService.Scope.Calendar };
ServiceAccountCredential credential;
using (Stream stream = new FileStream("ToprServiceAccount-xxxxyyyyy.json", FileMode.Open, FileAccess.Read, FileShare.Read))
{
credential = GoogleCredential.FromStream(stream).CreateScoped(scopes).UnderlyingCredential as ServiceAccountCredential;
}
var service = new CalendarService(new BaseClientService.Initializer()
{
HttpClientInitializer = credential
});
var list = service.CalendarList.Get("planning@mydomain.com").Execute();
我确认了我所请求的日历确实存在。它是我用来执行以上所有步骤的帐户中的日历。
但我仍然收到404错误,这意味着很可能我没有权限访问(我的)日历。
这可能与角色有关吗?我不确定在创建服务帐户时应选择哪些角色。
此外,当尝试获取所有日历列表时,它是一个空列表。