2017-01-13 04:50:20 -08:00
|
|
|
<?php
|
|
|
|
namespace App\Http\Controllers\Api;
|
|
|
|
|
|
|
|
use App\Models\AssetModel;
|
2017-01-26 21:02:59 -08:00
|
|
|
use App\Models\Asset;
|
2017-01-13 04:50:20 -08:00
|
|
|
use App\Http\Controllers\Controller;
|
|
|
|
use App\Helpers\Helper;
|
|
|
|
use Illuminate\Http\Request;
|
2017-01-24 22:25:17 -08:00
|
|
|
use App\Http\Transformers\AssetModelsTransformer;
|
2017-01-26 21:02:59 -08:00
|
|
|
use App\Http\Transformers\AssetsTransformer;
|
2017-10-26 21:50:01 -07:00
|
|
|
use App\Http\Transformers\SelectlistTransformer;
|
2017-01-13 04:50:20 -08:00
|
|
|
|
2017-01-25 02:19:26 -08:00
|
|
|
|
2017-01-13 04:50:20 -08:00
|
|
|
/**
|
|
|
|
* This class controls all actions related to asset models for
|
|
|
|
* the Snipe-IT Asset Management application.
|
|
|
|
*
|
|
|
|
* @version v4.0
|
|
|
|
* @author [A. Gianotto] [<snipe@snipe.net>]
|
|
|
|
*/
|
|
|
|
class AssetModelsController extends Controller
|
|
|
|
{
|
|
|
|
/**
|
|
|
|
* Display a listing of the resource.
|
|
|
|
*
|
|
|
|
* @author [A. Gianotto] [<snipe@snipe.net>]
|
|
|
|
* @since [v4.0]
|
|
|
|
* @return \Illuminate\Http\Response
|
|
|
|
*/
|
2017-01-13 08:18:22 -08:00
|
|
|
public function index(Request $request)
|
2017-01-13 04:50:20 -08:00
|
|
|
{
|
|
|
|
$this->authorize('view', AssetModel::class);
|
2018-01-11 15:21:51 -08:00
|
|
|
$allowed_columns = ['id','image','name','model_number','eol','notes','created_at','manufacturer','assets_count'];
|
2017-01-13 08:18:22 -08:00
|
|
|
|
2018-02-25 12:10:02 -08:00
|
|
|
$assetmodels = AssetModel::select([
|
|
|
|
'models.id',
|
|
|
|
'models.image',
|
|
|
|
'models.name',
|
|
|
|
'model_number',
|
|
|
|
'eol',
|
|
|
|
'models.notes',
|
|
|
|
'models.created_at',
|
|
|
|
'category_id',
|
|
|
|
'manufacturer_id',
|
|
|
|
'depreciation_id',
|
|
|
|
'fieldset_id',
|
|
|
|
'models.deleted_at',
|
|
|
|
'models.updated_at',
|
|
|
|
])
|
2017-01-13 08:39:02 -08:00
|
|
|
->with('category','depreciation', 'manufacturer','fieldset')
|
2019-05-22 00:52:51 -07:00
|
|
|
->withCount('assets as assets_count');
|
2017-01-13 08:18:22 -08:00
|
|
|
|
2018-01-11 15:17:34 -08:00
|
|
|
|
2017-01-13 08:18:22 -08:00
|
|
|
|
2017-10-03 17:53:08 -07:00
|
|
|
if ($request->has('status')) {
|
|
|
|
$assetmodels->onlyTrashed();
|
|
|
|
}
|
|
|
|
|
2018-01-11 15:17:34 -08:00
|
|
|
if ($request->has('search')) {
|
|
|
|
$assetmodels->TextSearch($request->input('search'));
|
|
|
|
}
|
2017-02-03 20:20:03 -08:00
|
|
|
|
2019-02-14 14:49:08 -08:00
|
|
|
$offset = (($assetmodels) && (request('offset') > $assetmodels->count())) ? 0 : request('offset', 0);
|
2017-01-13 08:18:22 -08:00
|
|
|
$limit = $request->input('limit', 50);
|
|
|
|
$order = $request->input('order') === 'asc' ? 'asc' : 'desc';
|
2017-02-03 20:20:03 -08:00
|
|
|
$sort = in_array($request->input('sort'), $allowed_columns) ? $request->input('sort') : 'models.created_at';
|
|
|
|
|
|
|
|
switch ($sort) {
|
|
|
|
case 'manufacturer':
|
|
|
|
$assetmodels->OrderManufacturer($order);
|
|
|
|
break;
|
|
|
|
default:
|
2017-10-30 21:26:25 -07:00
|
|
|
$assetmodels->orderBy($sort, $order);
|
2017-02-03 20:20:03 -08:00
|
|
|
break;
|
|
|
|
}
|
|
|
|
|
2017-01-13 08:18:22 -08:00
|
|
|
|
2018-01-11 15:17:34 -08:00
|
|
|
|
2017-01-13 08:18:22 -08:00
|
|
|
$total = $assetmodels->count();
|
|
|
|
$assetmodels = $assetmodels->skip($offset)->take($limit)->get();
|
2017-01-24 22:25:17 -08:00
|
|
|
return (new AssetModelsTransformer)->transformAssetModels($assetmodels, $total);
|
2017-01-13 04:50:20 -08:00
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
/**
|
|
|
|
* Store a newly created resource in storage.
|
|
|
|
*
|
|
|
|
* @author [A. Gianotto] [<snipe@snipe.net>]
|
|
|
|
* @since [v4.0]
|
|
|
|
* @param \Illuminate\Http\Request $request
|
|
|
|
* @return \Illuminate\Http\Response
|
|
|
|
*/
|
|
|
|
public function store(Request $request)
|
|
|
|
{
|
|
|
|
$this->authorize('create', AssetModel::class);
|
|
|
|
$assetmodel = new AssetModel;
|
|
|
|
$assetmodel->fill($request->all());
|
|
|
|
|
|
|
|
if ($assetmodel->save()) {
|
2017-08-24 22:24:02 -07:00
|
|
|
return response()->json(Helper::formatStandardApiResponse('success', $assetmodel, trans('admin/models/message.create.success')));
|
2017-01-13 04:50:20 -08:00
|
|
|
}
|
|
|
|
return response()->json(Helper::formatStandardApiResponse('error', null, $assetmodel->getErrors()));
|
|
|
|
|
|
|
|
}
|
|
|
|
|
|
|
|
/**
|
|
|
|
* Display the specified resource.
|
|
|
|
*
|
|
|
|
* @author [A. Gianotto] [<snipe@snipe.net>]
|
|
|
|
* @since [v4.0]
|
|
|
|
* @param int $id
|
|
|
|
* @return \Illuminate\Http\Response
|
|
|
|
*/
|
|
|
|
public function show($id)
|
|
|
|
{
|
|
|
|
$this->authorize('view', AssetModel::class);
|
2019-05-22 00:52:51 -07:00
|
|
|
$assetmodel = AssetModel::withCount('assets as assets_count')->findOrFail($id);
|
2017-01-24 22:25:17 -08:00
|
|
|
return (new AssetModelsTransformer)->transformAssetModel($assetmodel);
|
2017-01-13 04:50:20 -08:00
|
|
|
}
|
|
|
|
|
2017-01-26 21:02:59 -08:00
|
|
|
/**
|
|
|
|
* Display the specified resource's assets
|
|
|
|
*
|
|
|
|
* @author [A. Gianotto] [<snipe@snipe.net>]
|
|
|
|
* @since [v4.0]
|
|
|
|
* @param int $id
|
|
|
|
* @return \Illuminate\Http\Response
|
|
|
|
*/
|
|
|
|
public function assets($id)
|
|
|
|
{
|
|
|
|
$this->authorize('view', AssetModel::class);
|
|
|
|
$assets = Asset::where('model_id','=',$id)->get();
|
|
|
|
return (new AssetsTransformer)->transformAssets($assets, $assets->count());
|
|
|
|
}
|
|
|
|
|
2017-01-13 04:50:20 -08:00
|
|
|
|
|
|
|
/**
|
|
|
|
* Update the specified resource in storage.
|
|
|
|
*
|
|
|
|
* @author [A. Gianotto] [<snipe@snipe.net>]
|
|
|
|
* @since [v4.0]
|
|
|
|
* @param \Illuminate\Http\Request $request
|
|
|
|
* @param int $id
|
|
|
|
* @return \Illuminate\Http\Response
|
|
|
|
*/
|
|
|
|
public function update(Request $request, $id)
|
|
|
|
{
|
2018-07-12 18:28:02 -07:00
|
|
|
$this->authorize('update', AssetModel::class);
|
2017-01-13 04:50:20 -08:00
|
|
|
$assetmodel = AssetModel::findOrFail($id);
|
|
|
|
$assetmodel->fill($request->all());
|
2017-07-12 17:51:22 -07:00
|
|
|
$assetmodel->fieldset_id = $request->get("custom_fieldset_id");
|
2017-01-13 04:50:20 -08:00
|
|
|
|
|
|
|
if ($assetmodel->save()) {
|
2018-02-25 12:10:02 -08:00
|
|
|
return response()->json(Helper::formatStandardApiResponse('success', $assetmodel, trans('admin/models/message.update.success')));
|
2017-01-13 04:50:20 -08:00
|
|
|
}
|
|
|
|
|
|
|
|
return response()->json(Helper::formatStandardApiResponse('error', null, $assetmodel->getErrors()));
|
|
|
|
}
|
|
|
|
|
|
|
|
/**
|
|
|
|
* Remove the specified resource from storage.
|
|
|
|
*
|
|
|
|
* @author [A. Gianotto] [<snipe@snipe.net>]
|
|
|
|
* @since [v4.0]
|
|
|
|
* @param int $id
|
|
|
|
* @return \Illuminate\Http\Response
|
|
|
|
*/
|
|
|
|
public function destroy($id)
|
|
|
|
{
|
|
|
|
$this->authorize('delete', AssetModel::class);
|
|
|
|
$assetmodel = AssetModel::findOrFail($id);
|
|
|
|
$this->authorize('delete', $assetmodel);
|
2017-03-11 08:03:16 -08:00
|
|
|
|
|
|
|
if ($assetmodel->assets()->count() > 0) {
|
|
|
|
return response()->json(Helper::formatStandardApiResponse('error', null, trans('admin/models/message.assoc_users')));
|
|
|
|
}
|
|
|
|
|
2017-10-28 05:46:43 -07:00
|
|
|
if ($assetmodel->image) {
|
|
|
|
try {
|
|
|
|
unlink(public_path().'/uploads/models/'.$assetmodel->image);
|
|
|
|
} catch (\Exception $e) {
|
2019-03-13 15:14:03 -07:00
|
|
|
\Log::info($e);
|
2017-10-28 05:46:43 -07:00
|
|
|
}
|
|
|
|
}
|
|
|
|
|
2017-01-13 04:50:20 -08:00
|
|
|
$assetmodel->delete();
|
2018-02-25 12:10:02 -08:00
|
|
|
return response()->json(Helper::formatStandardApiResponse('success', null, trans('admin/models/message.delete.success')));
|
2017-01-13 04:50:20 -08:00
|
|
|
|
|
|
|
}
|
2017-10-26 21:50:01 -07:00
|
|
|
|
|
|
|
/**
|
|
|
|
* Gets a paginated collection for the select2 menus
|
|
|
|
*
|
|
|
|
* @author [A. Gianotto] [<snipe@snipe.net>]
|
|
|
|
* @since [v4.0.16]
|
|
|
|
* @see \App\Http\Transformers\SelectlistTransformer
|
|
|
|
*
|
|
|
|
*/
|
|
|
|
public function selectlist(Request $request)
|
|
|
|
{
|
|
|
|
|
|
|
|
$assetmodels = AssetModel::select([
|
|
|
|
'models.id',
|
|
|
|
'models.name',
|
|
|
|
'models.image',
|
|
|
|
'models.model_number',
|
2017-12-04 19:52:18 -08:00
|
|
|
'models.manufacturer_id',
|
2017-12-04 20:19:30 -08:00
|
|
|
'models.category_id',
|
|
|
|
])->with('manufacturer','category');
|
2017-10-26 21:50:01 -07:00
|
|
|
|
2018-01-24 10:43:46 -08:00
|
|
|
$settings = \App\Models\Setting::getSettings();
|
2017-10-26 21:50:01 -07:00
|
|
|
|
|
|
|
if ($request->has('search')) {
|
2017-12-04 20:19:30 -08:00
|
|
|
$assetmodels = $assetmodels->SearchByManufacturerOrCat($request->input('search'));
|
2017-10-26 21:50:01 -07:00
|
|
|
}
|
2017-12-04 19:52:18 -08:00
|
|
|
|
2017-12-04 20:19:30 -08:00
|
|
|
$assetmodels = $assetmodels->OrderCategory('ASC')->OrderManufacturer('ASC')->orderby('models.name', 'asc')->orderby('models.model_number', 'asc')->paginate(50);
|
2017-10-26 21:50:01 -07:00
|
|
|
|
|
|
|
foreach ($assetmodels as $assetmodel) {
|
2018-01-24 10:43:46 -08:00
|
|
|
|
|
|
|
$assetmodel->use_text = '';
|
|
|
|
|
|
|
|
if ($settings->modellistCheckedValue('category')) {
|
|
|
|
$assetmodel->use_text .= (($assetmodel->category) ? e($assetmodel->category->name).' - ' : '');
|
|
|
|
}
|
|
|
|
|
|
|
|
if ($settings->modellistCheckedValue('manufacturer')) {
|
|
|
|
$assetmodel->use_text .= (($assetmodel->manufacturer) ? e($assetmodel->manufacturer->name).' ' : '');
|
|
|
|
}
|
|
|
|
|
|
|
|
$assetmodel->use_text .= e($assetmodel->name);
|
|
|
|
|
|
|
|
if (($settings->modellistCheckedValue('model_number')) && ($assetmodel->model_number!='')) {
|
|
|
|
$assetmodel->use_text .= ' (#'.e($assetmodel->model_number).')';
|
|
|
|
}
|
|
|
|
|
|
|
|
$assetmodel->use_image = ($settings->modellistCheckedValue('image') && ($assetmodel->image)) ? url('/').'/uploads/models/'.$assetmodel->image : null;
|
2017-10-26 21:50:01 -07:00
|
|
|
}
|
|
|
|
|
|
|
|
return (new SelectlistTransformer)->transformSelectlist($assetmodels);
|
|
|
|
}
|
|
|
|
|
2017-01-13 04:50:20 -08:00
|
|
|
}
|