1
0
mirror of synced 2025-01-05 17:34:22 +01:00
GC-local-server-rewrite/Application/Game/Card/Write/WriteCardDetailCommand.cs

38 lines
1.5 KiB
C#
Raw Normal View History

2023-02-16 09:53:02 +01:00
using Domain.Enums;
using Microsoft.Extensions.Logging;
namespace Application.Game.Card.Write;
public record WriteCardDetailCommand(long CardId, string TenpoId, string Data) : IRequestWrapper<string>;
2023-02-16 17:38:01 +01:00
public class WriteDetailCommandHandler : RequestHandlerBase<WriteCardDetailCommand, string>
{
2023-02-16 17:38:01 +01:00
private readonly ILogger<WriteDetailCommandHandler> logger;
2023-02-16 17:38:01 +01:00
public WriteDetailCommandHandler(ICardDependencyAggregate aggregate, ILogger<WriteDetailCommandHandler> logger) : base(aggregate)
{
this.logger = logger;
}
public override async Task<ServiceResult<string>> Handle(WriteCardDetailCommand request, CancellationToken cancellationToken)
{
var exists = await CardDbContext.CardMains.AnyAsync(card => card.CardId == request.CardId, cancellationToken: cancellationToken);
if (!exists)
{
logger.LogWarning("Card id: {CardId} does not exist!", request.CardId);
return ServiceResult.Failed<string>(
new ServiceError($"Card id: {request.CardId} does not exist!", (int)CardReturnCode.CardNotRegistered));
}
var dto = request.Data.DeserializeCardData<CardDetailDto>();
var detail = dto.DtoToCardDetail();
detail.CardId = request.CardId;
detail.LastPlayTime = DateTime.Now;
detail.LastPlayTenpoId = request.TenpoId;
await CardDbContext.CardDetails.Upsert(detail).RunAsync(cancellationToken);
await CardDbContext.SaveChangesAsync(cancellationToken);
return new ServiceResult<string>(request.Data);
}
}