Single Sign-on using Azure AD with Static Web Apps, let’s create a Simple Azure AD Page, Enable Single Sign-on Using Azure AD.
Uploaded the same javascript below the GitHub repo.
Sign in, Redirects to Microsoft Login, and Logout Kills all the session.
data:image/s3,"s3://crabby-images/5b4da/5b4da3e6410c52081eb84d8fd10099c0aa3a264b" alt=""
data:image/s3,"s3://crabby-images/a2a20/a2a20d401a88c382e78e4e3da263e4621ee679df" alt=""
GitHub Repo Reference – azure365pro/AAD-StaticWebApp: Simple Login Logout Page using Azure AD in Static Web App (github.com)
Let’s create an Azure Static Web App, Deployment source is GitHub.
data:image/s3,"s3://crabby-images/c89fa/c89fa97ea6e2029d375d568956af241ef2181606" alt=""
Choose Organization / Repo / Branch / Build presets to Custom
data:image/s3,"s3://crabby-images/3fb8f/3fb8f154db82df3ff412c3a7e4aef80159f78094" alt=""
data:image/s3,"s3://crabby-images/f9b9e/f9b9e590eea4af9ffc4dd363ef07f6b397dbb93b" alt=""
data:image/s3,"s3://crabby-images/4637f/4637f16eaa22d1ef622c1fc0d93cf3d8085b4e09" alt=""
Now the site is loaded using GitHub repo
data:image/s3,"s3://crabby-images/6c883/6c88312892bdad3b1e5f4c723dee427c392c4015" alt=""
Now lets create an enterprise application for Single Sign on
data:image/s3,"s3://crabby-images/2efbb/2efbb9b4e414a9301363c56e9a2d762b8a0654c9" alt=""
Assign users for enabling sso
data:image/s3,"s3://crabby-images/a9ea2/a9ea28c86945b54486908385ab305a3ade4071b7" alt=""
Copy AZURE_CLIENT_ID
data:image/s3,"s3://crabby-images/a45cf/a45cf2513ff063f57d956fd7b700fc14f906d4b8" alt=""
Add a Variable for the same
data:image/s3,"s3://crabby-images/de626/de6260f830892a30111907c5d140e17533c43f76" alt=""
Copy AZURE_CLIENT_SECRET
data:image/s3,"s3://crabby-images/62616/626162c7f2d52cbae11645d9ac0f854f59c2df2d" alt=""
Add a Variable for the same – Choose SAVE
data:image/s3,"s3://crabby-images/90513/90513575480943b47213c8b175a44528ba59c88b" alt=""
Modify staticwebapp.config.json based on your environment, Maybe you can fork it and do a simple lab.
The appropriate tenant ID is updated in the JSON file.
data:image/s3,"s3://crabby-images/448ea/448eac2e6499dbe1cd8e646aeefd37dfe6b30cf7" alt=""
App User.Read Permissions
data:image/s3,"s3://crabby-images/3f335/3f335a0026651fd1781a361d0122bd4ea5f8e0c2" alt=""
Grant Admin Consent
data:image/s3,"s3://crabby-images/b37fc/b37fc6143e1cd12adcfa6ead60f0ddecd8a28d07" alt=""
Redirect URIs based on your URL Add /.auth/login/aad/callback
https://zealous-grass-0ea7c0c03.2.azurestaticapps.net/.auth/login/aad/callback
data:image/s3,"s3://crabby-images/7feca/7fecaa87cdad0638806a409b60cfd5b31996b656" alt=""
Choose Web
data:image/s3,"s3://crabby-images/0be35/0be35ac54a2a164bc6f44436985b60b1542099cb" alt=""
data:image/s3,"s3://crabby-images/a2ad5/a2ad51aa4f41c97b7c7aa03328847fbde2458615" alt=""
Based on my URL – Changing the login route to Authenticated directory.
https://zealous-grass-0ea7c0c03.2.azurestaticapps.net/authenticated/
data:image/s3,"s3://crabby-images/d34b9/d34b90813fadebdee1bf7457b4e459adf3994b8b" alt=""
As soon as you update any files – you can see GitHub Actions takes places to deploy
data:image/s3,"s3://crabby-images/afb02/afb02e623e1e719df2bccc400bda2489ddeb68d6" alt=""
Update Index.js on Sign in Button action
https://zealous-grass-0ea7c0c03.2.azurestaticapps.net/authenticated/
data:image/s3,"s3://crabby-images/ba87b/ba87b7ce6088d88de030f395ed5138c4e91d5592" alt=""
Now after login
data:image/s3,"s3://crabby-images/a2a20/a2a20d401a88c382e78e4e3da263e4621ee679df" alt=""