Back to Laravel Activitylog

Introduction

docs/introduction.md

5.0.02.5 KB
Original Source

The spatie/laravel-activitylog package provides easy to use functions to log the activities of the users of your app. It can also automatically log model events. All activity will be stored in the activity_log table.

Here's a little demo of how you can use it:

php
activity()->log('Look mum, I logged something');

You can retrieve all activity using the Spatie\Activitylog\Models\Activity model.

php
Activity::all();

Here's a more advanced example:

php
activity()
   ->performedOn($anEloquentModel)
   ->causedBy($user)
   ->withProperties(['customProperty' => 'customValue'])
   ->log('Look mum, I logged something');

$lastLoggedActivity = Activity::all()->last();

$lastLoggedActivity->subject; //returns an instance of an eloquent model
$lastLoggedActivity->causer; //returns an instance of your user model
$lastLoggedActivity->getProperty('customProperty'); //returns 'customValue'
$lastLoggedActivity->description; //returns 'Look mum, I logged something'

Here's an example on event logging.

php
$newsItem->name = 'updated name';
$newsItem->save();

//updating the newsItem will cause an activity to be logged
$activity = Activity::all()->last();

$activity->description; //returns 'updated'
$activity->subject; //returns the instance of NewsItem that was updated

Calling $activity->attribute_changes will return this collection:

php
[
    'attributes' => [
        'name' => 'updated name',
        'text' => 'Lorem',
    ],
    'old' => [
        'name' => 'original name',
        'text' => 'Lorem',
    ],
];

We have badges!

<section class="article_badges"> <a href="https://packagist.org/packages/spatie/laravel-activitylog"></a> <a href="https://github.com/spatie/laravel-activitylog/actions/workflows/run-tests.yml"></a> <a href="https://github.com/spatie/laravel-activitylog/blob/main/LICENSE.md"></a> <a href="https://packagist.org/packages/spatie/laravel-activitylog"></a> </section>