Single Sign-on (SSO)
UpdatedOrganizations that need enhanced security requirements can configure their Customer.io account to use Single Sign-on (SSO).
To enable/disable SSO for your account, you must be an Account Admin.
How to set up SSO
The process for configuring SSO will depend on your specific identity provider (IdP). Customer.io has dedicated integrations with the following providers and protocols:
- SSO with Google
- SSO with Okta
- SSO with Microsoft Azure
- SSO with OpenID SSO - works with a variety of providers
- SSO with SAML 2.0 - works with Cloudflare, Jumpcloud, and more
Frequently Asked Questions
What is OpenID Connect and how does it differ from SAML?
OpenID Connect is a security standard for logging into applications, built on the OAuth 2.0 protocol. It uses an additional JSON Web Token (JWT), called an ID token, to standardize areas that OAuth 2.0 leaves up to choice, such as scopes and endpoint discovery. It is specifically focused on user authentication and is widely used to enable user logins on consumer websites and mobile apps. Learn more about OpenID Connect.
Security Assertion Markup Language - SAML - is also a widely used authentication protocol for logging into apps but built on the SAML 2.0 specification.
Unlike OpenID Connect, SAML allows you to include various attributes in the SAML statement sent to the SaaS application based on the mapping of attributes in your Identity Provider (IdP).
How do I require 2FA with SSO?
When you use SSO with Customer.io, you must enable 2FA within your identity provider. (Before you can enable SSO in Customer.io, you must disable Customer.io’s 2FA feature.)
I’m able to log in with Google. Is that the same as Google SSO?
No, it is not. “Log in with Google” is an option on the Customer.io sign-in page to quickly and securely log in, but team members can still use their email and password during sign-in. To block team members from signing in with an email/password, you must enable Google SSO on the Account Security page.
Manage team members
How do I add a new team member to my account after enabling SSO?
When a new team member is added through Customer.io to an SSO-enabled account, the new team member will receive an email prompting them to log in. On invite, they should not need to set or reset a password, but instead can directly enter their email into the Customer.io login page.
You’ll need to add team members to your Identity Provider (IdP) and Customer.io using a matching email address.
Is there any sync between my Identity Provider (IdP) and the team member list in Customer.io?
No, there is no profile or team list sync between the two. You can only update a team member’s name or role in Customer.io. Manage team members
Can I manage team member roles through my Identify Provider (IdP)?
It’s not possible to define a user’s permissions via your IdP. You can only manage a user’s permissions in Customer.io. Manage team permissions
Reach out to support at win@customer.io if you’re still experiencing issues with enabling SSO.
I have two (or more) Customer.io accounts. Can I link both to my Identity Provider (IdP) account?
Yes, you can, by adding two Customer.io applications within your IdP account. Repeat the steps that apply to your provider for each Customer.io account. Make sure the usernames in each app in your IdP match the corresponding usernames in Customer.io: Account Settings > Team Members.
How do I force an account to log out?
To invalidate someone’s active sessions in your Customer.io account, delete the team member from Account settings > Team Members.
Do you support SLO?
We do not support Single Logout (SLO) - the ability for someone to log out of one application which triggers a log out from all applications using the same credentials. For instance, your team member can’t log out of Customer.io and then trigger a log out of Salesforce.
SSO with Google
If you are using G Suite to manage your company email, then you can enable Google SSO in your Customer.io account. You must:
- Have a G Suite account (public @gmail.com email accounts cannot set up SSO),
- Have an Account Admin role in Customer.io, and
- Disable “Require 2FA” for your Customer.io account.
After setup is complete, members of your account will immediately be logged out and will need to log in again using their Google-managed email address.
To enable SSO with Google:
- Log in to your Customer.io account and navigate to Account Settings → Security.
- On the Security page, select Configure SSO to get started.
- In Step 1, select Google SSO.
- In the next and final step, click Authenticate your account. This will open a Google authorization window asking you to choose the account you’d like to use with Customer.io. Make sure to choose the email account used by you and your team to log in — anyone with a different Google email domain will not be able to log in.
Check your team email addresses!
After Google SSO is enabled, only team members in your company G Suite account will be able to log in. Any team members with an external email address will not be able to log in until their emails are updated in Customer.io.
SSO with Okta
Requirements
To configure SSO with Okta, you must have:
- an existing Okta account,
- an Account Admin role in Customer.io, and
- Disable “Require 2FA” for your Customer.io account.
Supported Features
This implementation supports User Authentication. After a team member is added to your Customer.io account, they’ll be asked to authenticate with Okta in order to log in.
No other features (i.e. profile sync, provisioning, etc.) are supported at this time.
Okta SSO Configuration Steps
Setting up Okta SSO with Customer.io is a two-step process. You’ll first add the Customer.io Application to your Okta account. Then, you’ll configure your Customer.io security settings to connect to Okta.
After setup is complete, team members will be immediately required to re-login to Customer.io using their Okta credentials. Their current work may be interrupted.
Part 1: Add Customer.io Application to Okta
Add Customer.io to your Okta account by going to your Applications page, clicking Browse App Catalog and searching for Customer.io.
On the opened page, click Add to install the Customer.io integration.
You’ll be asked to provide an Application label (Customer.io) and configure whether the application should display to users or auto-submit with the browser plugin. Select your preference and click Next (these can be changed later).
Next, you’ll see Step 2: Sign-On Options. Select OpenID Connect and click Done.
After you click Done, the application will be added to your Okta org and is ready to be assigned to your team members. Click Assign to add the team members or groups who will be accessing Customer.io, including yourself!
Once you’ve added People, keep the Okta window open and move to Step 2 below.
Part 2: Configure Okta SSO in Customer.io
- Open a new window and get ready to set up SSO in your Customer.io account. Log in to Customer.io and navigate to the Security page of Account Settings.
- On the Security page, select Configure SSO.
- Select Okta SSO with OpenID Connect to show the configuration settings.
- In the Configuration form, enter the following information:
- Okta Organization URL: This can be found in your Okta dashboard header and typically follows the format of https://[companyname].okta.com. Learn more about Okta Org URLs.
- Okta Application Client ID and Client Secret: Go back to your Okta window and look for the Client ID and Client Secret on the Sign On tab of the Customer.io Application.
- Click Authenticate your Okta account to confirm the connection and enable SSO.
- Once the connection is authenticated, you’ve successfully enabled SSO for you and your team members.
SSO with Microsoft Azure
Requirements
To configure SSO with Azure, you must:
- Have an existing Azure account
- Have an Account Admin role in Customer.io, and
- Disable “Require 2FA” for your Customer.io account
Register a new app
You can find more info on setup in Microsoft Azure’s Quick Start Guide.
- Log into your Microsoft Azure account and go to Microsoft Entra ID.
- On the Overview page, click Add at the top and select App registration.
- Enter a display Name for your application. This helps you distinguish between your registered apps in Azure. This will not appear in Customer.io.
- Click Register to complete initial setup.
Configure your app
- To finish configuring your registered app, go to Authentication > Add a platform.
- Select Web.
- Add this redirect URI: https://fly.customer.io/oauth2/redirect.
- Select Configure.
Add credentials
Select Certificates & secrets > Client secrets > New client secret.
Enter a Description for your secret. Change the Expiration time period if you need.
Keep track of your expiration timeline
Customer.io doesn’t know when your client secret will expire. You’ll need to track your client secret’s expiration date outside Customer.io to maintain a smooth sign-in process
Select Add.
- Your client secret is under Value.
Keep your Microsoft Azure account open to finish integrating with Customer.io.
Finish setup in Customer.io
- Go to Account Settings > Security > Enable Single Sign-On (SSO).
- Select Azure SSO with OpenID Connect.
- Back in Microsoft Azure AD, select Overview from the left hand menu.
- Then click Endpoints from the top menu. Copy the OpenID Connect metadata document and paste into Azure Issuer URL in Customer.io. The URL should follow this pattern: https://login.microsoftonline.com/{tenant_id}/v2.0/well-known/openid-configuration.
- Copy the Application/Client ID and paste into Azure Application Client ID in Customer.io.
- In Microsoft Azure AD, select Certificates & Secrets.
- Copy the Value of your client secret and paste into Azure Application Client Secret in Customer.io. Your configuration will not authenticate if you use the Secret ID; make sure you use the Value.
- In Customer.io, select Authenticate your Microsoft Azure account. You will be prompted to sign in using Azure. You will see a success banner upon completion or information to help you remedy any issues in your configuration.
SSO with OpenID
You can enable SSO for providers beyond Google, Okta, and Azure using our generic OpenID SSO option in Account Settings. OpenID SSO works with any provider that is compliant with OpenID Connect, such as OneLogin and Auth0.
Requirements
Like with other IdPs, these are the general requirements to get started:
- Have an existing account with the provider
- Have an Account Admin role in Customer.io, and
- Disable “Require 2FA” for your Customer.io account
Set up OpenID SSO
- Configure your IdP:
- Register your app with your IdP.
- Configure the app.
- Create a client secret.
- Set up the login URL and redirect URI to send a user to the correct place after your identity provider verifies your users’ identities. The image below is an example from OneLogin.
- Login URL: https://fly.customer.io/login
- Redirect URI: https://fly.customer.io/oauth2/redirect
- Set up your Customer.io account:
- Go to Account Settings > Security > Enable Single Sign-On (SSO).
- Select OpenID SSO with OpenID Connect.
- Fill in the following using the equivalent fields in your IdP:
- OpenID Configuration Documentation URL
- Client ID
- Client Secret
- Select Authenticate. You’ll be prompted to sign in using your IdP. You will see a success banner upon completion or information to help you remedy any issues in your configuration.
SSO with SAML 2.0
You can enable SSO for some providers using our SAML option in Account Settings. We’ve tested our solution with a variety of providers. The table below shows the providers we’ve tested and whether or not they work with Customer.io.
Because our solution complies with the SAML 2.0 specification, it may work with other providers. Contact us if you need help with a specific provider.
Provider | Supported |
---|---|
Cloudflare | ✅ |
Jumpcloud | ✅ |
Okta | See Set up SAML for Okta |
❌ | |
Azure | ❌ |
Auth0 | Not Tested |
Requirements
To get started, you must
- Have an existing account with an identity provider
- Have an Account Admin role in Customer.io, and
- Disable “Require 2FA” for your Customer.io account
Set up SAML
If you use Okta, see Set up SAML for Okta below. Otherwise,
- Register your app with your IdP.
- Set SAML Subject NameID Format to email address, just like the NameID.
- Set up your Customer.io account:
- Go to Account Settings > Security > Enable Single Sign-On (SSO).
- Select SAML 2.0.
- Paste in the Metadata URL from the equivalent field in your IdP.
- Select Generate your SAML SSO metadata.
- Finish configuring your IdP:
- Copy these fields from Customer.io and paste them into the corresponding fields in the SSO app you just made in your IdP:
- Service Provider (SP) Entity ID
- ACS URL
- Click Export SP Certificate in Customer.io then upload this to SP Certificate in your SSO app.
- Save your changes.
- Copy these fields from Customer.io and paste them into the corresponding fields in the SSO app you just made in your IdP:
After you’ve set up SAML SSO, you must add your colleagues to both your IdP and Customer.io for them to successfully log into Customer.io.
We do not support provisioning.
Set up SAML for Okta
To set up SAML for Okta, reach out to our support team for assistance.
Disable SSO
Disabling SSO will affect all of your team members
After you disable SSO, we log your team members out which may interrupt their work and cause them to lose unsaved changes.
- Go to Account Settings > Security > Enable Single Sign-On (SSO).
- Click Disable and confirm the action.
- All team members will need to use Customer.io credentials to sign in moving forward.
Do not sign up for a new account after SSO is disabled
If any of your team members do not have or remember their Customer.io credentials after disabling SSO, send password reset emails from Team Members. You must have the Account Admin role to do this.
Troubleshooting
I’m getting an error when I click Authenticate.
If you’re still getting an error after double checking your organization URL, client ID and client secret, check to see that you’ve added yourself to the Customer.io app.
I’m using an aliased email (i.e. ami+cio@customer.io) as my Customer.io login. Can I still SSO?
Yes. Simply update your username in your IdP to your aliased email in the scope of the Customer.io app.
For Google SSO: you can login using ami@customer.io
and have access to CIO accounts linked to ami@customer.io
, ami+cio@customer.io
, etc.
For Okta, Azure, and other IdPs: it has to be a 1-to-1 match. If your account has ami+cio@customer.io
, your CIO account must be ami+cio@customer.io
(not ami@customer.io
).
I’m unable to log in after SSO was enabled. What do I do?
The email address you use to log into Customer.io must match the email registered in your IdP. An Account Admin on your account can verify or update your email in Customer.io on the Team Management page.
Reach out to support at win@customer.io if you’re still experiencing issues logging in.