using MediatR; using Sledgemapper.Api.Infrastructure.Data; using Sledgemapper.Api.Commands; using Sledgemapper.Api.Notifications; using Sledgemapper.Shared.Entities; using System.Linq; using System.Text.Json; using System.Threading; using System.Threading.Tasks; namespace Sledgemapper.Api.Handlers { public class DeleteWallCommandHandler : IRequestHandler { private readonly SledgemapperDbContext _dbcontext; private readonly IMediator _mediator; public DeleteWallCommandHandler(IMediator mediator, SledgemapperDbContext dbcontext) { _dbcontext = dbcontext; _mediator = mediator; } public async Task Handle(DeleteWallCommand notification, CancellationToken cancellationToken) { var jsonString = JsonSerializer.Serialize(notification.Wall); var session = _dbcontext.Sessions.First(m => m.SessionName == notification.SessionName); _dbcontext.MapLogs.Add(new Sledgemapper.Api.Models.MapLog { Operation = "D", SessionId = session.SessionId, Type = "W", Timestamp = notification.Timestamp, Object = jsonString, UserId = notification.UserId }); await _dbcontext.SaveChangesAsync(); await _mediator.Publish(new DeleteWallNotification(session, notification.Wall, notification.UserId)); return true; } } }