Google OAuth (On-Prem)
These instructions are specific to On-Premises Deployments of the Sysdig platform. If you are using the cloud-based (SaaS) Sysdig platform, refer to Google OAuth (SaaS) instead.
Google supports OAuth 2.0, which lets you log in to third-party applications such as Sysdig using Google credentials. By default, the created user will not have Admin rights within the Sysdig application, though these rights can be subsequently assigned.
Prerequisites
The Sysdig platform on-premises installation must have a DNS name associated with it. Google does not support applications that do not have an associated DNS name.
DNS Name
Kubernetes
For Kubernetes-based installations, ensure the api.url
ConfigMap
element
contains your hostname (older installations), or use the sysdig.dnsname
(newer Installer-based).
In the following examples, DNS_NAME
refers to the hostname you configured in your platform settings.
In Google Console: Obtain OAuth Client Credentials
Log in to the Google API Console.
Create your project.
Select Credentials from the left-hand navigation, and choose the OAuth consent screen from the navigation bar.
When prompted, select Internal or External User Type and click Create.
Choosing Internal will limit the users to those with accounts belonging to the same domain as the email used to create the project, for example,
mycompany.com
. Note that if some of your users have a different domain, such asmycompany.uk
, choose the External user type.On the subsequent OAuth Consent screen, enter the required Email address and Product name, as well as other additional optional information, then click Save.
From the Credentials tab, click the Create Credentials drop-down and select OAuth client ID.
When prompted for Application type, select Web application, then enter the following parameters:
Name: Use a meaningful name, such as “Sysdig”.
Authorized Javascript Origins: Enter
https://DNS_NAME:API_PORT
Authorized Redirect URLs: Enter one or more of the following values:
If configuring Sysdig Monitor, enter:
https://DNS_NAME:API_PORT/api/oauth/google/auth
If configuring Sysdig Secure, enter:
https://DNS_NAME:API_PORT/api/oauth/google/secureAuth
Click Create.
A success message with client ID and client secret will be displayed. Copy these to a safe place, as you will need them in the next step.
Configure Settings in Sysdig Platform
You can choose one of the following options to configure OAuth settings on the Sysdig side: a UI page, scripts, or entries in your Replicated or Kubernetes orchestrator.
1. UI-Based: Configure Google OAuth in Settings
To enable baseline Google OAuth functionality:
Enter Google OAuth Basic Settings
Log in to Sysdig Monitor or Sysdig Secure as “super” Admin and select Settings.
Select Authentication.
Select the Google OAuth tab.
Enter the relevant parameters and click Save.
Application ID: the Client ID you were sent
Application Secret: the Client Secret you were sent
URL Redirect:
If configuring Sysdig Monitor, enter:
https://DNS_NAME:API_PORT/api/oauth/google/auth
If configuring Sysdig Secure, enter:
https://DNS_NAME:API_PORT/api/oauth/google/secureAuth
Allowed Domains: Comma-separated list of domains permitted to log in. For example, mycompany.com, myxompanyalias.com.
Select Google OAuth for SSO
Select Google OAuthfrom the
Enabled Single Sign-On
dropdownClick Save Authentication.
Repeat for Sysdig Monitor or Sysdig Secure, if you want to enable on both applications.
2. Script-Based: Configure OAuth Using Scripts
The configuration of the Google OAuth feature can be viewed, updated, and deleted by the “super”
Admin. A
google_oauth_config.sh
helper script is available in the
SSO
folder at sysdig-cloud-scripts
repository to assist in completing
this configuration. Invoking the script with no options will display help text.
# ./google_oauth_config.sh -h
Usage: ./google_oauth_config.sh [OPTIONS]
Affect Google OAuth login settings for your Sysdig software platform installation
To use the helper script, modify env.sh
to set the required values
for API_TOKEN
of the “super” Admin user and the URL
for
accessing the Sysdig platform API (which will be the same URL that your
users access for the Sysdig Monitor application).
Depending if the API_TOKEN has been obtained from the Sysdig Monitor or Sysdig Secure application UI, the settings will be applied to the consequent product.
Initially, no Google OAuth settings are set. A initial run of the script would confirm that:
# ./google_oauth_config.sh
No google-oauth settings are set
Run for further info: ./google_oauth_config.sh -h
Add the -s
option to set the Google OAuth configuration for a
particular Sysdig application. When setting the config, you’ll use
additional options to provide the config details you saved in the
earlier Google OAuth step.
Config Detail | Option |
---|---|
Client ID | -i |
Client Secret | -e |
Allowed Domains | -a |
Redirect URL | -r |
If the configuration is successfully posted to the Sysdig platform, the new configuration will be echoed back.
Depending if the API_TOKEN has been obtained from the Sysdig Monitor or Sysdig Secure application UI, the settings will be applied to the relevant product.
# ./google_oauth_config.sh -s -i "t2em0alq7l13n1hevua48ehieenkb06q.apps.googleusercontent.com" -e "ucP_WY908-k" -r "https://sysdigtest.com:443/api/oauth/google/auth" -a "[\"sysdig.com\"]"
{
"authenticationSettings": {
"id": 1,
"version": 1,
"createdOn": 1547709552000,
"type": "google-oauth",
"scope": "SYSTEM",
"settings": {
"clientId": "t2em0alq7l13n1hevua48ehieenkb06q.apps.googleusercontent.com",
"clientSecret": "ucP_WY908-k",
"redirectUrl": "https://sysdigtest.com:443/api/oauth/google/auth",
"allowedDomains": [
"sysdig.com"
]
}
}
}
Once you’ve completed this configuration, clicking the Google Login button at the login screen of the appropriate Sysdig application(s) should redirect to Google OAuth login page.
If you wish to delete your Google OAuth configuration, invoke the
-d
option. If successful, the disabled configuration will be
printed.
# ./google_oauth_config.sh -d
{
"authenticationSettings": {
"id": 1,
"version": 1,
"createdOn": 1547709552000,
"type": "google-oauth",
"scope": "SYSTEM",
"settings": {
"clientId": "t2em0alq7l13n1hevua48ehieenkb06q.apps.googleusercontent.com",
"clientSecret": "ucP_WY908-k",
"redirectUrl": "https://sysdigtest.com:443/api/oauth/google/auth",
"allowedDomains": [
"sysdig.com"
]
}
}
}
3. Orchestrator-Based: Enter Settings Using Orchestrator
Kubernetes
Enter the OAuth allowed domains, Client ID, and Client Secret into the appropriate elements of the Kubernetes ConfigMap. Use appropriate Kubernetes methods to push the updated settings and restart the backend containers to apply the changes.
# Optional: OAuth allowed domains (comma separated list of domains) sysdigcloud.oauth.allowed.domains.list: "" # Optional: Sysdig Cloud Google OAuth Client ID sysdigcloud.google.oauth.client.id: "" # Optional: Sysdig Cloud Google OAuth Client Secret sysdigcloud.google.oauth.client.secret: "" |
User Experience
The following are required for successful Google OAuth login:
You must have already logged in successfully at least once to your environment (such as via email-based Invitation and set an initial password).
Your login username in the Sysdig platform must precisely match your Google email address (it cannot be a shortened/altered Google email alias).
If your setup meets the requirements, you can log in via Google OAuth by clicking the Log in with Google button.
If your browser has not already successfully authenticated via Google and/or has multiple Google profiles known by their browser, you will be presented a Google page to select a profile and enter a password (if necessary) before being redirected back to your Sysdig environment.
See also User and Team Administration for information on creating users.
Feedback
Was this page helpful?
Glad to hear it! Please tell us how we can improve.
Sorry to hear that. Please tell us how we can improve.