Search Results :

×

Configure Azure B2C Single Sign-On (SSO) with WordPress OAuth


Azure B2C Single Sign-On (SSO) for WordPress uses OAuth Authorization flow to provide users secure access to WordPress site. With our WordPress OAuth Single Sign-On (SSO) plugin, Azure B2C acts as the OpenID Connect and OAuth provider, ensuring secure Single Sign-On (SSO) login for WordPress websites.

The integration of WordPress with Azure B2C simplifies and secures the login process using Azure B2C OAuth. This solution allows employees to access their WordPress sites with a single click using their Azure B2C credentials, completely removing the need to store, remember, and reset multiple passwords.

In addition to offering Azure B2C SSO functionality, the plugin extends its support to various IDPs, including Azure AD, Office 365, and specialized providers, offering robust Single Sign-On (SSO) capabilities like multi-tenant login, role mapping, and user profile attribute mapping. For a detailed overview of the features, check out the WordPress OAuth Single Sign-On (SSO) plugin. You can follow the below steps to setup Azure B2C Single Sign-On (SSO) with WordPress.

To know more details about different features provided in Azure AD SSO and Microsoft Office 365 SSO, please click here.


  If you want to enable users to unlock their account or reset passwords using Azure AD B2C self-service password reset, Refer to this Setup Guide.


WordPress Azure Integration


WordPress Azure integration provides functionality to manage all the user operations from your WordPress site.

Click here

Prerequisites: Download and Installation

  • Log into your WordPress instance as an admin.
  • Go to the WordPress Dashboard -> Plugins and click on Add New.
  • Search for a WordPress OAuth Single Sign-On (SSO) plugin and click on Install Now.
  • Once installed click on Activate


Steps to configure Azure B2C Single Sign-On (SSO) Login into WordPress

1. Setup Azure B2C as OAuth Provider

  • Sign in to Azure portal.
  • Go to Home and in the Azure services, select Azure AD B2C.
  • Configure Azure B2C SSO (Single Sign-On) - Select Azure AD B2C
  • Please make sure you are in the Azure AD B2C directory with an active subscription and if not, you can switch to the correct directory.
  • Configure Azure B2C SSO (Single Sign-On) - Login Applications
  • In the Essentials tab, you will find the Azure B2C domain name, keep it handy, you will need it later for configuring the Azure B2C tenant name under WordPress as an OAuth client.

    What is Tenant Name?
    You will need to copy the highlighted domain name portion only as shown in the below screenshot in order to configure the tenant name in the WordPress OAuth Client plugin.
    Eg. If your domain name is 'exampledomain.onmicrosoft.com', then your tenant name will be 'exampledomain'.


  • Configure Azure B2C SSO (Single Sign-On) - Generate Key
  • Now, click on App registrations and then click on the New registration option to create a new Azure b2c application.
  • Configure Azure B2C SSO (Single Sign-On) - Login Applications
  • Configure the following options to create a new application.
    • Enter a name for your application under the Name text field.
    • In supported account types, select 3rd option ‘Accounts in any organizational directory (Any Azure AD directory - Multitenant) and personal Microsoft accounts (e.g. Skype, Xbox)’
    • In the Redirect URI section, select the Web application and enter the Callback URL from the miniOrange OAuth Client plugin (Configure OAuth tab) and save it under the Redirect URL textbox.
    • Click on the Register button to create your application.
    • Configure Azure B2C SSO (Single Sign-On) - Create
  • After successful application creation, you will be redirected to the newly created application’s overview page. If not, you can go to the app registrations and search the name of your application and you will find your application in the list.
  • Configure Azure B2C SSO (Single Sign-On) - Applications option
  • Copy your Application ID and keep it handy, you will need it later for configuring the Client ID under WordPress as an OAuth Client plugin.
  • Configure Azure B2C SSO (Single Sign-On) - Application ID
  • Now, click on Certificates and secrets and then click on New client secret to generate a client secret. Enter a description and click on the Add button.
  • Configure Azure B2C SSO (Single Sign-On) - Generate Key
  • Copy the secret value from certificates & secrets page and keep it handy, you will need it later for configuring the Client Secret under WordPress as an OAuth Client plugin.
  • Configure Azure B2C SSO (Single Sign-On) - Generate Key

Step 1.1: Add Users in your b2c application

  • In home page, go to the Users tab in the left corner
  • Configure Azure B2C SSO (Single Sign-On) - user flow
  • Click on New user in the users page. Then click on Create new user option.
  • Configure Azure B2C SSO (Single Sign-On) - user flow
  • Select Create Azure AD B2C user. Then, scroll down and click on Email from sign in method and set your password and click create to save the user details to perform test configuration.
  • Configure Azure B2C SSO (Single Sign-On) - user flow

Step 1.2: How to create & add Azure B2C Policy

  • Go to User Flows tab and then click on New user flow.
  • Configure Azure B2C SSO (Single Sign-On) - user flow
  • Select a User flow type Sign up and Sign in then click on Create button.
  • Configure Azure B2C SSO (Single Sign-On) - sect user flow
  • Fill all the information e.g. Name, Identity providers, etc. Select the User attributes you want to fetch while Signup. Then click on Create button.
  • Configure Azure B2C SSO (Single Sign-On) - information of user flow Configure Azure B2C SSO (Single Sign-On) - information of user flow
  • Copy the Policy name this value whenever you need to enter Azure B2C Policy in miniOrange OAuth Client plugin.

Step 1.3: Add user claims to your application

  • Go to user flows under policies in the left corner.Select the configured policy.
  • Configure Azure B2C SSO (Single Sign-On) - information of user flow
  • Select Application claims in settings
  • Configure Azure B2C SSO (Single Sign-On) - information of user flow
  • Select the desired attributes to be displayed on the test configuration and save it.
  • Configure Azure B2C SSO (Single Sign-On) - information of user flow

Step 1.4: Configure ID-Token Claims in Azure B2C [Premium]

  • Go to your application in Azure Active Directory and select Token configuration from the left menu.
  • Click on Add optional claim and then select ID from the right section.
  • Now choose all the attributes you want to fetch while SSO (e.g family_name, given_name, etc) and click on Add button.
  • You might see a popup to Turn on the Microsoft Graph profile permission (required for claims to appear in token), enable it, and click on Add button.
  • Azure B2C B2C Single Sign-on (SSO) - Custom Attribute Mapping

You have successfully configured Azure B2C as OAuth Provider for achieving Azure B2C SSO (Single Sign-On) with WordPress for user authentication.

2. Setup WordPress as OAuth Client


  • Go to Configure OAuth tab and click Add New Application to add a new client application into your website.
  • Azure B2C Single Sign-On (SSO) OAuth - Add new application
  • Choose your Application from the list of OAuth / OpenID Connect Providers, Here Azure B2C
  • Azure B2C Single Sign-On (SSO) OAuth - Select Application
  • After selecting the provider copy the Callback URL which needs to be configured in OAuth Provider's SSO application Configuration.
  • Enter the Client Credentials like Client ID & Client Secret which you will get from the Azure B2C SSO application.
  • Configure Tenant Name & Policy Name found from the Azure B2C SSO application. Please refer the below table for configuring the scope & endpoints for Azure B2C in the plugin.
  • Scope: openid
    Authorize Endpoint: https://<domain-name >.b2clogin.com/<domain-name>.onmicrosoft.com/<policy-name>/oauth2/v2.0/authorize
    Access Token Endpoint: https://<domain-name>.b2clogin.com/<domain-name>.onmicrosoft.com/<policy-name>/oauth2/v2.0/token
    Get User Info Endpoint: https://graph.microsoft.com/v1.0/me
    Custom redirect URL after logout: [optional] https://<domain-name>.b2clogin.com/<domain-name>.onmicrosoft.com/<policy-name>/oauth2/v2.0/logout?post_logout_redirect_uri=<your url>
    Azure B2C Single Sign-On (SSO) OAuth - Finish configuration
  • Click on Next.
  • After verifying all the details on the summary page, click on Finish to save the configuration as well as test the SSO connection.
  • Azure B2C Single Sign-On (SSO) OAuth - Finish configuration

You have successfully configured WordPress as OAuth Client for achieving Azure B2C SSO (Single Sign-On) with WordPress for user authentication.


3. User Attribute Mapping

  • User Attribute Mapping is mandatory for enabling users to successfully login into WordPress. We will be setting up user profile attributes for WordPress using below settings.
  • Finding user attributes

    • Go to Configure OAuth tab. Scroll down and click on Test Configuration.
    • Azure B2C B2C Single Sign-on (SSO) - OAuth Test Configuration
    • You will see all the values returned by your OAuth Provider to WordPress in a table. If you don't see value for First Name, Last Name, Email or Username, make the required settings in your OAuth Provider to return this information.
    • Once you see all the values in Test Configuration, go to Attribute / Role Mapping tab, you will get the list of attributes in a Username dropdown.
    • Azure B2C B2C Single Sign-on (SSO) - WordPress Attribute Mapping

4. Steps to fetch Azure B2C Groups

  • Activate the Azure B2C Role Mapping Addon along with the paid version of the WordPress OAuth Client Single Sign-On (SSO) plugin.
  • Azure B2C B2C Single Sign-on (SSO) - azure addon
  • Go to your Azure B2C Portal and click on the Roles and administrators option.
  • Azure B2C B2C Single Sign-on (SSO) -role and administrator
  • Search for User administrator from the list and click on it.
  • Azure B2C B2C Single Sign-on (SSO) - user-admini
  • Click on Add assignments. Search and select your Azure B2C SSO application and click on Add button.
  • Azure B2C B2C Single Sign-on (SSO) - add assignments
  • Now click on Your Azure Application. Search and click on Assign user and groups.
  • Azure B2C B2C Single Sign-on (SSO) - assign user and groups
  • Click on Add user/group. You can select the users need to be added to a specific group.
  • Azure B2C B2C Single Sign-on (SSO) - add user/group
  • Click on Groups, then click on Add membership it will open Select group modal, So select the groups you want to fetch in your WordPress website.
  • Azure B2C B2C Single Sign-on (SSO) - add user/group
  • Select the added Group, and click on Members.
  • Azure B2C B2C Single Sign-on (SSO) - add user/group
  • Click on Add members, and add users to the selected group.
  • Azure B2C B2C Single Sign-on (SSO) - add user/group
  • You can now test the configuration of the Azure B2C application by clicking on the Test Configuration button in the Configure OAuth tab of the OAuth Client Single Sign-On (SSO) plugin. Here, you will be able to see the assigned B2C Group IDs of the users in the attribute name b2cGroups.
  • Azure B2C B2C Single Sign-on (SSO) - OAuth Test Configuration
  • Scroll down and go to the Role Mapping section, you need to map Group Attribute Name. Select the attribute name from the list of attributes that return the groups from the test configuration table of Azure B2C.
  • Azure B2C B2C Single Sign-on (SSO) - add user/group
  • Assign the WordPress role to the Provider Groups: Based on the Azure B2C application, you can allocate the WordPress role to Azure B2C Groups. Add the Azure B2C group's value under Group Attribute Value and assign the required WordPress role in front of it under WordPress Role.
  • Azure B2C B2C Single Sign-on (SSO) - add user/group

5. Steps to configure Azure B2C Groups in plugin [Premium]

  • Go to the Attribute Mapping section in the plugin and map the Attribute Names from the Test Configuration table. Make sure Enable Role Mapping option is enabled and click on the Save Settings button. (Refer to the screenshot)
  • Azure B2C B2C Single Sign-on (SSO) - azure addon
  • Scroll down and go to the Role Mapping section, you need to map Group Attribute Name. Select the attribute name from the list of attributes that return the groups from the test configuration table of Azure B2C.
    Eg: b2cGroups
  • Azure B2C B2C Single Sign-on (SSO) -role and administrator
  • Assign the WordPress role to the Provider Groups: Based on the Azure B2C application, you can allocate the WordPress role to Azure B2C Groups. Add the Azure B2C group's value under Group Attribute Value and assign the required WordPress role in front of it under WordPress Role.
    For example, in the below image. Group value has been assigned the role of Subscriber.
  • Azure B2C B2C Single Sign-on (SSO) - user-admini
  • Once you save the mapping, the Azure B2C group will be assigned the WordPress Subscriber role after SSO.
    Example: As per the given example, a User with group value will be added as a Subscriber.

6. Sign In Settings

  • The settings in Single Sign-On (SSO) Settings tab define the user experience for Single Sign-On (SSO). To add a Azure B2C login widget on your WordPress page, you need to follow the below steps.
    • Go to WordPress Left Panel > Appearances > Widgets.
    • Select miniOrange OAuth. Drag and drop to your favourite location and save.
    • Configure Azure B2C SSO (Single Sign-On) - WordPress create-newclient login button setting
    • Go to WordPress Left Panel > Appearances > Widgets.
    • Select miniOrange OAuth. Drag and drop to your favourite location and save.
    • Configure Azure B2C SSO (Single Sign-On) - WordPress create-newclient login button setting
    • Open your WordPress page and you can see the Azure B2C SSO login button there. You can test the Azure B2C Single Sign-On (SSO) now.
    • Make sure the "Show on login page" option is enabled for your application. (Refer to the below image)
    • Configure Azure B2C SSO (Single Sign-On) - WordPress create-newclient login button setting
    • Now, go to your WordPress Login page. (Eg. https://< your-wordpress-domain >/wp-login.php)
    • You will see an Azure B2C SSO login button there. Once you click the login button, you will be able to test the Azure B2C Single Sign-On (SSO).
    • Configure Azure B2C SSO (Single Sign-On) - WordPress create-newclient login button setting

In conclusion, after successfully configuring Azure B2C as an OAuth Provider and WordPress as an OAuth Client, you've achieved a smooth and secure authentication process for your users. Through Azure B2C SSO (Single Sign-On), you can ensure a robust user experience within the WordPress environment. This allows users the ease of accessing multiple applications with a single set of login credentials. Through the integration of Azure B2C with WordPress, users can securely log into their WordPress accounts with their existing Azure B2C credentials.


Additional Resources


Mail us on oauthsupport@xecurify.com for quick guidance(via email/meeting) on your requirement and our team will help you to select the best suitable solution/plan as per your requirement.

Hello there!

Need Help? We are right here!

support
Contact miniOrange Support
success

Thanks for your inquiry.

If you dont hear from us within 24 hours, please feel free to send a follow up email to info@xecurify.com