Ecosyste.ms: Awesome
An open API service indexing awesome lists of open source software.
https://github.com/ismarslomic/google-assistant-oauth
Simple utility for retrieving OAuth 2.0 tokens for access to Google Assistant SDK
https://github.com/ismarslomic/google-assistant-oauth
google google-assistant-sdk oauth oauth2
Last synced: 3 months ago
JSON representation
Simple utility for retrieving OAuth 2.0 tokens for access to Google Assistant SDK
- Host: GitHub
- URL: https://github.com/ismarslomic/google-assistant-oauth
- Owner: ismarslomic
- Created: 2022-04-13T09:03:47.000Z (over 2 years ago)
- Default Branch: main
- Last Pushed: 2022-09-08T16:44:34.000Z (over 2 years ago)
- Last Synced: 2024-04-14T18:37:56.689Z (9 months ago)
- Topics: google, google-assistant-sdk, oauth, oauth2
- Language: JavaScript
- Homepage:
- Size: 28.3 KB
- Stars: 4
- Watchers: 4
- Forks: 2
- Open Issues: 0
-
Metadata Files:
- Readme: README.md
Awesome Lists containing this project
README
# google-assistant-oauth
[![Docker Image CI](https://github.com/ismarslomic/google-assistant-oauth/actions/workflows/docker-image.yml/badge.svg?branch=main)](https://github.com/ismarslomic/google-assistant-oauth/actions/workflows/docker-image.yml)
> Simple utility wrapped in Docker image for retrieving the OAuth 2.0 tokens for access to
> [Google Assistant Service](https://developers.google.com/assistant/sdk/overview#google_assistant_service).## Get support
Bugs and questions related to the source code and Docker image can be reported at
[Github Issues](https://github.com/ismarslomic/google-assistant-oauth/issues) in the
[ismarslomic/google-assistant-oauth](https://github.com/ismarslomic/google-assistant-oauth) repo.## About
In order to access the
[Google Assistant Service](https://developers.google.com/assistant/sdk/overview#google_assistant_service)
you need to retrieve access and refresh tokens by using Google OAuth2 implementation, this is
explained in
[Google Authorization and Authentication documentation](https://developers.google.com/identity/protocols/oauth2/openid-connect)
.This utility simplifies going through the OAuth2 flow and was created in the context of implementing
embedded Google Assistant for broadcasting message to Google Assistant enabled speakers,
see [ismarslomic/google-assistant-broadcast](https://github.com/ismarslomic/google-assistant-broadcast)
.## Setup
### Prerequisites
- **docker** - you need to have Docker installed on your machine,
read [Get Docker](https://docs.docker.com/get-docker/) for more information.
- **Google OAuth 2.0 Client ID** - in order to authenticate yourself and get access to your Google
Assistant.
- Follow steps **1-5**
in [Configure an Actions Console project](https://developers.google.com/assistant/sdk/guides/service/python/embed/config-dev-project-and-account)
- Make sure that you choose **"Device registration"** when creating new project in **Actions
Console**
- **!Important!** Download the OAuth Client file from GCP Console / API & Services / Credentials page (not from Google Actions Console), read solution on issue [#7](https://github.com/ismarslomic/google-assistant-broadcast/issues/7#issuecomment-1151601639). Make also sure that the `Application type` of the OAuth Client is `Desktop`
- Rename the downloaded file **from** `client_secret_****.apps.googleusercontent.com.json` **to** `client_secret.json`### Run docker container with `docker run`
Replace `/home/pi/config` with full path to the folder where your `client_secret.json` file is
located.> **Warning**
> To avoid write permission issues inside container, please use a folder with ownership of the OS user you are logged in with. Typically `/home/pi` on RPI or `/home/ubuntu` on Ubuntu.When docker container is terminated and the OAuth2 flow finished, you will find `tokens.json`
file produced in the same folder.```bash
docker run --rm \
-p 3005:3005 \
-v /home/pi/config:/usr/src/config \
ismarslomic/google-assistant-oauth:latest
```Click on the URL provided in the console output from the Docker container.
#### Example of expected `client_secret.json` file
```json
{
"installed": {
"client_id": "****.apps.googleusercontent.com",
"project_id": "you-project-id",
"auth_uri": "https://accounts.google.com/o/oauth2/auth",
"token_uri": "https://oauth2.googleapis.com/token",
"auth_provider_x509_cert_url": "https://www.googleapis.com/oauth2/v1/certs",
"client_secret": "****",
"redirect_uris": [
"http://localhost"
]
}
}
```