Versões comparadas

Chave

  • Esta linha foi adicionada.
  • Esta linha foi removida.
  • A formatação mudou.

Produto:

NOVO Log de Auditoria

Versões:

12.1.19 +

Ocorrência:

Manual

Ambiente:

RM
Introdução:

Com o Log de Auditoria podemos obter um histórico de todas as inclusões, alterações e exclusões que ocorreram na(s) tabela(s) selecionada(s) para serem auditadas.     

O Log de auditoria é composto por uma série de Procedures, onde quando é(são) selecionada(s) uma tabela(s) a ser(em) auditada(s), cria-se uma "Tabela Espelho" em um Schema exclusivo do Log de Auditoria(TOTVSAUDIT) e Trigger(s) no banco de dados, dependendo da ação escolhida (Insert, Update, Delete).

Quando houver transações que utilizam a(s) tabela(s) selecionada(s), a Trigger é disparada e grava na tabela de Log (ZAUDITCHANGES) as informações sobre o autor da ação, e os dados que foram criados, alterados ou deletados é salvo na "Tabela Espelho"  (Ex.: TOTVSAUDIT.PFUNC, tabela espelho a tabela do sistema RM.PFUNC).

Estas informações podem ser consultadas através de QUERY´s no banco de dados ou através da interface do usuário do Log de Auditoria.

Homologação Conversões de Bases de Dados Oracle

Caso seja necessário se restaurar uma base de dados Oracle em um ambiente de homologação, utilizando-se das ferramentas IMP e IMPDP, deve-se restaurar o Schema RM,  após o final da restauração deve-se executar a Stored Procedure p_FixNovoLog.

Comando: EXEC p_FixNovoLog

Esta nova Stored Procedure faz uma verificação e cria/recria os objetos necessários para o correto funcionamento do Novo Log de Auditoria, Schema, Tabelas, Grants, Etc.

Passo a passo:

  1. Para habilitar o Log de Auditoria vá em Serviços Globais, Administração, Log de Auditoria, Configurações:


  2. Após clique no botão Inativo para que o mesmo mude para Ativo:



  3. Clique em Salvar:


  4. A partir do momento que o Log estiver ativo você poderá selecionar as tabelas que serão necessárias para auditoria.

    Para habilitar a auditoria na tabela PFUNC, vamos em [P] Totvs Folha de Pagamento e pressione CTRL + F para localizar a tabela, ou se preferir busque a mesma na lista de tabelas.

    Assim que a tabela é localizada escolhemos o tipo de Auditoria que necessitamos na tabela, elas são, Update (Quando um registro é alterado na tabela), Delete (Quando um registro é excluído na tabela) e Insert (Quando um registro e inserido na tabela):



  5. Após selecionar é só clicar em salvar que as Triggers de auditoria serão criadas no banco para a tabela em questão e um log será exibido:



  6. E possível manipular quantas Triggers forem necessárias ao mesmo tempo, tanto habilitando quanto desabilitando:




  7. Para remover uma Trigger é só desmarcar todas as opções da tabela:



  8. No novo Log foi implementada a funcionalidade de Exceção.

    Existem 2 tipos de exceções, uma por Tabelas/Colunas e outra de DataServer da aplicação.

    A primeira (Tabelas/Colunas), não audita a tabela especifica caso somente esta coluna tenha sido alterada:




  9. No campo domínio, digite o nome da tabela que você deseja criar a exceção de coluna:


  10. E selecione as colunas que serão ignoradas, clique em Salvar e depois OK:



  11. Marcação de muitas colunas, pode acarretar em uma queda de performance na execução da Trigger que será montada, desta forma criamos uma validação apenas para informar o cliente:
  12. Outra validação desenvolvida, caso Caso o cliente marque todas as colunas da tabela, neste caso entendemos que o correto é retirar a coluna da auditoria, nestes casos será mostrado a seguinte mensagem:
  13. Somente poderá ser cadastrado uma exceção por Domínio, caso tentem realizar a adição duplicada será apresentado a seguinte mensagem:
  14. Após o cadastro do registro, no momento da edição o campo Dominio ficará desabilitado para edição:
  15. Exceção criada com sucesso, as triggers já refletirão esta nova exceção:



  16. A Segunda (DataServer), ignora processos específicos do sistema, como o Recalculo da Folha.

    Para adicionar uma exceção de Dataserver vá até a aba DataServers, e depois botão incluir:


  17. As exceções de DataServer são globais, assim elas se aplicam a todas as tabelas que estão sendo utilizadas pelo processo e que estão sendo auditadas.

    Exemplo: Caso seja incluída uma exceção de DataServer no processo RM.Fop.CalcularFolha.FopCalcLogServer (Calculo da Folha) e a tabela PFUNC esteja sendo auditada, nenhum registro modificado pelo processo será auditado, porem caso exista uma alteração manual (realizada pelo usuário) sendo realizada ao mesmo tempo (alteração no cadastro do funcionário) a mesma será auditada normalmente.

    Inclua o código do Dataserver no campo Descrição, Salvar e depois OK:


  18. Assim como nas exceções de Colunas quando o registro é salvo a exceção reflete em todas as triggers do sistema, então quanto mais tabelas auditadas, maior poderá ser o tempo para finalizar o processo:


  19. Para excluir uma exceção, tanto de coluna quanto de DataServer é só selecionar a mesma e clicar no X para excluir:


  20. Para desativar o Log de auditoria em todas as tabelas, é só clicar no botão ATIVO e Salvar:


  21. Com isso todas as triggers serão removidas, mas irá manter a configuração que você já realizou, para caso queira reativar o Log:


  22. Visualização do Log de Auditoria


  23. Para visualizar selecione o registro desejado e de um duplo clique no mesmo, nesta tela teremos as informações do Usuário que gerou a auditoria.


  24. Para verificar o que foi alterado vá em Detalhe das alterações do Log de Auditoria, selecione o registro e de um duplo clique.
    Neste exemplo vemos que os campos Apelido, Investtreinament e CodNaturalidade foram alterados.


  25. Expurgo parcial é realizado quando desejamos excluir das tabelas de auditoria registros específicos.
    Vá em Processos, e Expurgo Parcial do Log de Auditoria
  26. Nesta etapa temos que selecionar o filtro de Limpeza/Expurgo
  27. Neste exemplo iremos expurgar os registros de 14/01/2018 a 15/01/2018 para operações de Update
  28. Aqui selecionamos as tabelas que desejamos que seja feito o expurgo.



  29. Expurgo Total
    Aqui iremos fazer o expurgo de todos os dados das tabelas de auditoria, esta é a forma mais rápida e pratica para quando a auditoria não é mais necessária.




  30. Podemos gerar os relatórios a partir dos dados coletados pela auditoria para isso vamos em Processos, Gerar Relatório com Base no Log de Auditoria

    Aqui teremos a tela de filtros

    Definimos os filtros necessário e onde o arquivo deve ser gerado.

    Selecionamos as tabelas que desejamos que o relatório seja gerado


    Abaixo modelo de relatório gerado

Observações:

Para mais informações:


   COMUNIDADE  R@Tecnologia

 Canais de Atendimento:

Abertura de Chamados Através do Portal Totvs www.suporte.totvs.com.br

Telefônico: 4003-0015 Escolhendo as opções 2 – (Software), 2 – (Suporte Técnico), 3 – (RM), 8 – (Tecnologia), 2 – (Banco de Dados)