mirror of
https://github.com/snipe/snipe-it.git
synced 2024-12-25 13:44:06 -08:00
Add write-only image_source
field for asset create/edit API endpoint (#6146)
`image_source` should contain base64 encoded image data with mime-type.
This commit is contained in:
parent
8c65214b1f
commit
8d63533205
|
@ -10,6 +10,7 @@ use App\Models\Depreciation;
|
||||||
use App\Models\Setting;
|
use App\Models\Setting;
|
||||||
use App\Models\Statuslabel;
|
use App\Models\Statuslabel;
|
||||||
use Crypt;
|
use Crypt;
|
||||||
|
use Image;
|
||||||
use Illuminate\Contracts\Encryption\DecryptException;
|
use Illuminate\Contracts\Encryption\DecryptException;
|
||||||
|
|
||||||
class Helper
|
class Helper
|
||||||
|
@ -693,4 +694,47 @@ class Helper
|
||||||
}
|
}
|
||||||
return $password;
|
return $password;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Process base64 encoded image data and save it on supplied path
|
||||||
|
*
|
||||||
|
* @param string $image_data base64 encoded image data with mime type
|
||||||
|
* @param string $save_path path to a folder where the image should be saved
|
||||||
|
* @return string path to uploaded image or false if something went wrong
|
||||||
|
*/
|
||||||
|
public static function processUploadedImage(String $image_data, String $save_path) {
|
||||||
|
if ($image_data != null && $save_path != null) {
|
||||||
|
// After modification, the image is prefixed by mime info like the following:
|
||||||
|
// data:image/jpeg;base64,; This causes the image library to be unhappy, so we need to remove it.
|
||||||
|
$header = explode(';', $image_data, 2)[0];
|
||||||
|
// Grab the image type from the header while we're at it.
|
||||||
|
$extension = substr($header, strpos($header, '/')+1);
|
||||||
|
// Start reading the image after the first comma, postceding the base64.
|
||||||
|
$image = substr($image_data, strpos($image_data, ',')+1);
|
||||||
|
|
||||||
|
$file_name = str_random(25).".".$extension;
|
||||||
|
|
||||||
|
$directory= public_path($save_path);
|
||||||
|
// Check if the uploads directory exists. If not, try to create it.
|
||||||
|
if (!file_exists($directory)) {
|
||||||
|
mkdir($directory, 0755, true);
|
||||||
|
}
|
||||||
|
|
||||||
|
$path = public_path($save_path.$file_name);
|
||||||
|
|
||||||
|
try {
|
||||||
|
Image::make($image)->resize(500, 500, function ($constraint) {
|
||||||
|
$constraint->aspectRatio();
|
||||||
|
$constraint->upsize();
|
||||||
|
})->save($path);
|
||||||
|
} catch (\Exception $e) {
|
||||||
|
return false;
|
||||||
|
}
|
||||||
|
|
||||||
|
return $file_name;
|
||||||
|
}
|
||||||
|
|
||||||
|
return false;
|
||||||
|
}
|
||||||
|
|
||||||
}
|
}
|
||||||
|
|
|
@ -427,6 +427,22 @@ class AssetsController extends Controller
|
||||||
$asset->requestable = $request->get('requestable', 0);
|
$asset->requestable = $request->get('requestable', 0);
|
||||||
$asset->rtd_location_id = $request->get('rtd_location_id', null);
|
$asset->rtd_location_id = $request->get('rtd_location_id', null);
|
||||||
|
|
||||||
|
if ($request->has('image_source') && $request->input('image_source') != "") {
|
||||||
|
$saved_image_path = Helper::processUploadedImage(
|
||||||
|
$request->input('image_source'), 'uploads/assets/'
|
||||||
|
);
|
||||||
|
|
||||||
|
if (!$saved_image_path) {
|
||||||
|
return response()->json(Helper::formatStandardApiResponse(
|
||||||
|
'error',
|
||||||
|
null,
|
||||||
|
trans('admin/hardware/message.create.error')
|
||||||
|
), 200);
|
||||||
|
}
|
||||||
|
|
||||||
|
$asset->image = $saved_image_path;
|
||||||
|
}
|
||||||
|
|
||||||
// Update custom fields in the database.
|
// Update custom fields in the database.
|
||||||
// Validation for these fields is handled through the AssetRequest form request
|
// Validation for these fields is handled through the AssetRequest form request
|
||||||
$model = AssetModel::find($request->get('model_id'));
|
$model = AssetModel::find($request->get('model_id'));
|
||||||
|
@ -448,6 +464,11 @@ class AssetsController extends Controller
|
||||||
if (isset($target)) {
|
if (isset($target)) {
|
||||||
$asset->checkOut($target, Auth::user(), date('Y-m-d H:i:s'), '', 'Checked out on asset creation', e($request->get('name')));
|
$asset->checkOut($target, Auth::user(), date('Y-m-d H:i:s'), '', 'Checked out on asset creation', e($request->get('name')));
|
||||||
}
|
}
|
||||||
|
|
||||||
|
if ($asset->image) {
|
||||||
|
$asset->image = $asset->getImageUrl();
|
||||||
|
}
|
||||||
|
|
||||||
return response()->json(Helper::formatStandardApiResponse('success', $asset, trans('admin/hardware/message.create.success')));
|
return response()->json(Helper::formatStandardApiResponse('success', $asset, trans('admin/hardware/message.create.success')));
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -477,6 +498,25 @@ class AssetsController extends Controller
|
||||||
($request->filled('company_id')) ?
|
($request->filled('company_id')) ?
|
||||||
$asset->company_id = Company::getIdForCurrentUser($request->get('company_id')) : '';
|
$asset->company_id = Company::getIdForCurrentUser($request->get('company_id')) : '';
|
||||||
|
|
||||||
|
if ($request->has('image_source')) {
|
||||||
|
if ($request->input('image_source') == "") {
|
||||||
|
$asset->image = null;
|
||||||
|
} else {
|
||||||
|
$saved_image_path = Helper::processUploadedImage(
|
||||||
|
$request->input('image_source'), 'uploads/assets/'
|
||||||
|
);
|
||||||
|
|
||||||
|
if (!$saved_image_path) {
|
||||||
|
return response()->json(Helper::formatStandardApiResponse(
|
||||||
|
'error',
|
||||||
|
null,
|
||||||
|
trans('admin/hardware/message.update.error')
|
||||||
|
), 200);
|
||||||
|
}
|
||||||
|
|
||||||
|
$asset->image = $saved_image_path;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
// Update custom fields
|
// Update custom fields
|
||||||
if (($model = AssetModel::find($asset->model_id)) && (isset($model->fieldset))) {
|
if (($model = AssetModel::find($asset->model_id)) && (isset($model->fieldset))) {
|
||||||
|
@ -502,6 +542,10 @@ class AssetsController extends Controller
|
||||||
$asset->checkOut($target, Auth::user(), date('Y-m-d H:i:s'), '', 'Checked out on asset update', e($request->get('name')), $location);
|
$asset->checkOut($target, Auth::user(), date('Y-m-d H:i:s'), '', 'Checked out on asset update', e($request->get('name')), $location);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
if ($asset->image) {
|
||||||
|
$asset->image = $asset->getImageUrl();
|
||||||
|
}
|
||||||
|
|
||||||
return response()->json(Helper::formatStandardApiResponse('success', $asset, trans('admin/hardware/message.update.success')));
|
return response()->json(Helper::formatStandardApiResponse('success', $asset, trans('admin/hardware/message.update.success')));
|
||||||
}
|
}
|
||||||
return response()->json(Helper::formatStandardApiResponse('error', null, $asset->getErrors()), 200);
|
return response()->json(Helper::formatStandardApiResponse('error', null, $asset->getErrors()), 200);
|
||||||
|
|
Loading…
Reference in a new issue