diff options
author | Dimitris Kavvathas <dimitris.kavvathas@sonarsource.com> | 2022-09-19 11:04:23 +0200 |
---|---|---|
committer | sonartech <sonartech@sonarsource.com> | 2022-09-22 20:03:33 +0000 |
commit | 4403555a430bfa814e261a0e680b953bab9d9594 (patch) | |
tree | e8adcf7047fd5cde719f61a75bae375adbfdd907 | |
parent | 3eeb15ab739dc67d135128142a37b8c75635a8d1 (diff) | |
download | sonarqube-4403555a430bfa814e261a0e680b953bab9d9594.tar.gz sonarqube-4403555a430bfa814e261a0e680b953bab9d9594.zip |
SONAR-17229 Improve Azure AD integration documentation
3 files changed, 71 insertions, 62 deletions
diff --git a/server/sonar-docs/src/images/azure/saml-azure-signature.jpg b/server/sonar-docs/src/images/azure/saml-azure-signature.jpg Binary files differnew file mode 100644 index 00000000000..8fa055c2771 --- /dev/null +++ b/server/sonar-docs/src/images/azure/saml-azure-signature.jpg diff --git a/server/sonar-docs/src/pages/instance-administration/authentication/saml/azuread.md b/server/sonar-docs/src/pages/instance-administration/authentication/saml/azuread.md index fb757426f1c..9f9cab97cbe 100644 --- a/server/sonar-docs/src/pages/instance-administration/authentication/saml/azuread.md +++ b/server/sonar-docs/src/pages/instance-administration/authentication/saml/azuread.md @@ -5,71 +5,80 @@ url: /instance-administration/authentication/saml/azuread/ The following content may be useful if you're using Azure AD as a SAML Identity Provider. -To integrate Azure AD (Identity Provider) with SonarQube SAML configuration (Service Provider), both sides need to be configured. +To integrate Azure AD (Identity Provider) with SonarQube (Service Provider), both sides need to be configured. For SonarQube, navigate to **Administration > Authentication > SAML**. For Azure AD, login to Azure and navigate to Azure AD. ## Set up the SonarQube application in Azure AD -- In Azure AD, navigate to **Enterprise applications** and add a **New Application**. +1. In Azure AD, navigate to **Enterprise applications** and add a **New Application**. data:image/s3,"s3://crabby-images/253b7/253b7a89706193deabfed717a711f2af54178e78" alt="SAML Azure AD New Application" -- Create your **own application** and fill in the **name**. +1. Create your **own application** and fill in the **name**. data:image/s3,"s3://crabby-images/088e2/088e269a19e61545e8c271ca208c72e9dd10835a" alt="SAML Azure AD Create application" ## Link SonarQube with Azure AD -- Navigate to **Single sign-on** and select **SAML**. +1. Navigate to **Single sign-on** and select **SAML**. data:image/s3,"s3://crabby-images/7ff55/7ff552a741a8b77886774c90d7085c21f9f48b9d" alt="SAML Azure AD SSO" -- Edit the **Basic SAML Configuration** and fill in the **Identifier** and the **Reply URL**. The **Identifier** has to be the same as the **Application ID** in SonarQube. The **Reply URL** must have the format `<Your SonarQube URL>/oauth2/callback/saml`. +1. Edit the **Basic SAML Configuration** and fill in the **Identifier** and the **Reply URL**. The **Identifier** has to be the same as the **Application ID** in SonarQube. The **Reply URL** must have the format `<Your SonarQube URL>/oauth2/callback/saml`. data:image/s3,"s3://crabby-images/2c3f7/2c3f73980c9e1bb23fe6f5531c5988bae13f5184" alt="SAML Azure AD Basic SAML configuration" -- Fill in the corresponding SonarQube configuration. + + [[info]] + |The **Reply URL** uses the **Server base URL** provided in SonarQube under **Administration > General**. +1. Make sure that the **Application ID** in SonarQube has the same value as the **Identifier** in the Identity Provider. data:image/s3,"s3://crabby-images/991a1/991a1bd67b9bca20455596d2aed20f44d212d969" alt="SAML Azure AD SonarQube Application ID" -- In the Azure AD SAML configuration, navigate to **Set up "application name"** and copy the **Login URL** and **Azure AD Identifier** +1. In the Azure AD SAML configuration, navigate to **Set up <application name>** and copy the **Login URL** and **Azure AD Identifier** data:image/s3,"s3://crabby-images/a69b5/a69b5b861dfdfdb4569c1c2890d56038f52cfbe9" alt="SAML Azure AD Links" -- Paste them into the corresponding fields in the SonarQube SAML configuration. +1. Paste the **Login URL** into the **SAML login url** and the **Azure AD Identifier** into the **Provider ID** field in the SonarQube SAML configuration. data:image/s3,"s3://crabby-images/c0bf3/c0bf38935c2a2174a80e0bc5dacbde8acd13469a" alt="SAML Azure AD SonarQube Links" ## Attributes and Claims -- In the Azure AD SAML configuration, edit **Attributes & Claims** to view, edit or add attributes. +1. In the Azure AD SAML configuration, edit **Attributes & Claims** to view, edit or add attributes. data:image/s3,"s3://crabby-images/9b1a8/9b1a85d6f92c03a82ef8a031c247fffc7c15dff2" alt="SAML Azure AD Attributes" SonarQube uses the following attributes: - - **Login** (required) A unique name to identify the user in SonarQube. The default Azure AD attribute `emailaddress` is used in the example. - - **Name** (required) The full name of the user. The default Azure AD attribute `givenname` is used in the example. - - **Email** (optional) The email of the user. - - **Group** (optional) Supports mapping to group names in SonarQube. These have to be the same as the group name passed by Azure AD. Otherwise, the default **sonar-users** group is assigned. - **Note:** The **NameID** attribute is *not* used in SonarQube. -- Corresponding configuration in SonarQube. The full namespace of the attribute should be used. + - **Login** (required) A unique name to identify the user in SonarQube. The default Azure AD attribute `emailaddress` is used in the example. + - **Name** (required) The full name of the user. The default Azure AD attribute `givenname` is used in the example. + - **Email** (optional) The email of the user. + - **Group** (optional) Supports mapping to group names in SonarQube. Group name passed by Azure AD and the group name in SonarQube should match. Otherwise, the default **sonar-users** group is assigned. + [[warning]] + |The **NameID** attribute is *not* used in SonarQube. +1. Corresponding configuration in SonarQube. The namespace + name of the attribute should be used, as defined in Azure AD. data:image/s3,"s3://crabby-images/33fba/33fba9443d40cdcb202d783b70fcb6f6c68173e1" alt="SAML Azure AD SonarQube Attributes" ## Certificates & Signatures -- Navigate to **SAML Certificates** and download **Certificate (Base64)**. +1. Navigate to **SAML Certificates** and download **Certificate (Base64)**. data:image/s3,"s3://crabby-images/156e7/156e77ed38804cfe2f6f8204814ecc16361e063c" alt="SAML Azure AD Certificate" -- The certificate should be copied into the **Identity provider certificate** field in the SonarQube SAML configuration. +1. The certificate should be copied into the **Identity provider certificate** field in the SonarQube SAML configuration. data:image/s3,"s3://crabby-images/f2cf3/f2cf3b3887e3392e27afec3da1929139a3eb003c" alt="SAML Azure AD SonarQube Certificate" -- (Optional) Encryption for SonarQube requests can be activated by generating an asymmetric key pair. - +1. (Optional) Encryption for SonarQube requests can be activated by generating an asymmetric key pair. (For more information, see [SAML token encryption in Azure](https://docs.microsoft.com/en-us/azure/active-directory/manage-apps/howto-saml-token-encryption?tabs=azure-portal)) Add the private key in SonarQube. data:image/s3,"s3://crabby-images/5eb61/5eb6105710355dc093b63836154b4757c1509021" alt="SAML Azure AD SonarQube Encryption" Import the public key certificate (.cer) file in Azure AD and activate token encryption data:image/s3,"s3://crabby-images/3b0a3/3b0a352eb51e47b46d5975b323aae7abdd69dad3" alt="SAML Azure AD Encryption" -- Azure AD, as an Identity Provider, does not verify signed requests from the Service Providers. SonarQube, however, offers the option for signing the SAML requests by adding a Service Provider private key and certificate. +1. (Optional) Azure AD supports signed SAML requests from the Service Provider (under Preview). + Edit the **Verification certificates**, upload a certificate and enable the **Require verification certificates** option. + data:image/s3,"s3://crabby-images/64d82/64d827df7ba42629fa68e0f6dccc105b04d05408" alt="SAML Azure AD Encryption" + In SonarQube, fill in the corresponding private key and the same certificate and enable the **Sign requests** option. data:image/s3,"s3://crabby-images/57a45/57a451267a9910f1edab3cd2bc1c74d9bd504753" alt="SAML Azure AD SonarQube certs" ## Users and Groups -- In the Azure AD SonarQube application, navigate to **Users and groups** and assign users or groups to the application. +1. In the Azure AD SonarQube application, navigate to **Users and groups** and assign users or groups to the application. data:image/s3,"s3://crabby-images/b2910/b2910a72074c5e5654be958a6f598e3c040b2bc2" alt="SAML Azure AD SonarQube Links" ## Group mapping Group mapping between Azure AD and SonarQube can be achieved either by using the Azure AD roles or the Azure AD groups. -For either case, the corresponding group name should exist in SonarQube. +For either case, the corresponding group name should exist in SonarQube under **Administration > Security > Groups**. (For more information, see [Authorization](/instance-administration/security/)) - For mapping with the Azure AD groups, a group claim must be added with `sAMAccountName` as a source attribute. + [[warning]] + |According to Azure: This source attribute only works for groups synchronized from an on-premises Active Directory using AAD Connect Sync 1.2.70.0 or above data:image/s3,"s3://crabby-images/9a953/9a953b7f5b20786381b3785264ba83b8984b8c33" alt="SAML Azure AD SonarQube Links" data:image/s3,"s3://crabby-images/c1841/c184165f8b3c77a04a7c4db9bc099014a5c2368f" alt="SAML Azure AD SonarQube Links" -- For mapping with the Azure AD roles, an application role should be assigned to the user. Azure AD sends the role claim automatically with `http://schemas.microsoft.com/ws/2008/06/identity/claims/role` as a key. +- For mapping with the Azure AD app roles, an application role should be assigned to the user. Azure AD sends the role claim automatically with `http://schemas.microsoft.com/ws/2008/06/identity/claims/role` as a key. data:image/s3,"s3://crabby-images/79557/795571181d42cb5090aadfe4344d5fe07dd018ea" alt="SAML Azure AD SonarQube Links" ## Enabling and testing SAML authentication -- In the SonarQube SAML settings, enable SAML. +1. In the SonarQube SAML settings, enable SAML. data:image/s3,"s3://crabby-images/3fc86/3fc86139df5a3887cd48c989079a13d536a3ba87" alt="SAML Azure AD SonarQube SAML" -- In the login form, the new button **Log in with SAML** (or a custom name specified in the `sonar.auth.saml.providerName` setting) allows users to connect with their SAML account. +1. In the login form, the new button **Log in with SAML** (or a custom name specified in the `sonar.auth.saml.providerName` setting) allows users to connect with their SAML account. + data:image/s3,"s3://crabby-images/b8eef/b8eefa4272bfe4f36fc2d2b4fcdfbd16c9343ab4" alt="SAML Azure AD SonarQube Login" diff --git a/server/sonar-docs/src/pages/instance-administration/authentication/saml/okta.md b/server/sonar-docs/src/pages/instance-administration/authentication/saml/okta.md index 4e61ab7a19c..58497ecc7f0 100644 --- a/server/sonar-docs/src/pages/instance-administration/authentication/saml/okta.md +++ b/server/sonar-docs/src/pages/instance-administration/authentication/saml/okta.md @@ -23,83 +23,83 @@ To integrate Okta (Identity Provider) with SonarQube (Service Provider), both si ### Configure SAML settings -Under *General Settings*, configure the following fields: +1. Under *General Settings*, configure the following fields: -- **Single sign on URL**: `<Your SonarQube URL>/oauth2/callback/saml` (e.g., `https://sonarqube.mycompany.com/oauth2/callback/saml`). + - **Single sign on URL**: `<Your SonarQube URL>/oauth2/callback/saml` (e.g., `https://sonarqube.mycompany.com/oauth2/callback/saml`). -- **Audience URI (SP Entity ID)**: Something like `sonarqube` (SonarQube default value). It must not contain whitespace. + - **Audience URI (SP Entity ID)**: Something like `sonarqube` (SonarQube default value). It must not contain whitespace. -data:image/s3,"s3://crabby-images/132bd/132bd29d5df59e3e65f3bf999f5848413b33b975" alt="SAML settings" + data:image/s3,"s3://crabby-images/132bd/132bd29d5df59e3e65f3bf999f5848413b33b975" alt="SAML settings" -Assertion signature is mandatory. You must keep the following default settings in *Show Advanced Settings*: +2. Assertion signature is mandatory. You must keep the following default settings in *Show Advanced Settings*: -- **Response**: Choose *Signed*. + - **Response**: Choose *Signed*. -- **Assertion Signature**: Choose *Signed*. + - **Assertion Signature**: Choose *Signed*. -- **Signature Algorithm**: Choose *RSA-SHA256*. + - **Signature Algorithm**: Choose *RSA-SHA256*. -(Optional) If you want to enable assertion encryption, expand *Show Advanced Settings* and configure the following fields: +3. (Optional) If you want to enable assertion encryption, expand *Show Advanced Settings* and configure the following fields: -- **Assertion Encryption**: Choose *Encrypted*. + - **Assertion Encryption**: Choose *Encrypted*. -- **Encryption Algorithm**: Choose *AES256-GCM* for high security. + - **Encryption Algorithm**: Choose *AES256-GCM* for high security. -- **Key Transport Algorithm**: Choose *RSA-OAEP*. + - **Key Transport Algorithm**: Choose *RSA-OAEP*. -- **Encryption Certificate**: Add the service provider certificate. It should be the same certificate as the one found in the SonarQube SAML settings under "Service provider certificate". + - **Encryption Certificate**: Add the service provider certificate. It should be the same certificate as the one found in the SonarQube SAML settings under "Service provider certificate". -data:image/s3,"s3://crabby-images/8c6d6/8c6d6f68497b6d39da7e0ee5940dcbd44046f01b" alt="Encryption attributes" + data:image/s3,"s3://crabby-images/8c6d6/8c6d6f68497b6d39da7e0ee5940dcbd44046f01b" alt="Encryption attributes" -Under **Attribute Statements**, add the following attribute mappings: +4. Under **Attribute Statements**, add the following attribute mappings: -- Create a mapping for the *name*: + - Create a mapping for the *name*: - 1. **Name**: `name`. + 1. **Name**: `name`. - 2. **Name format**: *Unspecified*. + 2. **Name format**: *Unspecified*. - 3. **Value**: Choose `user.firstName`. + 3. **Value**: Choose `user.firstName`. -- Create a mapping for the *login*: + - Create a mapping for the *login*: - 1. **Name**: `login`. + 1. **Name**: `login`. - 2. **Name format**: *Unspecified*. + 2. **Name format**: *Unspecified*. - 3. **Value**: Choose `user.login`. + 3. **Value**: Choose `user.login`. -- (Optional) Create a mapping for the *email*: + - (Optional) Create a mapping for the *email*: - 1. **Name**: `email`. + 1. **Name**: `email`. - 2. **Name format**: *Unspecified*. + 2. **Name format**: *Unspecified*. - 3. **Value**: Choose `user.email`. + 3. **Value**: Choose `user.email`. - data:image/s3,"s3://crabby-images/1a058/1a0585980b33ea5f72d02b546feadb3f4f06ba12" alt="Attributes" + data:image/s3,"s3://crabby-images/1a058/1a0585980b33ea5f72d02b546feadb3f4f06ba12" alt="Attributes" -- (Optional) Under *Group Attribute Statements* (See details in [Group Mapping](/instance-administration/authentication/overview/)): + - (Optional) Under *Group Attribute Statements* (See details in [Group Mapping](/instance-administration/authentication/overview/)): - 1. **Name**: `groups`. + 1. **Name**: `groups`. - 2. **Name format**: *Unspecified*. + 2. **Name format**: *Unspecified*. - 3. **Filter**: Choose *Matches regex* and set the value to `.*`. + 3. **Filter**: Choose *Matches regex* and set the value to `.*`. - data:image/s3,"s3://crabby-images/6fabb/6fabbe6208a367365a000bc2da576d72c6618319" alt="Group attribute" + data:image/s3,"s3://crabby-images/6fabb/6fabbe6208a367365a000bc2da576d72c6618319" alt="Group attribute" -Click **Finish** in the **Feedback** dialog to confirm the creation of the application. +5. Click **Finish** in the **Feedback** dialog to confirm the creation of the application. -You can now add users and groups in the *Assignments* tab of the application. +6. You can now add users and groups in the *Assignments* tab of the application. data:image/s3,"s3://crabby-images/9e5fe/9e5fe681197cb7cfd87710f2cd33cabb59993d8e" alt="Assign users" -Navigate to the **Sign On** tab of the *SonarQube* application in Okta. +7. Navigate to the **Sign On** tab of the *SonarQube* application in Okta. data:image/s3,"s3://crabby-images/3bebc/3bebc61474f87ab42de0b03d53ef6bb0d386206c" alt="Signon tab" -Next to the **SAML Signing Certificates** subsection, you will find the configurations needed for setting up SonarQube, under **View SAML setup instructions**. +8. Next to the **SAML Signing Certificates** subsection, you will find the configurations needed for setting up SonarQube, under **View SAML setup instructions**. data:image/s3,"s3://crabby-images/af000/af000a69ab8a78ff13c9489b743ccc877c810008" alt="Setup instructions" |