承接 umairhanifdev/laravel-table-logger 相关项目开发

从需求分析到上线部署,全程专人跟进,保证项目质量与交付效率

邮箱:yvsm@zunyunkeji.com | QQ:316430983 | 微信:yvsm316

umairhanifdev/laravel-table-logger

最新稳定版本:2.0.2

Composer 安装命令:

composer require umairhanifdev/laravel-table-logger

包简介

Automated Laravel model auditing and application log management with dynamic table creation. Tracks all model changes (create/update/delete) in dedicated log tables while maintaining native Laravel conventions. Provides comprehensive activity monitoring without database modifications.

README 文档

README

A Laravel package to automatically or manually log model events (create, update, delete) either to the database or file system, based on .env configuration.

🚀 Features

  • 🔁 Automatically logs create, update, delete actions on models

  • ⚙️ Supports both database and file logging via .env

  • 🧠 Easily retrieve logs using model relationships

  • 🔧 Manually log any action without relying on model events

  • 📁 Structured file-based logs per table and record

  • 📦 Simple to integrate via Eloquent traits

📦 Installation

composer  require  umairhanifdev/laravel-table-logger

⚙️ Configuration

Publish config (optional):

php  artisan  vendor:publish  --tag=config

Set logging driver in your .env:

TABLE_LOGGER_DRIVER=database # or "file"
  • database: Logs are stored in {table_name}_logs tables

  • file: Logs are stored in storage/logs/umairhanifdev/{table}/{id}.log

📘 Usage

1. Eloquent Model Logging

Step 1: Add Traits

Add the following traits to your Eloquent model. Once added, logs will automatically be generated on create, update, and delete actions.

use UmairHanif\LaravelTableLogger\Traits\Loggable;

use UmairHanif\LaravelTableLogger\Traits\HasLogs;

  

class  ExaminationReport  extends  Model

{

use  Loggable, HasLogs;

}

2. Retrieve Stored Logs

Logs for a Single Model Record

$report = ExaminationReport::find($id);

$reportLogs = $report->logs()->get();

Logs for Multiple Records

$examReports = ExaminationReport::where('user_id', 16)->get();

$examinationLogs = $examReports->logsBatch()

->where('this_log_action', 'update') // optional filter

->get();

3. Manual Logging (No Eloquent Required)

You can manually log an action without triggering Eloquent events:

use UmairHanif\LaravelTableLogger\Helpers\LoggerLog;

  

LoggerLog::logAction('examination_reports', $id, 'delete');

DB::table('examination_reports')->where('id', $id)->delete();

4. Nested Logs via Relationships

If your model (e.g., User) has child models using logs (e.g., ExaminationReport), you can retrieve logs as:

$user = User::with(['examination' => function ($q) {

$q->whereStatus(1)->orderBy('id', 'DESC');

}])->find($id);

  

// Logs for the parent model (User)

$usersLogs = $user->logs()->get();

  

// Logs for nested model (Examinations)

$examinationLogs = collect();

if ($user->examination) {

$examinationLogs = $user->examination->logsBatch()

->where('this_log_action', 'update') //optional - to filter the logs futher

->get();

}

🗃️ Log Table Naming Convention

Log tables are automatically named using the singular form of the model table name + _logs. Example: usersuser_logs

You can define custom mappings for irregular plurals:

'irregular_plurals' => [

'people' => 'person',

'children' => 'child',

'men' => 'man',

'women' => 'woman',

],

📂 File-based Log Format

When using TABLE_LOGGER_DRIVER=file, logs are saved as JSON files in:


storage/logs/umairhanifdev/{table}/{id}.log

Each file will contain all logs of a specific record.

📝 License

MIT

Built with ❤️ by Umair Hanif

🌐 umairhanif.com

📫 hello@umairhanif.com

🔗 LinkedIn

统计信息

  • 总下载量: 6
  • 月度下载量: 0
  • 日度下载量: 0
  • 收藏数: 0
  • 点击次数: 0
  • 依赖项目数: 0
  • 推荐数: 0

GitHub 信息

  • Stars: 0
  • Watchers: 0
  • Forks: 0
  • 开发语言: PHP

其他信息

  • 授权协议: MIT
  • 更新时间: 2025-06-22