Google Sheet API v4创建工作表并邀请用户

Mik*_*ike 6 php google-api google-sheets google-api-php-client service-accounts

我正在使用服务帐户身份验证来使用Google表格API创建Google表格.我想创建一个电子表格,并以某种方式允许我的团队打开它.

    $private_key  = file_get_contents($rootDir . '/config/googleApiCredentials.p12');
    $client_email = 'project-names@positive-water-134xxx.iam.gserviceaccount.com';
    $scopes       = implode(' ', ["https://www.googleapis.com/auth/drive"]);

    $credentials = new \Google_Auth_AssertionCredentials(
        $client_email,
        $scopes,
        $private_key
    );
    // tried once with additional constructor params:
    // $privateKeyPassword = 'notasecret',
    // $assertionType = 'http://oauth.net/grant_type/jwt/1.0/bearer',
    // $sub = 'myMail@gmail.com

    $this->googleClient = new \Google_Client();
    $this->googleClient->setAssertionCredentials($credentials);
    if ($this->googleClient->getAuth()->isAccessTokenExpired()) {
        $this->googleClient->getAuth()->refreshTokenWithAssertion();
    }
    $service = new \Google_Service_Sheets($this->googleClient);
    $newSheet = new \Google_Service_Sheets_Spreadsheet();
    $newSheet->setSpreadsheetId('34534534'); // <- hardcoded for test
    $response = $service->spreadsheets->create($newSheet);
    print_r($response);
Run Code Online (Sandbox Code Playgroud)

工作表正在创建,我收到回复

[spreadsheetId] => 34534534
Run Code Online (Sandbox Code Playgroud)

但是,即使我在Google的开发者控制台中添加了作为所有者,编辑,作者和读者的项目权限,我也无法通过浏览器使用我的谷歌帐户打开此文件.浏览器说我没有办法,我可以联系管理员获取权限

有什么建议?是否有人管理过如何创建文档并为任何"人类"提供访问权限?

DaI*_*mTo 6

服务帐户是虚拟用户。它有自己的驱动器帐户,拥有在其帐户上创建的文件。服务帐户需要向您的个人谷歌驱动器帐户授予对所述文件的访问权限。(就像其他用户一样与您分享)

权限:插入插入文件的权限。

注意:您目前已通过身份验证,可以使用 Google Sheets API,您必须将 google Drive API(范围)添加到 Google 开发人员控制台上的代码和项目中。无法通过 Google Sheets API 更改文件的权限。

是的,您必须为您希望允许查看/编辑此文件的团队中的每个成员添加权限。

提示:当您添加 Google Drive API 时,尝试执行files.list在结果中查找 downloadUrl、alternateLink 和 embedLink。有时,这些内容会被填写并可用于共享仅供其他用户查看的内容。


Mik*_*ike 5

可以为域帐户授予权限:

private function createNewSheet($title)
{
    $properties = new \Google_Service_Sheets_SpreadsheetProperties();
    $properties->setTitle($title);

    $newSheet = new \Google_Service_Sheets_Spreadsheet();
    $newSheet->setProperties($properties);

    $response = $this->sheetService->spreadsheets->create($newSheet);
    $fileId = $response['spreadsheetId'];

    $domainPermission = new \Google_Service_Drive_Permission([
        'type'  => 'domain',
        'role'  => 'writer',
        'value' => 'myCompany.com' //eg user@myCompany.com
    ]);

    $this->driveService->permissions->insert($fileId, $domainPermission);
    return $response;
}
Run Code Online (Sandbox Code Playgroud)