using System.Collections.Generic; using System.Linq; using System.Threading.Tasks; using Marechai.Database.Models; using Marechai.ViewModels; using Microsoft.EntityFrameworkCore; using Microsoft.Extensions.Localization; namespace Marechai.Services { public class MachinesService { readonly MarechaiContext _context; readonly GpusService _gpusService; readonly IStringLocalizer _l; readonly ProcessorsService _processorsService; readonly SoundSynthsService _soundSynthsService; public MachinesService(MarechaiContext context, IStringLocalizer localizer, GpusService gpusService, ProcessorsService processorsService, SoundSynthsService soundSynthsService) { _context = context; _l = localizer; _gpusService = gpusService; _processorsService = processorsService; _soundSynthsService = soundSynthsService; } public async Task> GetAsync() => await _context.Machines.OrderBy(m => m.Company.Name).ThenBy(m => m.Name).ThenBy(m => m.Family.Name). Select(m => new MachineViewModel { Id = m.Id, Company = m.Company.Name, Name = m.Name, Model = m.Model, Introduced = m.Introduced, Type = m.Type, Family = m.Family.Name }).ToListAsync(); public async Task GetMachine(int id) { Machine machine = await _context.Machines.FindAsync(id); if(machine is null) return null; var model = new MachineViewModel { Introduced = machine.Introduced, Name = machine.Name, CompanyId = machine.CompanyId, Model = machine.Model }; Company company = await _context.Companies.FindAsync(model.CompanyId); if(company != null) { model.CompanyName = company.Name; IQueryable logos = _context.CompanyLogos.Where(l => l.CompanyId == company.Id); if(model.Introduced.HasValue) model.CompanyLogo = (await logos.FirstOrDefaultAsync(l => l.Year >= model.Introduced.Value.Year))?. Guid; if(model.CompanyLogo is null && logos.Any()) model.CompanyLogo = (await logos.FirstAsync())?.Guid; } MachineFamily family = await _context.MachineFamilies.FindAsync(machine.FamilyId); if(family != null) { model.FamilyName = family.Name; model.FamilyId = family.Id; } model.Gpus = await _gpusService.GetByMachineAsync(machine.Id); model.Memory = await _context.MemoryByMachine.Where(m => m.MachineId == machine.Id). Select(m => new MemoryViewModel { Type = m.Type, Usage = m.Usage, Size = m.Size, Speed = m.Speed }).ToListAsync(); model.Processors = await _processorsService.GetByMachineAsync(machine.Id); model.SoundSynthesizers = await _soundSynthsService.GetByMachineAsync(machine.Id); model.Storage = await _context.StorageByMachine.Where(s => s.MachineId == machine.Id). Select(s => new StorageViewModel { Type = s.Type, Interface = s.Interface, Capacity = s.Capacity }).ToListAsync(); return model; } } }