Authorize Sitecore JSS Layout Services with Azure Identity in Micro-frontends Implementation

If you have Sitecore Headless Services publicly accessible and you are willing to authorize them with Azure AD. Here's how we achieved it in Microfrontend implementation.


“Talk is cheap. Show me the code.”
― Linus Torvalds
Photo by Mohammad Rahmani / Unsplash

Overview

In our case, we have a React app built with a Micro-front end approach where we get the user authentication token from the host application (which is already authenticated with Azure AD and has a valid user token).

The host app is responsible to pass the Azure AD token to our React app that fetches all the content using Sitecore Headless Services.

Since the host app is authenticated with Azure AD it was clear to us that we need to secure Sitecore Layout Services as well with the same identity provider.

Implementation logic

I'm explaining the implementation approach in a sequence below in order to make it more logical for you.

  1. The host app challenges the user and authenticates his identity with the Azure AD authentication.
  2. Once the user bypasses the authentication he will be redirected to the host app with an authorization token.
  3. The host app bypasses the authorization token to our React App that communicates and fetches all the content from Sitecore Headless Services.
  4. Now our React app is having an access to Azure AD token by executing a callback function on the host app.
  5. The React app is adding the authorization token on each request header to Sitecore Headless Services.
  6. Sitecore Headless Services must receive the authorization token with every request.
  7. We have implemented a custom Sitecore processor that extends the getLayoutServiceContext pipeline provided by the Layout Service.  The code is added below.
  8. The processor gets the Azure AD authorization token and verifies it with Azure AD on each request that occurs on the Layout Service.

Code

I'm adding the code to this blog post that extends the getLayoutServiceContext pipeline provided by the Layout Service to allow Sitecore Layout Service to authorize the token with Azure AD.

  1. First, we create a config file to patch our custom processor to Sitecore Layout Service.
Foundation.Security.config

2. Second, we create our processor that accesses the authorization token from the request header and verifies the token with Azure AD.  

AuthorizeHeadlessServicesCalls.cs

That's all for now.