0
0
mirror of https://github.com/alex289/CleanArchitecture.git synced 2025-06-29 18:21:08 +00:00
CleanArchitecture/CleanArchitecture.Application/Queries/Users/GetAll/GetAllUsersQueryHandler.cs
2024-12-08 22:51:08 +01:00

59 lines
2.2 KiB
C#

using System.Linq;
using System.Threading;
using System.Threading.Tasks;
using CleanArchitecture.Application.Extensions;
using CleanArchitecture.Application.ViewModels;
using CleanArchitecture.Application.ViewModels.Sorting;
using CleanArchitecture.Application.ViewModels.Users;
using CleanArchitecture.Domain.Entities;
using CleanArchitecture.Domain.Interfaces.Repositories;
using MediatR;
using Microsoft.EntityFrameworkCore;
namespace CleanArchitecture.Application.Queries.Users.GetAll;
public sealed class GetAllUsersQueryHandler :
IRequestHandler<GetAllUsersQuery, PagedResult<UserViewModel>>
{
private readonly ISortingExpressionProvider<UserViewModel, User> _sortingExpressionProvider;
private readonly IUserRepository _userRepository;
public GetAllUsersQueryHandler(
IUserRepository userRepository,
ISortingExpressionProvider<UserViewModel, User> sortingExpressionProvider)
{
_userRepository = userRepository;
_sortingExpressionProvider = sortingExpressionProvider;
}
public async Task<PagedResult<UserViewModel>> Handle(
GetAllUsersQuery request,
CancellationToken cancellationToken)
{
var usersQuery = _userRepository
.GetAllNoTracking()
.IgnoreQueryFilters()
.Where(x => request.IncludeDeleted || x.DeletedAt == null);
if (!string.IsNullOrWhiteSpace(request.SearchTerm))
{
usersQuery = usersQuery.Where(user =>
user.Email.Contains(request.SearchTerm) ||
user.FirstName.Contains(request.SearchTerm) ||
user.LastName.Contains(request.SearchTerm));
}
var totalCount = await usersQuery.CountAsync(cancellationToken);
usersQuery = usersQuery.GetOrderedQueryable(request.SortQuery, _sortingExpressionProvider);
var users = await usersQuery
.Skip((request.Query.Page - 1) * request.Query.PageSize)
.Take(request.Query.PageSize)
.Select(user => UserViewModel.FromUser(user))
.ToListAsync(cancellationToken);
return new PagedResult<UserViewModel>(
totalCount, users, request.Query.Page, request.Query.PageSize);
}
}