Páginas filhas
  • ER_Transferir_para_histórico_auditoria_de_ADS_e_APS_excluídas_e_transferidas

 Este documento é material de especificação dos requisitos de inovação, trata-se de conteúdo extremamente técnico.                                                             

  

(Obrigatório)

Informações Gerais

 

Especificação

Produto

Logix

Módulo

Contas a Pagar

Segmento Executor

 

Projeto1

MANFIN01 - Projeto Equipe Desenvolvimento - Finanças

IRM1

MANFIN01-103 - Pequenas melhorias - Financeiro

Requisito1

MANFIN01-521 - Transferir para histórico auditoria de ADS e APS excluídas e transferidas

Subtarefa1

MANFIN01-534 - Gerar Especificação

Chamado2

TSTCA8

País

( X ) Brasil  (  ) Argentina  (  ) Mexico  (  ) Chile  (  ) Paraguai  (  ) Equador

(  ) USA  (  ) Colombia   (  ) Outro _____________.

Outros

<Caso necessário informe outras referências que sejam pertinentes a esta especificação. Exemplo: links de outros documentos ou subtarefas relacionadas>.

   Legenda: 1 – Inovação 2 – Manutenção (Os demais campos devem ser preenchidos para ambos os processos). 

(Obrigatório)

Objetivo

Efetuar a transferência para histórico das auditorias de ADs e APs já incluídas anteriormente pela rotina de inclusão de dados em histórico do contas a pagar.

 

(Obrigatório)

Definição da Regra de Negócio

 O processo de envio dos dados para histórico no contas a pagar é dividido em duas rotinas:

 

  • CAP1450 - Transferências das tabelas de movimentação do contas a pagar;
  • CAP1501 - Transferência da tabela de auditoria (audit_cap);


O processo foi separado em duas rotinas em função do volume de dados, a tabela de auditoria do contas a pagar pode conter
mais de hum milhão de registros, e pode afetar a performance da rotina, em função desta situação foi separada a inclusão
dos históricos de auditoria em outro programa.

A partir da execução da rotina cap1465, os dados relacionados a históricos será selecionada a partir de seleção entre
a tabela audit_cap e as tabelas de histórico de ADs e APs. abaixo segue exemplo das alterações necessárias para
transferência para históricos destas auditorias.

#-------------------------------------------#
FUNCTION cap1501_processa()
#------------------------------------------#

    # Audit_cap ad_mestre
    MESSAGE "Transferindo auditoria de ADs ..." ATTRIBUTE(reverse)
    IF NOT cap1501_processa1() THEN
         RETURN FALSE
     END IF

 

     # Audit_cap AP excluida
      MESSAGE "Transferindo auditoria de APs excluídas ..." ATTRIBUTE(reverse)
      IF NOT cap1501_processa2() THEN
           RETURN FALSE
      END IF

 

      #Audit_cap de AP paga até a data informada na tela
      MESSAGE "Transferindo auditoria de Aps pagas ..." ATTRIBUTE(reverse)
      IF NOT cap1501_processa3() THEN
           RETURN FALSE
      END IF

 

      #Audit_cap de AP transferida para histórico
        MESSAGE "Transferindo auditoria de APs em histórico ..." ATTRIBUTE(reverse)
        IF NOT cap1501_processa4() THEN
             RETURN FALSE
        END IF

 

      #Audit_cap de AD transferida para histórico
       MESSAGE "Transferindo auditoria de APs em histórico ..." ATTRIBUTE(reverse)
       IF NOT cap1501_processa5() THEN
            RETURN FALSE
      END IF

      MESSAGE "Transferencia efetuada com sucesso." ATTRIBUTE(reverse)

      RETURN TRUE

END FUNCTION

#------------------------------#
FUNCTION cap1501_processa4()
#------------------------------#
DEFINE l_audit_cap RECORD LIKE audit_cap.*

 

       CALL log085_transacao("BEGIN")

 

       DECLARE cl_audit4 CURSOR WITH HOLD FOR
         SELECT *
            FROM audit_cap
         WHERE cod_empresa = mr_tela.empresa
               AND ies_ad_ap = 2
              AND data_manut < mr_tela.dat_manut
             AND EXISTS (SELECT *
                                           FROM cap_hist_ap h
                                        WHERE h.empresa         = mr_tela.empresa
                                              AND h.autoriz_pagto = audit_cap.num_ad_ap
                                              AND h.nota_fiscal     = audit_cap.num_nf
                                              AND h.fornecedor      = audit_cap.cod_fornecedor
                                              AND h.versao_atual  = 'S')

 

           FOREACH cl_audit4 INTO l_audit_cap.*

 

                      WHENEVER ERROR CONTINUE
                        DELETE FROM audit_cap
                          WHERE cod_empresa       = mr_tela.empresa
                                AND num_ad_ap          = l_audit_cap.num_ad_ap
                                AND ies_ad_ap            = l_audit_cap.ies_ad_ap
                                AND num_nf                = l_audit_cap.num_nf
                                 AND ser_nf                 = l_audit_cap.ser_nf
                                 AND ssr_nf                 = l_audit_cap.ssr_nf
                                 AND cod_fornecedor = l_audit_cap.cod_fornecedor
                                 AND num_seq            = l_audit_cap.num_seq

                       WHENEVER ERROR STOP

 

                       IF SQLCA.sqlcode = 0 THEN
                             WHENEVER ERROR CONTINUE
                             INSERT INTO cap_auditoria_hist VALUES (l_audit_cap.*, TODAY)
                            WHENEVER ERROR STOP

 

                            IF SQLCA.sqlcode = 0 THEN
                                  CALL log085_transacao("COMMIT")
                            ELSE
                                  CALL log003_err_sql("INSERT","CAP_AUDITORIA_HIST")
                                  CALL log085_transacao("ROLLBACK")
                                  RETURN FALSE 
                           END IF
                     ELSE
                           CALL log003_err_sql("DELETE","AUDIT_CAP")
                           CALL log085_transacao("ROLLBACK")
                           RETURN FALSE
                    END IF

          END FOREACH

          WHENEVER ERROR CONTINUE
          CLOSE cl_audit4
          FREE cl_audit4
          WHENEVER ERROR STOP

          RETURN TRUE

END FUNCTION


#---------------------------------------------#
FUNCTION cap1501_processa5()
#---------------------------------------------#
      DEFINE l_audit_cap RECORD LIKE audit_cap.*

      CALL log085_transacao("BEGIN")

       DECLARE cl_audit5 CURSOR WITH HOLD FOR
          SELECT *
             FROM audit_cap
          WHERE cod_empresa = mr_tela.empresa
                AND ies_ad_ap       = 1
                AND data_manut < mr_tela.dat_manut
                AND EXISTS (SELECT *
                                             FROM cap_h_ad_mestre a
                                           WHERE a.empresa               = mr_tela.empresa
                                                 AND a.apropr_desp         = audit_cap.num_ad_ap
                                                 AND a.nota_fiscal           = audit_cap.num_nf
                                                 AND a.serie_nota_fiscal = audit_cap.ser_nf
                                                 AND a.subserie_nf          = audit_cap.ssr_nf
                                                 AND a.fornecedor            = audit_cap.cod_fornecedor)

 

          FOREACH cl_audit5 INTO l_audit_cap.*

                   WHENEVER ERROR CONTINUE

                     DELETE FROM audit_cap
                     WHERE cod_empresa     = mr_tela.empresa
                           AND num_ad_ap        = l_audit_cap.num_ad_ap
                           AND ies_ad_ap          = l_audit_cap.ies_ad_ap
                           AND num_nf               = l_audit_cap.num_nf
                           AND ser_nf                 = l_audit_cap.ser_nf
                           AND ssr_nf                 = l_audit_cap.ssr_nf
                           AND cod_fornecedor = l_audit_cap.cod_fornecedor
                           AND num_seq            = l_audit_cap.num_seq
                   WHENEVER ERROR STOP

 

                 IF SQLCA.sqlcode = 0 THEN
                      WHENEVER ERROR CONTINUE
                      INSERT INTO cap_auditoria_hist VALUES (l_audit_cap.*, TODAY)
                      WHENEVER ERROR STOP

                       IF SQLCA.sqlcode = 0 THEN

                            CALL log085_transacao("COMMIT")
                       ELSE
                             CALL log003_err_sql("INSERT","CAP_AUDITORIA_HIST")
                             CALL log085_transacao("ROLLBACK")
                             RETURN FALSE
                       END IF
                ELSE
                       CALL log003_err_sql("DELETE","AUDIT_CAP")
                       CALL log085_transacao("ROLLBACK")
                        RETURN FALSE
                 END IF

         END FOREACH

         WHENEVER ERROR CONTINUE
         CLOSE cl_audit5
            FREE cl_audit5
          WHENEVER ERROR STOP

          RETURN TRUE

END FUNCTION


<Na tabela abaixo informe quais são as rotinas envolvidas, o tipo de operação, a opção de menu e se necessário uma breve descrição das regras de negócio relacionadas a rotina>.

 

Rotina

Tipo de Operação

Opção de Menu

Regras de Negócio

CAP1501 - Transfere auditoria de AD/AP para histórico

[Alteração]

 

 

    
   

 

 

Exemplo de Aplicação:

  • Criar o campo “% Mínimo Espécie” (AAA_PERESP) onde o usuário informará o % que o aluno pagará em dinheiro. Esse % poderá ser alterado durante a negociação.
  • Criar o campo “Referência Mínima para Cálculo” (AAA_REFCAL) onde o usuário informará um dos 4 valores disponíveis para pagamento das mensalidades  como a referência mínima para calcular o débito total do aluno.
  • Criar o parâmetro MV_ACPARNE que definirá se as informações de “% Mínimo Espécie” e “Referência Mínima para Cálculo” serão obrigatórias.
  • O parâmetro MV_ACPARNE deve ter as seguintes opções: 1=Obrigatório e 2=Opcional. Deve ser inicializado como opcional>.

 

Tabelas Utilizadas

  • SE2 – Cadastro de Contas a Pagar
  • FI9 – Controle de Emissão de DARF>.

Opcional

Protótipo de Tela

 

<Caso necessário inclua protótipos de telas com o objetivo de facilitar o entendimento do requisito, apresentar conceitos e funcionalidades do software>.

 

Protótipo 01

 

 

 

 

 

 

 

 

 

Opcional

Fluxo do Processo

 

<Nesta etapa incluir representações gráficas que descrevam o problema a ser resolvido e o sistema a ser desenvolvido. Exemplo: Diagrama - Caso de Uso, Diagrama de Atividades, Diagrama de Classes, Diagrama de Entidade e Relacionamento e Diagrama de Sequência>. 

Opcional

Dicionário de Dados

 

Arquivo ou Código do Script: AAA – Negociação Financeira / *Versao=CP.2014.12_03*/

  

Índice

Chave

01

<FI9_FILIAL+FI9_IDDARF+FI9_STATUS>

02

<FI9_FILIAL+FI9_FORNEC+ FI9_LOJA+FI9_EMISS+FI9_IDDARF>

03

<FI9_FILIAL+FI9_FORNEC+ FI9_LOJA+FI9_PREFIX+FI9_NUM+FI9_PARCEL+FI9_TIPO>

Campo

<AAA_PERESP>

Tipo

<N>

Tamanho

<6>

Valor Inicial

<Varia de acordo com o tipo informado. Por exemplo, quando o campo “tipo” for date, neste campo pode ser informado uma data>. 

Mandatório

Sim (  ) Não (  )

Descrição

<Referência Mínima para Cálculo>

Título

<Ref.Calc.>

Picture

<@E999.99>

Help de Campo

<Informar o % que o aluno pagará em dinheiro. Esse % poderá ser alterado durante a negociação>

 

(Opcional)

Grupo de Perguntas

 

<Informações utilizadas na linha Protheus>.

 

Nome: FINSRF2

X1_ORDEM

01

X1_PERGUNT

Emissão De

X1_TIPO

D

X1_TAMANHO

8

X1_GSC

G

X1_VAR01

MV_PAR01

X1_DEF01

Comum

X1_CNT01

'01/01/08'

X1_HELP

Data inicial do intervalo de emissões das guias de DARF a serem consideradas na seleção dos dados para o relatório 

 

(Opcional)

Consulta Padrão

<Informações utilizadas na linha Protheus>

 

Consulta: AMB

Descrição

Configurações de Planejamento

Tipo

Consulta Padrão

Tabela

“AMB”

Índice

“Código”

Campo

“Código”; ”Descrição”

Retorno

AMB->AMB_CODIGO

 

(Opcional)

Estrutura de Menu

 

<Informações utilizadas na linha Datasul>.

 

Procedimentos

 

Procedimento

 

 

 

Descrição

(Max 40 posições)

(Max 40 posições)

(Max 40 posições)

Módulo

 

 

 

Programa base

 

 

 

Nome Menu

(Max 32 posições)

(Max 32 posições)

(Max 32 posições)

Interface

GUI/WEB/ChUI/Flex

GUI/WEB/ChUI/Flex

GUI/WEB/ChUI/Flex

Registro padrão

Sim

Sim

Sim

Visualiza Menu

Sim/Não

Sim/Não

Sim/Não

Release de Liberação

 

 

 

 

 

 

Programas

 

Programa

 

 

 

Descrição

(Max 40 posições)

(Max 40 posições)

(Max 40 posições)

Nome Externo

 

 

 

Nome Menu/Programa

(Max 32 posições)

(Max 32 posições)

(Max 32 posições)

Nome Verbalizado[1]

(Max 254 posições)

(Max 254 posições)

(Max 254 posições)

Procedimento

 

 

 

Template

(Verificar lista de opções no man01211)

(Verificar lista de opções no man01211)

(Verificar lista de opções no man01211)

Tipo[2]

Consulta/Manutenção/ Relatório/Tarefas

Consulta/Manutenção/ Relatório/Tarefas

Consulta/Manutenção/ Relatório/Tarefas

Interface

GUI/WEB/ChUI/Flex

GUI/WEB/ChUI/Flex

GUI/WEB/ChUI/Flex

Categoria[3]

 

 

 

Executa via RPC

Sim/Não

Sim/Não

Sim/Não

Registro padrão

Sim

Sim

Sim

Outro Produto

Não

Não

Não

Visualiza Menu

Sim/Não

Sim/Não

Sim/Não

Query on-line

Sim/Não

Sim/Não

Sim/Não

Log Exec.

Sim/Não

Sim/Não

Sim/Não

Rotina (EMS)

 

 

 

Sub-Rotina (EMS)

 

 

 

Localização dentro da Sub Rotina (EMS)

 

 

 

Compact[4]

Sim/Não

Sim/Não

Sim/Não

Home[5]

Sim/Não

Sim/Não

Sim/Não

Posição do Portlet[6]

0 – Top Left

1 – Top Right

2 – Bottom Left

3 – Bottom Right

0 – Top Left

1 – Top Right

2 – Bottom Left

3 – Bottom Right

0 – Top Left

1 – Top Right

2 – Bottom Left

3 – Bottom Right

Informar os papeis com os quais o programa deve ser vinculado

 

 

 

 

Cadastro de Papéis

<O cadastro de papéis é obrigatório para os projetos de desenvolvimento FLEX a partir do Datasul 10>.

<Lembrete: o nome dos papeis em inglês descrito neste ponto do documento, devem ser homologados pela equipe de tradução>.

 

Código Papel

(máx 3 posições)

Descrição em Português*

 

Descrição em Inglês*

 


[1] Nome Verbalizado é obrigatório para desenvolvimentos no Datasul 10 em diante.

[2] Tipo é obrigatório para desenvolvimento no Datasul 10 em diante

[3] Categorias são obrigatórias para os programas FLEX.

[4] Obrigatório quando o projeto for FLEX

[5] Obrigatório quando o projeto for FLEX

[6] Obrigatório quando o projeto for FLEX

 Este documento é material de especificação dos requisitos de inovação, trata-se de conteúdo extremamente técnico.