mirror of
https://github.com/snipe/snipe-it.git
synced 2025-01-25 20:51:30 -08:00
770092f23f
This should make it easier to handle action logging between the GUI and the API
71 lines
1.7 KiB
PHP
71 lines
1.7 KiB
PHP
<?php
|
|
|
|
namespace App\Observers;
|
|
|
|
use App\Models\Asset;
|
|
use App\Models\Setting;
|
|
use App\Models\Actionlog;
|
|
use Auth;
|
|
|
|
class AssetObserver
|
|
{
|
|
/**
|
|
* Listen to the User created event.
|
|
*
|
|
* @param Asset $asset
|
|
* @return void
|
|
*/
|
|
public function updated(Asset $asset)
|
|
{
|
|
|
|
$logAction = new Actionlog();
|
|
$logAction->item_type = Asset::class;
|
|
$logAction->item_id = $asset->id;
|
|
$logAction->created_at = date("Y-m-d H:i:s");
|
|
$logAction->user_id = Auth::user()->id;
|
|
$logAction->logaction('update');
|
|
|
|
|
|
}
|
|
|
|
|
|
/**
|
|
* Listen to the Asset created event, and increment
|
|
* the next_auto_tag_base value in the settings table when i
|
|
* a new asset is created.
|
|
*
|
|
* @param Asset $asset
|
|
* @return void
|
|
*/
|
|
public function created(Asset $asset)
|
|
{
|
|
$settings = Setting::first();
|
|
$settings->increment('next_auto_tag_base');
|
|
\Log::debug('Setting new next_auto_tag_base value');
|
|
|
|
$logAction = new Actionlog();
|
|
$logAction->item_type = Asset::class;
|
|
$logAction->item_id = $asset->id;
|
|
$logAction->created_at = date("Y-m-d H:i:s");
|
|
$logAction->user_id = Auth::user()->id;
|
|
$logAction->logaction('create');
|
|
|
|
}
|
|
|
|
/**
|
|
* Listen to the Asset deleting event.
|
|
*
|
|
* @param Asset $asset
|
|
* @return void
|
|
*/
|
|
public function deleting(Asset $asset)
|
|
{
|
|
$logAction = new Actionlog();
|
|
$logAction->item_type = Asset::class;
|
|
$logAction->item_id = $asset->id;
|
|
$logAction->created_at = date("Y-m-d H:i:s");
|
|
$logAction->user_id = Auth::user()->id;
|
|
$logAction->logaction('delete');
|
|
}
|
|
}
|