Setting Up An OAuth 2.0 Authorizer with JumpCloud
data:image/s3,"s3://crabby-images/c3083/c308389b4b0202e8841a3d14691c3fb3483efd38" alt="Setting Up An OAuth 2.0 Authorizer with JumpCloud"
Introduction
Note: This guide was written with the intent of being used with my other post on Federating S3 Access Grants with IAM Identity Center Trusted Identity Propagation. Some of the naming conventions and configurations may not make sense if you are not following along with that guide.
When working with AWS services, you may want to use an external identity provider (IdP) to authenticate users and grant them access to your resources.
In this guide, we will walk through setting up an OAuth 2.0 authorizer with JumpCloud to federate with AWS IAM Identity Center. This will allow you to use JumpCloud as an identity provider (IdP) to authenticate users and grant them access to AWS services.
Create a JumpCloud Account
Head over to https://jumpcloud.com/ and create a free account. Once you have an account, log in and click User Groups in the left-hand menu - then create a new group called s3-access-grants
.
data:image/s3,"s3://crabby-images/77fd7/77fd72c4809a2277b29adbd6d336401667c6a0f6" alt="Create a JumpCloud user group"
Next, choose Users in the left-hand menu and create a new user call whatever you like - making sure to set the Company Email to the email address of your user in AWS IAM Identity Center.
data:image/s3,"s3://crabby-images/d833d/d833dcbd66ec9c4cdea462cd6f78df138182dce2" alt="Create a JumpCloud user"
You should also add the user to the s3-access-grants
group.
data:image/s3,"s3://crabby-images/38d22/38d223fd73a6bb6a9949b2f2714f555b974d0b38" alt="Add user to JumpCloud group"
Create an OAuth 2.0 Application
Next, click Applications in the left-hand menu and create a new Custom Application
data:image/s3,"s3://crabby-images/39354/393542e5d1f328f4db212adc9cf4f58fd18f8f78" alt="Create a JumpCloud custom application"
Click through and select Manage Single Sign-On (SSO) then Configure SSO with OIDC.
data:image/s3,"s3://crabby-images/2c7a0/2c7a0a8d267d6c9afd9ff8f85962adf89fd5adc3" alt="Create JumpCloud custom application as OIDC"
Give the application a name (e.g. s3-access-grants
) and click Configure Application.
data:image/s3,"s3://crabby-images/802ae/802ae9b85e88eaa0eea438a2c4c91b79b7c5120b" alt="Finish creating JumpCloud custom application"
Configure the OAuth 2.0 Application
Once the application is created, click on SSO - then provide the following configuration:
- Refresh Token: ✅
- Redirect URI: http://localhost:5000/authorize
- Client Authentication Type: Client Secret Post
- Login URL: http://localhost:5000/login
data:image/s3,"s3://crabby-images/594a1/594a1a582c7ece26ae4b9f131b53e782f9f2477f" alt="Configure JumpCloud custom application"
Under Attribute Mapping be sure to select Email as a scope and map it to the email claim.
data:image/s3,"s3://crabby-images/f6a8c/f6a8c16f779325a7643a59a44c6675562c0238c4" alt="Configure JumpCloud custom application attribute mappings"
Click Activate to save the configuration. You will be provided with a Client ID and Client Secret - make a note of these as they will be needed later.
data:image/s3,"s3://crabby-images/78852/7885264c0fd1b7a0aeb9be81b6000be2809e3e29" alt="JumpCloud custom application client ID and secret"
You will also need to assign the s3-access-grants
group to the application.
data:image/s3,"s3://crabby-images/a06e1/a06e17be21df765549f5a88b046d4fa48a4ee6f6" alt="JumpCloud custom application group assignment"