(howto-auth-google)= # Authenticate using Google ```{warning} This documentation has not been updated recently, and a major version of OAuthenticator has been released since it was. Due to that, please only use this _as a complement_ to the official [OAuthenticator documentation]. [OAuthenticator documentation]: https://oauthenticator.readthedocs.io/en/latest/tutorials/provider-specific-setup/providers/google.html Going onwards, the goal is to ensure we have good documentation in the OAuthenticator project and reference that instead of maintaining similar documentation in this project also. ``` The **Google OAuthenticator** lets users log into your JupyterHub using their Google user ID / password. To do so, you'll first need to register an application with Google, and then provide information about this application to your `tljh` configuration. See [Google's documentation](https://developers.google.com/identity/protocols/OAuth2) on how to create OAUth 2.0 client credentials. :::{note} You'll need a Google account in order to complete these steps. ::: ## Step 1: Create a Google project Go to [Google Developers Console](https://console.developers.google.com) and create a new project: ```{image} ../../images/auth/google/create_new_project.png :alt: Create a Google project ``` ## Step 2: Set up a Google OAuth client ID and secret 1. After creating and selecting the project: - Go to the credentials menu: ```{image} ../../images/auth/google/credentials_button.png :alt: Credentials menu ``` - Click "Create credentials" and from the dropdown menu select **"OAuth client ID"**: ```{image} ../../images/auth/google/create_credentials.png :alt: Generate credentials ``` - You will have to fill a form with: - **Application type**: Choose _Web application_ - **Name**: A descriptive name for your OAuth client ID (e.g. `tljh-client`) - **Authorized JavaScript origins**: Use the IP address or URL of your JupyterHub. e.g. `http(s)://`. - **Authorized redirect URIs**: Insert text with the following form: ``` http(s):///hub/oauth_callback ``` - When you're done filling in the page, it should look something like this (ideally without the red warnings): ```{image} ../../images/auth/google/create_oauth_client_id.png :alt: Create a Google OAuth client ID ``` 2. Click "Create". You'll be taken to a page with the registered application details. 3. Copy the **Client ID** and **Client Secret** from the application details page. You will use these later to configure your JupyterHub authenticator. ```{image} ../../images/auth/google/client_id_secret.png :alt: Your client ID and secret ``` :::{important} If you are using a virtual machine from a cloud provider and **stop the VM**, then when you re-start the VM, the provider will likely assign a **new public IP address** to it. In this case, **you must update your Google application information** with the new IP address. ::: ## Step 3: Configure your JupyterHub to use the Google OAuthenticator ### Configuration with `tljh-config` In this section we'll use the `tljh-config` tool to configure your JupyterHub's authentication. For more information on `tljh-config`, see [](/topic/tljh-config). :::{important} By default, the following allows _anyone_ with a Google account to login. You can set specific allowed users and admins using [](#tljh-set-user-lists). ::: 1. Log in as an administrator account to your JupyterHub. 2. Open a terminal window. ```{image} ../../images/notebook/new-terminal-button.png :alt: New terminal button. ``` 3. Configure the Google OAuthenticator to use your client ID, client secret and callback URL with the following commands: ``` sudo tljh-config set auth.GoogleOAuthenticator.client_id '' ``` ``` sudo tljh-config set auth.GoogleOAuthenticator.client_secret '' ``` ``` sudo tljh-config set auth.GoogleOAuthenticator.oauth_callback_url 'http(s):///hub/oauth_callback' ``` 4. Tell your JupyterHub to _use_ the Google OAuthenticator for authentication: ``` sudo tljh-config set auth.type oauthenticator.google.GoogleOAuthenticator ``` 5. Restart your JupyterHub so that new users see these changes: ``` sudo tljh-config reload ``` ### Advanced Configuration with Google Groups Administrative and regular users of your TLJH can also be easily managed with Google Groups. This requires a service account and a Workspace admin account that can be impersonated by the service account to read groups in your domain. You may need to contact your Google Workspace administrator for help performing these steps. 1. [Create a service account](https://cloud.google.com/iam/docs/service-accounts-create). 1. [Create a service account key](https://developers.google.com/workspace/guides/create-credentials#create_credentials_for_a_service_account). Keep this key in a safe space, you will need to add it to your instance later. 1. Setup [domain-wide delegation](https://developers.google.com/workspace/guides/create-credentials#optional_set_up_domain-wide_delegation_for_a_service_account) for the service account that includes the following scopes: ``` https://www.googleapis.com/auth/admin.directory.user.readonly https://www.googleapis.com/auth/admin.directory.group.readonly ``` 1. Add the service account key to your instance and ensure it is _not_ readable by non-admin users of the hub. :::{important} The service account key is a secret. Anyone for whom you configure admin privileges on your TLJH instance will be able to access it. ::: 1. Log in as an administrator account to your JupyterHub. 1. Open a terminal window. ```{image} ../../images/notebook/new-terminal-button.png :alt: New terminal button. ``` 1. Install the extra requirements within the hub environment. ``` source /opt/tljh/hub/bin/activate pip3 install oauthenticator[googlegroups] deactivate ``` 1. Create a configuration directory `jupyterhub_config.d` within `/opt/tljh/config/`. Any `.py` files within this directory will be sourced for configuration. ``` sudo mkdir /opt/tljh/config/jupyterhub_config.d ``` 1. Configure your hub for Google Groups-based authentication by adding the following to a `.py` file within `/opt/tljh/config/jupyterhub_config.d`. ```python from oauthenticator.google import GoogleOAuthenticator c.JupyterHub.authenticator_class = GoogleOAuthenticator c.GoogleOAuthenticator.google_service_account_keys = {'': ''} c.GoogleOAuthenticator.gsuite_administrator = {'': ''} c.GoogleOAuthenticator.allowed_google_groups = {'': ['example-group', 'another-example-group']} c.GoogleOAuthenticator.admin_google_groups = {'': ['example-admin-group', 'another-example-admin-group']} c.GoogleOAuthenticator.client_id = '' c.GoogleOAuthenticator.client_secret = '' c.GoogleOAuthenticator.hosted_domain = '' c.GoogleOAuthenticator.login_service = '' c.GoogleOAuthenticator.oauth_callback_url = 'http(s):///hub/oauth_callback' ``` See the [Google OAuthenticator documentation](https://oauthenticator.readthedocs.io/en/latest/reference/api/gen/oauthenticator.google.html) for more information on these and other configuration options. 1. Reload your configuration for the changes to take effect: ``` sudo tljh-config reload ``` ## Step 4: Confirm that the new authenticator works 1. **Open an incognito window** in your browser (do not log out until you confirm that the new authentication method works!) 2. Go to your JupyterHub URL. 3. You should see a Google login button like below: ```{image} ../../images/auth/google/login_button.png :alt: The Google authenticator login button. ``` 4. After you log in with your Google credentials, you should be directed to the Jupyter interface used in this JupyterHub. 5. **If this does not work** you can revert back to the default JupyterHub authenticator by following the steps in [](/howto/auth/firstuse).