Table of Contents
- Prerequisites
- GitHub Account
- Configure GitHub as an identity provider
- Add GitHub identity provider to a user flow
- Google Account
- Configure Google as an identity provider
- Add Google identity provider to a user flow
- Microsoft Account
- Configure Microsoft as an identity provider
- Add Microsoft identity provider to a user flow
- Successful Sign in
- Cloudapp-dev, and before you leave us
In this last story of a series of three, we will focus on possible Identity providers for our Azure B2C Tenant because we would like to remove every obstacle for our users during the login process. Since we will also add comment functionality in the upcoming stories, we need the login to be as handy as possible. So let's start with the ID Providers from Github, Google and Microsoft.
In the last three stories, we did:
We will now add three Identity providers, allowing our users to log in very quickly via their existing account (Social Login).
To add new identity providers to our B2C Tenant, we open the Azure B2C Tenant and then select “Identity providers” on the left. We will now see all possible providers but focus on the three mentioned at the beginning.
data:image/s3,"s3://crabby-images/bb124/bb124ff0ec4ed4129c6854fc253120963c18dacc" alt="Azure-AD-B2C-ID-Overview"
Prerequisites
(are identical for all three ID providers)
Create a user flow, what we already did in our first story
GitHub Account
Create a GitHub OAuth application
To enable sign-in with a GitHub account in Azure Active Directory B2C (Azure AD B2C), you need to create an application in GitHub Developer portal. For more information, see Creating an OAuth App. If you don’t already have a GitHub account, you can sign up at https://www.github.com/.
data:image/s3,"s3://crabby-images/df97d/df97d5a1523a4f6b9526449cafd537bbc0788522" alt="Github-Developer-applications"
Sign in to the GitHub Developer with your GitHub credentials.
Select OAuth Apps and then select New OAuth App.
Enter an Application name and your Homepage URL (in our case, we use our example URL from the Vercel deployment -> https://nextjs14-auth-azureb2c.vercel.app/)
For the Authorization callback URL, enter https://your-tenant-name.b2clogin.com/your-tenant-name.onmicrosoft.com/oauth2/authresp (For my use case -> https://cloudappdevorg.b2clogin.com/cloudappdevorg.onmicrosoft.com/oauth2/authresp). If you use a custom domain, enter https://your-domain-name/your-tenant-name.onmicrosoft.com/oauth2/authresp. Replace your-domain-name with your custom domain, and your-tenant-name with the name of your tenant. Use all lowercase letters when entering your tenant name, even if the tenant is defined with uppercase letters in Azure AD B2C.
Click Register application.
Copy the values of Client ID and Client Secret (You have to create a new secret with the CTA -> generate a new client secret). Save the values, especially the secret, in a safe place. You need both to add the identity provider to your tenant.
data:image/s3,"s3://crabby-images/58a94/58a94c20c329fee8286407a211e0f04373f8b0b6" alt="Github-Developer-applications Details"
data:image/s3,"s3://crabby-images/c4515/c4515b10821562122089079677f4e5de91404eb4" alt="Github-Developer-applications final"
Configure GitHub as an identity provider
Sign in to the Azure portal and go back to our Azure AD B2C Tenant (Url should be ->
https://portal.azure.com/#view/Microsoft_AAD_B2CAdmin/TenantManagementMenuBlade/~/overview)
Select Identity Providers, then select GitHub (Preview).
Enter a Name. For example, GitHub ID Provider.
For the Client ID, enter the Client ID of the GitHub application you created earlier.
For the Client secret, enter the Client Secret that you created earlier and recorded.
Select Save.
data:image/s3,"s3://crabby-images/ba3db/ba3db6dff1bd25eaa9b48b0a41f8a4b59eea04e5" alt="Github-AD-B2C-Setup"
Add GitHub identity provider to a user flow
data:image/s3,"s3://crabby-images/32e09/32e093090390409ccd47f342e26f7ef2d6c70123" alt="Github-AD-B2C-Userflow-Setup"
At this point, the GitHub identity provider has been set up, but it’s not yet available in any of the sign-in pages. To add the GitHub identity provider to a user flow:
In your Azure AD B2C tenant, select User flows.
Click the user flow that you want to add to the GitHub identity provider.
Under the Social identity providers, select GitHub.
Select Save.
To test your policy, select Run user flow.
For Application, select the web application named Localhost that you previously registered. The Reply URL should show https://jwt.ms.
Select the Run user flow button.
From the sign-up or sign-in page, select GitHub to sign in with GitHub account.
If there is no “https://jwt.ms” available on the right flyout, you have to go back to the “Localhost” app registration, and you must add a new “Authentication Platform” of type Web and with URL “https://jwt.ms.”
data:image/s3,"s3://crabby-images/6a63c/6a63cf6e8e73f810606aaa64eb45d581f413d891" alt="Github-AD-B2C-Localhost-JWT"
Great, now we are done with GitHub. Let’s continue with Google and then Microsoft.
data:image/s3,"s3://crabby-images/83495/8349579f1d94ea1d8f3d65b215a56de94e746b8c" alt="Github-Sign-up-or-sign-in-Overlay"
Google Account
To enable sign-in for users with a Google account in Azure Active Directory B2C (Azure AD B2C), you need to create an application in Google Developers Console. For more information, see Setting up OAuth 2.0. If you don’t already have a Google account, you can sign up at https://accounts.google.com/signup.
data:image/s3,"s3://crabby-images/f3078/f3078e8d5737cf1bd825a0de3c9b38fa697d68e3" alt="Google-Cloud-console-New-project"
data:image/s3,"s3://crabby-images/f21df/f21df4b68bd4012238a178749ae19484fd71104d" alt="Google-Cloud-console-project-selection"
data:image/s3,"s3://crabby-images/7a34c/7a34c48674fe2c67eb78d800142cb7151698535d" alt="Google-Cloud-console-api-services"
data:image/s3,"s3://crabby-images/52ad3/52ad303bcb72b7fe5725ea4cb3c46df13cf6b435" alt="Google-Cloud-console-Oauth-details"
data:image/s3,"s3://crabby-images/70ad0/70ad07a40d83379e151639c1f95db011c17bce0c" alt="Google-Cloud-console-Oauth-testuser"
data:image/s3,"s3://crabby-images/93205/932052fe5434149eb36ae847da5ad8e2fbadf7af" alt="Google-Cloud-console-Oauth-credentials"
Sign in to the Google Developers Console with your Google account credentials.
In the upper-left corner of the page, select the project list, and then select New Project.
Enter a Project Name, select Create.
Make sure you are using the new project by selecting the project drop-down in the top-left of the screen. Select your project by name, then select Open.
In the left menu, select APIs and services and then OAuth consent screen. Select External and then select Create.
Enter a Name for your application.
Select a User support email.
In the App domain section, enter a link to your Application home page, a link to your Application privacy policy, and a link to your Application terms of service.
In the Authorized domains section, enter b2clogin.com and nextjs14-auth-azureb2c.vercel.app (example domain)
In the Developer contact information section, enter comma-separated emails for Google to notify you about any changes to your project.
Select Save and Continue
Let’s add one Testuser and Select Save and Continue again
Select Credentials in the left menu, then select Create credentials > Oauth client ID.
Under Application type, select Web application.
Enter a Name for your application.
For the Authorized JavaScript origins, enter https://your-tenant-name.b2clogin.com. (https://cloudappdevorg.b2clogin.com in my case). If you use a
For the Authorized redirect URIs, enter https://your-tenant-name.b2clogin.com/your-tenant-name.onmicrosoft.com/oauth2/authresp. If you use a custom domain, enter https://your-domain-name/your-tenant-name.onmicrosoft.com/oauth2/authresp. Replace your-domain-name with your custom domain, and your-tenant-name with the name of your tenant. Use all lowercase letters when entering your tenant name, even if the tenant is defined with uppercase letters in Azure AD B2C. In all instances, replace your-tenant-name with the Directory (tenant) subdomain. We always use cloudappdevorg
Select Create.
Copy the values of Client ID and Client secret. You will need both of them to configure Google as an identity provider in your tenant. Client secret is an important security credential.
Configure Google as an identity provider
Here, you can follow the steps mentioned before for GitHub.
data:image/s3,"s3://crabby-images/33714/3371483a0284846cd2098c38627254435b75cbd7" alt="Google-AD-B2C-Setup"
Add Google identity provider to a user flow
The Google identity provider has been set up at this point, but it’s not yet available on any of the sign-in pages. To add the Google identity provider to a user flow:
Here, you can follow the steps mentioned before for GitHub.
data:image/s3,"s3://crabby-images/df43d/df43dff03519c0c816beb779633238cde382df2d" alt="Google-AD-B2C-Userflow-Setup"
Microsoft Account
To enable sign-in for users with a Microsoft account in Azure Active Directory B2C (Azure AD B2C), you need to create an application in the Azure portal. For more information, see Register an application with the Microsoft identity platform. If you don’t already have a Microsoft account, you can get one at https://www.live.com/.
Sign in to the Azure portal.
If you have access to multiple tenants, select the Settings icon in the top menu to switch to your Microsoft Entra ID tenant from the Directories + Subscriptions menu.
Choose All services in the top-left corner of the Azure portal, and then search for and select App registrations.
Select New registration.
Enter a Name for your application. For example, Azure AD B2C ID Provider.
Under Supported account types, select Accounts in any organizational directory (Any Microsoft Entra ID tenant — Multitenant) and personal Microsoft accounts (e.g. Skype, Xbox)
Under Redirect URI (optional), select Web and enter https://your-tenant-name.b2clogin.com/your-tenant-name.onmicrosoft.com/oauth2/authresp
. If you use a custom domain, enter https://your-domain-name/your-tenant-name.onmicrosoft.com/oauth2/authresp. Replace your-tenant-name with the name of your Azure AD B2C tenant, and your-domain-name with your custom domain.
Select Register
Record the Application (client) ID shown on the application Overview page. You need the client ID when you configure the identity provider in the next section.
Select Certificates & secrets
Click New client secret
Enter a Description for the secret, for example AD B2C APP Reg Secret, and then click Add.
Record the application password shown in the Value column. The client secret is needed when you configure the identity provider in the next section.
Configure Microsoft as an identity provider
Here, you can follow the steps mentioned before for GitHub.
Add Microsoft identity provider to a user flow
At this point, the Microsoft identity provider has been set up, but it’s not yet available in any of the sign-in pages. To add the Microsoft identity provider to a user flow:
Here, you can follow the steps mentioned before for GitHub.
Successful Sign in
What is valid for all three Identity providers is the fact that if the sign-in process is successful, your browser is redirected to https://jwt.ms, which displays the contents of the token returned by Azure AD B2C. You can add as many Identity providers as you want. The process is always the same.
data:image/s3,"s3://crabby-images/685df/685df75871c7c3d3e45604fadda82439c4aa5dbe" alt="Microsoft-Overlay"
Cloudapp-dev, and before you leave us
Thank you for reading until the end. Before you go: