谷歌API:404域名未找到

2022-08-30 22:21:12

我是使用Google API的新手,但我有一个项目,需要我访问他们的域以通过电子邮件查找用户的经理。在我开始编写代码之前,我想设置所有内容,因此我按照PHP的示例文件进行操作。我能够让它工作,但在令牌过期后刷新令牌时遇到了一些问题,研究促使我使用服务帐户,因为这是一个服务器cron脚本,我不想处理任何用户交互。

我创建了服务帐号,启用了 G Suite 网域范围的委派,并添加了以下访问权限:https://www.googleapis.com/auth/admin.directory.user.readonly

我得到了一个与我的脚本。Google_Service_Exception

响应是:

{
 "error": {
  "errors": [
   {
    "domain": "global",
    "reason": "notFound",
    "message": "Domain not found."
   }
  ],
  "code": 404,
  "message": "Domain not found."
 }
}

我假设这意味着它不知道帐户域,但我不知道如何解决这个问题。我假设如果这是一个权限问题,谷歌会告诉我。我尝试在线搜索,但没有运气,因为我发现的问题是使用不同的方法,并且修复程序无法在服务帐户上完成。我现在陷入困境,所以我希望朝着正确的方向前进,能让我走上正轨。

这是我正在使用的测试脚本:

<?php

require_once( __DIR__. '/vendor/autoload.php' );

define('CREDENTIALS_PATH', '/path/to/service_account.json');

define('SCOPES', implode(' ', array(
        Google_Service_Directory::ADMIN_DIRECTORY_USER_READONLY)
));

date_default_timezone_set('America/New_York');

/**
 * Returns an authorized API client.
 * @return Google_Client the authorized client object
 */
function getClient() {
    $client = new Google_Client();
    $client->setApplicationName('TestingApp');
    $client->setAuthConfig(CREDENTIALS_PATH);
    $client->setScopes(SCOPES);

    return $client;
}   

// Get the API client and construct the service object.
$client = getClient();
$service = new Google_Service_Directory($client);

// Print the first 10 users in the domain.
$optParams = array(
    'customer' => 'my_customer',
    'maxResults' => 10,
    'orderBy' => 'email',
);
$results = $service->users->listUsers($optParams);

if (count($results->getUsers()) == 0) {
    print "No users found.\n";
} else {
    print "Users:\n";
    foreach ($results->getUsers() as $user) {
        printf("%s (%s)\n", $user->getPrimaryEmail(),
            $user->getName()->getFullName());
    }
}

我的包含(明显清洁)service_account.json

{
    "type": "service_account",
    "project_id": "PROJECT_ID",
    "private_key_id": "PRIVATE_KEY_ID",
    "private_key": "PRIVATE_KEY",
    "client_email": "SERVICE_ACCOUNT_EMAIL.iam.gserviceaccount.com",
    "client_id": "CLIENT_ID",
    "auth_uri": "https://accounts.google.com/o/oauth2/auth",
    "token_uri": "https://accounts.google.com/o/oauth2/token",
    "auth_provider_x509_cert_url": "https://www.googleapis.com/oauth2/v1/certs",
    "client_x509_cert_url": "https://www.googleapis.com/robot/v1/metadata/x509/SERVICE_ACCOUNT_IDENTIFIER.iam.gserviceaccount.com"
}

感谢您对此的任何帮助。


答案 1

好吧,这是一个非常容易忽略的步骤,但这是一个非常简单的修复。

这里的问题是未标识帐户的域。我的印象是服务帐户已经附加到域,但事实并非如此。因此,修复程序只需将一行代码添加到客户端,以将其设置为域中的用户(对于我的情况)。

我的修复是添加:

$client->setSubject('account@domain.com');

到我的方法。getClient

所以现在的方法看起来像这样:

/**
 * Returns an authorized API client.
 * @return Google_Client the authorized client object
 */
function getClient() {
    $client = new Google_Client();
    $client->setApplicationName('TestingApp');
    $client->setAuthConfig(CREDENTIALS_PATH);
    $client->setScopes(SCOPES);
    $client->setSubject('account@domain.com');
    return $client;
}

我在API中看到了这一点,但它将其声明为可选。希望这也有助于其他人。


答案 2

对我来说是同样的错误,但我需要与服务帐户电子邮件(在json auth文件中找到)共享我的日历。在那之后,错误消失了。


推荐