I am having the following problem:
Exception: OAuth token endpoint failure: Status: Body: {"error":"invalid_client","error_description":"AADSTS700025: Client is public so neither 'client_assertion' nor 'client_secret' should be presented}.
I am using the Microsoft.AspNetCore.Authentication.Microsoft Account library
Program file
builder.Services.AddAuthentication()
.AddCookie(CookieAuthenticationDefaults.AuthenticationScheme, options =>
{
options.LoginPath = "/page";
options.LogoutPath = "/page";
options.AccessDeniedPath = "/page?code={0}";
options.ExpireTimeSpan = TimeSpan.FromMinutes(tiempoDeSesion);
options.Cookie.Name = ".CookieName.Sec";
options.SlidingExpiration = true;
})
.AddMicrosoftAccount(microsoftOptions =>
{
microsoftOptions.ClientId = builder.Configuration["AzureAd:ClientId"];
microsoftOptions.ClientSecret = builder.Configuration["AzureAd:ClientSecret"];
microsoftOptions.CallbackPath = new PathString("/signin-microsoft-token");
microsoftOptions.AuthorizationEndpoint = $"https://login.microsoftonline.com/{builder.Configuration["AzureAd:TenantId"]}/oauth2/v2.0/authorize";
microsoftOptions.TokenEndpoint = $"https://login.microsoftonline.com/{builder.Configuration["AzureAd:TenantId"]}/oauth2/v2.0/token";
microsoftOptions.Scope.Add("https://graph.microsoft.com/user.read");
microsoftOptions.SaveTokens = true;
microsoftOptions.ClaimActions.MapJsonKey(ClaimTypes.NameIdentifier, "id");
microsoftOptions.ClaimActions.MapJsonKey(ClaimTypes.Name, "displayName");
microsoftOptions.ClaimActions.MapJsonKey(ClaimTypes.GivenName, "givenName");
microsoftOptions.ClaimActions.MapJsonKey(ClaimTypes.Surname, "surname");
microsoftOptions.ClaimActions.MapCustomJson(ClaimTypes.Email,
user => user.GetString("mail") ?? user.GetString("userPrincipalName"));
});