diff options
| author | Lucas Faria Mendes <lucas.fariamo08@gmail.com> | 2026-03-30 15:29:41 +0000 |
|---|---|---|
| committer | Lucas Faria Mendes <lucas.fariamo08@gmail.com> | 2026-03-30 15:29:41 +0000 |
| commit | 225aa1499e37faf9d38257caabbadc68d78b427e (patch) | |
| tree | 102bb7a40c58595348ae9d3c7076201759fe0720 /Decompiler/Gestor.Application.Servicos.Ferramentas/ReciboServico.cs | |
| parent | 1f4e14b2e973ee7de337fd4866d9a5ceff5cb6d1 (diff) | |
| download | gestor-225aa1499e37faf9d38257caabbadc68d78b427e.tar.gz gestor-225aa1499e37faf9d38257caabbadc68d78b427e.zip | |
decompiler.com
Diffstat (limited to 'Decompiler/Gestor.Application.Servicos.Ferramentas/ReciboServico.cs')
| -rw-r--r-- | Decompiler/Gestor.Application.Servicos.Ferramentas/ReciboServico.cs | 122 |
1 files changed, 122 insertions, 0 deletions
diff --git a/Decompiler/Gestor.Application.Servicos.Ferramentas/ReciboServico.cs b/Decompiler/Gestor.Application.Servicos.Ferramentas/ReciboServico.cs new file mode 100644 index 0000000..4fb8220 --- /dev/null +++ b/Decompiler/Gestor.Application.Servicos.Ferramentas/ReciboServico.cs @@ -0,0 +1,122 @@ +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 ReciboServico : BaseServico +{ + internal async Task<List<Recibo>> BuscarRecibos() + { + int tries = 3; + return await Task.Run(delegate + { + while (tries > 0) + { + try + { + UnitOfWork read = Instancia.Read; + try + { + return read.ReciboRepository.BuscarRecibos(); + } + finally + { + ((IDisposable)read)?.Dispose(); + } + } + catch (Exception e) + { + tries = Registrar(e, (TipoErro)123, tries); + } + } + return new List<Recibo>(); + }); + } + + public async Task<Recibo> Save(Recibo recibo) + { + int tries = 3; + base.Sucesso = true; + Recibo reciboOriginal = recibo; + return await Task.Run((Func<Recibo>)delegate + { + while (tries > 0) + { + List<RegistroLog> list = new List<RegistroLog>(); + recibo = reciboOriginal; + try + { + UnitOfWork commited = Instancia.Commited; + try + { + bool num = ((DomainBase)recibo).Id != 0L; + if (num) + { + list.Add(CreateLog(((DomainBase)recibo).Id, recibo, (TipoTela)42)); + } + recibo = ((((DomainBase)recibo).Id == 0L) ? commited.ReciboRepository.SaveOrUpdate(recibo) : commited.ReciboRepository.Merge(recibo)); + if (!num) + { + list.Add(CreateLog(((DomainBase)recibo).Id, ((DomainBase)recibo).GetValorOriginal(), (TipoTela)42, (TipoAcao)0)); + } + SaveLog(list, commited); + ((GenericUnitOfWork)commited).Commit(); + return recibo; + } + finally + { + ((IDisposable)commited)?.Dispose(); + } + } + catch (Exception e) + { + tries = Registrar(e, (TipoErro)231, tries, recibo); + } + } + return reciboOriginal; + }); + } + + public async Task<bool> Delete(Recibo recibo) + { + int tries = 3; + return await Task.Run(delegate + { + while (tries > 0) + { + List<RegistroLog> list = new List<RegistroLog>(); + try + { + UnitOfWork commited = Instancia.Commited; + try + { + list.Add(CreateLog(((DomainBase)recibo).Id, ((DomainBase)recibo).GetValorOriginal(), (TipoTela)42, (TipoAcao)2)); + commited.ReciboRepository.Delete(((DomainBase)recibo).Id); + SaveLog(list, commited); + ((GenericUnitOfWork)commited).Commit(); + return true; + } + finally + { + ((IDisposable)commited)?.Dispose(); + } + } + catch (Exception e) + { + tries = Registrar(e, (TipoErro)232, tries, recibo); + } + } + return false; + }); + } +} |