Google Drive API(.NET) - 将所有权从服务帐户转移到域用户

时间:2017-03-12 17:33:47

标签: c# google-api google-drive-api google-api-dotnet-client service-accounts

我正在使用.NET client API和服务帐户在Google云端硬盘上创建文件。

    string[] scopes = new string[] { DriveService.Scope.Drive };
    GoogleCredential credential;
    using (var stream = new FileStream(Directory.GetCurrentDirectory() + "/Resources/GoogleCredentials.json", FileMode.Open, FileAccess.Read))
    {
        credential = GoogleCredential.FromStream(stream).CreateScoped(scopes);
    }
    DriveService drive = new DriveService(new BaseClientService.Initializer()
    {
        HttpClientInitializer = credential,
    });

我成功创建了文件,

    var f = drive.Files;
    var request = f.Create(new Google.Apis.Drive.v3.Data.File()
    {
        Name = "Test from ASP.NET Core",
        AppProperties = prop,
        MimeType = "application/vnd.google-apps.document"
    });
    var file = await request.ExecuteAsync();

与所有域共享,但我无法将所有权转让给域用户。

    Permission permission = new Permission()
    {
        EmailAddress = "user@example.com",
        Type = "user",
        Domain = "example.com",
        Role = "owner"
    };
    var requestpermission = drive.Permissions.Create(permission, file.Id);
    requestpermission.TransferOwnership = true;
    var perm = await requestpermission.ExecuteAsync();

我收到错误:

  

指定的域无效或不适用于给定的域   许可类型。

我找到了this link,但建议不要使用p12证书文件。所以我想使用JSON。

1 个答案:

答案 0 :(得分:2)

所有权转移只能在同一域中的用户之间进行,而服务帐户不属于任何域。您最好的选择可能是创建服务帐户可以访问的团队驱动器,并执行两个阶段的过程:

  1. 使用服务帐户将文件移动到团队驱动器中。 Files.update addParents参数设置为团队驱动器ID。
  2. 使用域用户将文件移出团队驱动器。 Files.update参数设置为addParents(或某个目标文件夹的ID),root参数设置为团队驱动器ID的removeParents