Microsoft (Public) OpenID Setup
Warning
Be mindful when configuring OpenID providers that are public. Any user that can successfully authenticate with the provider will have access to your deployment of Kasm Workspaces. While access to Kasm Workspace apps and desktops can be resitricted with Kasm group permissions, any user of the public authentication provider would still be able to login to your deployment of Kasm. It is recommended to use a private OpenID provider unless your intention is to allow authentictioned access to all users of the OpenID platform provider.
This guide walks through a basic setup allowing Microsoft users to authenticate with your Kasm deployment.
Reference Docs:
https://docs.microsoft.com/en-us/azure/active-directory/develop/quickstart-register-app
https://docs.microsoft.com/en-us/azure/active-directory/develop/active-directory-v2-protocols
Creating a Microsoft OAuth App
Login to the Microsoft Azure Portal: https://portal.azure.com/
Select Azure Active Directory.
data:image/s3,"s3://crabby-images/0844a/0844a1f80c16084b65bc51bd2af7e3bfd5251310" alt="../../_images/azure_ad.png"
Azure Active Directory
Select App Registrations.
data:image/s3,"s3://crabby-images/d65f7/d65f7a39a011cbe569128e6cbec096bf1ede7696" alt="../../_images/app_registrations.png"
App Registration
Select New Registration.
Give the app a Name (e.g
Kasm
).In the Supported account types select Accounts in any organizational directory (Any Azure AD directory - Multitenant) and personal Microsoft accounts (e.g. Skype, Xbox).
Warning
In this example, we walk through creating an integration where any Microsoft user can auth with the Kasm app. This is ideal for a public facing deployment. Other options are available for single-tenant and multi-tenant configurations.
data:image/s3,"s3://crabby-images/2b3e6/2b3e64cb409e8823601194eada0b4e3a83373812" alt="../../_images/register_app.png"
Register App
On the next page, the Application (client) ID is shown, save this value as the Client ID to be used in the next section.
Select Add a certificate or secret next to Client credentials.
data:image/s3,"s3://crabby-images/6027c/6027c0444d920c8358269bc99f6f58e9da63dc10" alt="../../_images/client_credentials.png"
Client Credentials
Select the Client secrets tab, then slick New client secret.
Enter a description and expiration then click Add.
The credentials are shown, save the Value as the Client Secret to be used in the next section.
data:image/s3,"s3://crabby-images/9e761/9e7612108f69d20e9ed11be091081b25ac9a1ed7" alt="../../_images/client_secret2.png"
Client Secret
Select Token configuration.
Select Add Optional Claim
Under Token Type select ID, then check the box for sid. Click Add.
data:image/s3,"s3://crabby-images/11ded/11ded3188da7c4995924543384a4732cb24d5f62" alt="../../_images/sid_claim.webp"
SID Claim
Select Authentication
In Front-channel Logout URL, provide the Kasm
/api/oidc_frontchannel_logout
endpoint as shown. Click Save.
data:image/s3,"s3://crabby-images/ca629/ca6293aeb82368be11bb297fb5f5936eeef4a59b" alt="../../_images/frontchannel_endpoint.webp"
Front-channel Logout URL
Kasm OpenID Config
Log into the Kasm UI as an administrator.
Select Access Management -> Authentication -> OpenID -> Add Config.
Update the form with the following entries, using the Client ID and Client Secret gathered in the previous section.
Property |
Value |
Enabled |
Checked |
Display Name |
Continue with Microsoft |
Logo URL |
|
Auto Login |
Unchecked |
Hostname |
<Empty> |
Default |
Checked |
Client ID |
<Client ID From Microsoft OAuth App> |
Client Secret |
<Client Secret from Microsoft OAuth App> |
Authorization URL |
|
Token URL |
|
User Info URL |
|
Scope |
|
Username Attribute |
|
Groups Attribute |
Unchecked |
Debug |
Unchecked |
Redirect URL |
|
OpenID Connect Issuer |
|
Logout with OIDC Provider |
Checked |
Enable OIDC SLO Frontchannel Endpoint |
Checked |
data:image/s3,"s3://crabby-images/511ee/511eef58d0fe5838083a1c4c5d96172b3cb06ec4" alt="../../_images/kasm_oidc_configuration4.webp"
Kasm OIDC Configurations
Click Save to save the changes.
Microsoft Login Test
Logout of the Kasm to display the login screen. The OpenID configuration should be shown.
data:image/s3,"s3://crabby-images/f8382/f83826dc5f991a4c8311cb21cd697dcdee4e10df" alt="../../_images/login4.webp"
Login Screen
Click Continue with Microsoft
The user is redirected to Microsoft for auth.
data:image/s3,"s3://crabby-images/dcccd/dcccd4effd12435c8ba0adf23ee15dba6bec03c5" alt="../../_images/authorization4.png"
Microsoft Auth
Upon completion, the user is logged into the Kasm app.