mirror of
https://github.com/snipe/snipe-it.git
synced 2024-12-27 14:39:49 -08:00
638a7b2d91
* Extract method/cleanup * Remove apiStore method that is unusued since api controllers. * Use proper model exception * Remove old user importer. This is now supported by the general importer framework. * Refactor AssetsController methods. This is a giant diff without many functional changes, mostly cosmetic. I've pulled a number of methods out of assetscontroller, preferring instead to create some more targetted controllers for related actions. I think this cleans up the file some, and suggests some places for future targetted improvement. Fix weird missing things. * Fix Unit test failing after date changes. * Pass valid string to be translated. * Some method cleanup for codacy. * Extract trait for common checkout uses and codacy fixes.
193 lines
6.9 KiB
PHP
Executable file
193 lines
6.9 KiB
PHP
Executable file
<?php
|
|
namespace App\Http\Controllers;
|
|
|
|
use Input;
|
|
use Lang;
|
|
use App\Models\Statuslabel;
|
|
use App\Models\Asset;
|
|
use Redirect;
|
|
use DB;
|
|
use App\Models\Setting;
|
|
use Str;
|
|
use View;
|
|
use App\Helpers\Helper;
|
|
use Auth;
|
|
use Illuminate\Http\Request;
|
|
|
|
use Symfony\Component\HttpFoundation\JsonResponse;
|
|
|
|
/**
|
|
* This controller handles all actions related to Status Labels for
|
|
* the Snipe-IT Asset Management application.
|
|
*
|
|
* @version v1.0
|
|
*/
|
|
class StatuslabelsController extends Controller
|
|
{
|
|
/**
|
|
* Show a list of all the statuslabels.
|
|
*
|
|
* @return \Illuminate\Contracts\View\View
|
|
*/
|
|
|
|
public function index()
|
|
{
|
|
$this->authorize('view', Statuslabel::class);
|
|
return view('statuslabels.index', compact('statuslabels'));
|
|
}
|
|
|
|
public function show($id)
|
|
{
|
|
$this->authorize('view', Statuslabel::class);
|
|
if ($statuslabel = Statuslabel::find($id)) {
|
|
return view('statuslabels.view')->with('statuslabel', $statuslabel);
|
|
}
|
|
|
|
return redirect()->route('statuslabels.index')->with('error', trans('admin/statuslabels/message.does_not_exist', compact('id')));
|
|
}
|
|
|
|
|
|
|
|
/**
|
|
* Statuslabel create.
|
|
*
|
|
* @return \Illuminate\Contracts\View\View
|
|
*/
|
|
public function create()
|
|
{
|
|
// Show the page
|
|
$this->authorize('create', Statuslabel::class);
|
|
$item = new Statuslabel;
|
|
$use_statuslabel_type = $item->getStatuslabelType();
|
|
$statuslabel_types = Helper::statusTypeList();
|
|
|
|
return view('statuslabels/edit', compact('statuslabel_types', 'item'))->with('use_statuslabel_type', $use_statuslabel_type);
|
|
}
|
|
|
|
|
|
/**
|
|
* Statuslabel create form processing.
|
|
*
|
|
* @param Request $request
|
|
* @return \Illuminate\Http\RedirectResponse
|
|
*/
|
|
public function store(Request $request)
|
|
{
|
|
|
|
$this->authorize('create', Statuslabel::class);
|
|
// create a new model instance
|
|
$statusLabel = new Statuslabel();
|
|
|
|
if (!$request->has('statuslabel_types')) {
|
|
return redirect()->back()->withInput()->withErrors(['statuslabel_types' => trans('validation.statuslabel_type')]);
|
|
}
|
|
|
|
$statusType = Statuslabel::getStatuslabelTypesForDB($request->input('statuslabel_types'));
|
|
|
|
// Save the Statuslabel data
|
|
$statusLabel->name = Input::get('name');
|
|
$statusLabel->user_id = Auth::id();
|
|
$statusLabel->notes = Input::get('notes');
|
|
$statusLabel->deployable = $statusType['deployable'];
|
|
$statusLabel->pending = $statusType['pending'];
|
|
$statusLabel->archived = $statusType['archived'];
|
|
$statusLabel->color = Input::get('color');
|
|
$statusLabel->show_in_nav = Input::get('show_in_nav', 0);
|
|
$statusLabel->default_label = Input::get('default_label', 0);
|
|
|
|
|
|
if ($statusLabel->save()) {
|
|
// Redirect to the new Statuslabel page
|
|
return redirect()->route('statuslabels.index')->with('success', trans('admin/statuslabels/message.create.success'));
|
|
}
|
|
return redirect()->back()->withInput()->withErrors($statusLabel->getErrors());
|
|
}
|
|
|
|
/**
|
|
* Statuslabel update.
|
|
*
|
|
* @param int $statuslabelId
|
|
* @return \Illuminate\Contracts\View\View
|
|
*/
|
|
public function edit($statuslabelId = null)
|
|
{
|
|
$this->authorize('update', Statuslabel::class);
|
|
// Check if the Statuslabel exists
|
|
if (is_null($item = Statuslabel::find($statuslabelId))) {
|
|
// Redirect to the blogs management page
|
|
return redirect()->route('statuslabels.index')->with('error', trans('admin/statuslabels/message.does_not_exist'));
|
|
}
|
|
|
|
$use_statuslabel_type = $item->getStatuslabelType();
|
|
|
|
$statuslabel_types = array('' => trans('admin/hardware/form.select_statustype')) + array('undeployable' => trans('admin/hardware/general.undeployable')) + array('pending' => trans('admin/hardware/general.pending')) + array('archived' => trans('admin/hardware/general.archived')) + array('deployable' => trans('admin/hardware/general.deployable'));
|
|
|
|
return view('statuslabels/edit', compact('item', 'statuslabel_types'))->with('use_statuslabel_type', $use_statuslabel_type);
|
|
}
|
|
|
|
|
|
/**
|
|
* Statuslabel update form processing page.
|
|
*
|
|
* @param int $statuslabelId
|
|
* @return \Illuminate\Http\RedirectResponse
|
|
*/
|
|
public function update(Request $request, $statuslabelId = null)
|
|
{
|
|
$this->authorize('update', Statuslabel::class);
|
|
// Check if the Statuslabel exists
|
|
if (is_null($statuslabel = Statuslabel::find($statuslabelId))) {
|
|
// Redirect to the blogs management page
|
|
return redirect()->route('statuslabels.index')->with('error', trans('admin/statuslabels/message.does_not_exist'));
|
|
}
|
|
|
|
if (!$request->has('statuslabel_types')) {
|
|
return redirect()->back()->withInput()->withErrors(['statuslabel_types' => trans('validation.statuslabel_type')]);
|
|
}
|
|
|
|
|
|
// Update the Statuslabel data
|
|
$statustype = Statuslabel::getStatuslabelTypesForDB(Input::get('statuslabel_types'));
|
|
$statuslabel->name = Input::get('name');
|
|
$statuslabel->notes = Input::get('notes');
|
|
$statuslabel->deployable = $statustype['deployable'];
|
|
$statuslabel->pending = $statustype['pending'];
|
|
$statuslabel->archived = $statustype['archived'];
|
|
$statuslabel->color = Input::get('color');
|
|
$statuslabel->show_in_nav = Input::get('show_in_nav', 0);
|
|
$statuslabel->default_label = Input::get('default_label', 0);
|
|
|
|
|
|
// Was the asset created?
|
|
if ($statuslabel->save()) {
|
|
// Redirect to the saved Statuslabel page
|
|
return redirect()->route("statuslabels.index")->with('success', trans('admin/statuslabels/message.update.success'));
|
|
}
|
|
return redirect()->back()->withInput()->withErrors($statuslabel->getErrors());
|
|
}
|
|
|
|
/**
|
|
* Delete the given Statuslabel.
|
|
*
|
|
* @param int $statuslabelId
|
|
* @return \Illuminate\Http\RedirectResponse
|
|
*/
|
|
public function destroy($statuslabelId)
|
|
{
|
|
$this->authorize('delete', Statuslabel::class);
|
|
// Check if the Statuslabel exists
|
|
if (is_null($statuslabel = Statuslabel::find($statuslabelId))) {
|
|
return redirect()->route('statuslabels.index')->with('error', trans('admin/statuslabels/message.not_found'));
|
|
}
|
|
|
|
// Check that there are no assets associated
|
|
if ($statuslabel->assets()->count() == 0) {
|
|
$statuslabel->delete();
|
|
return redirect()->route('statuslabels.index')->with('success', trans('admin/statuslabels/message.delete.success'));
|
|
}
|
|
|
|
return redirect()->route('statuslabels.index')->with('error', trans('admin/statuslabels/message.assoc_assets'));
|
|
}
|
|
|
|
}
|