Integrate with Salesforce

Use JumpCloud SAML Single Sign On (SSO) to give your users convenient but secure access to all their web applications with a single set of credentials. Integrate your JumpCloud account with Salesforce through an Identity Management Connector. After you connect JumpCloud with Salesforce, you can provision, update, and deprovision users and groups from JumpCloud and manually import users from Salesforce into JumpCloud. Leverage this integration for centralized user lifecycle management and get immediate attribute management of users bound to integrated applications.

Read this article to learn how to configure the Salesforce SSO integration. 

Prerequisites

  • A JumpCloud administrator account
  • JumpCloud SSO Package or higher or SSO à la carte option
  • A Salesforce user account with administrative permissions
  • Your Salesforce domain name
  • Just-in-time (JIT) user provisioning must be disabled or Identity Management will not work as documented. Disable JIT by going to the Salesforce admin console and navigating to SAML Single Sign-On Settings panel:
    • Under SAML Identity Type, select Assertion contains User's salesforce.com username
    • Under Just-in-time User Provisioning, uncheck User Provisioning Enabled

Important Considerations

  • SAML is the recommended method for managing secure user authentication into Salesforce. It is recommended, but not required, for the Identity Management configuration
  • Salesforce SAML configuration details can also be found here. This link is valid as of April 2021. If there are any discrepancies between 'Configure the Service Provider' below and Salesforce's  instructions, please follow the Salesforce guidance
  • Country/state picklist values must be deactivated or the sync will error - see this Salesforce article for more information
  • The SCIM integration would not populate the Federation Identifier value
  • If you are using a Sandbox version of Salesforce, you must use the Salesforce Sandbox connector for SCIM to work properly
  • If you delete an integrated Salesforce application from your Applications list, the Salesforce application is removed from JumpCloud, but any previously bound users remain active in Salesforce. Additionally, these users can't log in to Salesforce with the password they used prior to your deletion of the Salesforce application from your JumpCloud account
  • At this time, English is the only supported language
  • Users are created with the default entitlement, Standard User. If you update the entitlement in Salesforce, JumpCloud won’t overwrite it
  • Salesforce requests users to authorize changes made to their email address that’s associated with their account. This means you can’t use JumpCloud’s provisioning functionality to update a users email address in Salesforce.
  • Users are created with the “nickname” attribute value set to null. If you update “nickname” in Salesforce, JumpCloud won’t overwrite it
  • Locale and preferred language default to en_US on user creation
  • We don't update the entitlements, the locale/preferred language, nor the nickname of an existing user
  • Groups are supported

Attribute Considerations

  • A default set of attributes are managed for users. See the Attribute Mappings section for more details
  • A user’s JumpCloud email address is used as the username and email in Salesforce
  • Salesforce doesn't support the use of special characters in a username, such as [email protected]
  • Usernames in Salesforce must be unique

Creating a new JumpCloud Application Integration

  1. Log in to the JumpCloud Admin Portal.
  2. Go to USER AUTHENTICATION SSO Applications.
  3. Click + Add New Application.
  4. Type the name of the application in the Search field and select it.
  5. Click Next.
  6. In the Display Label, type your name for the application. Optionally, you can enter a Description, adjust the User Portal Image and choose to hide or Show in User Portal.

Note:

If this is a Bookmark Application, enter your sign-in URL in the Bookmark URL field.

  1. Optionally, expand Advanced Settings to specify a value for the SSO IdP URL. If no value is entered, it will default to https://sso.jumpcloud.com/saml2/<applicationname>.

Warning:

The SSO IdP URL is not editable after the application is created. You will have to delete and recreate the connector if you need to edit this field at a later time.

  1. Click Save Application.
  2. If successful, click:
    • Configure Application and go to the next section
    • Close to configure your new application at a later time

Configuring the SSO Integration

Configuration of the service provider (SP) requires multiple actions. Configuration actions should be completed in the order listed.

To configure Salesforce

To configure a Salesforce MyDomain

Note:

This is for new Salesforce setups and requires System Administrator access. Skip to the next step if this is already completed in your environment.

  1. Log into Salesforce as an Administrator.
  2. From the gear icon at upper right, select Setup.
  3. From the left-hand sidenav, navigate to Settings > Company Settings > My Domain.
  4. Enter a new My Domain Name for your Salesforce account.
  5. Click Check Availability.
  6. Click Save.
  7. Agree to  the Terms and Conditions.
  8. Wait for the email confirmation that your new My Domain is ready to be deployed
  9. Follow the instructions in the email
  10. From the gear icon at upper right, select Setup.
  11. From the left-hand sidenav, navigate to Settings > Company Settings > My Domain.
  12. Click Deploy New Domain.

To generate the certificate

  1. Log into Salesforce as an Administrator.
  2. From the gear icon at upper right, select Setup.
  3. From the left-hand sidenav, navigate to Settings > Security > Certificate and Key Management.​
  4. Select Create Self-Signed Certificate and check "Create Exportable Key"
  5. Enter the following Label: JumpCloud SAML.
  6. Leave the auto-populated value Salesforce generated in the Unique Name field..
  7. Select Save.
  8. Select Download Certificate.

To enable SAML

  1. From the left-hand sidenav, navigate to Settings > Identity > Single Sign-On Settings.​
  2. Select Edit.
  3. Select the SAML Enabled checkbox.
  4. Select Save.
  5. Optionally, select the Make Federation ID case-insensitive checkbox.
  6. Select New.
  7. Enter the Name: JumpCloud.
  8. Enter the  API Name: JumpCloud.
  9. Enter the Issuer: JumpCloud.
  10. Enter the Entity Id  in the following format: https://YOUR_DOMAIN.TLD.
    • If you have a custom domain setup, use https://[customDomain].my.salesforce.com
    • If you do not have a custom domain setup, use https://saml.salesforce.com
  11. Select Choose File next to Identity Provider Certificate and upload the certificate that was downloaded in step 8 of 'Generate the Service Provider Certificate'.
    • This is a temporary placeholder for the JumpCloud certificate that will be created during the JumpCloud configuration.
    • Once the JumpCloud connector is configured the actual cert.pem will need to be uploaded. 
  12. In the dropdown menu for Request Signing Certificate, select JumpCloud SAML.
  13. In the dropdown menu for Assertion Decryption Certificate, select JumpCloud SAML.
  14. Leave the default selections for SAML Identity Type and SAML Identity Location unless you are going to use Just-in-time User Provisioning
    1. If you are going to use Just-in-time User Provisioning, make the following selections.  Note: If you are going to use the Identity Management SCIM integration, do not enable Just-in-time User provisioning.
      1. Select Assertion contains the Federation ID from the User object for SAML Identity Type.
      2. Select Identity is in an Attribute element for SAML Identity Location
      3. Enter the Attribute Name that will be sent in the SAML assertion, for example FederationIdentifier.
         
  15. Select HTTP POST for Service Provider Initiated Request Binding
  16. Enter the following Identity Provider Login URL: https://sso.jumpcloud.com/saml2/salesforce
    • This is the default IdP URL, but if you plan to change this value in JumpCloud in step 10 of 'Configure the JumpCloud Salesforce Application', then enter your chosen value.
  17. If you will be using Just-in-time User Provisioning, do the following:
  • Note: If you are going to use automatic provisioning with the  Identity Management SCIM integration in JumpCloud, do not enable this option.
  • Select the User Provisioning Enabled checkbox.
  • Select Standard.
  1. Leave all other fields blank and options unselected
  2. Select Save.
  3. Once saved, on this screen, copy the Salesforce Login URL for later use. It will be in the form of https://<YOUR_DOMAIN>.my.salesforce.com?sc=<SOME_SPECIFIC_STRING>; or https://<YOUR_DOMAIN>.my.salesforce.com?sc=<SOME_SPECIFIC_STRING>
  4. Download metadata.

To configure JumpCloud

  1. Create a new application or select it from the Configured Applications list.
  2. Select the SSO tab.
  3. Upload the metadata file you downloaded in the Enable SAML for Salesforce section above. If you prefer to enter the information manually, do the following:
    1. Enter the IdP Entity ID: JumpCloud.
    2. Enter the SP Entity ID in this format: https://YOUR_DOMAIN.TLD
      1. Ensure the SP Entity ID matches the value you entered in Salesforce.
    3. In the ACS URL field, enter the URL you copied from Salesforce in 'Enable SAML for Salesforce'.
    4. Select Upload SP Certificate and upload the JumpCloud_SAML.crt file as done in 'Generate the Service Provider Certificate'.
  4. For the IdP URL, either leave the default value or if  you used a custom string in 'Enable SAML for Salesforce', enter the same value here; the IdP URL must match the value entered in Salesforce.
  5. Additional attributes are required to use Just-in-Time (JIT) provisioning. In JumpCloud, JIT required attributes necessary for JIT provisioning are enabled by default. If you are not using JIT, you may toggle off the attributes to opt out of sending the attributes in the SAML assertion.  

Note:

You can’t edit the JIT required service provider attributes but you can customize the JumpCloud attribute name and the constant value for JIT required attributes.

  1. Select save.

Download the certificate

  1. Find your application in the Configured Applications list and click anywhere in the row to reopen its configuration window.
  2. Select the SSO tab and click IDP Certificate Valid > Download certificate.

Tip:

The certificate.pem will download to your local Downloads folder.

Update the Identity Provider Certificate in Salesforce 

  1. Return to Salesforce
  2. Navigate back to Settings > Identity > Single Sign-On Settings.​
  3. Select Edit.
  4. Replace the temporary certificate uploaded in Enable SAML for Salesforce with the actual JumpCloud certificate.
    • Select Choose File next to Identity Provider Certificate
    • Upload the certificate.pem certificate that was downloaded in the previous section.
  5. Click Save.

Use JIT Provisioning 

Note:

You can provision, update, and deprovision users in Salesforce in real-time with our Identity Management Integration.  

The SCIM integration would not populate the Federation Identifier value as that is not one of the values we currently send.    If you are planning on using the Federation Identifier for other reasons,  the Identity Management SCIM integration may not be a viable option. 

Considerations when enabling JIT Provisioning after the integration is configured

To use JIT provisioning, you will need to bulk update the existing users to add the Federation Identifier.   To do a bulk update of users, they can use the Data Loader in Salesforce.  They would need to export the list of users.  The export produces a csv. They would need to update the csv to add the Federation Identifier for each user that doesn't have one. They would then upload the updated csv file . 

To complete the provisioning process:

  1. Authorize a user’s access to the application 
  2. Have the user log in to the application using SSO. The SAML assertion passes from JumpCloud to the service provider, and gives the service provider the information it needs to create the user account.

To enable JumpCloud SSO Login for All Salesforce Users

  1. Navigate to Settings > Company Settings > My Domain.​
  2. Scroll down to the Authentication Configuration section.
  3. Select Edit.
  4. Select the checkbox for JumpCloud.
  5. Deselect the checkbox for Login Form.
  6. Select Save.

Authorizing User SSO Access

Users are implicitly denied access to applications. After you connect an application to JumpCloud, you need to authorize user access to that application. You can authorize user access from the Application Configuration panel or from the Groups Configuration panel. 

To authorize user access from the Application Configuration panel

  1. Log in to the JumpCloud Admin Portal.
  2. Go to USER AUTHENTICATION > SSO Applications, then select the application to which you want to authorize user access.
  3. Select the User Groups tab. If you need to create a new group of users, see Get Started: User Groups.
  4. Select the check box next to the group of users you want to give access.
  5. Click save

To learn how to authorize user access from the Groups Configuration panel, see Authorize Users to an SSO Application.

Validating SSO user authentication workflow(s)

IdP-initiated user workflow

  • Access the JumpCloud User Console
  • Go to Applications and click an application tile to launch it
  • JumpCloud asserts the user's identity to the SP and is authenticated without the user having to log in to the application

SP-initiated user workflow

  • Go to the SP application login - generally, there is either a special link or an adaptive username field that detects the user is authenticated through SSO

Note:

This varies by SP.

  • Login redirects the user to JumpCloud where the user enters their JumpCloud credentials
  • After the user is logged in successfully, they are redirected back to the SP and automatically logged in

Configuring the Identity Management Integration

To configure JumpCloud

  1. Create a new application or select it from the Configured Applications list.
  2. Select the Identity Management tab.
  3. Click Configure.
  4. You're prompted to save the application. Note that the IdP URL can't be shared across applications and can't be edited after it's created. Click save.
  5. Sign in to your Salesforce admin account, then click Continue
  6. When you're prompted to give JumpCloud permission to administer your org's Salesforce workspace, click Allow. If you aren't a Salesforce admin, you will see a request asking for admin permissions.
  7. If successful, you receive a confirmation of a successful integration.
  8. Click save when you return to the Salesforce application page in JumpCloud.

Attribute Mappings

The following table lists attributes that JumpCloud sends to the application. See Attribute Considerations for more information regarding attribute mapping considerations. 

Learn about JumpCloud Properties and how they work with system users in our API

Salesforce User Attributes

Salesforce User Attribute Type JumpCloud User Attribute Notes
Id string id
name.givenName string firstname
name.familyName string lastname
displayName string displayname
nickName string null Users are created with the nickname attribute value set to null. If you update nickname in Salesforce, JumpCloud won’t overwrite it.
entitlements[primary=true].Entitlement string "Standard User" Required. Users are created with the default entitlement profile of "Standard User". If you update the profile entitlement or permission sets in Salesforce, JumpCloud won’t overwrite it.
userName string email SF username must be the user email.
password string password
emails[type='work',primary=true].Email string email
active boolean !suspended && !passwordExpired
userType string employeeType
title string jobTitle
locale string "en_US"
preferredLanguage string "en_US"
addresses[].type string addresses[].type SF only allows one address
addresses[].streetAddress string addresses[].streetAddress
addresses[].locality string addresses[].locality
addresses[].region string addresses[].region
addresses[].postalCode string addresses[].postalCode
addresses[].country string addresses[].country
phoneNumbers[].type string phoneNumbers[].type SF only allows one phone number
phoneNumbers[].value string phoneNumbers[].value
urn:ietf:params:scim:schemas:extension:enterprise:2.0:User object
-> employeeNumber string employeeIdentifier
-> department string department
-> organization string company

Group Attributes

JumpCloud Property JumpCloud UI Field Name SCIM v2 Mapping Application Value
name Name displayName Name

Importing Users

This functionality is helpful if users have already been created in the application but have not been created in JumpCloud.

  1. Log in to the JumpCloud Admin Portal.
  2. Go to USER AUTHENTICATION > SSO Applications.
  3. Search for the application and click to open its configuration panel. 
  4. Select the Identity Management tab.
  5. Click manual import.
  6. Select the users you want to create in JumpCloud from the application from the list of users that appear. Users in the list have two import statuses:
    • New - user has not been imported
    • Imported - user has been imported and has an account in JumpCloud

Tip: Try using the New Users-only filter when selecting users to import. This will move all of your new users to the top of the list, making them easier to identify and select.

  1. Click import.
    • If you are importing less than 100 users, your import results will display in real time and you can continue onboarding your users 
    • If you have more than 100 users being imported, JumpCloud will send you an email when your import is complete
  1. You can now connect and grant users access to all their JumpCloud resources. Learn more in the Authorize Users to an Application and Connecting Users to Resources articles.

Warning: Imported users must be members of a user group bound to an application for JumpCloud to manage their identity in, and access to, the application.

SCIM Directory Insights Events

The following Directory Insights (DI) events provide visibility into failures and detailed information about the user and group data being added or updated from HR or other external solutions to JumpCloud.

Note:

Customers with no package or the Device Management Package will need to add the Directory Insights à la carte option. Directory Insights is included in all other packages.

SCIM DI Integration Events

Event Name Event Description
idm_integration_activate Logged when an IT admin attempts to activated new SCIM Identity Management integration.
idm_integration_update Logged when an IT admin attempts to update a configured and activated SCIM Identity Management integration.
idm_integration_reauth Logged when an IT admin attempts to change the credentials for an activated SCIM Identity Management integration.
idm_integration_delete Logged when an IT admin attempts to deactivate an activated SCIM Identity Management integration.

SCIM DI User Events

Event Name Event Description
user_create_provision Logged when JumpCloud tries to create a new user in service provider application.
user_update_provision Logged when JumpCloud tries to update an existing user in service provider application.
user_deprovision Logged when JumpCloud tries to change an existing user to inactive in the service provider application.
user_delete_provision Logged when JumpCloud tries to delete an existing user in service provider application.
user_lookup_provision Logged when JumpCloud encounters an issue when trying to lookup a user to determine if the user needs to be created or updated.

SCIM DI Group Events

Important:

These DI events will only be present if SCIM Groups are supported.

Event Name Event Description
group_create_provision Logged when JumpCloud tries to create a new group in service provider application.
group_update_provision Logged when JumpCloud tries to update an existing group in service provider application.
group_delete_provision Logged when JumpCloud tries to delete an existing group in service provider application.

Removing the Integration

Important:

These are steps for removing the integration in JumpCloud. Consult your SP's documentation for any additional steps needed to remove the integration in the SP. Failure to remove the integration successfully for both the SP and JumpCloud may result in users losing access to the application.

To deactivate the IdM Integration

  1. Log in to the JumpCloud Admin Portal.
  2. Go to USER AUTHENTICATION > SSO Applications.
  3. Search for the application that you’d like to deactivate and click to open its details panel. 
  4. Under the company name and logo on the left hand panel, click the Deactivate IdM connection link.
  5. Click confirm
  6. If successful, you will receive a confirmation message.

To deactivate the SSO Integration or Bookmark

  1. Log in to the JumpCloud Admin Portal.
  2. Go to USER AUTHENTICATION > SSO Applications.
  3. Search for the application that you’d like to deactivate and click to open its details panel. 
  4. Select the SSO or Bookmark tab.
  5. Scroll to the bottom of the configuration.
  6. Click Deactivate SSO or Deactivate Bookmark
  7. Click save
  8. If successful, you will receive a confirmation message.

To delete the application

  1. Log in to the JumpCloud Admin Portal.
  2. Go to USER AUTHENTICATION > SSO Applications.
  3. Search for the application that you’d like to delete.
  4. Check the box next to the application to select it.
  5. Click Delete.
  6. Enter the number of the applications you are deleting
  7. Click Delete Application.
  8. If successful, you will see an application deletion confirmation notification.
Back to Top

List IconIn this Article

Still Have Questions?

If you cannot find an answer to your question in our FAQ, you can always contact us.

Submit a Case