Skip to content

Commit

Permalink
Fix metadata address creation when using AddMicrosoftIdentityWebApp (#…
Browse files Browse the repository at this point in the history
  • Loading branch information
JoshLozensky authored Jun 10, 2024
1 parent b1847f1 commit 434473a
Show file tree
Hide file tree
Showing 2 changed files with 33 additions and 1 deletion.
Original file line number Diff line number Diff line change
Expand Up @@ -317,7 +317,7 @@ s.ServiceKey is null &&
mergedOptions.PreserveAuthority = preserveAuthority;
if (mergedOptions.ExtraQueryParameters != null)
{
options.MetadataAddress = mergedOptions.Authority + "/.well-known/openid-configuration?" + string.Join("&", mergedOptions.ExtraQueryParameters.Select(p => $"{p.Key}={p.Value}"));
mergedOptions.MetadataAddress = mergedOptions.Authority + "/.well-known/openid-configuration?" + string.Join("&", mergedOptions.ExtraQueryParameters.Select(p => $"{p.Key}={p.Value}"));
}
}

Expand Down
32 changes: 32 additions & 0 deletions tests/Microsoft.Identity.Web.Test/WebAppExtensionsTests.cs
Original file line number Diff line number Diff line change
Expand Up @@ -183,6 +183,38 @@ public void AddMicrosoftIdentityWebApp_WithConfigActionParameters(bool subscribe
AddMicrosoftIdentityWebApp_TestSubscribesToDiagnostics(services, diagnosticsMock, subscribeToDiagnostics);
}

[Fact]
public Task AddMicrosoftIdentityWebApp_WithConfigAuthority_TestCorrectMetadataAddress()
{
// Arrange
string authority = "https://login.microsoftonline.com/some-tenant-id/v2.0";
string appId = "some-client-id";
string expectedMetadataAddress = $"{authority}/.well-known/openid-configuration?appId={appId}";
var configMock = Substitute.For<IConfiguration>();
configMock.Configure().GetSection(ConfigSectionName).Returns(_configSection);

var services = new ServiceCollection()
.AddSingleton(configMock)
.PostConfigure<MicrosoftIdentityOptions>(OidcScheme, (options) =>
{
options.Authority = authority;
options.ExtraQueryParameters = new Dictionary<string, string>
{
{"appId", appId}
};
});

// Act
services.AddAuthentication()
.AddMicrosoftIdentityWebApp(configMock, ConfigSectionName, OidcScheme, CookieScheme, subscribeToOpenIdConnectMiddlewareDiagnosticsEvents: false);
var provider = services.BuildServiceProvider();
var providedOptions = provider.GetRequiredService<IOptionsMonitor<OpenIdConnectOptions>>().Get(OidcScheme);

// Assert
Assert.Equal(expectedMetadataAddress, providedOptions.MetadataAddress);
return Task.CompletedTask;
}

[Fact]
public async Task AddMicrosoftIdentityWebApp_WithConfigNameParameters_TestRedirectToIdentityProviderEvent()
{
Expand Down

0 comments on commit 434473a

Please sign in to comment.