Em vez de usar uma conta de serviço, você pode evitar a necessidade de adicionar novas permissões de usuário (de acordo com as principais respostas deste segmento) usando OAuth client ID
credenciais.
Acesse o painel de credenciais da API e clique em "Criar credenciais" -> "ID do cliente OAuth". Posteriormente, você deve obter um ID do cliente e um segredo do cliente, necessário para autenticar a API.
Agora você pode usar OAuth2WebServerFlow
para autenticar em uma base por uso. Aqui está um exemplo 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()