WordPress Integration with AuthPoint

Deployment Overview

This document describes how to set up multi-factor authentication (MFA) for WordPress with AuthPoint as an identity provider. WordPress must already be configured and deployed before you set up MFA with AuthPoint.

To use SAML authentication to log in to WordPress, you must install a plugin. For our integration, we use the miniOrange SAML SP (service provider) Single Sign On plugin.

This integration was tested with version 5.4.1 of WordPress.

WordPress Authentication Data Flow with AuthPoint

AuthPoint communicates with various cloud-based services and service providers with the SAML protocol. This diagram shows the data flow of a SAML MFA transaction.

Diagram that shows the data flow of an MFA transaction for a SAML resource with the push authentication method.

Before You Begin

Before you begin these procedures, make sure that:

Configure WordPress

To start, you must download the metadata file and certificate file from the Certificate Management page in the AuthPoint management UI. After you have that, you can configure WordPress.

  1. Log in to WatchGuard Cloud.
  2. From the navigation menu, select Configure > AuthPoint. If you have a Service Provider account, you must select an account from Account Manager.
  3. Select Resources.
  4. Click Certificate.

Screen shot of the Download Certificate

  1. Next to AuthPoint certificate you will associate with your resource, click and select Download Metadata and Download Certificate . We recommend that you choose the certificate with the latest expiration date. If you do not have a certificate, or if all of your certificates have expired, click Add Certificate and use the newly created certificate.

    The AuthPoint metadata and certificate provides your resource, in this case WordPress, with information necessary to identify AuthPoint as a trusted identity provider.

Screen shot of the Download Certificate

  1. Log in to your WordPress site.

Screen shot of the wordpress config

  1. Select miniOrange SSO using SAML 2.0 > Plugin Configuration > Service Provider Setup.
  2. From the Select configuration guide for your Identity Provider drop-down list, select Other.
  3. In the Identity Provider Name text box, type AuthPoint.
  4. Open the AuthPoint metadata file you downloaded and find these values:
    • entityID
    • SingleSignOnService Location
  5. In the IdP Entity ID or Issuer text box, type or paste the entityID value from the AuthPoint metadata file.
  6. In the SAML Login URL text box, type or paste the SingleSignOnService Location value from the AuthPoint metadata file.
  7. In the X.509 Certificate text box, paste the Certificate value from the AuthPoint certificate file that you downloaded.

Screen shot of the wordpress config

  1. Click Save.
  2. Select the Service Provider Metadata tab.

Screen shot of the wordpress config

  1. Copy the SP-EntityID / Issuer and ACS (AssertionConsumerService) URL values. You need these values to create a SAML resource in AuthPoint.
  2. Select Appearance > Widgets.

Screen shot of the wordpress config

  1. From the Login with AuthPoint drop-down list, select Footer #1.
  2. Click Add Widget.

Screen shot of the wordpress config

  1. In the Footer #1 section, expand Login with AuthPoint and type a title. In our example, we type SAML Login.

Screen shot of the wordpress config

  1. Click Save.
  2. Click Done.

Configure AuthPoint

Before AuthPoint can receive authentication requests from WordPress, you must add a SAML resource in AuthPoint. You must also create a Zero Trust authentication policy for the WordPress resource to determine which users can authenticate and log in to WordPress and which authentication methods they can use (Push, QR code, and OTP).

Add a SAML Resource in AuthPoint

From the AuthPoint management UI:

  1. From the navigation menu, select Resources. Click Add Resource.
    The Add Resource page opens.

  1. From the Type drop-down list, select SAML.
    Additional fields appear.

  1. Type a name for this resource.
  2. From the Application Type drop-down list, select WordPress.
  3. In the Service Provider Entity ID text box, type or paste the SP-EntityID / Issuer value that you copied from WordPress.
  4. In the Assertion Consumer Service text box, type or paste the ACS (AssertionConsumerService) URL value that you copied from WordPress.
  5. From the User ID sent on redirection to service provider drop-down list, select Email.
  6. From the Signature Method drop-down list, select SHA-256.
  7. From the AuthPoint Certificate drop-down list, select the certificate to associate with your resource. This must be the same certificate that you downloaded the metadata for in the previous section.
  8. Click Save.

Add a Group in AuthPoint

You must have at least one user group in AuthPoint to configure MFA. If you already have a group, you do not have to add another group.

To add a WatchGuard Cloud-hosted group to the WatchGuard Cloud Directory:

  1. Go to Configure > Directories and Domain Services.
  2. Click the WatchGuard Cloud Directory domain name. If you have not yet added the WatchGuard Cloud Directory, click Add Authentication Domain and select the WatchGuard Cloud Directory.
    The New Group page appears.

Screenshot that shows the Directories and Domain Services page.

  1. In the Groups tab, click Add Group.
  2. In the Group Name text box, type a descriptive name for the group.
  3. (Optional) In the Description text box, type a description of the group.

Screen shot of the Add Group page.

  1. Click Save.
    Your group is added to the WatchGuard Cloud Directory and to AuthPoint.

Add a Zero Trust Authentication Policy

Zero Trust policies specify which resources users can authenticate to and which authentication methods they can use (Push, QR code, and OTP).

You must have at least one Zero Trust authentication policy that includes the WordPress resource. If you already have Zero Trust authentication policies, you do not have to create a new authentication policy. You can add this resource to your existing authentication policies.

Users that do not have an authentication policy for a specific resource cannot authenticate to log in to that resource.

To configure a Zero Trust authentication policy:

  1. Go to Configure > Zero Trust. If you have a Service Provider account, you must select an account from Account Manager.
  2. Click Add Policy.
  3. Type a name for this policy.
  4. In the Target section, from the Content drop-down list, select which groups this policy applies to. You can make multiple selections to add multiple groups.
  5. In the Resources section, select the AuthPoint resources this policy applies to.
  6. In the Conditions section, select the conditions that apply to this policy. When you add a condition to an authentication policy, the policy applies only to user authentications that match the policy and the policy conditions. For example, if you add a Network Location to a policy, the policy only applies to user authentications that come from that Network Location. Users who only have a policy that includes a Network Location do not get access to the resource when they authenticate outside of that Network Location (because they do not have a policy that applies, not because authentication is denied). For more information, go to About Zero Trust Conditions.
    1. (Optional) To create a new condition, click Add New Condition. After you create a new condition, you must still add the condition to the policy.
    2. From the Type drop-down list, select the type of condition to add to the policy.
    3. From the Name drop-down list, select which condition of the chosen type to add to the policy.
    4. To add more conditions, repeat Step 6.

      If you add conditions to a policy, we recommend that you create a second policy for the same groups and resources without the conditions. Assign a higher priority to the policy with the policy objects. For more information about priority, go to About Zero Trust Policy Precedence.

  7. In the Action section, select an option to specify whether to allow or deny authentications for the resources in this policy. In our example, we want to allow authentications.
    • Allow — Allow user groups in this policy access to the resources associated with this policy.
    • Deny — Deny authentications when users in the groups associated with this policy try to authenticate to the resources associated with this policy.
  8. If you allow access with this policy, select the check box for each authentication option users can select when they authenticate to resources in this policy with MFA.

    For SAML resources, if you select more than one authentication option, users must select one of the available options when they authenticate. For example, if you select OTP and Push, users can choose to type their OTP or approve a push to authenticate. You cannot require that they do both.

  9. Click Save.
    Your policy is created and added to the end of the policy list.
  10. Review the order of your policies and adjust as necessary. For more information about priority, go to About Zero Trust Policy Precedence.

Add Users to AuthPoint

Before you assign users to a group, you must add the users to AuthPoint. There are two ways to add AuthPoint user accounts:

  • Sync users from an external user database
  • Add WatchGuard Cloud-hosted AuthPoint users

Each user must be a member of a group. You must add at least one group before you can add users to AuthPoint.

Test the Integration

To test AuthPoint MFA with WordPress, you can authenticate with a mobile token on your mobile device. For SAML resources, you can choose any method (push, QR code, or one-time password).

In this example, we show the push authentication method (users receive a push notification in the mobile app that they must approve to authenticate).

  1. In a web browser, navigate to your WordPress site (http://localhost/<your site>/)

Screen shot of the login

  1. Below SAML Login, click Login with AuthPoint. If you specified a different Identity Provider name in WordPress, the link instead says Login with <IDP name>.
    The AuthPoint single sign-on page appears.
  2. Type your email address or AuthPoint user name. Click Next.
  3. If required, in the Password text box, type your password.
  4. For the authentication method, select Send Push.
  5. Approve the authentication request that is sent to your mobile device.
    You are logged in to WordPress.