snipe-it/app/Models/CheckoutAcceptance.php

137 lines
3.6 KiB
PHP
Raw Normal View History

<?php
namespace App\Models;
use Illuminate\Database\Eloquent\Builder;
2023-05-03 14:21:13 -07:00
use Illuminate\Database\Eloquent\Factories\HasFactory;
use Illuminate\Database\Eloquent\Model;
use Illuminate\Database\Eloquent\SoftDeletes;
use Illuminate\Notifications\Notifiable;
class CheckoutAcceptance extends Model
{
2023-05-03 14:21:13 -07:00
use HasFactory, SoftDeletes, Notifiable;
protected $casts = [
'accepted_at' => 'datetime',
'declined_at' => 'datetime',
];
/**
* Get the mail recipient from the config
*
* @return mixed|string|null
*/
public function routeNotificationForMail()
{
// At this point the endpoint is the same for everything.
// In the future this may want to be adapted for individual notifications.
$recipients_string = explode(',', Setting::getSettings()->alert_email);
$recipients = array_map('trim', $recipients_string);
return array_filter($recipients);
}
2018-07-28 04:32:29 -07:00
/**
* The resource that was is out
*
2018-07-28 04:32:29 -07:00
* @return Illuminate\Database\Eloquent\Relations\MorphTo
*/
public function checkoutable()
{
return $this->morphTo();
}
2018-07-28 04:32:29 -07:00
/**
* The user that the checkoutable was checked out to
*
2018-07-28 04:32:29 -07:00
* @return Illuminate\Database\Eloquent\Relations\BelongsTo
*/
public function assignedTo()
{
return $this->belongsTo(User::class);
}
2018-07-28 04:32:29 -07:00
/**
* Is this checkout acceptance pending?
*
* @return bool
2018-07-28 04:32:29 -07:00
*/
public function isPending()
{
return $this->accepted_at == null && $this->declined_at == null;
}
2018-07-28 04:32:29 -07:00
/**
* Was the checkoutable checked out to this user?
*
2018-07-28 04:32:29 -07:00
* @param User $user
* @return bool
2018-07-28 04:32:29 -07:00
*/
public function isCheckedOutTo(User $user)
{
return $this->assignedTo->is($user);
}
2018-07-28 04:32:29 -07:00
/**
* Add a record to the checkout_acceptance table ONLY.
* Do not add stuff here that doesn't have a corresponding column in the
* checkout_acceptances table or you'll get an error.
*
2018-07-28 04:32:29 -07:00
* @param string $signature_filename
*/
2024-04-03 11:36:03 -07:00
public function accept($signature_filename, $eula = null, $filename = null, $note = null)
{
$this->accepted_at = now();
$this->signature_filename = $signature_filename;
$this->stored_eula = $eula;
$this->stored_eula_file = $filename;
2024-04-03 11:36:03 -07:00
$this->note = $note;
$this->save();
/**
* Update state for the checked out item
*/
$this->checkoutable->acceptedCheckout($this->assignedTo, $signature_filename, $filename);
}
2018-07-28 04:32:29 -07:00
/**
* Decline the checkout acceptance
*
2018-07-28 04:32:29 -07:00
* @param string $signature_filename
*/
public function decline($signature_filename, $note = null)
{
$this->declined_at = now();
$this->note = $note;
$this->signature_filename = $signature_filename;
$this->save();
/**
* Update state for the checked out item
*/
$this->checkoutable->declinedCheckout($this->assignedTo, $signature_filename);
}
2018-07-28 04:32:29 -07:00
/**
* Filter checkout acceptences by the user
* @param Illuminate\Database\Eloquent\Builder $query
* @param User $user
* @return \Illuminate\Database\Eloquent\Builder
2018-07-28 04:32:29 -07:00
*/
public function scopeForUser(Builder $query, User $user)
{
return $query->where('assigned_to_id', $user->id);
}
2018-07-28 04:32:29 -07:00
/**
* Filter to only get pending acceptances
* @param Illuminate\Database\Eloquent\Builder $query
* @return \Illuminate\Database\Eloquent\Builder
2018-07-28 04:32:29 -07:00
*/
public function scopePending(Builder $query)
{
return $query->whereNull('accepted_at')->whereNull('declined_at');
}
}