Skip to content

Commit

Permalink
Merge pull request #178 from DuendeSoftware/brock/dpop-test
Browse files Browse the repository at this point in the history
add test for dpop workflow
  • Loading branch information
brockallen authored Jun 27, 2023
2 parents d545697 + d4aa717 commit cbc89eb
Show file tree
Hide file tree
Showing 4 changed files with 34 additions and 7 deletions.
3 changes: 2 additions & 1 deletion src/Duende.Bff.Yarp/AccessTokenRequestTransform.cs
Original file line number Diff line number Diff line change
Expand Up @@ -98,7 +98,8 @@ private async Task ApplyDPoPToken(RequestTransformContext context, DPoPTokenResu
context.ProxyRequest.Headers.Add(OidcConstants.HttpHeaders.DPoP, proofToken.ProofToken);
context.ProxyRequest.Headers.Authorization =
new AuthenticationHeaderValue(OidcConstants.AuthenticationSchemes.AuthorizationHeaderDPoP, token.AccessToken);
} else
}
else
{
// The proof service can opt out of DPoP by returning null. If so,
// we just use the access token as a bearer token.
Expand Down
5 changes: 0 additions & 5 deletions src/Duende.Bff.Yarp/AccessTokenTransformProvider.cs
Original file line number Diff line number Diff line change
Expand Up @@ -4,12 +4,7 @@
using System;
using System.Collections.Generic;
using System.Linq;
using System.Net.Http.Headers;
using System.Threading.Tasks;
using Duende.AccessTokenManagement;
using Duende.Bff.Logging;
using Duende.Bff.Yarp.Logging;
using IdentityModel;
using Microsoft.Extensions.Logging;
using Microsoft.Extensions.Options;
using Yarp.ReverseProxy.Transforms;
Expand Down
1 change: 0 additions & 1 deletion src/Duende.Bff.Yarp/IHttpTransformerFactory.cs
Original file line number Diff line number Diff line change
@@ -1,7 +1,6 @@
// Copyright (c) Duende Software. All rights reserved.
// See LICENSE in the project root for license information.

using Duende.AccessTokenManagement;
using Yarp.ReverseProxy.Forwarder;

namespace Duende.Bff.Yarp;
Expand Down
32 changes: 32 additions & 0 deletions test/Duende.Bff.Tests/Endpoints/RemoteEndpointTests.cs
Original file line number Diff line number Diff line change
Expand Up @@ -4,10 +4,13 @@
using Duende.Bff.Tests.TestFramework;
using Duende.Bff.Tests.TestHosts;
using FluentAssertions;
using Microsoft.Extensions.DependencyInjection;
using Microsoft.IdentityModel.Tokens;
using System;
using System.Linq;
using System.Net;
using System.Net.Http;
using System.Security.Cryptography;
using System.Text;
using System.Text.Json;
using System.Threading.Tasks;
Expand Down Expand Up @@ -374,5 +377,34 @@ public async Task calls_to_bff_not_in_endpoint_routing_should_fail()
Func<Task> f = () => BffHost.BrowserClient.SendAsync(req);
await f.Should().ThrowAsync<Exception>();
}

[Fact]
public async Task test_dpop()
{
var rsaKey = new RsaSecurityKey(RSA.Create(2048));
var jsonWebKey = JsonWebKeyConverter.ConvertFromRSASecurityKey(rsaKey);
jsonWebKey.Alg = "PS256";
var jwk = JsonSerializer.Serialize(jsonWebKey);

BffHost.OnConfigureServices += svcs =>
{
svcs.PostConfigure<BffOptions>(opts =>
{
opts.DPoPJsonWebKey = jwk;
});
};
BffHost.InitializeAsync().Wait();

var req = new HttpRequestMessage(HttpMethod.Get, BffHost.Url("/api_client/test"));
req.Headers.Add("x-csrf", "1");
var response = await BffHost.BrowserClient.SendAsync(req);

response.IsSuccessStatusCode.Should().BeTrue();
response.Content.Headers.ContentType.MediaType.Should().Be("application/json");
var json = await response.Content.ReadAsStringAsync();
var apiResult = JsonSerializer.Deserialize<ApiResponse>(json);
apiResult.RequestHeaders["DPoP"].First().Should().NotBeNullOrEmpty();
apiResult.RequestHeaders["Authorization"].First().StartsWith("DPoP ").Should().BeTrue();
}
}
}

0 comments on commit cbc89eb

Please sign in to comment.