Generator Changes at 11/12/2025 1:32:03 AM +03:30

This commit is contained in:
masoodafar-web
2025-11-12 02:24:02 +03:30
parent 826ae4589f
commit b27c765731
290 changed files with 30811 additions and 21316 deletions

View File

@@ -0,0 +1,21 @@
namespace CMSMicroservice.Application.UserCartsCQ.Queries.GetAllUserCartsByFilter;
public record GetAllUserCartsByFilterQuery : IRequest<GetAllUserCartsByFilterResponseDto>
{
//موقعیت صفحه بندی
public PaginationState? PaginationState { get; init; }
//مرتب سازی بر اساس
public string? SortBy { get; init; }
//فیلتر
public GetAllUserCartsByFilterFilter? Filter { get; init; }
}public class GetAllUserCartsByFilterFilter
{
//
public long? Id { get; set; }
//
public long? ProductId { get; set; }
//
public long? UserId { get; set; }
//
public int? Count { get; set; }
}

View File

@@ -0,0 +1,33 @@
namespace CMSMicroservice.Application.UserCartsCQ.Queries.GetAllUserCartsByFilter;
public class GetAllUserCartsByFilterQueryHandler : IRequestHandler<GetAllUserCartsByFilterQuery, GetAllUserCartsByFilterResponseDto>
{
private readonly IApplicationDbContext _context;
public GetAllUserCartsByFilterQueryHandler(IApplicationDbContext context)
{
_context = context;
}
public async Task<GetAllUserCartsByFilterResponseDto> Handle(GetAllUserCartsByFilterQuery request, CancellationToken cancellationToken)
{
var query = _context.UserCartss
.ApplyOrder(sortBy: request.SortBy)
.AsNoTracking()
.AsQueryable();
if (request.Filter is not null)
{
query = query
.Where(x => request.Filter.Id == null || x.Id == request.Filter.Id)
.Where(x => request.Filter.ProductId == null || x.ProductId == request.Filter.ProductId)
.Where(x => request.Filter.UserId == null || x.UserId == request.Filter.UserId)
.Where(x => request.Filter.Count == null || x.Count == request.Filter.Count)
;
}
return new GetAllUserCartsByFilterResponseDto
{
MetaData = await query.GetMetaData(request.PaginationState, cancellationToken),
Models = await query.PaginatedListAsync(paginationState: request.PaginationState)
.ProjectToType<GetAllUserCartsByFilterResponseModel>().ToListAsync(cancellationToken)
};
}
}

View File

@@ -0,0 +1,14 @@
namespace CMSMicroservice.Application.UserCartsCQ.Queries.GetAllUserCartsByFilter;
public class GetAllUserCartsByFilterQueryValidator : AbstractValidator<GetAllUserCartsByFilterQuery>
{
public GetAllUserCartsByFilterQueryValidator()
{
}
public Func<object, string, Task<IEnumerable<string>>> ValidateValue => async (model, propertyName) =>
{
var result = await ValidateAsync(ValidationContext<GetAllUserCartsByFilterQuery>.CreateWithOptions((GetAllUserCartsByFilterQuery)model, x => x.IncludeProperties(propertyName)));
if (result.IsValid)
return Array.Empty<string>();
return result.Errors.Select(e => e.ErrorMessage);
};
}

View File

@@ -0,0 +1,19 @@
namespace CMSMicroservice.Application.UserCartsCQ.Queries.GetAllUserCartsByFilter;
public class GetAllUserCartsByFilterResponseDto
{
//متادیتا
public MetaData MetaData { get; set; }
//مدل خروجی
public List<GetAllUserCartsByFilterResponseModel>? Models { get; set; }
}public class GetAllUserCartsByFilterResponseModel
{
//
public long Id { get; set; }
//
public long ProductId { get; set; }
//
public long UserId { get; set; }
//
public int Count { get; set; }
}

View File

@@ -0,0 +1,7 @@
namespace CMSMicroservice.Application.UserCartsCQ.Queries.GetUserCarts;
public record GetUserCartsQuery : IRequest<GetUserCartsResponseDto>
{
//
public long Id { get; init; }
}

View File

@@ -0,0 +1,22 @@
namespace CMSMicroservice.Application.UserCartsCQ.Queries.GetUserCarts;
public class GetUserCartsQueryHandler : IRequestHandler<GetUserCartsQuery, GetUserCartsResponseDto>
{
private readonly IApplicationDbContext _context;
public GetUserCartsQueryHandler(IApplicationDbContext context)
{
_context = context;
}
public async Task<GetUserCartsResponseDto> Handle(GetUserCartsQuery request,
CancellationToken cancellationToken)
{
var response = await _context.UserCartss
.AsNoTracking()
.Where(x => x.Id == request.Id)
.ProjectToType<GetUserCartsResponseDto>()
.FirstOrDefaultAsync(cancellationToken);
return response ?? throw new NotFoundException(nameof(UserCarts), request.Id);
}
}

View File

@@ -0,0 +1,16 @@
namespace CMSMicroservice.Application.UserCartsCQ.Queries.GetUserCarts;
public class GetUserCartsQueryValidator : AbstractValidator<GetUserCartsQuery>
{
public GetUserCartsQueryValidator()
{
RuleFor(model => model.Id)
.NotNull();
}
public Func<object, string, Task<IEnumerable<string>>> ValidateValue => async (model, propertyName) =>
{
var result = await ValidateAsync(ValidationContext<GetUserCartsQuery>.CreateWithOptions((GetUserCartsQuery)model, x => x.IncludeProperties(propertyName)));
if (result.IsValid)
return Array.Empty<string>();
return result.Errors.Select(e => e.ErrorMessage);
};
}

View File

@@ -0,0 +1,13 @@
namespace CMSMicroservice.Application.UserCartsCQ.Queries.GetUserCarts;
public class GetUserCartsResponseDto
{
//
public long Id { get; set; }
//
public long ProductId { get; set; }
//
public long UserId { get; set; }
//
public int Count { get; set; }
}