Exemple #1
0
        public IEnumerable <AgendamentoInfo> ObterTodosAgendamentosEnfileirar()
        {
            try
            {
                using (_contexto.Connection)
                {
                    _contexto.GetConnection();
                    var q            = AgendamentoInfoQueries.SelecionarAgendamentosEnfileirar();
                    var agendamentos = _contexto
                                       .Connection
                                       .Query <AgendamentoInfo>(q, new { });


                    foreach (var ag in agendamentos)
                    {
                        ag.AtualizaEmail(_contexto
                                         .Connection
                                         .Query <EmailInfo>(EmailInfoQueries.SelectEmailInfoPorId(ag.IdProcesso.ToString()), new { Id = ag.IdProcesso.ToString() }).FirstOrDefault());
                    }

                    return(agendamentos);
                }
            }
            catch (SQLiteException ex)
            {
                throw ex;
            }
        }
Exemple #2
0
        public AgendamentoInfo ObterAgendamento(string Id)
        {
            try
            {
                using (_contexto.Connection)
                {
                    _contexto.GetConnection();


                    var agendamento = _contexto
                                      .Connection
                                      .Query <AgendamentoInfo>(AgendamentoInfoQueries.SelectAgendamentoInfoPorId(Id.ToString()), new { Id = Id }).FirstOrDefault();

                    agendamento.AtualizaEmail(_contexto
                                              .Connection
                                              .Query <EmailInfo>(EmailInfoQueries.SelectEmailInfoPorId(Id.ToString()), new { Id = Id }).FirstOrDefault());

                    return(agendamento);
                }
            }
            catch (SQLiteException ex)
            {
                throw ex;
            }
        }
Exemple #3
0
        public CommandResponse AdicionarAgendamento(AgendamentoInfo obj)
        {
            try
            {
                _contexto.Connection.Open();
                _contexto.BeginTransaction();
                var query = AgendamentoInfoQueries.InsertAgendamentoInfo();

                var param = new DynamicParameters();
                param.Add(name: "IdProcesso", value: obj.IdProcesso.ToString(), direction: ParameterDirection.Input);
                if (obj.DataInicio != DateTime.MinValue)
                {
                    param.Add(name: "DataInicio", value: obj.DataInicio, direction: ParameterDirection.Input);
                }
                else
                {
                    param.Add(name: "DataInicio", value: null, direction: ParameterDirection.Input);
                }


                param.Add(name: "Descricao", value: obj.Descricao, direction: ParameterDirection.Input);
                param.Add(name: "NomeAgente", value: obj.NomeAgente, direction: ParameterDirection.Input);
                param.Add(name: "Periodicidade", value: obj.Periodicidade.ToString(), direction: ParameterDirection.Input);
                param.Add(name: "FrequenciaPeriodicidade", value: obj.FrequenciaPeriodicidade, direction: ParameterDirection.Input);
                param.Add(name: "StatusAgendamento", value: obj.StatusAgendamento.ToString(), direction: ParameterDirection.Input);
                param.Add(name: "HoraInicio", value: obj.HoraInicio.ToString(), direction: ParameterDirection.Input);
                param.Add(name: "MinutoInicio", value: obj.MinutoInicio.ToString(), direction: ParameterDirection.Input);
                param.Add(name: "AmPm", value: obj.AmPm, direction: ParameterDirection.Input);
                param.Add(name: "Ativo", value: obj.Ativo, direction: ParameterDirection.Input);
                param.Add(name: "DisparoManual", value: obj.DisparoManual, direction: ParameterDirection.Input);
                param.Add(name: "Path_UltimaExecucao", value: obj.MinutoInicio.ToString(), direction: ParameterDirection.Input);

                _contexto.Connection.Execute(query, param, _contexto.Transaction);

                query = EmailInfoQueries.InsertEmailInfoPorId();
                param = new DynamicParameters();
                param.Add(name: "IdProcesso", value: obj.IdProcesso.ToString(), direction: ParameterDirection.Input);
                param.Add(name: "Assunto", value: obj.Email.Assunto, direction: ParameterDirection.Input);
                param.Add(name: "Remetente", value: obj.Email.Remetente, direction: ParameterDirection.Input);
                param.Add(name: "Destinatario", value: obj.Email.Destinatario, direction: ParameterDirection.Input);
                param.Add(name: "Destinatario_CC", value: obj.Email.Destinatario_CC, direction: ParameterDirection.Input);
                param.Add(name: "Destinatario_CO", value: obj.Email.Destinatario_CO, direction: ParameterDirection.Input);
                _contexto.Connection.Execute(query, param, _contexto.Transaction);

                _contexto.Transaction.Commit();
                _contexto.Dispose();

                return(new CommandResponse(true, $"{obj.Descricao} adicionada com sucesso"));
            }
            catch (SQLiteException ex)
            {
                _contexto.Transaction.Rollback();
                _contexto.Dispose();
                return(new CommandResponse(false, $"{ex.Message}"));
            }
        }
Exemple #4
0
        public CommandResponse AtualizarStatusAgendamento(AgendamentoInfo obj)
        {
            try
            {
                _contexto.Connection.Open();
                _contexto.Connection.Execute(AgendamentoInfoQueries.UpdateStatusExecucao(obj));
                _contexto.Dispose();

                return(new CommandResponse(true, $"{obj.Descricao} atualizado com sucesso"));
            }
            catch (SQLiteException ex)
            {
                _contexto.Dispose();
                return(new CommandResponse(false, $"Erro : {ex.Message}"));
            }
        }
Exemple #5
0
        public CommandResponse AtualizarAgendamentoInfoPorID(AgendamentoInfo obj)
        {
            try
            {
                _contexto.Connection.Open();
                _contexto.BeginTransaction();

                _contexto.Connection.Execute(AgendamentoInfoQueries.UpdateAgendamentoInfo(obj), _contexto.Transaction);
                _contexto.Connection.Execute(EmailInfoQueries.UpdateEmailInfoPorId(obj.Email), _contexto.Transaction);

                _contexto.Transaction.Commit();
                _contexto.Dispose();

                return(new CommandResponse(true, $"{obj.Descricao} atualizado com sucesso"));
            }
            catch (SQLiteException ex)
            {
                _contexto.Transaction.Rollback();
                _contexto.Dispose();
                return(new CommandResponse(false, $"Erro : {ex.Message}"));
            }
        }
Exemple #6
0
        public CommandResponse RemoverAgendamentoInfoPorID(string IdProcesso)
        {
            try
            {
                _contexto.Connection.Open();
                _contexto.BeginTransaction();

                _contexto.Connection.Execute(AgendamentoInfoQueries.DeleteAgendamentoInfo(IdProcesso), _contexto.Transaction);
                _contexto.Connection.Execute(EmailInfoQueries.DeleteEmailInfo(IdProcesso), _contexto.Transaction);

                _contexto.Transaction.Commit();
                _contexto.Dispose();

                return(new CommandResponse(true, $" Agendamento {IdProcesso} Removido com sucesso"));
            }
            catch (SQLiteException ex)
            {
                _contexto.Transaction.Rollback();
                _contexto.Dispose();
                return(new CommandResponse(false, $"Erro : {ex.Message}"));
            }
        }