summaryrefslogtreecommitdiff
path: root/Decompiler/Gestor.Application.Servicos.Seguros/ProfissaoServico.cs
diff options
context:
space:
mode:
authorLucas Faria Mendes <lucas.fariamo08@gmail.com>2026-03-30 15:29:41 +0000
committerLucas Faria Mendes <lucas.fariamo08@gmail.com>2026-03-30 15:29:41 +0000
commit225aa1499e37faf9d38257caabbadc68d78b427e (patch)
tree102bb7a40c58595348ae9d3c7076201759fe0720 /Decompiler/Gestor.Application.Servicos.Seguros/ProfissaoServico.cs
parent1f4e14b2e973ee7de337fd4866d9a5ceff5cb6d1 (diff)
downloadgestor-225aa1499e37faf9d38257caabbadc68d78b427e.tar.gz
gestor-225aa1499e37faf9d38257caabbadc68d78b427e.zip
decompiler.com
Diffstat (limited to 'Decompiler/Gestor.Application.Servicos.Seguros/ProfissaoServico.cs')
-rw-r--r--Decompiler/Gestor.Application.Servicos.Seguros/ProfissaoServico.cs76
1 files changed, 76 insertions, 0 deletions
diff --git a/Decompiler/Gestor.Application.Servicos.Seguros/ProfissaoServico.cs b/Decompiler/Gestor.Application.Servicos.Seguros/ProfissaoServico.cs
new file mode 100644
index 0000000..ed83d06
--- /dev/null
+++ b/Decompiler/Gestor.Application.Servicos.Seguros/ProfissaoServico.cs
@@ -0,0 +1,76 @@
+using System;
+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.Domain.Common;
+using Gestor.Model.Domain.Generic;
+
+namespace Gestor.Application.Servicos.Seguros;
+
+internal class ProfissaoServico : BaseServico
+{
+ public async Task<Profissao> Save(Profissao profissao)
+ {
+ int tries = 3;
+ base.Sucesso = true;
+ Profissao profissaoOriginal = profissao;
+ return await Task.Run((Func<Profissao>)delegate
+ {
+ while (tries > 0)
+ {
+ profissao = profissaoOriginal;
+ try
+ {
+ UnitOfWork commited = Instancia.Commited;
+ try
+ {
+ bool flag = ((DomainBase)profissao).Id == 0;
+ profissao = (flag ? commited.ProfissaoRepository.SaveOrUpdate(profissao) : commited.ProfissaoRepository.Merge(profissao));
+ ((GenericUnitOfWork)commited).Commit();
+ return profissao;
+ }
+ finally
+ {
+ ((IDisposable)commited)?.Dispose();
+ }
+ }
+ catch (Exception e)
+ {
+ tries = Registrar(e, (TipoErro)214, tries, profissao);
+ }
+ }
+ return profissaoOriginal;
+ });
+ }
+
+ public async Task<long> FindLastId()
+ {
+ int tries = 3;
+ return await Task.Run(delegate
+ {
+ while (tries > 0)
+ {
+ try
+ {
+ UnitOfWork read = Instancia.Read;
+ try
+ {
+ return read.ProfissaoRepository.FindLastId();
+ }
+ finally
+ {
+ ((IDisposable)read)?.Dispose();
+ }
+ }
+ catch (Exception e)
+ {
+ tries = Registrar(e, (TipoErro)17, tries);
+ }
+ }
+ return 0L;
+ });
+ }
+}