Tabla de Contenidos

Fábrica - Modelos Logs - Log de Transacciones

Este es el log utilizado para registrar los logs en las transacciones de modificación de información de los procesos de las aplicaciones.

Tipos de Transacciones

A continuación se listan los tipos de transacciones que deben ser considerados en el log.

¿Donde usar el Servicio?

Este servicio debe consumirse en los procesos de cargas de:

Nota: Aplicaciones Powerbuilder

Powerbuilder tiene restricciones para el consumo de servicios Rest por lo tanto en las aplicaciones de esta tecnología se implementará un API para realizar las llamadas.

Diccionario de Datos

OWNER SICOF TABLE TRANSACTIONAL_LOGCOMMENTS Contiene el log de transacciones de las aplicaciones de la compañia
# NAME NULLEABLE TYPE COMMENTS WS1)
1IDNNUMBERCódigo interno del registro (Se controla por secuencia)Interno, Autoincremental
2FECHAYDATEFecha en la cuál se genera la transacciónNo utilizado
3NOMBRE_PROCESOYVARCHAR2(256)Nombre del proceso que realiza la transacciónExterno, Requerido
4TIPO_TRANSACCIONYVARCHAR2(256)Identifica el tipo de operación (Insert, Select, Update, Delete, Execute)Externo, Requerido
5LOG_TABLAYVARCHAR2(256)Nombre de la TablaExterno, Requerido
6LOG_COLUMNAYVARCHAR2(256)Nombre de la columnaObsoleto, Externo
7LOG_VALOR_ANTYVARCHAR2(4000)Valor anterior de la columnaObsoleto, Externo, Requerido
8LOG_VALOR_ACTYVARCHAR2(4000)Valor actual de la columnaObsoleto, Externo
9LOG_PETICIONYCLOBSe utiliza en caso de ser necesario para almacenar el bloque de la petición completa realizadaExterno, Requerido
10LOGIN_USUARIOYVARCHAR2(256)Login del usuario que realiza el procesoExterno, Requerido
11HOST_CLIENTEYVARCHAR2(50)Host del cliente (Dirección IP)Externo, Requerido
12FECHA_REGISTROYDATEFecha del sistema DBInterno, Formato dd/mm/yyyy hh:mm:ss, Requerido
13CODIGO_USUARIOYNUMBERCódigo del usuario de la sesión en la cuál se genera el errorExterno, Requerido
14CODIGO_MEMPRESAYVARCHAR2(64)Código de la empresa de la sesión en la cuál se genera el errorExterno, Requerido
15CODIGO_APLICACIONYNUMBERCódigo de la aplicación (Identificador interno numérico)Externo, Requerido
16INFO_APPYVARCHAR2(256)Información de la aplicación (En las situaciónes donde no se identifique código interno se puede enviar el nombre de la aplicación o información adicional)Externo
17SESSION_MACYVARCHAR2(64)MAC del equipo del usuarioExterno
18SESSION_BROWSERVERSIONYVARCHAR2(64)Versión del NavegadorExterno, Requerido
19SESSION_OSTYPEYVARCHAR2(64)Sistema OperativoExterno, Requerido

Columna: WS

Se adiciona esta columna para identificar reglas asociadas a la implementación de los servicios web que permiten gestionar el almacenamiento de los logs. La columna es una referencia y no hace parte del servicio sin embargo las reglas que se definen en ella si aplican para la columna relacionada:

Reglas

Nota

Columna: LOG_PETICION

Esta columna sirve para almacenar la información de la peticion2) que se realiza en el registro que va a la base de datos. Se define la siguiente estructura base ejemplo:

{
  "columns":[
    {
      "column_name":"Requerido: Nombre de la columna",
      "column_old_value": "Valor anterior de la columna",
      "column_new_value": "Valor actual de la columna"
    }
  ]
}

Donde:

Ejemplo:

{
  "columns":[
    {
      "column_name":"codigo_tercero",
      "column_old_value": "1234",
      "column_new_value": "3456"
    },
    {
      "column_name":"valor_debito",
      "column_old_value": "0",
      "column_new_value": "100000"
    }
  ]
}

Notas

Modo de uso: Powerbuilder - Documentación

Para visualizar la documentación debe descargar el siguiente repositorio Documentación, abrir la pagina Index.html en su navegador web la cual es similar a la siguiente imagen:

En ella encontrará la documentación de las librerias que hacen parte del framework Objetos SICOF el cuál se irá actualizando frecuentmente a medida que se documenten las clases.

La Libreria que contiene la funcionalidad de los logs es la librería sf00util.pbl

Los Objetos relacionados en el API son:

Ejemplos de Uso

Para facilitar la implementación y uso del API de gestión de log de transacciones se crea un objeto interno privado en la clase global guo_app el cual puede ser accedido por el método of_log_transactional() que devuelve la instancia del objeto. Sin embargo para implementaciones específicas se puede optar por crear y administrar la clase n_cst_log_transactional según considere el desarrollador.

A continuación se listan ejemplos de uso el cuál presenta las forma de utilizar el API, para más información debe consultar la documentación en el repositorio.

/*Ejemplos de uso utilizando la instancia genérica de la clase guo_app*/
guo_app.of_log_transactional( ).of_add_log(f_hoy(), "Causación por Plantilla", "Update", "PRESUP01.MAESTRO_ASIENTO_CONTABLE", "codigo_tercero", "0", "6949", true, SQLCA)
guo_app.of_log_transactional( ).of_add_log(f_hoy(), "Causación por Plantilla", "Update", "PRESUP01.MAESTRO_ASIENTO_CONTABLE", ljson, true, SQLCA)
 
/*Ejemplo de uso definiendo la clase*/
n_cst_log_transactional luo_log_transactional
luo_log_transactional = Create n_cst_log_transactional 
luo_log_transactional.of_add_log(f_hoy(), "Causación por Plantilla", "Update", "PRESUP01.MAESTRO_ASIENTO_CONTABLE", ljson, true, SQLCA)
destroy luo_log_transactional
Consideraciones

API Json

Se adicionan métodos de procesamiento de bloques en formato json los cuales pueden ser utilizados para registrar trazas de error a continuación se muestran ejemplos de uso del API.

sailjson ljson, ljson1 
String ls_content
 
ljson = create sailjson
ljson.setattribute( 'version', '1001')
//add json object
ljson1 = ljson.addobject( 'header')
ljson1.setattribute( 'count', 3)
ljson1.setattribute( 'comment', 'items count')
 
//add json object array, first item
ljson1 = ljson.addarrayitem( 'data')
ljson1.setattribute( 'colid', 1)
ljson1.setattribute( 'colname', 'aaaaaa')
ljson1.setattribute( 'coladdr', '')
//add second item of the array
ljson1 = ljson.addarrayitem( 'data')
ljson1.setattribute( 'colid', 2)
ljson1.setattribute( 'colname', 'bbbbbbbb')
setnull(ls)
ljson1.setattribute( 'coladdr', ls)
//add third item of the array
ljson1 = ljson.addarrayitem( 'data')
ljson1.setattribute( 'colid', 3)
ljson1.setattribute( 'colname', 'cccccc')
 
ljson.setattribute( 'creattime', string(now(), 'yyyymmdd.hhmmss'))
 
ls_content =  ljson.getformatjson('' )
destroy ljson
Limitaciones

Se identifica que actualmente la versión de Appeon (2013/2016) presenta problemas con el procesamiento del API Json para estructuras complejas como Arrays por esta razon cada procesamiento del API debe ser realizado a un solo nivel de complejidad por cada registro que realice operaciones DML. A continuacion se muestra un ejemplo de uso funcional en Appeon/Powerbuilder que puede ser tomado como referencia.

/*PASO 1: Definir un objeto de la clase sailjson en la zona de instancia del componente donde se va utilizar el API como una ventana, objeto no visual, etc*/
sailjson iuo_json
/*PASO 2: Incializar el objeto iuo_json antes de utilizarlo*/
iuo_json= create sailjson
/*
PASO 3: No es obligatorio, pero se recomienda crear un método local de asignación para simplificar el proceso como ejemplo se define metodo of_add_log_transactional con los siguientes argumentos
string as_dataobject
string as_column
string as_old_value
string as_new_value
*/
 
//Validaciones previas de control
if IsNull(as_dataobject) then return
if IsNull(as_column) then return
if IsNull(as_old_value) then as_old_value = ""
if IsNull(as_new_value) then as_new_value = ""
 
//Crear propiedad de la columna con el valor anterior
iuo_json.setattribute(as_dataobject + "." + as_column + "_OldValue", as_old_value)
 
//Crear propiedad de la columna con el nuevo valor
iuo_json.setattribute(as_dataobject + "." + as_column + "_NewValue", as_new_value)
//En el metodo de guardado del proceso consumir el API de Log de transacciones con el objeto json
guo_app.of_log_transactional( ).of_add_log(Date(ldt_fecha), "w_conexion_cliente_fe::guardar", "update", 'TBL_FE_CONEXION_CLIENTE', iuo_json, true, ts_transaccion)
 
//Por último se debe reiniciar el componente para otro proceso
iuo_json = Create sailjson
//En el evento itemchanged del datawindow consumir el método local of_add_log_transactional
String ls_column, ls_old_data
ls_column = dwo.name
Choose Case ls_column
  Case 'codigo_cliente'		
    ls_old_data = getitemstring(row, ls_column)
    of_add_log_transactional(dataobject, ls_column, ls_old_data, data)
End Choose

Modo de uso: Java

Para las aplicaciones desarrolladas en las tecnologías (Web):

el log de sesión será implementado por medio de un Servicio Web el cual deberá considerar las reglas de Columna: WS

←Volver atras

1)
Define las reglas que debe aplicar el Web Service
2)
Valores anteriores y Actuales según corresponda