using System; using System.Collections.Generic; using System.Threading.Tasks; using Gestor.Application.Helpers; using Gestor.Application.Servicos.Generic; using Gestor.Infrastructure.UnitOfWork.Generic; using Gestor.Infrastructure.UnitOfWork.Logic; using Gestor.Model.API; using Gestor.Model.Common; using Gestor.Model.Domain.Common; using Gestor.Model.Domain.Ferramentas; using Gestor.Model.Domain.Generic; namespace Gestor.Application.Servicos.Ferramentas; internal class StatusProspeccaoServico : BaseServico { internal async Task> BuscarProspeccoes() { int tries = 3; return await Task.Run(delegate { while (tries > 0) { try { UnitOfWork read = Instancia.Read; try { return read.StatusProspeccaoRepository.FindAll(); } finally { ((IDisposable)read)?.Dispose(); } } catch (Exception e) { tries = Registrar(e, (TipoErro)308, tries); } } return new List(); }); } internal async Task Save(StatusDeProspeccao statusProspeccao) { int tries = 3; base.Sucesso = true; StatusDeProspeccao statusProspeccaoOriginal = statusProspeccao; return await Task.Run((Func)delegate { List list = new List(); statusProspeccao = statusProspeccaoOriginal; while (tries > 0) { statusProspeccao = statusProspeccaoOriginal; try { UnitOfWork commited = Instancia.Commited; try { bool num = ((DomainBase)statusProspeccao).Id != 0L; if (num) { list.Add(CreateLog(((DomainBase)statusProspeccao).Id, statusProspeccao, (TipoTela)57)); } statusProspeccao = ((((DomainBase)statusProspeccao).Id == 0L) ? commited.StatusProspeccaoRepository.SaveOrUpdate(statusProspeccao) : commited.StatusProspeccaoRepository.Merge(statusProspeccao)); if (!num) { list.Add(CreateLog(((DomainBase)statusProspeccao).Id, ((DomainBase)statusProspeccao).GetValorOriginal(), (TipoTela)57, (TipoAcao)0)); } SaveLog(list, commited); ((GenericUnitOfWork)commited).Commit(); return statusProspeccao; } finally { ((IDisposable)commited)?.Dispose(); } } catch (Exception e) { tries = Registrar(e, (TipoErro)307, tries, statusProspeccao); } } return statusProspeccaoOriginal; }); } }