Extension + PingFederate Integration Guide
System Requirements
For Twosense to work properly, service providers must be configured to receive SAML responses as POST, not GET.
Introduction
Use this guide to add Twosense MFA to your PingFederate SSO authentication flow. The following configuration steps are required:
Create RADIUS Password Credential Validator
Navigate to SYSTEM and select Password Credential Validators.
Click Create New Instance.
In the Type tab, set the following:
Instance Name: Twosense MFA RADIUS PCV
Instance ID: TwosenseMfaRadiusPcv
Type: RADIUS Username Password Credential Validator
Click Next.
In the Instance Configuration tab, click Add a new row to 'RADIUS Servers', and set the following:
Hostname: radius.twosense.ai
Authentication Port: {Provided by Twosense}
Authentication Protocol: PAP
Shared Secret: {Provided by Twosense}
Click Update.
Click Next.
In the Extended Contract tab, click Next.
Review the Summary tab, and click Save.
Create Twosense MFA IdP Adapter
This adapter will be used by the Twosense browser extension to automate MFA requests.
Copy the
html.form.twosense.mfa.html
andhtml.form.twosense.challenge.html
files from the setup package to your PingFederate instance underpingfederate/server/default/conf/template/
.Navigate to AUTHENTICATION and select IdP Adapters.
Click Create New Instance.
In the Type tab, set the following:
Instance Name: Twosense MFA Form
Instance ID: TwosenseMfaForm
Type: HTML Form IdP Adapter
Click Next.
In the IdP Adapter tab, under Password Credential Validator Instance, click Add a new row to 'Credential Validators':
Select Twosense MFA RADIUS PCV
Click Update.
Set the following fields:
Challenge Retries: 1
Click Show Advanced Fields.
Login Template: html.form.twosense.mfa.html
Login Challenge Template: html.form.twosense.challenge.html
Allow Username Edits During Chaining: true
Fail Authentication on Account Lockout: true
Click Next.
In the Extended Contract tab, click Next.
In the Adapter Attributes tab, check the Pseudonym checkbox for the username attribute, and click Next.
In the Adapter Contract Mapping tab, click Configure Adapter Contract.
In the Attribute Sources & User Lookup tab, click Next.
In the Adapter Contract Fulfillment tab, click Next.
In the Issuance Criteria tab, click Next.
In the Summary tab, click Done.
Click Next.
Review the Summary tab, and click Save.
Modify the primary authentication adapter to return the userSid
The Twosense MFA adapter requires the user's objectSid
attribute. In order to do this, we need to extend the contract of the primary login form IdP adapter.
Navigate to AUTHENTICATION and select IdP Adapters.
Click on the IdP adapter of your primary login HTML form.
In the Summary tab, click Extend Contract.
Under Extend the Contract, add the objectSid attribute.
Navigate back to the Summary tab.
In the Summary tab, click Attribute Sources & User Lookup.
In the Attribute Source & User Lookup tab, click Add Attribute Source.
In the Data Store tab, set the following:
ATTRIBUTE SOURCE ID: ActiveDirectory (or another descriptive name)
ATTRIBUTE SOURCE DESCRIPTION: Active Directory (or another descriptive name)
ACTIVE DATA STORE: {Your Active Directory Datastore}
Click Next.
In the LDAP Directory Search tab, set the following:
BASE DN: {Your Active Directory Search Base DN}
Attributes to return from search: objectSid
Click Next.
In the LDAP Binary Attribute Encoding Types tab, select SID as the Attribute Encoding Type for objectSID, and click Next.
In the LDAP Filter tab, set FILTER to sAMAccountName=${username}, click Next.
In the Summary tab, click Done.
In the Attribute Source & User Lookup tab, click Next.
In the Adapter Contract Fulfillment tab, for objectSid:
Select LDAP (Active Directory) as the Source.
Select objectSid as the Value.
Click Next.
In the Issuance Criteria tab, click Next.
In the Summary tab, click Done.
In the Adapter Contract Mapping tab, click Save.
Modify the primary authentication HTML form
The Twosense browser extension detects the presence of the primary login form by looking for a specific attribute in the HTML form. In order to do this, we need to modify the primary login form.
Navigate to AUTHENTICATION and select IdP Adapters.
Click on the IdP adapter of your primary login HTML form.
Find the name of the HTML form file by looking for the Login Template field in the Summary tab. The default value is
html.form.login.template.html
.Find the file on your PingFederate instance under
pingfederate/server/default/conf/template/
.Modify the HTML form to include the following attribute in the
<form>
tagdata-twosense-id="primary-login-form"
. The following is an example of a modified HTML form:
Create HTTP Header Authentication Selector
This selector will be used in the authentication policy to determine if the Twosense browser extension is active during the authentication flow.
Navigate to AUTHENTICATION and select Selectors.
Click Create New Instance.
In the Type tab, set the following:
Instance Name: Twosense HTTP Header Selector
Instance ID: TwosenseHttpHeaderSelector
Type: HTTP Header Authentication Selector
Click Next.
In the Authentication Selector tab, click Add a new row to 'Results'.
Set Match Expression to
*
, click Update.Set Header Name to X-Twosense-Extension.
Uncheck Case-Sensitive Matching.
Click Next.
In the Summary tab, click Save.
Create Authentication Policy
You can create a new authentication policy, or modify an existing one. These instructions will assume you are creating a new policy.
Navigate to AUTHENTICATION and select Policies.
Click Add Policy.
Set Name to Twosense MFA Policy or another descriptive name.
Under Policy, select any SP connection Selector you wish to use.
Under NO, click Continue.
Under YES, select your primary login HTML form IdP adapter.
Under FAIL, select DONE.
Under SUCCESS, select Twosense HTTP Header Selector.
Under NO, select your manual MFA IdP adapter (e.g., Duo).
Under YES, select your Twosense MFA Form.
Click Options, and in the Incoming User ID form:
Set Attribute to objectSid.
Check User ID Authenticated.
Click Done.
Under SUCCESS for the Twosense and manual MFA IdP adapters, select the appropriate policy contract.
Under FAIL, select the action you wish to occur when communication between PingFederate and Twosense fails.
Configure the Rules for the Twosense MFA Form adapter according to the table in the section below.
Click Done.
In the Policies tab, click Save.
Twosense MFA Form Adapter Rules
The Twosense adapter will set the policy.action
attribute to different values for different outcomes. The following table lists the possible values and their meaning. Use these values to create rules to fit your organization's needs.
| Outcome |
| The Twosense agent was not detected on the client machine. |
| An internal error occurred in the Twosense browser extension. |
| The user was not authenticated (i.e., due to a low trust score) and should be presented an additional MFA challenge. |
For example, here's how you can customize your policy with rules based on the outcome:
Then you can use these results to determine the next steps in your policy:
Last updated