Logo Questions Linux Laravel Mysql Ubuntu Git Menu
 

UseOpenIdConnectAuthentication - Unable to unprotect the message.State Error Message

I am trying to add Google and Azure Active Directory authorities as OpenIdConnect options in my application.

If i add each of them separately, it works fine. But if i add them both i get the following error message:

Unable to unprotect the message.State

These are the OpenIdConnectOptions configuration:

        //Google
        appBuilder.UseOpenIdConnectAuthentication(new OpenIdConnectOptions
        {                 
            ClientId = ".....apps.googleusercontent.com",
            Authority = $"https://accounts.google.com",
            ClientSecret = "xxxyyyzzzz",
            AuthenticationScheme = "Google",
            DisplayName = "Google",
            AutomaticChallenge = true                                       
        });

        //Azure AD Providers
        var schemeName = "Azure Active Directory";
        var clientId = "1234567890";  
        var tenantId = "0987654321";  

        appBuilder.UseOpenIdConnectAuthentication(new OpenIdConnectOptions
        {               
            ClientId = clientId,
            ClientSecret = "aaaaabbbbcccc",
            Authority = $"https://login.microsoftonline.com/{tenantId}",
            AuthenticationScheme = "Azure Active Directory",
            DisplayName = "Azure Active Directory",
            AutomaticChallenge = true,                                                
        });
like image 811
alessalessio Avatar asked May 03 '17 11:05

alessalessio


1 Answers

When you have multiple OIDC middleware, you need to set a unique CallbackPath for each of them. Otherwise they are stepping on each other's toes when handling the callback.

like image 180
leastprivilege Avatar answered Nov 15 '22 06:11

leastprivilege