cozmostars / bitacorizable
Trait Bitacorizable - Laravel 10+ para registrar bitácoras automáticas de cualquier modelo
Installs: 7
Dependents: 0
Suggesters: 0
Security: 0
Stars: 0
Watchers: 1
Forks: 0
Open Issues: 0
pkg:composer/cozmostars/bitacorizable
Requires
- php: ^8.1
- illuminate/support: ^10.0|^11.0|^12.0
README
Bitacorizable es un Trait para Laravel 10+ que registra automáticamente bitácoras (logs) en la base de datos cuando se crean, actualizan o eliminan modelos Eloquent.
Registra en la tabla bitacoras el historial detallado de los cambios, con los campos modificados y sus valores antes/después.
🔒 Los campos sensibles como
passwordse excluyen automáticamente.
Desarrollado por CozmoStars 🛠
🚀 Instalación
Requiere PHP >= 8.1 y Laravel 10.x, 11.x o 12.x.
composer require cozmostars/bitacorizable
Laravel registrará automáticamente el Service Provider gracias a extra.laravel.providers.
📂 Publicar migración personalizada
Este paquete incluye una migración que puedes publicar y modificar si tu tabla users no usa id como clave primaria (por ejemplo, si usas idUsuario):
php artisan vendor:publish --tag=bitacorizable-migrations
Luego edita la migración publicada y ajusta la clave foránea si es necesario:
$table->foreign('user_id')->references('idUsuario')->on('users');
Y después ejecuta:
php artisan migrate
⚠️ Si no necesitas modificar la migración, puedes simplemente correr
php artisan migratesin publicar nada.
⚙️ Uso
Agrega el trait Bitacorizable a cualquier modelo que quieras auditar:
use CozmoStars\Bitacorizable\Bitacorizable; class User extends Model { use Bitacorizable; }
¡Y listo! Cualquier create, update o delete sobre este modelo será registrado automáticamente en la tabla bitacoras.
🧠 ¿Qué registra?
| Evento | ¿Qué guarda? |
|---|---|
| created | Todos los campos iniciales del modelo (excluyendo los ignorados) |
| updated | Solo los campos modificados con su valor antes y después |
| deleted | Todos los valores del modelo antes de eliminarlo |
📄 Ejemplo de log generado
🔹 UPDATE
{
"name": {
"antes": "Said Guerrero",
"después": "Said G."
},
"email": {
"antes": "said@example.com",
"después": "contacto@cozmostars.dev"
}
}
🔹 CREATED
{
"name": "Said Guerrero",
"email": "said@example.com",
"curp": "GUFA950919HDFRRD05"
}
🔹 DELETED
{
"id": 14,
"name": "Empleado Inactivo",
"email": "empleado@empresa.com"
}
🧩 Tabla bitacoras
| Campo | Descripción |
|---|---|
id |
ID autoincremental |
user_id |
Usuario que ejecutó la acción (nullable) |
model_type |
Clase del modelo afectado (ej. App\Models\User) |
model_id |
ID del modelo afectado |
mensaje |
Descripción textual (Registro creado, etc.) |
codigo |
Código del evento (create, update, delete) |
log |
JSON con los valores previos y posteriores |
created_at |
Fecha de la acción |
❌ Exclusión de campos
Se excluyen por defecto:
created_atupdated_atpassword
Puedes agregar más en tu modelo:
protected array $bitacoraCamposIgnorados = [ 'remember_token', 'api_token', ];
🧬 Relación con el modelo original
El modelo Bitacora define una relación polimórfica model() que te permite acceder al registro afectado:
$bitacora = Bitacora::first(); $registroOriginal = $bitacora->model; // Ej. instancia de User, Post, etc.
✨ Ejemplo de consulta desde tu app
Bitacora::where('model_type', 'App\\Models\\User') ->where('model_id', 9) ->latest() ->get();
📦 Requerimientos
- Laravel 10, 11 o 12
- PHP 8.1 o superior
- Base de datos compatible con
jsonb(idealmente PostgreSQL, aunque también funciona con MySQL 5.7+)
💡 Contribuciones
Si deseas aportar mejoras, sugerencias o reportar errores, eres bienvenido a participar en el repositorio:
👉 https://github.com/cozmostars/bitacorizable
📄 Licencia
MIT © 2025 Said Guerrero