using AutoMapper; using DamageAssesment.Api.Surveys.Db; using DamageAssesment.Api.Surveys.Interfaces; using DamageAssesment.Api.Surveys.Models; using Microsoft.EntityFrameworkCore; using System.Collections.Generic; namespace DamageAssesment.Api.Surveys.Providers { public class SurveysProvider : ISurveyProvider { private readonly SurveysDbContext surveyDbContext; private readonly ILogger logger; private readonly IMapper mapper; public SurveysProvider(SurveysDbContext surveysDbContext, ILogger logger, IMapper mapper) { this.surveyDbContext = surveysDbContext; this.logger = logger; this.mapper = mapper; seedData(); } private void seedData() { if (!surveyDbContext.Surveys.Any()) { surveyDbContext.Surveys.Add(new Db.Survey { Id = 1, IsEnabled = true, StartDate = DateTime.Now, EndDate = DateTime.Now.AddDays(90), CreatedDate = DateTime.Now }); surveyDbContext.Surveys.Add(new Db.Survey { Id = 2, IsEnabled = true, StartDate = DateTime.Now, EndDate = DateTime.Now.AddDays(90), CreatedDate = DateTime.Now }); surveyDbContext.Surveys.Add(new Db.Survey { Id = 3, IsEnabled = true, StartDate = DateTime.Now, EndDate = DateTime.Now.AddDays(90), CreatedDate = DateTime.Now }); surveyDbContext.SaveChangesAsync(); } if (!surveyDbContext.SurveysTranslation.Any()) { surveyDbContext.SurveysTranslation.Add(new Db.SurveyTranslation { Id = 1, SurveyId = 1, Language = "en", Title = "Impact of Tropical Storm Emily on Florida's Economy" }); surveyDbContext.SurveysTranslation.Add(new Db.SurveyTranslation { Id = 2, SurveyId = 1, Language = "es", Title = "Impacto de la tormenta tropical Emily en la economía de Florida" }); surveyDbContext.SurveysTranslation.Add(new Db.SurveyTranslation { Id = 3, SurveyId = 1, Language = "fr", Title = "Impact de la tempête tropicale Emily sur l'économie de la Floride" }); surveyDbContext.SurveysTranslation.Add(new Db.SurveyTranslation { Id = 4, SurveyId = 2, Language = "en", Title = "Hurricane Andrew Aftermath Survey" }); surveyDbContext.SurveysTranslation.Add(new Db.SurveyTranslation { Id = 5, SurveyId = 2, Language = "es", Title = "Encuesta sobre las secuelas del huracán Andrew" }); surveyDbContext.SurveysTranslation.Add(new Db.SurveyTranslation { Id = 6, SurveyId = 2, Language = "fr", Title = "Enquête sur les conséquences de l'ouragan Andrew" }); surveyDbContext.SurveysTranslation.Add(new Db.SurveyTranslation { Id = 7, SurveyId = 3, Language = "en", Title = "Public Perception of Hurricane Michael's Response" }); surveyDbContext.SurveysTranslation.Add(new Db.SurveyTranslation { Id = 8, SurveyId = 3, Language = "es", Title = "Percepción pública de la respuesta del huracán Michael" }); surveyDbContext.SurveysTranslation.Add(new Db.SurveyTranslation { Id = 9, SurveyId = 3, Language = "fr", Title = "Perception du public de la réponse de l'ouragan Michael" }); surveyDbContext.SaveChangesAsync(); } } public async Task<(bool IsSuccess, IEnumerable Surveys, string ErrorMessage)> GetSurveysAsync(string Language) { IEnumerable surveysList = null; try { logger?.LogInformation("Gell all Surveys from DB"); var surveys = await surveyDbContext.Surveys.Where(s => s.IsEnabled == true).ToListAsync(); var surveyTranslations = await surveyDbContext.SurveysTranslation.ToListAsync(); if (surveys != null) { if (string.IsNullOrEmpty(Language)) { surveysList = from s in surveys select new Models.Survey { Id = s.Id, StartDate = s.StartDate, EndDate = s.EndDate, IsEnabled = s.IsEnabled, CreatedDate = s.CreatedDate, Titles = from t in surveyTranslations where t.SurveyId == s.Id select new Models.SurveyTranslation { Title = t.Title, Language = t.Language } }; } else { surveysList = from s in surveys select new Models.Survey { Id = s.Id, StartDate = s.StartDate, EndDate = s.EndDate, IsEnabled = s.IsEnabled, CreatedDate = s.CreatedDate, Titles = from t in surveyTranslations where t.SurveyId == s.Id && t.Language == Language select new Models.SurveyTranslation { Title = t.Title, Language = t.Language } }; } logger?.LogInformation($"{surveys.Count} Items(s) found"); return (true, surveysList, null); } return (false, null, "Not found"); } catch (Exception ex) { logger?.LogError(ex.ToString()); return (false, null, ex.Message); } } public async Task<(bool IsSuccess, Models.Survey Surveys, string ErrorMessage)> GetSurveysAsync(int Id, string Language) { try { logger?.LogInformation("Query Survey"); var survey = await surveyDbContext.Surveys.SingleOrDefaultAsync(s => s.Id == Id && s.IsEnabled == true); if (survey != null) { Models.Survey result = null; var surveyTranslations = await surveyDbContext.SurveysTranslation.Where(s => s.SurveyId == survey.Id).ToListAsync(); if (string.IsNullOrEmpty(Language)) { result = new Models.Survey { Id = survey.Id, StartDate = survey.StartDate, EndDate = survey.EndDate, IsEnabled = survey.IsEnabled, CreatedDate = survey.CreatedDate, Titles = from t in surveyTranslations select new Models.SurveyTranslation { Title = t.Title, Language = t.Language } }; } else { result = new Models.Survey { Id = survey.Id, StartDate = survey.StartDate, EndDate = survey.EndDate, IsEnabled = survey.IsEnabled, CreatedDate = survey.CreatedDate, Titles = from t in surveyTranslations where t.Language == Language select new Models.SurveyTranslation { Title = t.Title, Language = t.Language } }; } logger?.LogInformation($"Survey Id: {Id} found"); return (true, result, null); } return (false, null, "Not found"); } catch (Exception ex) { logger?.LogError(ex.ToString()); return (false, null, ex.Message); } } public async Task<(bool IsSuccess, Models.Survey Survey, string ErrorMessage)> PostSurveyAsync(Models.Survey survey) { try { if (survey != null) { survey.CreatedDate = DateTime.Now; Db.Survey _survey = mapper.Map(survey); surveyDbContext.Surveys.Add(_survey); await surveyDbContext.SaveChangesAsync(); foreach (var title in survey.Titles) { surveyDbContext.SurveysTranslation.Add(new Db.SurveyTranslation {SurveyId = _survey.Id, Language = title.Language, Title = title.Title }); } await surveyDbContext.SaveChangesAsync(); survey.Id = _survey.Id; return (true,survey, "Successful"); } else { logger?.LogInformation($"Survey Id: {survey.Id} cannot be added"); return (false, null, $"Survey Id: {survey.Id} cannot be added"); } } catch (Exception ex) { logger?.LogError(ex.ToString()); return (false, null, ex.Message); } } public async Task<(bool IsSuccess, Models.Survey Survey, string ErrorMessage)> PutSurveyAsync(int Id, Models.Survey survey) { try { if (survey != null) { var _survey = await surveyDbContext.Surveys.Where(s => s.Id == Id).SingleOrDefaultAsync(); if (_survey != null) { var surveysTranslation = await surveyDbContext.SurveysTranslation.Where(s => s.SurveyId == Id).ToListAsync(); surveyDbContext.SurveysTranslation.RemoveRange(surveysTranslation); await surveyDbContext.SaveChangesAsync(); _survey.IsEnabled = survey.IsEnabled; _survey.StartDate = survey.StartDate; _survey.EndDate = survey.EndDate; await surveyDbContext.SaveChangesAsync(); List listSurveyTranslation = new List(); Random random = new Random(); foreach (var title in survey.Titles) { listSurveyTranslation.Add(new Db.SurveyTranslation { Id = random.Next(), SurveyId = _survey.Id, Language = title.Language, Title = title.Title }); } surveyDbContext.SurveysTranslation.AddRange(listSurveyTranslation); await surveyDbContext.SaveChangesAsync(); var result = new Models.Survey { Id = Id, StartDate = survey.StartDate, EndDate = survey.EndDate, IsEnabled = survey.IsEnabled, CreatedDate = survey.CreatedDate, Titles = from t in listSurveyTranslation select new Models.SurveyTranslation { Title = t.Title, Language = t.Language } }; return (true, result, "Successful"); } else { logger?.LogInformation($"Survey Id : {Id} Not found"); return (false, null, "Not Found"); } } else { logger?.LogInformation($"Survey Id: {Id} Bad Request"); return (false, null, "Bad request"); } } catch (Exception ex) { logger?.LogError(ex.ToString()); return (false, null, ex.Message); } } public async Task<(bool IsSuccess, Models.Survey Survey, string ErrorMessage)> DeleteSurveyAsync(int Id) { try { var survey = await surveyDbContext.Surveys.Where(x => x.Id == Id).SingleOrDefaultAsync(); if (survey != null) { surveyDbContext.Surveys.Remove(survey); await surveyDbContext.SaveChangesAsync(); return (true, mapper.Map(survey), $"Survey Id: {Id} deleted Successfuly"); } else { logger?.LogInformation($"Survey Id : {Id} Not found"); return (false, null, "Not Found"); } } catch (Exception ex) { logger?.LogError(ex.ToString()); return (false, null, ex.Message); } } } }