Necesito algo para dejar asentado quién fue el usuario que editó un registro. Como información de auditoría.
Una excelente idea. La auditoría es una práctica fundamental en cualquier sistema para mantener la integridad de los datos y la rendición de cuentas. Implementar un registro de quién y cuándo se hizo un cambio es crucial.
La estrategia más común y robusta para lograrlo es agregar columnas a tus tablas para rastrear la información de auditoría.
Estrategia de Backend y Base de Datos
La forma más sencilla de implementar esto es añadir dos columnas a cada tabla que quieras auditar.
updated_by_user_id
: Un entero que almacenará el ID del usuario que realizó la última modificación. Puede ser una clave foránea si tienes una tabla deusers
.updated_at
: Un timestamp que registrará la fecha y hora exacta de la última modificación.
Tu tabla offices
, por ejemplo, quedaría de la siguiente manera:
CREATE TABLE offices (
id BIGINT UNSIGNED AUTO_INCREMENT PRIMARY KEY,
name VARCHAR(255) NOT NULL,
address VARCHAR(255) NOT NULL,
created_at TIMESTAMP NULL,
updated_at TIMESTAMP NULL,
updated_by_user_id BIGINT UNSIGNED NULL,
FOREIGN KEY (updated_by_user_id) REFERENCES users(id) ON DELETE SET NULL
);
En Laravel con Eloquent
En Laravel, puedes automatizar esto usando eventos de modelos (Model Events
) o observers. Los eventos updating
y saving
son perfectos para esta tarea, ya que se activan antes de que el registro se guarde en la base de datos.
Con este código, cada vez que un registro Office
se actualice, Laravel verificará si hay un usuario autenticado y, de ser así, llenará automáticamente la columna updated_by_user_id
antes de guardar el cambio.
Estrategia de Frontend con React e Inertia
En el frontend, no necesitas hacer ningún cambio explícito para que esto funcione. La información de auditoría se manejará completamente en el backend.
Sin embargo, para mostrar esta información al usuario final, puedes modificar tu componente de React para renderizar estas columnas en una tabla. Esto puede ser útil para que el personal sepa quién hizo el último cambio.
Con esta estrategia, cada vez que un registro se actualice, el backend registrará el usuario que lo hizo, y el frontend puede mostrar esta información de forma transparente.
No hay comentarios:
Publicar un comentario