Okta WordPress Login with WordPress OAuth

Okta WordPress Login with WordPress OAuth


Get Free Trial

Integrate WordPress Okta login using Okta as an OAuth and OpenID Connect provider, the WordPress OAuth plugin offers safe login into WordPress. Additionally, you can set up plugins with various IDPs and custom providers. Advanced Single Sign-On (SSO) capabilities including role mapping and attribute mapping for user profiles are supported. Here, we'll walk you through setting up Single Sign-On (SSO) for WordPress and Okta. Users should be able to access WordPress using Okta by the end of this guide. You can click here to learn more about the additional functionality offered by the WP OAuth Single Sign-On (OAuth & OpenID Connect Client) plugin.

Pre-requisites : 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 Okta WordPress Login with WordPress OAuth

1. Setup Okta as OAuth Provider

  • First of all, go to https://www.okta.com/login and log into your Okta account.
  • Go to the Okta Admin panel. Go to Applications -> Applications.
  • okta Single Sign-On (SSO) OAuth/OpenID-addapp-shortcut
  • You will get the following screen. Click on Create App Integration button.
  • okta Single Sign-On (SSO) OAuth/OpenID-addapplication
  • Select sign in method as the OIDC - OpenID Connect option and select Application type as web application, click on Next button.
  • okta Single Sign-On (SSO) OAuth/OpenID-select-webplatform
  • You will be redirected to the app details page. Enter App integration name and Sign-in redirect URIs. you will get that from miniOrange OAuth/OpenID connect Client Plugin's 'Configure OAuth' tab under the Redirect/Callback URL field.
  • okta Single Sign-On (SSO) OAuth/OpenID-callbackURL
  • Scroll down and you will see the Assignments section. Choose a controlled access option and uncheck the Enable immediate access with Federation Broker Mode option. Click on Save button.
  • okta Single Sign-On (SSO) OAuth/OpenID-clientcredentials
  • Now you will get the Client credentials and okta domain. Copy these credentials in Miniorange OAuth client single sign-on (SSO) Plugin configuration on corresponding fields.
  • Note: Enter https:// in the Okta domain field in the WordPress OAuth Single Sign-On (SSO) plugin which you will get from General Settings. eg.( https://dev-32414285.okta.com ).


    okta Single Sign-On (SSO) OAuth/OpenID-clientcredentials

    1.1 Assign an app integration to a user

    • Go to Applications tab and Click on your application.
    • okta Single Sign-On (SSO) OAuth/OpenID WordPress application tab
    • Select the Assignments tab.
    • okta Single Sign-On (SSO) OAuth/OpenID WordPress assignment
    • Click Assign and select Assign to People.
    • If you want to assign the application to multiple users at the same time then select Assign to Groups [If an app is assigned to a group then, the app will be assigned to all the people in that group]
    • okta Single Sign-On (SSO) OAuth/OpenID WordPress select assign people
    • Click Assign next to a user name.
    • okta Single Sign-On (SSO) OAuth/OpenID WordPress click on assign
    • Click Save and Go Back.
    • okta Single Sign-On (SSO) OAuth/OpenID WordPress go back
    • Click Done.
    • okta Single Sign-On (SSO) OAuth/OpenID WordPress done

    1.2 Profile Attributes for the id Token

    • In your Okta admin dashboard, navigate to Security -> API.
    • okta Single Sign-On (SSO) OAuth/OpenID WordPress create-newclient login button setting
    • Select your SSO application and click on the edit icon.
    • okta Single Sign-On (SSO) OAuth/OpenID WordPress create-newclient login button setting
    • Go to claims tab and select the ID token option.
    • okta Single Sign-On (SSO) OAuth/OpenID WordPress create-newclient login button setting
    • click on Add claim button.
    • okta Single Sign-On (SSO) OAuth/OpenID WordPress create-newclient login button setting
    • Give a Name to your claim/attribute and Select ID Token from the token type dropdown. Now, enter the value user.$attribute in the Value field based on the attribute you want to receive. Keep other settings as default and click on Create button.
    • okta Single Sign-On (SSO) OAuth/OpenID WordPress create-newclient login button setting
    • Follow the similar steps for all the attributes you want to see. You will have a list similar to the below one.
    • okta Single Sign-On (SSO) OAuth/OpenID WordPress create-newclient login button setting
    • You will be able to see the attributes in the Test Configuration output as follows.
    • okta Single Sign-On (SSO) OAuth/OpenID WordPress create-newclient login button setting

You have successfully configured Okta as OAuth Provider for achieving Okta WordPress Configuration.


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.
  • Okta  Single Sign-On (SSO) OAuth - Add new application
  • Choose your Application from the list of OAuth / OpenID Connect Providers, Here Okta.
  • Okta Single Sign-On (SSO) OAuth - Select Application
  • Copy the Callback URL to be used in OAuth Provider Configuration and click Next.
  • Okta Single Sign-On (SSO) OAuth - Callback URL
  • Configure App name & Endpoints found from the Okta SSO application. Click Next.
  • Okta AD Single Sign-On (SSO) OAuth - Add App name, TenantID
  • Enter the Client Credentials like Client ID & Client Secret as shown in the setup dialogue box, openid email profile is already filled. Click Next.
  • Okta  Single Sign-On (SSO) OAuth - Client ID & Client Secret
  • Verify the configuration details and click on Finish to save the configuration.
  • Okta Single Sign-On (SSO) OAuth - Finish configuration

ou have successfully configured WordPress as Miniorange OAuth Client for achieving user authentication with Okta WordPress Login.


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.

  • After clicking on Finish button, You will see different user attributes returned by your OAuth Provider in a test configuration table. If you don't see any user attributes, make the required settings in your OAuth Provider to return this information.
  • Okta Single Sign-On (SSO) OAuth - Add Grant Type
  • Once you see all the values in the Test Configuration table, click on Finish button and go to Attribute / Role Mapping tab,you will get the list of attributes in a Username dropdown.
  • Okta Single Sign-On (SSO) OAuth - Add Grant Type

You have successfully configured WordPress as OAuth Client for achieving user authentication with Okta Single Sign-On (SSO) login into your WordPress Site.

4: Steps to fetch Okta Groups

  • Click on the Sign On tab in your Okta application.
  • Okta Single Sign-On (SSO) - test configuration - role mapping
  • Go to the OpenID Connect ID Token section by scrolling down.
  • Under 'Group claims filter' section, enter groups as the default name, and then select 'Matches regex' from the drop down list and enter .* (without spaces) to return all the user's Groups. Click on Save button.
  • Okta Single Sign-On (SSO) - test configuration - role mapping

5: Steps to configure Okta Groups in plugin [Premium]

  • Go the OAuth Client Single Sign-On (SSO) plugin and enter the scope values as groups in addition to the scopes (refer to the image below). Click on Save and then “Test Configuration” button.
  • Okta Single Sign-On (SSO) - attribute mapping
  • Now you will get the list of Attribute Names, Attribute Values and Groups that are sent by Okta.
  • Okta Single Sign-On (SSO) - attribute mapping
  • From the Test Configuration window, map the Attribute Names in the Attribute Mapping section of the plugin. Refer to the screenshot for more details.
  • Okta Single Sign-On (SSO) - attribute mapping
  • Enable Role Mapping: To enable Role Mapping, you need to map Group Name Attribute. Select the attribute name from the list of attributes which returns the roles from your provider application.
    Eg: groups

  • Okta Single Sign-On (SSO) - test configuration - role mapping
  • Assign WordPress role to the Provider role: Based on your provider application, you can allocate the WordPress role to your provider roles. It can be a Administrator, Contributor,Subscriber or any other depending on your application. Add the provider roles under Group Attribute Value and assign the required WordPress role in front of it under WordPress Role.
    For example, in the below image. Football has been assigned the role of Contributor & Everyone is assigned the role of Subscriber.
  • Okta Single Sign-On (SSO) - test configuration - role mapping
  • Once you save the mapping, the provider role will be assigned the WordPress administrator role after SSO.
    Example: As per the given example, Users with role ‘Football’ will be added as Contributor in WordPress and ‘Everyone’ will be added as 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 Okta 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.
    •  Okta  Single Sign-on (SSO) - 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.
    • Okta Single Sign-on (SSO) - WordPress create-newclient login button setting
    • Open your WordPress page and you can see the Okta SSO login button there. You can test the Okta Single Sign-On (SSO) now.
    • Make sure the "Show on login page" option is enabled for your application. (Refer to the below image)
    • Okta Single Sign-on (SSO) - 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 Okta SSO login button there. Once you click the login button, you will be able to test the Okta Single Sign-On (SSO).
    • Okta Single Sign-on (SSO) - WordPress create-newclient login button setting

7: Scope & Endpoints

Please refer the below table for configuring the scope & endpoints for Okta in the plugin.

Scope: openid email profile
Authorize Endpoint: https://{yourOktaDomain}.com/oauth2/default/v1/authorize
Access Token Endpoint: https://{yourOktaDomain}.com/oauth2/default/v1/token
Get User Info Endpoint: https://{yourOktaDomain}.com/oauth2/default/v1/userinfo
Custom redirect URL after logout:[optional] https://{yourdomain.okta}.com/login/signout?fromURI= <your url>

Note: Please try the following endpoints if you receive a 404 Server error from Okta at the time of SSO.

Authorize Endpoint: https://{yourOktaDomain}.com/oauth2/v1/authorize
Access Token Endpoint: https://{yourOktaDomain}.com/oauth2/v1/token
Get User Info Endpoint: https://{yourOktaDomain}.com/oauth2/v1/userinfo

In this Guide, you have successfully configured Okta SSO login by configuring Okta as OAuth Provider and WordPress as OAuth Client using our WordPress Okta SSO plugin. This solution ensures that you are ready to roll out secure access to your WordPress site using Okta login credentials within minutes.


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