| | | 1 | | using MechanicsSoftware.Application.Abstractions; |
| | | 2 | | using MechanicsSoftware.Application.UseCases.Vehicles.Queries; |
| | | 3 | | using MechanicsSoftware.Domain.Entities; |
| | | 4 | | using MechanicsSoftware.Domain.ValueObjects; |
| | | 5 | | using Microsoft.EntityFrameworkCore; |
| | | 6 | | |
| | | 7 | | namespace MechanicsSoftware.Application.UseCases.Vehicles.Handlers; |
| | | 8 | | |
| | 8 | 9 | | public sealed class ListVehiclesHandler(IAppDbContext db) |
| | | 10 | | { |
| | | 11 | | public async Task<IReadOnlyList<VehicleResponse>> ExecuteAsync( |
| | | 12 | | ListVehiclesQuery query, |
| | | 13 | | CancellationToken cancellationToken = default) |
| | 8 | 14 | | { |
| | 8 | 15 | | IQueryable<Vehicle> vehicles = db.Vehicles; |
| | | 16 | | |
| | 8 | 17 | | if (query.CustomerId.HasValue) |
| | 2 | 18 | | vehicles = vehicles.Where(v => v.CustomerId == query.CustomerId.Value); |
| | | 19 | | |
| | 8 | 20 | | if (!string.IsNullOrWhiteSpace(query.LicensePlate)) |
| | 2 | 21 | | { |
| | 2 | 22 | | var plateVo = new LicensePlate(query.LicensePlate); |
| | 2 | 23 | | vehicles = vehicles.Where(v => v.LicensePlate == plateVo); |
| | 2 | 24 | | } |
| | | 25 | | |
| | 8 | 26 | | return await vehicles |
| | 8 | 27 | | .Select(v => VehicleResponse.From(v)) |
| | 8 | 28 | | .ToListAsync(cancellationToken); |
| | 8 | 29 | | } |
| | | 30 | | } |