mirror of
https://github.com/snipe/snipe-it.git
synced 2025-01-07 11:57:44 -08:00
1d65781d8d
Signed-off-by: snipe <snipe@snipe.net>
195 lines
6.4 KiB
PHP
195 lines
6.4 KiB
PHP
<?php
|
|
|
|
namespace App\Http\Controllers\Api;
|
|
|
|
use App\Helpers\Helper;
|
|
use App\Http\Controllers\Controller;
|
|
use App\Http\Transformers\CustomFieldsTransformer;
|
|
use App\Models\CustomField;
|
|
use App\Models\CustomFieldset;
|
|
use Illuminate\Http\Request;
|
|
use Illuminate\Support\Facades\Validator;
|
|
use Illuminate\Http\JsonResponse;
|
|
|
|
class CustomFieldsController extends Controller
|
|
{
|
|
/**
|
|
* Reorder the custom fields within a fieldset
|
|
*
|
|
* @author [Brady Wetherington] [<uberbrady@gmail.com>]
|
|
* @param int $id
|
|
* @since [v3.0]
|
|
* @return array
|
|
*/
|
|
public function index() : array
|
|
{
|
|
$this->authorize('index', CustomField::class);
|
|
$fields = CustomField::get();
|
|
|
|
return (new CustomFieldsTransformer)->transformCustomFields($fields, $fields->count());
|
|
}
|
|
|
|
/**
|
|
* Shows the given field
|
|
* @author [V. Cordes] [<volker@fdatek.de>]
|
|
* @param int $id
|
|
* @since [v4.1.10]
|
|
*/
|
|
public function show($id) : JsonResponse | array
|
|
{
|
|
$this->authorize('view', CustomField::class);
|
|
if ($field = CustomField::find($id)) {
|
|
return (new CustomFieldsTransformer)->transformCustomField($field);
|
|
}
|
|
|
|
return response()->json(Helper::formatStandardApiResponse('error', null, trans('admin/custom_fields/message.field.invalid')), 200);
|
|
}
|
|
|
|
/**
|
|
* Update the specified field
|
|
*
|
|
* @author [V. Cordes] [<volker@fdatek.de>]
|
|
* @since [v4.1.10]
|
|
* @param \Illuminate\Http\Request $request
|
|
* @param int $id
|
|
*/
|
|
public function update(Request $request, $id) : JsonResponse
|
|
{
|
|
$this->authorize('update', CustomField::class);
|
|
$field = CustomField::findOrFail($id);
|
|
|
|
/**
|
|
* Updated values for the field,
|
|
* without the "field_encrypted" flag, preventing the change of encryption status
|
|
* @var array
|
|
*/
|
|
$data = $request->except(['field_encrypted']);
|
|
|
|
$validator = Validator::make($data, $field->validationRules());
|
|
if ($validator->fails()) {
|
|
return response()->json(Helper::formatStandardApiResponse('error', null, $validator->errors()));
|
|
}
|
|
|
|
$field->fill($data);
|
|
|
|
if ($field->save()) {
|
|
return response()->json(Helper::formatStandardApiResponse('success', $field, trans('admin/custom_fields/message.field.update.success')));
|
|
}
|
|
|
|
return response()->json(Helper::formatStandardApiResponse('error', null, $field->getErrors()));
|
|
}
|
|
|
|
/**
|
|
* Store a newly created field.
|
|
*
|
|
* @author [V. Cordes] [<volker@fdatek.de>]
|
|
* @since [v4.1.10]
|
|
* @param \Illuminate\Http\Request $request
|
|
*/
|
|
public function store(Request $request) : JsonResponse
|
|
{
|
|
$this->authorize('create', CustomField::class);
|
|
$field = new CustomField;
|
|
|
|
$data = $request->all();
|
|
$regex_format = null;
|
|
|
|
if ((array_key_exists('format', $data)) && (str_contains($data['format'], 'regex:'))) {
|
|
$regex_format = $data['format'];
|
|
}
|
|
|
|
$validator = Validator::make($data, $field->validationRules($regex_format));
|
|
|
|
if ($validator->fails()) {
|
|
return response()->json(Helper::formatStandardApiResponse('error', null, $validator->errors()));
|
|
}
|
|
$field->fill($data);
|
|
|
|
if ($field->save()) {
|
|
return response()->json(Helper::formatStandardApiResponse('success', $field, trans('admin/custom_fields/message.field.create.success')));
|
|
}
|
|
|
|
return response()->json(Helper::formatStandardApiResponse('error', null, $field->getErrors()));
|
|
}
|
|
|
|
public function postReorder(Request $request, $id)
|
|
{
|
|
$fieldset = CustomFieldset::find($id);
|
|
|
|
$this->authorize('update', $fieldset);
|
|
|
|
$fields = [];
|
|
$order_array = [];
|
|
|
|
$items = $request->input('item');
|
|
|
|
foreach ($items as $order => $field_id) {
|
|
$order_array[$field_id] = $order;
|
|
}
|
|
|
|
foreach ($fieldset->fields as $field) {
|
|
$fields[$field->id] = ['required' => $field->pivot->required, 'order' => $order_array[$field->id]];
|
|
}
|
|
|
|
return $fieldset->fields()->sync($fields);
|
|
}
|
|
|
|
public function associate(Request $request, $field_id) : JsonResponse
|
|
{
|
|
$this->authorize('update', CustomFieldset::class);
|
|
|
|
$field = CustomField::findOrFail($field_id);
|
|
|
|
$fieldset_id = $request->input('fieldset_id');
|
|
foreach ($field->fieldset as $fieldset) {
|
|
if ($fieldset->id == $fieldset_id) {
|
|
return response()->json(Helper::formatStandardApiResponse('success', $fieldset, trans('admin/custom_fields/message.fieldset.update.success')));
|
|
}
|
|
}
|
|
|
|
$fieldset = CustomFieldset::findOrFail($fieldset_id);
|
|
$fieldset->fields()->attach($field->id, ['required' => ($request->input('required') == 'on'), 'order' => $request->input('order', $fieldset->fields->count())]);
|
|
|
|
return response()->json(Helper::formatStandardApiResponse('success', $fieldset, trans('admin/custom_fields/message.fieldset.update.success')));
|
|
}
|
|
|
|
public function disassociate(Request $request, $field_id) : JsonResponse
|
|
{
|
|
$this->authorize('update', CustomFieldset::class);
|
|
$field = CustomField::findOrFail($field_id);
|
|
|
|
$fieldset_id = $request->input('fieldset_id');
|
|
foreach ($field->fieldset as $fieldset) {
|
|
if ($fieldset->id == $fieldset_id) {
|
|
$fieldset->fields()->detach($field->id);
|
|
|
|
return response()->json(Helper::formatStandardApiResponse('success', $fieldset, trans('admin/custom_fields/message.fieldset.update.success')));
|
|
}
|
|
}
|
|
$fieldset = CustomFieldset::findOrFail($fieldset_id);
|
|
|
|
return response()->json(Helper::formatStandardApiResponse('success', $fieldset, trans('admin/custom_fields/message.fieldset.update.success')));
|
|
}
|
|
|
|
/**
|
|
* Delete a custom field.
|
|
*
|
|
* @author [Brady Wetherington] [<uberbrady@gmail.com>]
|
|
* @since [v1.8]
|
|
*/
|
|
public function destroy($field_id) : JsonResponse
|
|
{
|
|
$field = CustomField::findOrFail($field_id);
|
|
|
|
$this->authorize('delete', $field);
|
|
|
|
if ($field->fieldset->count() > 0) {
|
|
return response()->json(Helper::formatStandardApiResponse('error', null, 'Field is in use.'));
|
|
}
|
|
|
|
$field->delete();
|
|
|
|
return response()->json(Helper::formatStandardApiResponse('success', null, trans('admin/custom_fields/message.field.delete.success')));
|
|
}
|
|
}
|