using System; using Expedience.Infrastructure; using Expedience.Infrastructure.Models; using MassTransit; namespace Expedience.Api.Consumers { public class DutyCompletionResultConsumer : IConsumer { private readonly ILogger _logger; private readonly IServiceScopeFactory _serviceScopeFactory; public DutyCompletionResultConsumer(ILogger logger, IServiceScopeFactory serviceScopeFactory) { _logger = logger; _serviceScopeFactory = serviceScopeFactory; } public async Task Consume(ConsumeContext context) { var message = context.Message; using var scope = _serviceScopeFactory.CreateScope(); var dbContext = scope.ServiceProvider.GetRequiredService(); if (message == null || message.UserInfo == null || message.PlayerInfo == null || message.DutyInfo == null || message.ClientInfo == null || message.CompletionTimeInfo == null) { // TODO: Log error return; } var userHash = message.UserInfo.UserId; var worldId = message.UserInfo.WorldId; var user = dbContext.Users.FirstOrDefault(x => x.UserHash == userHash && x.WorldId == worldId); if (user == null) { string userName; do { userName = UserNameGenerator.Generate(); } while (dbContext.Users.Any(x => x.UserName == userName && x.WorldId == worldId)); user = new User { UserHash = userHash, WorldId = worldId, UserName = userName, CreatedAt = DateTime.UtcNow, }; dbContext.Users.Add(user); dbContext.SaveChanges(); } var completionResult = new DutyCompletionResult { Id = message.UploadId, DutyId = message.DutyInfo.DutyId, UserId = user.UserId, HasEcho = message.DutyInfo.HasEcho, IsUnrestricted = message.DutyInfo.IsUnrestricted, IsMinILevel = message.DutyInfo.IsMinILevel, HasNpcMembers = message.DutyInfo.IsNpcSupported, StartTime = message.DutyStartDateUtc, EndTime = message.DutyCompletionDateUtc, Hours = message.CompletionTimeInfo.Hours, Minutes = message.CompletionTimeInfo.Minutes, Seconds = message.CompletionTimeInfo.Seconds, Milliseconds = message.CompletionTimeInfo.Milliseconds, GameVersion = message.ClientInfo.GameVersion, PluginVersion = message.ClientInfo.PluginVersion, Lang = message.ClientInfo.GameLanguage, DataCenter = message.DataCenter, }; dbContext.DutyCompletionResults.Add(completionResult); var memberNumber = 0; var dutyMembers = new List(); foreach (var member in message.GroupMembers) { var dutyMember = new DutyMember { UploadId = message.UploadId, GroupNumber = member.GroupNumber, MemberNumber = memberNumber++, ClassJob = member.ClassJob, Level = member.Level, IsNpc = member.IsNpc, IsPlayer = member.IsPlayer, }; dutyMembers.Add(dutyMember); } dbContext.DutyMembers.AddRange(dutyMembers); await dbContext.SaveChangesAsync(); _logger.LogInformation("Consumed message {uploadId} from user {userId}", message.UploadId, userHash); } } }