using Core.Blueprint.Application.UsesCases.SQL.Input; using Core.Blueprint.Application.UsesCases.SQL.Ports; using Core.Blueprint.Service.External.Clients; using Core.Blueprint.Service.External.Clients.Adapters; using Core.Blueprint.Service.External.Clients.Requests; using FluentValidation; using Lib.Architecture.BuildingBlocks; using Lib.Architecture.BuildingBlocks.Helpers; namespace Core.Blueprint.Application.UsesCases.SQL { public class SQLHandler : IComponentHandler, IComponentHandler, IComponentHandler, IComponentHandler, IComponentHandler { private readonly ISQLPort _port; private readonly IValidator _createSampleValidator; private readonly IValidator _getSampleValidator; private readonly IValidator _updateSampleValidator; private readonly IValidator _deleteSampleValidator; private readonly IBlueprintServiceClient _SQLDALService; public SQLHandler( ISQLPort port, IValidator createSampleValidator, IValidator getSampleValidator, IValidator updateSampleValidator, IValidator deleteSampleValidator, IBlueprintServiceClient SQLDALService) { _port = port ?? throw new ArgumentNullException(nameof(port)); _createSampleValidator = createSampleValidator ?? throw new ArgumentNullException(nameof(createSampleValidator)); _getSampleValidator = getSampleValidator ?? throw new ArgumentNullException(nameof(getSampleValidator)); _updateSampleValidator = updateSampleValidator ?? throw new ArgumentNullException(nameof(updateSampleValidator)); _deleteSampleValidator = deleteSampleValidator ?? throw new ArgumentNullException(nameof(deleteSampleValidator)); _SQLDALService = SQLDALService ?? throw new ArgumentNullException(nameof(SQLDALService)); } public async ValueTask ExecuteAsync(CreateSqlSampleRequest command, CancellationToken cancellationToken = default) { try { ArgumentNullException.ThrowIfNull(command); if (!command.IsValid(_createSampleValidator)) { _port.ValidationErrors(command.Notifications); return; } var request = new SqlSampleRequest { Name = command.Name, Description = command.Description, }; var result = await _SQLDALService.CreateSqlSampleAsync(request, cancellationToken).ConfigureAwait(false); if (result == null) { _port.NoContentSuccess(); return; } _port.Success(result); } catch (Exception ex) { ApiResponseHelper.EvaluatePort(ex, _port); } } public async ValueTask ExecuteAsync(GetAllSqlSamplesRequest command, CancellationToken cancellationToken = default) { try { ArgumentNullException.ThrowIfNull(command); var _result = await _SQLDALService.GetAllSqlSamplesAsync().ConfigureAwait(false); if (!_result.Any()) { _port.NoContentSuccess(); return; } _port.Success(_result.ToList()); } catch (Exception ex) { ApiResponseHelper.EvaluatePort(ex, _port); } } public async ValueTask ExecuteAsync(GetSqlSampleRequest command, CancellationToken cancellationToken = default) { try { ArgumentNullException.ThrowIfNull(command); if (!command.IsValid(_getSampleValidator)) { _port.ValidationErrors(command.Notifications); return; } var result = await _SQLDALService.GetSqlSampleByIdAsync(command.Id, cancellationToken).ConfigureAwait(false); if (result == null) { _port.NoContentSuccess(); return; } _port.Success(result); } catch (Exception ex) { ApiResponseHelper.EvaluatePort(ex, _port); } } public async ValueTask ExecuteAsync(UpdateSqlSampleRequest command, CancellationToken cancellationToken = default) { try { ArgumentNullException.ThrowIfNull(command); if (!command.IsValid(_updateSampleValidator)) { _port.ValidationErrors(command.Notifications); return; } var request = new SqlSampleAdapter { Id = command.Id, Guid = command.Guid, ProjectCode = command.Name, ProjectDescription = command.Description, CreatedAt = command.CreatedAt, CreatedBy = command.CreatedBy, UpdatedAt = command.UpdatedAt, UpdatedBy = command.UpdatedBy, Status = command.Status }; int id = command.Id; var result = await _SQLDALService.UpdateSqlSampleAsync(id, request, cancellationToken).ConfigureAwait(false); if (result == null) { _port.NoContentSuccess(); return; } _port.Success(result); } catch (Exception ex) { ApiResponseHelper.EvaluatePort(ex, _port); } } public async ValueTask ExecuteAsync(DeleteSqlSampleRequest command, CancellationToken cancellationToken = default) { try { ArgumentNullException.ThrowIfNull(command); if (!command.IsValid(_deleteSampleValidator)) { _port.ValidationErrors(command.Notifications); return; } var result = await _SQLDALService.DeleteSqlSampleAsync(command.Id, cancellationToken).ConfigureAwait(false); if (result == null) { _port.NoContentSuccess(); return; } _port.Success(result); } catch (Exception ex) { ApiResponseHelper.EvaluatePort(ex, _port); } } } }