2026-04-16 18:53:57 -03:00
|
|
|
using System.Transactions;
|
|
|
|
|
using SIGCM2.Application.Abstractions;
|
|
|
|
|
using SIGCM2.Application.Abstractions.Persistence;
|
|
|
|
|
using SIGCM2.Application.Audit;
|
|
|
|
|
using SIGCM2.Domain.Entities;
|
|
|
|
|
using SIGCM2.Domain.Exceptions;
|
|
|
|
|
|
|
|
|
|
namespace SIGCM2.Application.Medios.Deactivate;
|
|
|
|
|
|
|
|
|
|
public sealed class DeactivateMedioCommandHandler : ICommandHandler<DeactivateMedioCommand, MedioStatusDto>
|
|
|
|
|
{
|
|
|
|
|
private readonly IMedioRepository _repo;
|
|
|
|
|
private readonly IAuditLogger _audit;
|
2026-04-18 10:12:17 -03:00
|
|
|
private readonly TimeProvider _timeProvider;
|
2026-04-16 18:53:57 -03:00
|
|
|
|
2026-04-18 10:12:17 -03:00
|
|
|
public DeactivateMedioCommandHandler(IMedioRepository repo, IAuditLogger audit, TimeProvider timeProvider)
|
2026-04-16 18:53:57 -03:00
|
|
|
{
|
|
|
|
|
_repo = repo;
|
|
|
|
|
_audit = audit;
|
2026-04-18 10:12:17 -03:00
|
|
|
_timeProvider = timeProvider;
|
2026-04-16 18:53:57 -03:00
|
|
|
}
|
|
|
|
|
|
|
|
|
|
public async Task<MedioStatusDto> Handle(DeactivateMedioCommand command)
|
|
|
|
|
{
|
|
|
|
|
var target = await _repo.GetByIdAsync(command.Id)
|
|
|
|
|
?? throw new MedioNotFoundException(command.Id);
|
|
|
|
|
|
|
|
|
|
// Idempotent: already inactive → return as-is without writing an audit event
|
|
|
|
|
if (!target.Activo)
|
|
|
|
|
return new MedioStatusDto(target.Id, target.Codigo, target.Activo);
|
|
|
|
|
|
2026-04-18 10:12:17 -03:00
|
|
|
var now = _timeProvider.GetUtcNow().UtcDateTime;
|
|
|
|
|
var updated = target.WithActivo(false, now);
|
2026-04-16 18:53:57 -03:00
|
|
|
|
|
|
|
|
using var tx = new TransactionScope(
|
|
|
|
|
TransactionScopeOption.Required,
|
|
|
|
|
new TransactionOptions { IsolationLevel = System.Transactions.IsolationLevel.ReadCommitted },
|
|
|
|
|
TransactionScopeAsyncFlowOption.Enabled);
|
|
|
|
|
|
|
|
|
|
await _repo.UpdateAsync(updated);
|
|
|
|
|
|
|
|
|
|
await _audit.LogAsync(
|
|
|
|
|
action: "medio.deactivate",
|
|
|
|
|
targetType: "Medio",
|
|
|
|
|
targetId: command.Id.ToString());
|
|
|
|
|
|
|
|
|
|
tx.Complete();
|
|
|
|
|
|
|
|
|
|
return new MedioStatusDto(updated.Id, updated.Codigo, updated.Activo);
|
|
|
|
|
}
|
|
|
|
|
}
|