Azure SSO via OIDC

Set up Azure SSO for OIDC

For a general overview of OIDC, see Setting up OIDC Federated SSO.

Set up OIDC SSO for Azure in Codefresh by:

  1. Registering the Codefresh application in Azure
  2. Configuring permissions for the Codefresh application in Azure
  3. Creating the Client secret in Azure
  4. Completing SSO configuration for Azure in Codefresh
  5. Configuring redirect URIs in Azure

Prerequisites

Make sure that your user in Azure who creates the application is assigned either of these roles:

  • Application Administrator
  • Global Administrator

If the user who creates the Azure application is not assigned to either of these roles, you cannot sync teams from Azure to Codefresh.

Step 1: Register the Codefresh application in Azure

To set up Microsoft Entra ID for SSO, first register a new application in Azure.

  1. Log in to the Azure Portal, and from the sidebar, select Microsoft Entra ID.

Microsoft Entra ID

Microsoft Entra ID
  1. From the sidebar, select App registrations, and then click + New registration on the top.
  2. Enter a name for the application, for example, Codefresh, and retain the default values for all other settings.

Enter a name and the register application

Enter a name and the register application
  1. To apply your changes, click Register. The application is created and registered in Microsoft Entra ID.

Step 2: Configure permissions for the application in Azure

Once the application has been created and registered, configure the required permissions.

  1. Open the application, and from the sidebar, select API permissions
  2. Configure the following:
    • Click + Add a permission.
    • From Request API Permissions, in the Microsoft APIs tab, select Microsoft Graph.

Select Microsoft Graph

Select Microsoft Graph
  1. Click Application permissions on the left.
    • Add Group > Read.All
    • Add User > Read.All
  2. Next add Delegated permissions on the right
    • Add User > Read.All

    NOTE
    The User.Read (Delegated) permission is added by default.

Full permissions for Microsoft Graph.

Full permissions for Microsoft Graph
  1. Click Add Permissions.
  2. Click Grant admin consent for Default Directory on the bar.

Step 3: Create client secret in Azure

Create a client secret for the application. You will need to provide it when you set up SSO for Azure in Codefresh.

  1. From the sidebar, select Certificates & secrets, and then click + New client secret.

Create client secret

Create client secret
  1. Optional. Add a meaningful description for the client secret, and either retain the default expiry date or define a custom one.

Description for client secret

Description for client secret

TIP
Make a note of the expiry date in your calendar to renew the key before the expiry date and prevent service interruptions.

  1. Click Add.
  2. Copy the secret Value, as you will need to provide it on setting up Azure SSO in Codefresh.

Step 4: Configure SSO settings for Azure in Codefresh

Configure SSO for Azure in the Codefresh UI. Depending on your configuration, you may need values for specific settings such as Tenant ID if you require team sync for example.

The Codefresh application settings you’ll require are available on log in to Microsoft Entra ID.

  • Home: Tenant ID or Primary Domain (required for team sync)
  • Enterprise Applications > Properties: Application ID and Object ID

Application and Object IDs under Enterprise Applications

Application and Object IDs under Enterprise Applications

Before You Begin

  • Have your client secret handy
  • From the Codefresh application in Azure:
    • Tenant ID or Primary Domain for team sync
    • Application ID and Object ID

How to

  1. In the Codefresh UI, click the Settings icon (gear) on the top right.
  2. In the sidebar, from Access & Collaboration, select Single Sign-On.
  3. Click Add Single Sign-On, and select Azure, and click Next.
  4. Enter the following:
    • Client Name: For auto-generation, leave empty. Codefresh generates the client name once you save the settings.
    • Display Name: Meaningful name for the SSO provider. This can be the name shown in Azure.
    • Application ID: Required for SSO. The Application ID from your Microsoft Entra ID > Enterprise Application Properties.
    • Client Secret: The key value you copied when you created the client secret in Azure.
    • Tenant: Optional. Required when Auto Sync users and teams to Codefresh is selected.
      Can be either the Tenant ID, for example, 0example1-0000-0aa0-a00a-1example0, or the Primary Domain, for example, mycompany.onmicrosoft.com from Microsoft Entra ID.
    • Object ID: Optional. Required when Auto Sync users and teams to Codefresh is selected.
      The Object ID from your Microsoft Entra ID > Enterprise Application Properties.
    • Auto Sync users and teams to Codefresh: Select to automatically sync user accounts in Microsoft Entra ID to your Codefresh account. Optionally, define the time interval, in hours, at which to sync, from 1 to 24. If you don’t specify an interval, the sync is every 12 hours.

SSO settings for Azure in Codefresh

SSO settings for Azure in Codefresh
  1. Click Save.
  2. Copy the Client Name that is displayed in the UI.

Example of Codefresh-generated Client Name for Azure

Example of Codefresh-generated Client Name for Azure

Step 5: Configure redirect URIs in Azure

As the final step, add the Codefresh callback URL to the allowed reply URLs for the created application in Azure.

  1. Go to Microsoft Entra ID > Apps registrations, and select the application you registered for SSO.
  2. From the sidebar, select Authentication.
  3. Below Platform Configuration, click Add a platform and then select Web.

Select Web configuration settings

Select Web configuration settings
  1. In the Configure Web form, do the following:
    • In the Redirect URIs field, enter the redirect URI in the format below:
      https://g.codefresh.io/api/auth/<your_codefresh_sso_client_name>/callback
      where:
      <your_codefresh_sso_client_name> is the Client Name shown in the SSO configuration, either defined by you or created by Codefresh.
    • Select ID tokens.

Web configuration settings

Web configuration settings

Step 6: (Optional) Configure for Azure Initiated Login

  1. Go to Microsoft Entra ID > Apps registrations, and select the application you registered for SSO.
  2. From the sidebar, select Branding & properties
  3. In the Home page URL field, insert the following https://g.codefresh.io/api/auth/<your_codefresh_sso_client_name>

Web configuration settings

Web configuration settings
  1. Go to Microsoft Entra ID > Enterprise Applications, and select the application you registered for SSO.
  2. Under Properties, toggle Visible to users to yes.
  3. Now the app can be added to a Collection for My Apps page for Azure Initiated Login.

About Federated Single Sign-On (SSO)
Setting up OIDC Federated SSO
Common configuration for SSO providers