using System.Globalization; namespace OI.Metrology.Server.Services; using OI.Metrology.Server.Models; using OI.Metrology.Shared.DataModels; using OI.Metrology.Shared.Models; using OI.Metrology.Shared.Models.Stateless; using OI.Metrology.Shared.Services; using System.Text.Json; public class AttachmentsService : IAttachmentsService { private readonly AppSettings _AppSettings; private readonly IHttpClientFactory _HttpClientFactory; private readonly IFileShareRepository _FileShareRepository; private readonly IMetrologyRepository _MetrologyRepository; public AttachmentsService(AppSettings appSettings, IHttpClientFactory httpClientFactory, IFileShareRepository fileShareRepository, IMetrologyRepository metrologyRepository) { _AppSettings = appSettings; _HttpClientFactory = httpClientFactory; _FileShareRepository = fileShareRepository; _MetrologyRepository = metrologyRepository; } protected Stream GetAttachmentStream(string? tableName, Guid attachmentId, string filename) { if (attachmentId.Equals(Guid.Empty)) throw new Exception("No attachments found"); if (tableName is null) throw new NullReferenceException(nameof(tableName)); DateTime insertDate = Convert.ToDateTime(_MetrologyRepository.GetAttachmentInsertDateByGUID(tableName, attachmentId)); string year = insertDate.Year.ToString(); HttpClient httpClient = _HttpClientFactory.CreateClient(); Uri mesaFileShareMetrologySi = new(_AppSettings.EcMesaFileShareMetrologySi); int weekNum = CultureInfo.CurrentCulture.Calendar.GetWeekOfYear(insertDate, CalendarWeekRule.FirstDay, DayOfWeek.Sunday); Uri uri = _FileShareRepository.Append(mesaFileShareMetrologySi, $"{tableName}_", year, $"WW{weekNum:00}", attachmentId.ToString(), filename); HttpResponseMessage httpResponseMessage = _FileShareRepository.ReadFile(httpClient, uri); if (httpResponseMessage.StatusCode != System.Net.HttpStatusCode.OK) throw new Exception("File not found!"); return httpResponseMessage.Content.ReadAsStream(); } Stream IAttachmentsService.GetAttachmentStreamByTitle(ToolType toolType, bool header, string title, string filename) { if (toolType is null) throw new Exception("Invalid tool type"); Guid attachmentId; string? tableName; if (header) { tableName = toolType.HeaderTableName; attachmentId = _MetrologyRepository.GetHeaderAttachmentIDByTitle(toolType.ID, title); } else { tableName = toolType.DataTableName; attachmentId = _MetrologyRepository.GetDataAttachmentIDByTitle(toolType.ID, title); } return GetAttachmentStream(tableName, attachmentId, filename); } Stream IAttachmentsService.GetAttachmentStreamByAttachmentId(ToolType toolType, bool header, Guid attachmentId, string filename) { if (toolType is null) throw new Exception("Invalid tool type"); string? tableName; if (header) tableName = toolType.HeaderTableName; else tableName = toolType.DataTableName; return GetAttachmentStream(tableName, attachmentId, filename); } private void SaveAttachment(ToolType toolType, long headerId, string dataUniqueId, string filename, IFormFile uploadedFile) { if (toolType is null) throw new Exception("Invalid tool type"); using System.Transactions.TransactionScope trans = _MetrologyRepository.StartTransaction(); Guid attachmentId = Guid.Empty; DateTime insertDate = new(); string? tableName = ""; if (string.IsNullOrWhiteSpace(dataUniqueId)) { attachmentId = _MetrologyRepository.GetHeaderAttachmentID(toolType.ID, headerId); insertDate = Convert.ToDateTime(_MetrologyRepository.GetHeaderInsertDate(toolType.ID, headerId)); tableName = toolType.HeaderTableName; } else { attachmentId = _MetrologyRepository.GetDataAttachmentID(toolType.ID, headerId, dataUniqueId); insertDate = Convert.ToDateTime(_MetrologyRepository.GetDataInsertDate(toolType.ID, headerId, dataUniqueId)); // Get Date for new directory name tableName = toolType.DataTableName; } if (Equals(attachmentId, Guid.Empty)) { trans.Dispose(); throw new Exception("Invalid attachment ID!"); } string year = insertDate.Year.ToString(); HttpClient httpClient = _HttpClientFactory.CreateClient(); Uri mesaFileShareMetrologySi = new(_AppSettings.EcMesaFileShareMetrologySi); int weekNum = CultureInfo.CurrentCulture.Calendar.GetWeekOfYear(insertDate, CalendarWeekRule.FirstDay, DayOfWeek.Sunday); Uri uri = _FileShareRepository.Append(mesaFileShareMetrologySi, $"{tableName}_", year, $"WW{weekNum:00}", attachmentId.ToString(), filename); HttpResponseMessage httpResponseMessage = _FileShareRepository.ReadFile(httpClient, uri); if (httpResponseMessage.StatusCode != System.Net.HttpStatusCode.OK) { trans.Dispose(); throw new Exception("Invalid attachment path!"); } uploadedFile.CopyTo(httpResponseMessage.Content.ReadAsStream()); trans.Complete(); } void IAttachmentsService.SaveAttachment(ToolType toolType, long headerId, string dataUniqueId, string filename, object uploadedFile) { IFormFile formFile = (IFormFile)uploadedFile; SaveAttachment(toolType, headerId, dataUniqueId, filename, formFile); } string? IAttachmentsService.GetProcessDataStandardFormat(IMetrologyRepository metrologyRepository, int toolTypeId, long headerId) { string? result; int weekNum; string year; Task json; Uri weekDirectory; Uri checkDirectory; List files = new(); NginxFileSystem[]? nginxFileSystemCollection; Task httpResponseMessage; HttpClient httpClient = _HttpClientFactory.CreateClient(); Uri mesaFileShareMetrologySi = new(_AppSettings.EcMesaFileShareMetrologySi); DateTime[] dateTimes = new DateTime[] { DateTime.Now, DateTime.Now.AddDays(-6.66) }; ToolType toolType = metrologyRepository.GetToolTypeByID(toolTypeId) ?? throw new Exception("Invalid tool type ID"); foreach (DateTime dateTime in dateTimes) { year = dateTime.Year.ToString(); weekNum = CultureInfo.CurrentCulture.Calendar.GetWeekOfYear(dateTime, CalendarWeekRule.FirstDay, DayOfWeek.Sunday); weekDirectory = _FileShareRepository.Append(mesaFileShareMetrologySi, $"{toolType.HeaderTableName}_", year, $"WW{weekNum:00}"); checkDirectory = _FileShareRepository.Append(weekDirectory, headerId.ToString()); httpResponseMessage = httpClient.GetAsync(checkDirectory); httpResponseMessage.Wait(); if (httpResponseMessage.Result.StatusCode != System.Net.HttpStatusCode.OK) continue; json = httpResponseMessage.Result.Content.ReadAsStringAsync(); json.Wait(); nginxFileSystemCollection = JsonSerializer.Deserialize(json.Result, NginxFileSystemCollectionSourceGenerationContext.Default.NginxFileSystemArray); if (nginxFileSystemCollection is null) continue; foreach (NginxFileSystem nginxFileSystem in nginxFileSystemCollection) files.Add(_FileShareRepository.Append(checkDirectory, nginxFileSystem.Name).AbsoluteUri); if (files.Count != 0) break; } result = files.Count == 0 ? null : files.First(); return result; } }