Да ... но ...
Существует служба REST, которая делает это, на самом деле, библиотека в конечном итоге вызывает ее.Это стандартная конечная точка обмена токенами OAuth2 на https://www.googleapis.com/oauth2/v4/token
.Подвох строит JWT, который вы можете передать этому сервису.Процитируем страницу Google по теме :
Хотя ваше приложение может выполнить эти задачи, напрямую взаимодействуя с системой OAuth 2.0 с использованием HTTP, механизм межсерверной аутентификациивзаимодействия требуют, чтобы приложения создавали и криптографически подписывали веб-токены JSON (JWT), и легко допускать серьезные ошибки, которые могут серьезно повлиять на безопасность вашего приложения.
По этой причине мы настоятельно рекомендуем вамиспользуйте библиотеки, такие как клиентские библиотеки API Google, которые абстрагируют криптографию от кода вашего приложения.
Короче говоря, если вы хотите это сделать, вам необходимо:
- Создание веб-токена JSON (JWT), который включает в себя заголовок, набор заявок и подпись.
- Запрос токена доступа с сервера авторизации Google OAuth 2.0.
- ОбработкаОтвет JSON для получения токена доступа.
- Отслеживание срока службы токена доступа и, когда онpires и вам нужен токен доступа, повторите шаги 1-4.
Подробности на Использование OAuth 2.0 для серверных приложений
Я неЯ знаком с библиотеками C #, однако мне сказали, что клиентская библиотека C # от Google , кажется, поддерживает ее, и документация высокого уровня для ServiceAccountCredential, как представляется, может генерировать токены аутентификации изполномочия.