Не удается создать URL-адрес регистрации управления Android

Я пытаюсь получить доступ к новому API управления Android для нашей организации, но у меня возникают проблемы с доступом к API. Все работает нормально при доступе к API через API Explorer. Чтобы запустить это на нашем сервере, я создал новый проект в облачной консоли Google и создал там служебную учетную запись. Я скачал ключ и использую его для локального тестирования на моей машине. Однако при первом вызове signupUrl я получаю сообщение об ошибке 403, в котором говорится: "Вызывающий не авторизован для управления проектом". У учетной записи службы, которую я использую, есть роль "Владелец проекта", я не понимаю, как я могу дать ей еще больше привилегий...

Код, который я использую:

def initial_enterprise_user(request):
    enterprise_token = request.GET.get('enterpriseToken')
    usr = request.user

    scopes = ['https://www.googleapis.com/auth/androidmanagement']

    credentials = ServiceAccountCredentials.from_json_keyfile_name(settings.SERVICE_ACCOUNT, scopes=scopes)

    if enterprise_token is None:
        androidmanagement = build('androidmanagement', 'v1', credentials=credentials)
        resp = androidmanagement.signupUrls().create(projectId=settings.ANDROID_MGMT_PROJECTID).execute()
        if resp.status_code == 200:
            usr.signup_url_name = resp.json()['name']
            usr.save()
            return render(request, 'initial_login.html', {'response_url': resp.json()['url']})
        else:
            return HttpResponse('Failed to get signup url')
    else:
        # handle token present

1 ответ

Я создал новый проект в системе, создав учетную запись службы перед включением API управления Android. Учетная запись службы была создана с выбранной ролью "Владелец". Похоже, это включило правильную последовательность в приложении, так как оно сейчас работает. Ранее я добавил API в проект, а затем создал свои учетные записи служб, связав его с API позже.

Другие вопросы по тегам