2018-07-27 15:23:58 -07:00
|
|
|
<?php
|
|
|
|
|
|
|
|
namespace App\Listeners;
|
|
|
|
|
|
|
|
use App\Events\AccessoryCheckedIn;
|
|
|
|
use App\Events\AccessoryCheckedOut;
|
|
|
|
use App\Events\AssetCheckedIn;
|
|
|
|
use App\Events\AssetCheckedOut;
|
2018-07-28 03:45:33 -07:00
|
|
|
use App\Events\CheckoutAccepted;
|
|
|
|
use App\Events\CheckoutDeclined;
|
2018-07-27 15:23:58 -07:00
|
|
|
use App\Events\ComponentCheckedIn;
|
|
|
|
use App\Events\ComponentCheckedOut;
|
|
|
|
use App\Events\ConsumableCheckedOut;
|
2018-07-27 16:15:32 -07:00
|
|
|
use App\Events\ItemAccepted;
|
|
|
|
use App\Events\ItemDeclined;
|
2018-07-27 15:23:58 -07:00
|
|
|
use App\Events\LicenseCheckedIn;
|
|
|
|
use App\Events\LicenseCheckedOut;
|
|
|
|
use App\Models\Actionlog;
|
|
|
|
use App\Models\Asset;
|
|
|
|
use App\Models\Component;
|
2018-07-28 03:45:33 -07:00
|
|
|
use App\Models\LicenseSeat;
|
2018-07-27 15:23:58 -07:00
|
|
|
|
|
|
|
|
|
|
|
class LogListener
|
|
|
|
{
|
|
|
|
public function onAccessoryCheckedIn(AccessoryCheckedIn $event) {
|
|
|
|
$event->accessory->logCheckin($event->checkedOutTo, $event->note);
|
|
|
|
}
|
|
|
|
|
|
|
|
public function onAccessoryCheckedOut(AccessoryCheckedOut $event) {
|
|
|
|
$event->accessory->logCheckout($event->note, $event->checkedOutTo);
|
|
|
|
}
|
|
|
|
|
|
|
|
public function onAssetCheckedIn(AssetCheckedIn $event) {
|
|
|
|
$event->asset->logCheckin($event->checkedOutTo, $event->note);
|
|
|
|
}
|
|
|
|
|
|
|
|
public function onAssetCheckedOut(AssetCheckedOut $event) {
|
|
|
|
$event->asset->logCheckout($event->note, $event->checkedOutTo);
|
|
|
|
}
|
|
|
|
|
|
|
|
public function onComponentCheckedIn(ComponentCheckedIn $event) {
|
|
|
|
$log = new Actionlog();
|
|
|
|
$log->user_id = $event->checkedInBy->id;
|
|
|
|
$log->action_type = 'checkin from';
|
|
|
|
$log->target_type = Asset::class;
|
|
|
|
$log->target_id = $event->checkedOutTo->asset_id;
|
|
|
|
$log->item_id = $event->checkedOutTo->component_id;
|
|
|
|
$log->item_type = Component::class;
|
|
|
|
$log->note = $event->note;
|
|
|
|
$log->save();
|
|
|
|
}
|
|
|
|
|
|
|
|
public function onComponentCheckedOut(ComponentCheckedOut $event) {
|
2018-07-27 15:41:31 -07:00
|
|
|
// Since components don't have a "note" field, submit empty note
|
|
|
|
$event->component->logCheckout(null, $event->checkedOutTo);
|
2018-07-27 15:23:58 -07:00
|
|
|
}
|
|
|
|
|
|
|
|
public function onConsumableCheckedOut(ConsumableCheckedOut $event) {
|
|
|
|
$event->consumable->logCheckout($event->note, $event->checkedOutTo);
|
|
|
|
}
|
|
|
|
|
|
|
|
public function onLicenseCheckedIn(LicenseCheckedIn $event) {
|
|
|
|
$event->license->logCheckin($event->checkedOutTo, $event->note);
|
|
|
|
}
|
|
|
|
|
|
|
|
public function onLicenseCheckedOut(LicenseCheckedOut $event) {
|
|
|
|
$event->license->logCheckout($event->note, $event->checkedOutTo);
|
|
|
|
}
|
|
|
|
|
2018-07-28 03:45:33 -07:00
|
|
|
public function onCheckoutAccepted(CheckoutAccepted $event) {
|
2018-07-27 16:15:32 -07:00
|
|
|
$logaction = new Actionlog();
|
2018-07-28 03:45:33 -07:00
|
|
|
|
|
|
|
$logaction->item()->associate($event->acceptance->checkoutable);
|
|
|
|
$logaction->target()->associate($event->acceptance->assignedTo);
|
|
|
|
$logaction->accept_signature = $event->acceptance->signature_filename;
|
2018-07-27 16:15:32 -07:00
|
|
|
$logaction->action_type = 'accepted';
|
|
|
|
|
2018-07-28 03:45:33 -07:00
|
|
|
// TODO: log the actual license seat that was checked out
|
|
|
|
if($event->acceptance->checkoutable instanceof LicenseSeat) {
|
|
|
|
$logaction->item()->associate($event->acceptance->checkoutable->license);
|
|
|
|
}
|
|
|
|
|
2018-07-27 16:15:32 -07:00
|
|
|
$logaction->save();
|
|
|
|
}
|
|
|
|
|
2018-07-28 03:45:33 -07:00
|
|
|
public function onCheckoutDeclined(CheckoutDeclined $event) {
|
2018-07-27 16:15:32 -07:00
|
|
|
$logaction = new Actionlog();
|
2018-07-28 03:45:33 -07:00
|
|
|
$logaction->item()->associate($event->acceptance->checkoutable);
|
|
|
|
$logaction->target()->associate($event->acceptance->assignedTo);
|
|
|
|
$logaction->accept_signature = $event->acceptance->signature_filename;
|
2018-07-27 16:15:32 -07:00
|
|
|
$logaction->action_type = 'declined';
|
|
|
|
|
2018-07-28 03:45:33 -07:00
|
|
|
// TODO: log the actual license seat that was checked out
|
|
|
|
if($event->acceptance->checkoutable instanceof LicenseSeat) {
|
|
|
|
$logaction->item()->associate($event->acceptance->checkoutable->license);
|
|
|
|
}
|
|
|
|
|
2018-07-27 16:15:32 -07:00
|
|
|
$logaction->save();
|
|
|
|
}
|
|
|
|
|
2018-07-27 15:23:58 -07:00
|
|
|
/**
|
|
|
|
* Register the listeners for the subscriber.
|
|
|
|
*
|
|
|
|
* @param Illuminate\Events\Dispatcher $events
|
|
|
|
*/
|
|
|
|
public function subscribe($events)
|
|
|
|
{
|
|
|
|
$list = [
|
|
|
|
'AccessoryCheckedIn',
|
2018-07-27 15:41:31 -07:00
|
|
|
'AccessoryCheckedOut',
|
2018-07-27 15:23:58 -07:00
|
|
|
'AssetCheckedIn',
|
|
|
|
'AssetCheckedOut',
|
|
|
|
'ComponentCheckedIn',
|
|
|
|
'ComponentCheckedOut',
|
|
|
|
'ConsumableCheckedOut',
|
|
|
|
'LicenseCheckedIn',
|
|
|
|
'LicenseCheckedOut',
|
2018-07-28 03:45:33 -07:00
|
|
|
'CheckoutAccepted',
|
|
|
|
'CheckoutDeclined',
|
2018-07-27 15:23:58 -07:00
|
|
|
];
|
|
|
|
|
|
|
|
foreach($list as $event) {
|
|
|
|
$events->listen(
|
|
|
|
'App\Events\\' . $event,
|
|
|
|
'App\Listeners\LogListener@on' . $event
|
|
|
|
);
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
}
|