Generic SAML 2.0 works with any SAML-compliant Identity Provider — Okta, Microsoft Entra ID, ADFS, OneLogin, JumpCloud, PingIdentity, Shibboleth, and others. This guide covers what you fill in on the firmly Connect side. For provider-specific application setup steps (creating the SAML application, configuring assertions, mapping attributes), refer to your IdP’s own integration documentation.
Prerequisites
Before you start, make sure you have:- At least one verified domain in firmly Connect — see Verify a Domain.
- A SAML 2.0 application registered in your IdP that signs assertions and accepts the SP’s Audience / Entity ID and Assertion Consumer Service URL.
- From your IdP, either:
- A metadata XML file describing the IdP, or
- The three values manually: Entity ID / Issuer, SSO URL, and the X.509 signing certificate in PEM format.
firmly’s Service Provider details
The IdP configuration form displays three Service Provider (SP) values that you provide to your IdP. Copy them from the firmly Connect Dashboard rather than guessing — they are deployment-specific.| firmly field | Where to use it in your IdP |
|---|---|
| SP Entity ID | Enter as the Audience / Entity ID / SP Identifier in your IdP application. Read-only on the firmly form, with a copy button. |
| ACS URL | Enter as the Assertion Consumer Service (ACS) URL / Reply URL / Single Sign-On URL in your IdP application. |
| SP Metadata XML | Click Download SP Metadata to download an XML file. If your IdP supports importing SP metadata, upload this file instead of copying the SP Entity ID and ACS URL fields manually. |

Add a SAML Identity Provider
Open Settings → Single Sign-On
Navigate to the Single Sign-On page in your firmly Connect Dashboard settings.
Provide IdP configuration
Either upload your IdP’s metadata XML for one-click setup, or fill in the three required fields manually. See Field reference below.

Fast path: upload IdP metadata XML
- With metadata XML (recommended)
- Without metadata XML
Most modern IdPs offer a downloadable metadata XML file describing the SAML endpoints and signing certificate.
- Download the metadata XML from your IdP.
- On the firmly SAML form, click the IdP Metadata XML (optional) upload control and select the file.
- firmly parses the file in your browser and auto-fills IdP Entity ID, SSO URL, and X.509 Certificate.
- Review the auto-filled values, edit anything if needed, and click Save.
Field reference
| Field | Required | What to enter |
|---|---|---|
| IdP Metadata XML | No | Optional metadata XML file from your IdP. Auto-fills the three fields below. UI-only — the file itself is not stored. |
| IdP Entity ID | Yes | The unique identifier of your IdP, sometimes called Issuer. Example: http://www.okta.com/exk1234567890. |
| SSO URL | Yes | Your IdP’s Single Sign-On endpoint — the URL firmly redirects users to in order to authenticate. Must use https://. |
| X.509 Certificate | Yes | Your IdP’s public signing certificate in PEM format, including the -----BEGIN CERTIFICATE----- and -----END CERTIFICATE----- lines. firmly validates the PEM wrapper and base64 body, and uses this certificate to verify the signatures on SAML responses. |
| Email Attribute | No | The SAML attribute Name containing the user’s email address. Leave empty to try common defaults automatically. Set this if your IdP emits the email under a non-standard attribute (for example, the long urn:oid:0.9.2342.19200300.100.1.3 URN used by some directories). |

NameID and user matching
firmly Connect uses the email returned by your IdP to look up the user. Configure your IdP to:- Send a
NameIDthat is either the user’s email address (with a NameID format such asurn:oasis:names:tc:SAML:1.1:nameid-format:emailAddress) or any stable user identifier — firmly does not parse NameID for matching. - Include an email attribute in the SAML assertion. By default firmly looks at common email attribute names; if your IdP uses a non-standard name, set the Email Attribute field to that exact name.
Bind the IdP to verified domains
The IdP configuration form includes an Authorized Domains section listing every domain you have verified. Each verified domain appears as a toggle.- Turn on the toggle for each domain you want this IdP to handle.
- A single IdP can be bound to multiple domains.
- A single domain can be bound to multiple IdPs (users will be presented with a choice at sign-in).
- At least one domain must be bound before the IdP can be enabled.
Enable the IdP
The Enabled toggle at the top of the form becomes available once:- All required fields are filled and pass validation (including a well-formed PEM certificate), and
- At least one verified domain is bound under Authorized Domains.
Test the connection
The Test Connection button appears on the IdP form in edit mode (after the initial save), provided there are no unsaved changes and all required fields are filled. Clicking Test Connection performs a real SAML round trip against your IdP:- firmly redirects you to your IdP’s SSO URL with a SAML AuthnRequest.
- You authenticate with a real account at your IdP.
- Your IdP posts a signed SAML response back to firmly’s ACS URL.
- firmly verifies the response signature against the configured X.509 certificate, validates the audience matches the configured SP Entity ID, and extracts the email attribute.

Update the certificate
When your IdP rotates the SAML signing certificate (typically annually):- Obtain the new certificate from your IdP — either as a fresh metadata XML, or as a PEM-formatted certificate.
- Open the IdP configuration in firmly Connect.
- Either re-upload the new metadata XML (which refreshes all three fields), or paste the new PEM into X.509 Certificate directly.
- Click Save, then run Test Connection to confirm the new certificate works.
Disable or delete the IdP
- Disable — turn the Enabled toggle off on the form. The configuration is preserved, the IdP is removed from sign-in, and any domain enforcement that depended solely on this IdP becomes unavailable.
- Delete — from the IdP row’s actions menu on the SSO page, choose Delete. This is a hard delete, recorded in the audit log, and will unbind the IdP from any domains that referenced it.
Troubleshooting
- Signature validation failed
- No email returned
- Audience / Entity ID mismatch
- ACS URL not accepted
The X.509 certificate stored in firmly does not match the certificate your IdP signed the response with. Re-download the current certificate (or metadata XML) from your IdP and update the X.509 Certificate field. Make sure the PEM is pasted with the
-----BEGIN CERTIFICATE----- and -----END CERTIFICATE----- lines intact and no extra whitespace.Next steps
Verify a Domain
Add and verify the domains you want this IdP to handle, and enable enforcement when you’re ready.
SSO Overview
Recap the full setup flow and per-domain enforcement model.