feat: 支付模块支持tenantId可选过滤

This commit is contained in:
2026-01-29 13:11:09 +00:00
parent 63b05da39a
commit a035334c94
9 changed files with 103 additions and 47 deletions

View File

@@ -3,7 +3,6 @@ using TakeoutSaaS.Application.App.Payments.Dto;
using TakeoutSaaS.Application.App.Payments.Queries;
using TakeoutSaaS.Domain.Payments.Repositories;
using TakeoutSaaS.Shared.Abstractions.Results;
using TakeoutSaaS.Shared.Abstractions.Tenancy;
namespace TakeoutSaaS.Application.App.Payments.Handlers;
@@ -11,30 +10,29 @@ namespace TakeoutSaaS.Application.App.Payments.Handlers;
/// 支付记录列表查询处理器。
/// </summary>
public sealed class SearchPaymentsQueryHandler(
IPaymentRepository paymentRepository,
ITenantProvider tenantProvider)
IPaymentRepository paymentRepository)
: IRequestHandler<SearchPaymentsQuery, PagedResult<PaymentDto>>
{
private readonly IPaymentRepository _paymentRepository = paymentRepository;
private readonly ITenantProvider _tenantProvider = tenantProvider;
/// <inheritdoc />
public async Task<PagedResult<PaymentDto>> Handle(SearchPaymentsQuery request, CancellationToken cancellationToken)
{
var tenantId = _tenantProvider.GetCurrentTenantId();
var payments = await _paymentRepository.SearchAsync(tenantId, request.Status, cancellationToken);
// 1. 查询支付记录(可选租户过滤)
var payments = await paymentRepository.SearchAsync(request.TenantId, request.Status, cancellationToken);
// 2. (空行后) 可选过滤:订单
if (request.OrderId.HasValue)
{
payments = payments.Where(x => x.OrderId == request.OrderId.Value).ToList();
}
// 3. (空行后) 排序与分页
var sorted = ApplySorting(payments, request.SortBy, request.SortDescending);
var paged = sorted
.Skip((request.Page - 1) * request.PageSize)
.Take(request.PageSize)
.ToList();
// 4. (空行后) 映射 DTO 并返回分页结果
var items = paged.Select(payment => new PaymentDto
{
Id = payment.Id,