Вместо использования служебной учетной записи вы можете обойти необходимость добавления добавления новых пользовательских разрешений (в соответствии с основными ответами в этой теме), используя OAuth client ID
учетные данные.
Перейти к панели управления учетными данными API и нажмите «Создать учетные данные» -> «Идентификатор клиента OAuth». После этого вы должны получить идентификатор клиента и секрет клиента, которые вам понадобятся для аутентификации API.
Теперь вы можете использовать OAuth2WebServerFlow
для аутентификации на основе использования. Вот пример на python3:
from apiclient.discovery import build
from oauth2client.client import OAuth2WebServerFlow
# TODO: Fill these in...
CLIENT_ID = ''
CLIENT_SECRET = ''
VIEW_ID = ''
flow = OAuth2WebServerFlow(
CLIENT_ID, CLIENT_SECRET,
'https://www.googleapis.com/auth/analytics.readonly',
redirect_uri='urn:ietf:wg:oauth:2.0:oob'
)
authorize_url = flow.step1_get_authorize_url()
print('Receive code from:\n%s\n' % authorize_url)
code = input('Enter code here:').strip()
credentials = flow.step2_exchange(code)
api = build('analyticsreporting', 'v4', credentials=credentials)
body={
'reportRequests': [{
'viewId': VIEW_ID,
'dateRanges': [{'startDate': '7daysAgo', 'endDate': 'today'}],
'metrics': [{'expression': 'ga:sessions'}],
'dimensions': [{'name': 'ga:country'}]
}]
}
data = api.reports().batchGet(body=body).execute()