phpcollective / tracker
Track your Elequent Model
Installs: 130
Dependents: 0
Suggesters: 0
Security: 0
Stars: 3
Watchers: 1
Forks: 1
Open Issues: 0
pkg:composer/phpcollective/tracker
Requires
- php: >=7.1.3
- laravel/framework: >=5.7
Requires (Dev)
- phpunit/phpunit: ^7.0
This package is auto-updated.
Last update: 2025-10-31 00:19:43 UTC
README
By default, Eloquent automatically manage created_at and updated_at columns to exist on your tables. In addition to this it also manage a deleted_at attribute if the model use "soft delete". However it is very tedious job to manage who create/update the model as well as delete (if soft delete). This also a indication of code repetition.
If you wish to have these automatically managed by Eloquent, Tracker is a nice and convenient way to do this.
Install
You may use Composer to install the package into your Laravel project:
composer require phpcollective/tracker
Laravel 5.5+:
If you don't use auto-discovery, add the ServiceProvider to the providers array in config/app.php
PhpCollective\Tracker\TrackingServiceProvider::class,
Database: Migrations
To add created_by and updated_by columns in your table you want to track just use $table->track() method in your table migration file. For dropping the columns use $table->dropTrack().
Schema::create('table', function (Blueprint $table) { ... $table->track(); }); // To drop columns Schema::table('table', function (Blueprint $table) { $table->dropTrack(); });
If Your table contains soft delete columns, just pass boolean true in the method. It will add a deleted_by column in database.
Schema::create('table', function (Blueprint $table) { ... $table->softDeletes(); $table->track(true); }); // To drop columns with soft delete Schema::table('table', function (Blueprint $table) { $table->dropTrack(true); });
Model
Add Trackable trait in model you want to track. Now it will handle all CRUD event by the authenticate user.
<?php namespace App; use PhpCollective\Tracker\Trackable; use Illuminate\Database\Eloquent\Model; class Foo extends Model { use Trackable; ... }
Usage
Trackable trait provides three belongsTo relationship with Authenticated Users. creator(), editor(), destroyer()
$foo = App\Foo::first(); $foo->creator; $foo->editor; // If your model use soft delete $foo->destroyer;
Credits
License
Laravel Model Tracker is open-sourced software licensed under the MIT license.