mirror of
https://github.com/snipe/snipe-it.git
synced 2025-01-12 14:27:33 -08:00
2d8269ddcd
* Create a new action_log table to replace asset_log. Use Polymorphism to generalize class and targets. Port everything I can find to use it. Add a migration to port the asset_logs table to action_logs. * Initial work on requestable asset models * Backend work for polymorphic requests table to store checkout requests. * Add missing files * Add a record to the db when requesting items. Build up a testing route for interfacing with this. * Users can now toggle requests of items on the request page. Reformat page to use the same tab layout we use elsewhere * Polymorphic request function. Implement requesting of asset models. Need to port mail/slack to notifications still. * Implement requesting of asset models. Build up emails and notifications to support it. Allow specifying a quantity of model to request. * Add view to show currently requested assets. Needs some work and cleanup, but it isn't accessible from anywhere yet.
183 lines
4.8 KiB
PHP
Executable file
183 lines
4.8 KiB
PHP
Executable file
<?php
|
|
namespace App\Models;
|
|
|
|
use App\Models\Requestable;
|
|
use Illuminate\Database\Eloquent\Model;
|
|
use Illuminate\Database\Eloquent\SoftDeletes;
|
|
use Watson\Validating\ValidatingTrait;
|
|
|
|
/**
|
|
* Model for Asset Models. Asset Models contain higher level
|
|
* attributes that are common among the same type of asset.
|
|
*
|
|
* @version v1.0
|
|
*/
|
|
class AssetModel extends Model
|
|
{
|
|
use SoftDeletes;
|
|
use Requestable;
|
|
protected $dates = ['deleted_at'];
|
|
protected $table = 'models';
|
|
|
|
// Declare the rules for the model validation
|
|
protected $rules = array(
|
|
'name' => 'required|min:1|max:255',
|
|
'modelno' => 'min:1|max:255',
|
|
'category_id' => 'required|integer',
|
|
'manufacturer_id' => 'required|integer',
|
|
'eol' => 'integer:min:0|max:240',
|
|
'user_id' => 'integer',
|
|
);
|
|
|
|
/**
|
|
* Whether the model should inject it's identifier to the unique
|
|
* validation rules before attempting validation. If this property
|
|
* is not set in the model it will default to true.
|
|
*
|
|
* @var boolean
|
|
*/
|
|
protected $injectUniqueIdentifier = true;
|
|
use ValidatingTrait;
|
|
|
|
/**
|
|
* The attributes that are mass assignable.
|
|
*
|
|
* @var array
|
|
*/
|
|
protected $fillable = ['name','manufacturer_id','category_id','eol'];
|
|
|
|
|
|
|
|
public function assets()
|
|
{
|
|
return $this->hasMany('\App\Models\Asset', 'model_id');
|
|
}
|
|
|
|
public function category()
|
|
{
|
|
return $this->belongsTo('\App\Models\Category', 'category_id');
|
|
}
|
|
|
|
public function depreciation()
|
|
{
|
|
return $this->belongsTo('\App\Models\Depreciation', 'depreciation_id');
|
|
}
|
|
|
|
public function adminuser()
|
|
{
|
|
return $this->belongsTo('\App\Models\User', 'user_id');
|
|
}
|
|
|
|
public function manufacturer()
|
|
{
|
|
return $this->belongsTo('\App\Models\Manufacturer', 'manufacturer_id');
|
|
}
|
|
|
|
public function fieldset()
|
|
{
|
|
return $this->belongsTo('\App\Models\CustomFieldset', 'fieldset_id');
|
|
}
|
|
|
|
public function getNote()
|
|
{
|
|
|
|
$Parsedown = new \Parsedown();
|
|
|
|
if ($this->note) {
|
|
return $Parsedown->text(e($this->note));
|
|
}
|
|
|
|
}
|
|
|
|
public function displayModelName()
|
|
{
|
|
$name = $this->manufacturer->name.' '.$this->name;
|
|
if ($this->modelno) {
|
|
$name .=" / ".$this->modelno;
|
|
}
|
|
return $name;
|
|
}
|
|
|
|
/**
|
|
* -----------------------------------------------
|
|
* BEGIN QUERY SCOPES
|
|
* -----------------------------------------------
|
|
**/
|
|
|
|
/**
|
|
* Query builder scope for Deleted assets
|
|
*
|
|
* @param Illuminate\Database\Query\Builder $query Query builder instance
|
|
* @return Illuminate\Database\Query\Builder Modified query builder
|
|
*/
|
|
|
|
public function scopeDeleted($query)
|
|
{
|
|
return $query->whereNotNull('deleted_at');
|
|
}
|
|
|
|
/**
|
|
* scopeInCategory
|
|
* Get all models that are in the array of category ids
|
|
*
|
|
* @param $query
|
|
* @param array $categoryIdListing
|
|
*
|
|
* @return mixed
|
|
* @author Vincent Sposato <vincent.sposato@gmail.com>
|
|
* @version v1.0
|
|
*/
|
|
public function scopeInCategory($query, array $categoryIdListing)
|
|
{
|
|
|
|
return $query->whereIn('category_id', $categoryIdListing);
|
|
}
|
|
|
|
/**
|
|
* scopeRequestable
|
|
* Get all models that are requestable by a user.
|
|
*
|
|
* @param $query
|
|
*
|
|
* @return $query
|
|
* @author Daniel Meltzer <parallelgrapefruit@gmail.com
|
|
* @version v3.5
|
|
*/
|
|
public function scopeRequestableModels($query)
|
|
{
|
|
|
|
return $query->where('requestable', '1');
|
|
}
|
|
|
|
/**
|
|
* Query builder scope to search on text
|
|
*
|
|
* @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)
|
|
{
|
|
|
|
return $query->where('name', 'LIKE', "%$search%")
|
|
->orWhere('modelno', 'LIKE', "%$search%")
|
|
->orWhere(function ($query) use ($search) {
|
|
$query->whereHas('depreciation', function ($query) use ($search) {
|
|
$query->where('name', 'LIKE', '%'.$search.'%');
|
|
});
|
|
})
|
|
->orWhere(function ($query) use ($search) {
|
|
$query->whereHas('category', function ($query) use ($search) {
|
|
$query->where('name', 'LIKE', '%'.$search.'%');
|
|
});
|
|
})
|
|
->orWhere(function ($query) use ($search) {
|
|
$query->whereHas('manufacturer', function ($query) use ($search) {
|
|
$query->where('name', 'LIKE', '%'.$search.'%');
|
|
});
|
|
});
|
|
|
|
}
|
|
}
|