diff options
Diffstat (limited to 'Decompiler/Gestor.Application.Servicos.Financeiro/PlanosServico.cs')
| -rw-r--r-- | Decompiler/Gestor.Application.Servicos.Financeiro/PlanosServico.cs | 90 |
1 files changed, 90 insertions, 0 deletions
diff --git a/Decompiler/Gestor.Application.Servicos.Financeiro/PlanosServico.cs b/Decompiler/Gestor.Application.Servicos.Financeiro/PlanosServico.cs new file mode 100644 index 0000000..1fbab43 --- /dev/null +++ b/Decompiler/Gestor.Application.Servicos.Financeiro/PlanosServico.cs @@ -0,0 +1,90 @@ +using System; +using System.Collections.Generic; +using System.Collections.ObjectModel; +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.Financeiro; +using Gestor.Model.Domain.Generic; + +namespace Gestor.Application.Servicos.Financeiro; + +internal class PlanosServico : BaseServico +{ + internal async Task<ObservableCollection<Planos>> BuscarPlanos() + { + int tries = 3; + return await Task.Run(delegate + { + while (tries > 0) + { + try + { + UnitOfWork read = Instancia.Read; + try + { + return new ObservableCollection<Planos>(read.PlanosRepository.Find()); + } + finally + { + ((IDisposable)read)?.Dispose(); + } + } + catch (Exception e) + { + tries = Registrar(e, (TipoErro)168, tries); + } + } + return new ObservableCollection<Planos>(); + }); + } + + public async Task<Planos> Save(Planos planos) + { + int tries = 3; + base.Sucesso = true; + Planos planosOriginal = planos; + return await Task.Run((Func<Planos>)delegate + { + while (tries > 0) + { + List<RegistroLog> list = new List<RegistroLog>(); + planos = planosOriginal; + try + { + UnitOfWork commited = Instancia.Commited; + try + { + bool num = ((DomainBase)planos).Id != 0L; + if (num) + { + list.Add(CreateLog(((DomainBase)planos).Id, planos, (TipoTela)28)); + } + planos = ((((DomainBase)planos).Id == 0L) ? commited.PlanosRepository.SaveOrUpdate(planos) : commited.PlanosRepository.Merge(planos)); + if (!num) + { + list.Add(CreateLog(((DomainBase)planos).Id, ((DomainBase)planos).GetValorOriginal(), (TipoTela)28, (TipoAcao)0)); + } + SaveLog(list, commited); + ((GenericUnitOfWork)commited).Commit(); + return planos; + } + finally + { + ((IDisposable)commited)?.Dispose(); + } + } + catch (Exception e) + { + tries = Registrar(e, (TipoErro)251, tries, planos); + } + } + return planosOriginal; + }); + } +} |