summaryrefslogtreecommitdiff
path: root/Codemerx/Gestor.Application/Servicos/Ferramentas/StatusProspeccaoServico.cs
blob: 1af67709646f9f942e84033c6ce5ac4056f01115 (plain)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
using Gestor.Application.Helpers;
using Gestor.Application.Servicos.Generic;
using Gestor.Infrastructure.Repository.Interface;
using Gestor.Infrastructure.UnitOfWork.Generic;
using Gestor.Infrastructure.UnitOfWork.Logic;
using Gestor.Model.Domain.Common;
using Gestor.Model.Domain.Ferramentas;
using Gestor.Model.Domain.Generic;
using System;
using System.Collections.Generic;
using System.Diagnostics;
using System.Runtime.CompilerServices;
using System.Threading.Tasks;

namespace Gestor.Application.Servicos.Ferramentas
{
	internal class StatusProspeccaoServico : BaseServico
	{
		public StatusProspeccaoServico()
		{
		}

		internal async Task<List<StatusDeProspeccao>> BuscarProspeccoes()
		{
			int num = 3;
			List<StatusDeProspeccao> statusDeProspeccaos1 = await Task.Run<List<StatusDeProspeccao>>(() => {
				List<StatusDeProspeccao> statusDeProspeccaos;
				while (num > 0)
				{
					try
					{
						using (UnitOfWork read = Instancia.Read)
						{
							statusDeProspeccaos = read.get_StatusProspeccaoRepository().FindAll();
						}
					}
					catch (Exception exception)
					{
						num = base.Registrar(exception, 308, num, null, true);
						continue;
					}
					return statusDeProspeccaos;
				}
				return new List<StatusDeProspeccao>();
			});
			return statusDeProspeccaos1;
		}

		internal async Task<StatusDeProspeccao> Save(StatusDeProspeccao statusProspeccao)
		{
			int num = 3;
			base.Sucesso = true;
			StatusDeProspeccao statusDeProspeccao1 = statusProspeccao;
			StatusDeProspeccao statusDeProspeccao2 = await Task.Run<StatusDeProspeccao>(() => {
				StatusDeProspeccao statusDeProspeccao;
				bool flag;
				List<RegistroLog> registroLogs = new List<RegistroLog>();
				statusProspeccao = statusDeProspeccao1;
				while (num > 0)
				{
					statusProspeccao = statusDeProspeccao1;
					try
					{
						using (UnitOfWork commited = Instancia.Commited)
						{
							flag = (statusProspeccao.get_Id() == 0 ? false : true);
							if (flag)
							{
								registroLogs.Add(base.CreateLog(statusProspeccao.get_Id(), statusProspeccao, 57));
							}
							statusProspeccao = (statusProspeccao.get_Id() == 0 ? commited.get_StatusProspeccaoRepository().SaveOrUpdate(statusProspeccao) : commited.get_StatusProspeccaoRepository().Merge(statusProspeccao));
							if (!flag)
							{
								registroLogs.Add(base.CreateLog(statusProspeccao.get_Id(), statusProspeccao.GetValorOriginal(), 57, 0));
							}
							base.SaveLog(registroLogs, commited);
							commited.Commit();
							statusDeProspeccao = statusProspeccao;
						}
					}
					catch (Exception exception)
					{
						num = base.Registrar(exception, 307, num, statusProspeccao, true);
						continue;
					}
					return statusDeProspeccao;
				}
				return statusDeProspeccao1;
			});
			return statusDeProspeccao2;
		}
	}
}