filipefernandes/laravel-model-access-audit 问题修复 & 功能扩展

解决BUG、新增功能、兼容多环境部署,快速响应你的开发需求

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

filipefernandes/laravel-model-access-audit

Composer 安装命令:

composer require filipefernandes/laravel-model-access-audit

包简介

Track, store, and visualize access and mutations of sensitive Eloquent models in enterprise applications.

README 文档

README

Track, store, and visualize access and mutations of sensitive Eloquent models in enterprise applications. This package provides a Telescope-inspired dashboard for auditing with advanced relationship and field-level tracking.

Features

  • Comprehensive Event Tracking: Logs read, create, update, delete, and restore.
  • Relation Auditing:
    • Automatic: Detects and labels foreign key changes (e.g., user_id -> Owner).
    • Reciprocal: Automatically logs the inverse change on related models (e.g., Post changed? Log on User too).
    • Manual: Helper for pivot changes (attach, detach, sync).
  • Field-Level Control: Explicitly include or exclude specific attributes from logs.
  • Dashboard:
    • Dynamic Sidebar: Lists all auditable models automatically.
    • Real-time Feel: Quick reload and purge buttons.
    • Diff Viewer: Premium side-by-side comparison of changes.
  • Masking: Protect sensitive fields (passwords, tokens) with [MASKED].
  • Performance: Optional queued logging for high-traffic apps.

Installation

composer require filipefernandes/laravel-model-access-audit

Publish configuration and assets:

php artisan vendor:publish --provider="FilipeFernandes\ModelAccessAudit\ModelAccessAuditServiceProvider"
php artisan migrate

Usage

1. Basic Setup

Add the Auditable trait and implement the AuditableModel contract.

use FilipeFernandes\ModelAccessAudit\Traits\Auditable;
use FilipeFernandes\ModelAccessAudit\Contracts\AuditableModel;

class Document extends Model implements AuditableModel {
    use Auditable;
}

2. Field-Level Auditing

Control exactly what gets logged.

class User extends Model implements AuditableModel {
    use Auditable;

    // Only log these fields
    protected array $auditInclude = ['name', 'role'];

    // OR exclude specific fields
    protected array $auditExclude = ['remember_token'];
}

3. Relation Auditing

Track foreign key changes with human-readable labels. To enable Reciprocal Auditing (logging on both models), provide the inverse relationship name.

class Post extends Model implements AuditableModel {
    use Auditable;

    protected array $auditRelations = [
        // 'foreign_key' => ['label', 'inverse_relation_on_target']
        'user_id' => ['owner', 'posts'],
    ];
}

For ManyToMany (pivots), use the manual helper. You can pass an optional inverse relation name for reciprocal logging:

// User #12 attaches Role #3 -> Also logs on Role #3 for 'users' relation
$user->auditRelation('roles', 'attach', [3], [], 'users');

4. Masking

Mask sensitive data globally in config/audit.php or per model:

protected array $auditMasked = ['ssn_number'];

Dashboard & Security

Access the dashboard at /audit.

Authorization: Define the viewAuditDashboard gate in your AuthServiceProvider:

Gate::define('viewAuditDashboard', function ($user) {
    return $user->isSystemAdmin();
});

Retrieving Audits

1. Basic Retrieval

// Via relationship
$history = $model->audits;

// Via scopes
$logs = Audit::for($model)->latest()->get();
$logs = Audit::byUser($user)->between($start, $end)->get();

2. Timeline & History

Retrieve a human-readable stream of events or a detailed history collection.

// Returns a collection of formatted strings: "[2026-03-09] Email changed"
$timeline = $user->timeline();

// Returns a collection of Audit instances (stable id-based ordering)
$history = $user->history();

Configuration

Review config/audit.php to customize:

  • queue: Enable background processing.
  • route_prefix: Change /audit to something else.
  • log_reads: Toggle read access tracking.

License

The MIT License (MIT).

统计信息

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

GitHub 信息

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

其他信息

  • 授权协议: MIT
  • 更新时间: 2026-03-14

承接程序开发

PHP开发

VUE

Vue开发

前端开发

小程序开发

公众号开发

系统定制

数据库设计

云部署

网站建设

安全加固