Amazon Web Services Cognito

Amazon Cognito lets you add user sign-up, sign-in, and access control to your GitLab instance. The following documentation enables Cognito as an OAuth2 provider.

Configure AWS Cognito

To enable the AWS Cognito OAuth2 OmniAuth provider, register your application with Cognito, where it will generate a Client ID and Client Secret for your application. Any settings you configure in the following procedure can be modified later. The following steps enable AWS Cognito as an authentication provider:

  1. Sign in to the AWS console.

  2. Select Cognito from the Services menu.

  3. Select Manage User Pools, and click the Create a user pool button in the top right corner.

  4. Enter the pool name and then click the Step through settings button.

  5. Under How do you want your end users to sign in?, select Email address or phone number and Allow email addresses.

  6. Under Which standard attributes do you want to require?, select email.

  7. Go to the next steps of configuration and set the rest of the settings to suit your needs - in the basic setup they are not related to GitLab configuration.

  8. In the App clients settings, click Add an app client, add App client name and select the Enable username password based authentication check box.

  9. Click Create app client.

  10. In the next step, you can set up AWS Lambda functions for sending emails. You can then finish creating the pool.

  11. After creating the user pool, go to App client settings and provide the required information:

    • Enabled Identity Providers - select all
    • Callback URL - https://gitlab.example.com/users/auth/cognito/callback
      • Substitute the URL of your GitLab instance for gitlab.example.com
    • Allowed OAuth Flows - Authorization code grant
    • Allowed OAuth2 Scopes - email, openid, and profile
  12. Save changes for the app client settings.

  13. Under Domain name include the AWS domain name for your AWS Cognito application.

  14. Under App Clients, find your App client id and App client secret. These values correspond to the OAuth2 Client ID and Client Secret. Save these values.

Configure GitLab

  1. See Initial OmniAuth Configuration for initial settings.

  2. On your GitLab server, open the configuration file.

    For Omnibus installations

    sudo editor /etc/gitlab/gitlab.rb
  3. In the following code block, substitute the Client ID (app_id), Client Secret (app_secret), and the Amazon domain name (site) for your AWS Cognito application. Include the code block in the /etc/gitlab/gitlab.rb file:

    gitlab_rails['omniauth_allow_single_sign_on'] = ['cognito']
    gitlab_rails['omniauth_providers'] = [
      {
        "name" => "cognito",
        "app_id" => "CLIENT ID",
        "app_secret" => "CLIENT SECRET",
        "args" => {
          "scope" => "openid profile email",
          client_options: {
            'site' => 'https://your_domain.auth.your_region.amazoncognito.com',
            'authorize_url' => '/oauth2/authorize',
            'token_url' => '/oauth2/token',
            'user_info_url' => '/oauth2/userInfo'
          },
          user_response_structure: {
            root_path: [],
            id_path: ['sub'],
            attributes: { nickname: 'email', name: 'email', email: 'email' }
          },
          name: 'cognito',
          strategy_class: "OmniAuth::Strategies::OAuth2Generic"
        }
      }
    ]
  4. Save the configuration file.

  5. Save the file and reconfigure GitLab for the changes to take effect.

Your sign-in page should now display a Cognito button below the regular sign-in form. To begin the authentication process, click the icon, and AWS Cognito will ask the user to sign in and authorize the GitLab application. If successful, the user will be redirected and signed in to your GitLab instance.