snipe-it/app/Models/Actionlog.php

235 lines
6.7 KiB
PHP
Raw Normal View History

2016-03-25 01:18:05 -07:00
<?php
namespace App\Models;
use App\Presenters\Presentable;
2016-03-25 01:18:05 -07:00
use Illuminate\Database\Eloquent\Model;
use Illuminate\Database\Eloquent\SoftDeletes;
use Illuminate\Support\Facades\Auth;
use Response;
2017-08-28 17:20:20 -07:00
use Carbon;
2016-03-25 01:18:05 -07:00
2016-04-07 13:21:09 -07:00
/**
* Model for the Actionlog (the table that keeps a historical log of
* checkouts, checkins, and updates).
*
* @version v1.0
*/
class Actionlog extends SnipeModel
2016-03-25 01:18:05 -07:00
{
protected $presenter = "App\Presenters\ActionlogPresenter";
2016-03-25 01:18:05 -07:00
use SoftDeletes;
use Presentable;
2016-03-25 01:18:05 -07:00
protected $dates = [ 'deleted_at' ];
protected $table = 'action_logs';
2016-03-25 01:18:05 -07:00
public $timestamps = true;
protected $fillable = [ 'created_at', 'item_type','user_id','item_id','action_type','note','target_id', 'target_type' ];
2016-03-25 01:18:05 -07:00
// Overridden from Builder to automatically add the company
public static function boot()
2016-03-25 01:18:05 -07:00
{
parent::boot();
2016-12-29 14:02:18 -08:00
static::creating(function (Actionlog $actionlog) {
// If the admin is a superadmin, let's see if the target instead has a company.
if (Auth::user() && Auth::user()->isSuperUser()) {
if ($actionlog->target) {
$actionlog->company_id = $actionlog->target->company_id;
2016-12-29 14:02:18 -08:00
} elseif ($actionlog->item) {
$actionlog->company_id = $actionlog->item->company_id;
}
2016-12-29 14:02:18 -08:00
} elseif (Auth::user() && Auth::user()->company) {
$actionlog->company_id = Auth::user()->company_id;
}
});
2016-03-25 01:18:05 -07:00
}
// Eloquent Relationships below
public function item()
2016-03-25 01:18:05 -07:00
{
return $this->morphTo('item')->withTrashed();
2016-03-25 01:18:05 -07:00
}
2016-12-29 14:02:18 -08:00
public function company()
{
return $this->hasMany('\App\Models\Company', 'id', 'company_id');
}
public function itemType()
2016-03-25 01:18:05 -07:00
{
2016-09-20 00:45:25 -07:00
2016-12-29 14:02:18 -08:00
if ($this->item_type == AssetModel::class) {
return "model";
}
return camel_case(class_basename($this->item_type));
2016-03-25 01:18:05 -07:00
}
2017-05-23 14:31:14 -07:00
public function targetType()
{
if ($this->target_type == User::class) {
return "user";
}
return camel_case(class_basename($this->target_type));
}
2016-12-29 14:02:18 -08:00
public function parseItemRoute()
{
2016-12-15 20:52:39 -08:00
if ($this->itemType() == "asset") {
$itemroute = 'assets';
} elseif ($this->itemType() == "accessory") {
$itemroute = 'accessories';
} elseif ($this->itemType()=="consumable") {
$itemroute = 'consumables';
2016-12-29 14:02:18 -08:00
} elseif ($this->itemType()=="license") {
2016-12-15 20:52:39 -08:00
$itemroute = 'licenses';
} elseif ($this->itemType()=="component") {
$itemroute = 'components';
} else {
$itemroute = '';
}
return $itemroute;
}
public function uploads()
2016-03-25 01:18:05 -07:00
{
return $this->morphTo('item')
->where('action_type', '=', 'uploaded')
2016-03-25 01:18:05 -07:00
->withTrashed();
}
public function userlog()
2016-03-25 01:18:05 -07:00
{
return $this->target();
2016-03-25 01:18:05 -07:00
}
public function user()
2016-03-25 01:18:05 -07:00
{
return $this->belongsTo(User::class, 'user_id')
2016-03-25 01:18:05 -07:00
->withTrashed();
}
public function target()
2016-03-25 01:18:05 -07:00
{
return $this->morphTo('target')->withTrashed();
2016-08-02 05:06:17 -07:00
}
2016-03-25 01:18:05 -07:00
public function childlogs()
{
return $this->hasMany('\App\Models\ActionLog', 'thread_id');
}
public function parentlog()
{
return $this->belongsTo('\App\Models\ActionLog', 'thread_id');
}
2017-08-25 18:40:20 -07:00
public function location() {
return $this->belongsTo('\App\Models\Location', 'location_id' )->withTrashed();
}
2016-03-25 01:18:05 -07:00
/**
* Check if the file exists, and if it does, force a download
**/
public function get_src($type = 'assets', $fieldname = 'filename')
2016-03-25 01:18:05 -07:00
{
$file = config('app.private_uploads') . '/' . $type . '/' . $this->{$fieldname};
2016-03-25 01:18:05 -07:00
return $file;
}
2016-03-25 01:18:05 -07:00
/**
* Get the parent category name
*/
public function logaction($actiontype)
{
$this->action_type = $actiontype;
if ($this->save()) {
return true;
} else {
return false;
}
}
2017-08-25 18:40:20 -07:00
public function daysUntilNextAudit($monthInterval = null, $asset = null) {
// check for next_audit_date to override global
if (!$monthInterval) {
$monthInterval = 12;
}
$last_audit_date = $this->created_at;
$next_audit_days = $last_audit_date->diffInDays($last_audit_date->copy()->addMonth($monthInterval));
// Override the default setting for interval if the asset has its own next audit date
if (($asset) && ($asset->next_audit_date)) {
$override_default_next = \Carbon::parse($asset->next_audit_date);
$suborder['payment_date'] = $override_default_next->format('M d Y');
$next_audit_days = $last_audit_date->diffInDays($override_default_next);
}
return $next_audit_days;
}
public function calcNextAuditDate($monthInterval = null, $asset = null) {
if (!$monthInterval) {
$monthInterval = 12;
}
$last_audit_date = Carbon::parse($this->created_at);
// If there is an asset-specific next date already given,
if (($asset) && ($asset->next_audit_date)) {
2017-08-28 17:20:20 -07:00
return \Carbon::parse($asset->next_audit_date);
2017-08-25 18:40:20 -07:00
}
2017-08-28 17:20:20 -07:00
return \Carbon::parse($last_audit_date)->addMonths($monthInterval)->toDateString();
2017-08-25 18:40:20 -07:00
}
2016-03-25 01:18:05 -07:00
/**
* getListingOfActionLogsChronologicalOrder
*
* @return mixed
* @author Vincent Sposato <vincent.sposato@gmail.com>
* @version v1.0
*/
public function getListingOfActionLogsChronologicalOrder()
{
return $this->all()
2016-03-25 01:18:05 -07:00
->where('action_type', '!=', 'uploaded')
->orderBy('item_id', 'asc')
2016-03-25 01:18:05 -07:00
->orderBy('created_at', 'asc')
->get();
}
/**
* Query builder scope to search on text for complex Bootstrap Tables API
*
* @param Illuminate\Database\Query\Builder $query Query builder instance
* @param text $search Search term
*
* @return Illuminate\Database\Query\Builder Modified query builder
*/
public function scopeTextSearch($query, $search)
{
$search = explode(' OR ', $search);
return $query->where(function ($query) use ($search) {
foreach ($search as $search) {
$query->where(function ($query) use ($search) {
$query->whereHas('company', function ($query) use ($search) {
$query->where('companies.name', 'LIKE', '%'.$search.'%');
});
})->orWhere('action_type', 'LIKE', '%'.$search.'%')
->orWhere('note', 'LIKE', '%'.$search.'%');
}
});
}
2016-03-25 01:18:05 -07:00
}