Download the PHP package testmonitor/laravel-accountable without Composer
On this page you can find all versions of the php package testmonitor/laravel-accountable. It is possible to download/install these versions without Composer. Possible dependencies are resolved automatically.
Download testmonitor/laravel-accountable
More information about testmonitor/laravel-accountable
Files in testmonitor/laravel-accountable
Package laravel-accountable
Short Description Tracks the user responsible for creating, modifying, or deleting an Eloquent model
License MIT
Informations about the package laravel-accountable
Accountable Eloquent models
This package provides a trait that tracks the user responsible for creating, modifying, or deleting an Eloquent model.
Accountable will observe any activity on your models and it sets the created_by_user_id, updated_by_user_id, and deleted_by_user_id accordingly using the currently authenticated user.
It also provides you with some useful scope query functions, allowing you to fetch models that were either created, modified, or deleted by a specific user.
Table of Contents
- Installation
- Usage
- Using the Migration helper
- Using the Trait
- Examples
- Tests
- Changelog
- Contributing
- Credits
- License
Installation
This package can be installed through Composer:
The package will automatically register itself.
Optionally, publish the configuration file:
The configuration file allows you to set the preferred authentication driver, the database column names, and anonymous user. The latter can be used to deal with records created/updated by unauthenticated users.
When left untouched, Accountable will use the default authentication driver and the default column names (created_by_user_id, updated_by_user_id, and deleted_by_user_id).
Usage
In order to add Accountable to your Laravel application, you'll need to:
- Add the required columns to your migration file(s).
- Use the trait on your model(s).
Please note that due to the nature of Laravel event system, mass updates will not be handled by Accountable.
Using the Migration helper
The migration helper simplifies the process of adding columns to your migration:
Tip: if you do not use soft-deletes on your model, use Accountable::columns($table, false)
to prevent
the helper from adding a deleted_by_user_id column.
Using the Trait
Add the Accountable trait on the models you want to track:
Examples
Set up your model and make sure you are authenticated.
Basics
Create a project and show the name of the user that created it:
Get all projects created by a specific user:
Properties
You can use the following properties and methods to reveal the user responsible for creating, updating or deleting the record.
Scope Queries
The following scope queries are at your disposal:
Disable Logging
In some cases, you don't want to automatically save the user along
with the model (for example: when seeding test data). You can disable
accountable by using the disableUserLogging
method.
If you want to re-enable accountable, simply use the enableUserLogging
method afterwards.
Impersonation
When authentication is not available - for example, when running jobs
in a queue - you might want to "impersonate" a user. Simply override
user identification with the actingAs
method:
You can end the impersonation by calling the reset
method.
Tests
The package contains integration tests. You can run them using PHPUnit.
Changelog
Refer to CHANGELOG for more information.
Contributing
Refer to CONTRIBUTING for contributing details.
Credits
- Thijs Kok - Lead developer - ThijsKok
- Stephan Grootveld - Developer - Stefanius
- Frank Keulen - Developer - FrankIsGek
- Muriel Nooder - Developer - ThaNoodle
- All Contributors
License
The MIT License (MIT). Refer to the License for more information.
All versions of laravel-accountable with dependencies
illuminate/support Version ^11.0
illuminate/database Version ^11.0
illuminate/config Version ^11.0
illuminate/contracts Version ^11.0