/// <summary>
        /// Valida uma requisição quanto as ações que estão sendo feitas sobre ela
        /// </summary>
        /// <param name="obj">É o objeto requisição</param>
        /// <param name="user_id">É o usuário que está solicitando a operação</param>
        /// <param name="action">É o tipo de ação que está sendo feita pelo usuário</param>
        /// <returns></returns>
        public List <string> Validate(Request obj, int user_id, string action)
        {
            List <string> list_erros = new List <string>();
            RequestDao    dao        = new RequestDao(conn, tran);
            UserDao       userDao    = new UserDao(conn, tran);
            Request       request    = new Request();

            if (action == "reopen" || action == "finish")
            {
                if (!userDao.GetPermission(user_id, "purchase", "update"))
                {
                    list_erros.Add("Permissão Negada.");
                }
            }
            else
            {
                if (!userDao.GetPermission(user_id, "purchase", action))
                {
                    list_erros.Add("Permissão Negada.");
                }
            }

            if (action == "update" || action == "delete" || action == "finish" || action == "reopen")
            {
                if (obj.req_id == 0)
                {
                    list_erros.Add("O objeto informado se refere a um novo registro.");
                    return(list_erros);
                }

                // Verifica se o registro existe
                if (dao.GetById((int)obj.req_id).req_id == 0)
                {
                    list_erros.Add("Registro não encontrado.");
                    return(list_erros);
                }

                request = dao.GetById(obj.req_id);
                if (action != "reopen" && request.req_status != "E")                 // --> Em digitação
                {
                    list_erros.Add("O Status do registro não permite alterações.");
                    return(list_erros);
                }

                if (action == "reopen" && request.req_status != "A")                 // --> Ativa ou finalizada
                {
                    list_erros.Add("O Status do registro não permite estorno.");
                    return(list_erros);
                }

                if (RequestIsEmpty(request.req_id))
                {
                    list_erros.Add("A requisição não contém itens!");
                    return(list_erros);
                }
            }

            return(list_erros);
        }
        public List <string> Validate(RequestItem obj, int user_id, string action)
        {
            Request        request        = new Request();
            RequestDao     requestDao     = new RequestDao(conn, tran);
            RequestItemDao requestItemDao = new RequestItemDao(conn, tran);
            UserDao        userDao        = new UserDao(conn, tran);

            List <string> list_erros = new List <string>();

            // Verificar permissão do usuário para realizar a operação
            if (!userDao.GetPermission(user_id, "purchase", action))
            {
                list_erros.Add("Permissão Negada.");
                return(list_erros);
            }

            // Verificar se a ação for criar, atualizar ou deletar, buscar a requisição referente ao item
            if (action == "create" || action == "update" || action == "delete")
            {
                request = requestDao.GetById(obj.itm_request_id);

                if (request.req_status != "E")
                {
                    list_erros.Add("Não é possível efetuar a ação, pois o status da requisição não permite.");
                }
            }

            // Verificar se a atualização ou exclusão é possível para o item
            if (action == "update" || action == "delete")
            {
                // É um novo registro
                if (obj.itm_id == 0)
                {
                    list_erros.Add("O objeto informado se refere a um novo registro.");
                    return(list_erros);
                }
                // Não foi encontrado o registro
                if (requestItemDao.GetById((int)obj.itm_id).itm_id == 0)
                {
                    list_erros.Add("Registro não encontrado.");
                    return(list_erros);
                }
            }

            return(list_erros);
        }
示例#3
0
        /// <summary>Retorna uma determinada requisição</sumary>
        public ObjResult GetById(int request_id)
        {
            connection = db.GetCon();
            connection.Open();

            Request    request = new Request();
            ObjResult  result  = new ObjResult();
            RequestDao dao     = new RequestDao(connection, null);

            try
            {
                request = dao.GetById(request_id);
                result.SetData(request);
                result.Success();
            }
            finally
            {
                connection.Close();
                db.Close();
            }

            return(result);
        }
示例#4
0
        /// <summary>
        /// Reabre uma determinada requisição
        /// </summary>
        /// <param name="request_id">É o id da requisição</param>
        /// <param name="user_id">É o id do usuário que está solicitando a reabertura da requisição</param>
        /// <param name="action">É o tipo de ação que está sendo feita pelo usuário</param>
        /// <returns></returns>
        public ObjResult ReopenRequest(int request_id, int user_id, string action)
        {
            connection = db.GetCon();
            connection.Open();

            ObjResult     result        = new ObjResult();
            List <string> messages_list = new List <string>();
            Request       request       = new Request();

            RequestDao      dao      = new RequestDao(connection, null);
            RequestBusiness business = new RequestBusiness(connection, null);
            RequestItemDao  item_dao = new RequestItemDao(connection, null);

            // Fazer a validação primeiro da requisição, se pode ser revertida, se o usuário tem autorização para realizar essa ação etc.
            try
            {
                request       = dao.GetById(request_id);
                messages_list = business.Validate(request, user_id, action);

                if (messages_list.Count > 0)
                {
                    result.resultStatus   = "error";
                    result.resultMessages = messages_list;
                    connection.Close();
                    return(result);
                }
            }
            finally
            {
                connection.Close();
            }

            // Agora vem a ação de reabrir a requisição
            // Obs.: As transações são feitas separadamente para cada serviço chamado.
            try
            {
                // Excluir as mensagens que estiverem associadas à requisição
                MessageService msg_service = new MessageService();
                List <Message> messages    = new List <Message>();
                messages = msg_service.GetMessagesBySourceKey(request_id);

                if (messages.Count != 0)
                {
                    foreach (Message msg in messages)
                    {
                        msg_service.DeleteMessage(msg.msg_id);
                    }
                }

                // Alterar o status de todos os itens da requisição para 1 <ED>
                foreach (RequestItem item in item_dao.GetItemsByRequest(request_id))
                {
                    item_dao.SetStatus(item.itm_id, "ED");
                }

                // Altera o status da requisição para 'E' (Em digitação).
                request_id          = ChangeStatus(request_id, 'E');
                result.resultStatus = "success";
                result.data         = request_id;
            }
            catch (Exception e)
            {
                throw new Exception(e.ToString());
            }

            return(result);
        }
示例#5
0
        /// <summary>Faz a publicação de uma determinada requisição</sumary>
        public ObjResult Send(int request_id, int user_id, string action, Message msg)
        {
            connection = db.GetCon();
            connection.Open();

            Request         request       = new Request();
            ObjResult       result        = new ObjResult();
            List <string>   messages_list = new List <string>();
            RequestDao      requestDao    = new RequestDao(connection, null);
            RequestBusiness business      = new RequestBusiness(connection, null);

            try
            {
                // Validar requisição
                request = requestDao.GetById(request_id);
                Console.WriteLine("Status da requisição: " + request.req_status);
                messages_list = business.Validate(request, user_id, action);
                if (messages_list.Count > 0)
                {
                    result.resultStatus   = "error";
                    result.resultMessages = messages_list;
                    connection.Close();
                    return(result);
                }
            }
            finally
            {
                connection.Close();
            }

            connection.Open();
            NpgsqlTransaction transaction = connection.BeginTransaction();
            RequestItemDao    itemDao     = new RequestItemDao(connection, transaction);
            MessageDao        messageDao  = new MessageDao(connection, transaction);
            RequestDao        r_dao       = new RequestDao(connection, transaction);

            try
            {
                // Altera o status da requisição para ativa
                request_id = r_dao.ChangeStatus(request_id, 'A');

                // Altera o status de todos os itens para <AAT> Aguardando Aprovação Técnica
                foreach (RequestItem item in itemDao.GetItemsByRequest(request_id))
                {
                    itemDao.SetStatus(item.itm_id, "AAT");
                }

                // Envia mensagem e informa que foi gerada por meio de uma requisição de compra
                msg.SetSourceKey(request_id);
                msg.SetSourceType("request");
                messageDao.Post(msg);

                // Adiciona o status de sucesso e data
                result.Success();
                result.SetData(request_id);

                // Comita as alterações
                transaction.Commit();
            }
            catch (Exception e)
            {
                transaction.Rollback();
                throw new Exception(e.ToString());
            }
            finally
            {
                connection.Close();
            }

            return(result);
        }