Межсерверная аутентификация Appengine и авторизация на уровне домена Google

Я пытаюсь получить свои отчеты из API отчетов YouTube и загрузить их в GCS. Поскольку я должен использовать oauth2, я использовал руководство Google по созданию учетной записи службы и предоставлению ей полномочий на уровне домена. Пока я могу получить аутентифицированный сервис для получения отчетов на уровне пользователя. Я получаю сообщение «У вызывающего абонента нет разрешения», когда appengine выполняет запрос. Есть идеи, где искать дальше?

SCOPES = ['https://www.googleapis.com/auth/yt-analytics-monetary.readonly',
     'https://www.googleapis.com/auth/youtubepartner-content-owner-readonly',
     'https://www.googleapis.com/auth/devstorage.read_write']
SERVICE_ACCOUNT_FILE = 'file.json'
credentials = service_account.Credentials.from_service_account_file(
    SERVICE_ACCOUNT_FILE, scopes=SCOPES)
delegated_credentials = credentials.with_subject('[email protected]')
storage_client = build('storage', 'v1', credentials=credentials)
youtube_reporting = build('youtubereporting', 'v1', 
credentials=credentials)

Проследить:

Traceback (most recent call last):
  File "/base/alloc/tmpfs/dynamic_runtimes/python27/b93f87cfaa0115e5_unzipped/python27_lib/versions/third_party/webapp2-2.5.2/webapp2.py", line 1535, in __call__
    rv = self.handle_exception(request, response, e)
  File "/base/alloc/tmpfs/dynamic_runtimes/python27/b93f87cfaa0115e5_unzipped/python27_lib/versions/third_party/webapp2-2.5.2/webapp2.py", line 1529, in __call__
    rv = self.router.dispatch(request, response)
  File "/base/alloc/tmpfs/dynamic_runtimes/python27/b93f87cfaa0115e5_unzipped/python27_lib/versions/third_party/webapp2-2.5.2/webapp2.py", line 1278, in default_dispatcher
    return route.handler_adapter(request, response)
  File "/base/alloc/tmpfs/dynamic_runtimes/python27/b93f87cfaa0115e5_unzipped/python27_lib/versions/third_party/webapp2-2.5.2/webapp2.py", line 1102, in __call__
    return handler.dispatch()
  File "/base/alloc/tmpfs/dynamic_runtimes/python27/b93f87cfaa0115e5_unzipped/python27_lib/versions/third_party/webapp2-2.5.2/webapp2.py", line 572, in dispatch
    return self.handle_exception(e, self.app.debug)
  File "/base/alloc/tmpfs/dynamic_runtimes/python27/b93f87cfaa0115e5_unzipped/python27_lib/versions/third_party/webapp2-2.5.2/webapp2.py", line 570, in dispatch
    return method(*args, **kwargs)
  File "/base/data/home/apps/s~test-project-67412/20180712t103610.411083715789214207/main.py", line 66, in get
    jobs = list_jobs(youtube_reporting, ContentOwner, True)
  File "/base/data/home/apps/s~test-project-67412/20180712t103610.411083715789214207/main.py", line 52, in list_jobs
    includeSystemManaged=True).execute()
  File "/base/data/home/apps/s~test-project-67412/20180712t103610.411083715789214207/lib/googleapiclient/_helpers.py", line 130, in positional_wrapper
    return wrapped(*args, **kwargs)
  File "/base/data/home/apps/s~test-project-67412/20180712t103610.411083715789214207/lib/googleapiclient/http.py", line 840, in execute
    raise HttpError(resp, content, uri=self.uri)
HttpError: <HttpError 403 when requesting https://youtubereporting.googleapis.com/v1/jobs?onBehalfOfContentOwner=ContentOwner&alt=json&includeSystemManaged=true returned "The caller does not have permission">

- ОБНОВЛЕНИЕ - Полагаю, это было связано с полномочиями домена для учетной записи службы. Я удалил учетную запись, создал новую, дал ей полномочия на уровне домена, и теперь она работает нормально.


person Lilo    schedule 11.07.2018    source источник
comment
While I can get authenticated service to pull the data at user level - вы имеете в виду, что можете успешно запустить это локально, на своей машине?   -  person FelixEnescu    schedule 12.07.2018
comment
Извините за расплывчатость. Я имел в виду, что могу успешно запустить запрос локально в скрипте Python, используя аутентификацию на уровне пользователя oauth2.   -  person Lilo    schedule 12.07.2018
comment
Где именно вы получили ошибку? На storage_client ? Можете ли вы опубликовать обратную связь?   -  person FelixEnescu    schedule 12.07.2018
comment
Конечно, я добавил трассировку. Я получаю сообщение об ошибке при вызове API отчетов YouTube.   -  person Lilo    schedule 12.07.2018