Compare commits

..

3 Commits

Author SHA1 Message Date
khwezi 851ca72b46 Merge pull request 'payments' (#4) from payments into master
Reviewed-on: #4
2026-06-02 00:33:11 +02:00
Khwezi Mngoma 27418322f4 Stable run
continuous-integration/drone/pr Build is passing
2026-06-02 00:31:36 +02:00
Khwezi Mngoma 99a307527a Fixed return bug
Added quartz job
Added otel exports
2026-06-01 23:11:25 +02:00
2 changed files with 20 additions and 8 deletions
+3 -2
View File
@@ -53,13 +53,13 @@
</ItemGroup>
<ItemGroup>
<PackageReference Include="LiteCharms.Features" Version="1.61.0" />
<PackageReference Include="LiteCharms.Features" Version="1.64.0" />
</ItemGroup>
<!-- UI -->
<ItemGroup>
<PackageReference Include="ANM.Blazored.Toast" Version="0.1.1" />
<PackageReference Include="LiteCharms.Features.MidrandBooks" Version="1.61.0" />
<PackageReference Include="LiteCharms.Features.MidrandBooks" Version="1.64.0" />
<!-- Global Usings -->
<Using Include="Blazored.Toast.Services" />
@@ -85,6 +85,7 @@
<!-- Shared Global Usings -->
<ItemGroup>
<Using Include="System.Diagnostics" />
<Using Include="System.Reflection" />
<Using Include="Microsoft.Extensions.DependencyInjection.Extensions" />
</ItemGroup>
@@ -1,17 +1,24 @@
using LiteCharms.Features.Extensions;
using LiteCharms.Features.Hasher;
using LiteCharms.Features.Hasher;
using LiteCharms.Features.MidrandBooks.Payments.Events;
using LiteCharms.Features.Models;
using LiteCharms.Features.Quartz.Abstractions;
namespace MidrandBooksApi.Payments.Endpoints;
[ApiVersionTarget(1)]
public sealed class ConfirmationEndpoint : IEndpoint
{
private static readonly ActivitySource PaymentActivitySource = new("MidrandBooksApi.Payments");
public void Map(IEndpointRouteBuilder builder)
{
builder.MapPost("payments/confirm", async (HttpRequest request, HashService hashService,
CancellationToken cancellationToken) =>
IJobOrchestrator jobOrchestrator, CancellationToken cancellationToken) =>
{
using Activity? activity = PaymentActivitySource.StartActivity("ReceivePayfastWebhook", ActivityKind.Server);
activity?.SetTag("messaging.system", "payfast");
activity?.SetTag("messaging.destination.name", "payments/confirm");
var formCollection = await request.ReadFormAsync(cancellationToken);
if (!formCollection.TryGetValue("signature", out var signatureValues) || string.IsNullOrWhiteSpace(signatureValues.ToString()))
@@ -28,9 +35,13 @@ public sealed class ConfirmationEndpoint : IEndpoint
var validationResult = hashService.VerifyPayfastWebhookSignature(payload, incomingSignature);
return validationResult.IsFailed || !validationResult.Value
? Results.Unauthorized()
: Results.Ok();
if (validationResult.IsFailed || !validationResult.Value) return Results.Unauthorized();
await jobOrchestrator.SendAsync(PayfastPaymentConfirmationReceivedEvent.Create(payload, payload.MPaymentId!), cancellationToken);
activity?.SetStatus(ActivityStatusCode.Ok);
return Results.Ok();
})
.WithDescription("Securely confirm and process an incoming Payfast merchant payment callback.")
.WithName(typeof(ConfirmationEndpoint).ToEndpointName())