mirror of
https://github.com/snipe/snipe-it.git
synced 2025-01-11 13:57:41 -08:00
Fixed handling deleting old images better
This commit is contained in:
parent
b748e7ed5e
commit
9d7455f022
|
@ -91,7 +91,7 @@ class AssetModelsController extends Controller
|
||||||
|
|
||||||
$image = Input::file('image');
|
$image = Input::file('image');
|
||||||
$file_name = str_slug($image->getClientOriginalName()) . "." . $image->getClientOriginalExtension();
|
$file_name = str_slug($image->getClientOriginalName()) . "." . $image->getClientOriginalExtension();
|
||||||
$path = public_path('uploads/models/');
|
$path = app('models_upload_path');
|
||||||
|
|
||||||
if ($image->getClientOriginalExtension()!='svg') {
|
if ($image->getClientOriginalExtension()!='svg') {
|
||||||
Image::make($image->getRealPath())->resize(500, null, function ($constraint) {
|
Image::make($image->getRealPath())->resize(500, null, function ($constraint) {
|
||||||
|
@ -198,8 +198,7 @@ class AssetModelsController extends Controller
|
||||||
$model->manufacturer_id = $request->input('manufacturer_id');
|
$model->manufacturer_id = $request->input('manufacturer_id');
|
||||||
$model->category_id = $request->input('category_id');
|
$model->category_id = $request->input('category_id');
|
||||||
$model->notes = $request->input('notes');
|
$model->notes = $request->input('notes');
|
||||||
|
$model->requestable = $request->input('requestable', '0');
|
||||||
$model->requestable = Input::has('requestable');
|
|
||||||
|
|
||||||
if ($request->input('custom_fieldset')=='') {
|
if ($request->input('custom_fieldset')=='') {
|
||||||
$model->fieldset_id = null;
|
$model->fieldset_id = null;
|
||||||
|
@ -207,34 +206,37 @@ class AssetModelsController extends Controller
|
||||||
$model->fieldset_id = $request->input('custom_fieldset');
|
$model->fieldset_id = $request->input('custom_fieldset');
|
||||||
}
|
}
|
||||||
|
|
||||||
if (Input::file('image')) {
|
$old_image = $model->image;
|
||||||
|
|
||||||
$image = Input::file('image');
|
// Set the model's image property to null if the image is being deleted
|
||||||
$file_name = str_slug($image->getClientOriginalName()) . "." . $image->getClientOriginalExtension();
|
if ($request->input('image_delete') == 1) {
|
||||||
$path = public_path('uploads/models/');
|
$model->image = null;
|
||||||
$old_image = $path.$model->image;
|
|
||||||
|
|
||||||
try {
|
|
||||||
unlink($old_image);
|
|
||||||
} catch (\Exception $e) {
|
|
||||||
\Log::error($e);
|
|
||||||
}
|
}
|
||||||
|
|
||||||
|
if ($request->file('image')) {
|
||||||
|
$image = $request->file('image');
|
||||||
|
$file_name = $model->id.'-'.str_slug($image->getClientOriginalName()) . "." . $image->getClientOriginalExtension();
|
||||||
|
|
||||||
if ($image->getClientOriginalExtension()!='svg') {
|
if ($image->getClientOriginalExtension()!='svg') {
|
||||||
Image::make($image->getRealPath())->resize(500, null, function ($constraint) {
|
Image::make($image->getRealPath())->resize(500, null, function ($constraint) {
|
||||||
$constraint->aspectRatio();
|
$constraint->aspectRatio();
|
||||||
$constraint->upsize();
|
$constraint->upsize();
|
||||||
})->save($path.'/'.$file_name);
|
})->save(app('models_upload_path').$file_name);
|
||||||
} else {
|
} else {
|
||||||
$image->move($path, $file_name);
|
$image->move(app('models_upload_path'), $file_name);
|
||||||
}
|
}
|
||||||
$model->image = $file_name;
|
$model->image = $file_name;
|
||||||
|
|
||||||
}
|
}
|
||||||
|
|
||||||
if ($request->input('image_delete') == 1 && Input::file('image') == "") {
|
if ((($request->file('image')) && (isset($old_image)) && ($old_image!='')) || ($request->input('image_delete') == 1)) {
|
||||||
$model->image = null;
|
try {
|
||||||
|
unlink(app('models_upload_path').$old_image);
|
||||||
|
} catch (\Exception $e) {
|
||||||
|
\Log::error($e);
|
||||||
}
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
|
||||||
if ($model->save()) {
|
if ($model->save()) {
|
||||||
return redirect()->route("models.index")->with('success', trans('admin/models/message.update.success'));
|
return redirect()->route("models.index")->with('success', trans('admin/models/message.update.success'));
|
||||||
|
|
|
@ -150,13 +150,11 @@ class CategoriesController extends Controller
|
||||||
|
|
||||||
$old_image = $category->image;
|
$old_image = $category->image;
|
||||||
|
|
||||||
|
|
||||||
// Set the model's image property to null if the image is being deleted
|
// Set the model's image property to null if the image is being deleted
|
||||||
if ($request->input('image_delete') == 1) {
|
if ($request->input('image_delete') == 1) {
|
||||||
$category->image = null;
|
$category->image = null;
|
||||||
}
|
}
|
||||||
|
|
||||||
// If a new file is being uploaded, resize it and save it
|
|
||||||
if ($request->file('image')) {
|
if ($request->file('image')) {
|
||||||
$image = $request->file('image');
|
$image = $request->file('image');
|
||||||
$file_name = $category->id.'-'.str_slug($image->getClientOriginalName()) . "." . $image->getClientOriginalExtension();
|
$file_name = $category->id.'-'.str_slug($image->getClientOriginalName()) . "." . $image->getClientOriginalExtension();
|
||||||
|
@ -173,7 +171,6 @@ class CategoriesController extends Controller
|
||||||
|
|
||||||
}
|
}
|
||||||
|
|
||||||
// If there is a new file being uploaded
|
|
||||||
if ((($request->file('image')) && (isset($old_image)) && ($old_image!='')) || ($request->input('image_delete') == 1)) {
|
if ((($request->file('image')) && (isset($old_image)) && ($old_image!='')) || ($request->input('image_delete') == 1)) {
|
||||||
try {
|
try {
|
||||||
unlink(app('categories_upload_path').$old_image);
|
unlink(app('categories_upload_path').$old_image);
|
||||||
|
|
|
@ -110,17 +110,35 @@ final class CompaniesController extends Controller
|
||||||
|
|
||||||
$company->name = $request->input('name');
|
$company->name = $request->input('name');
|
||||||
|
|
||||||
|
$old_image = $company->image;
|
||||||
|
|
||||||
|
// Set the model's image property to null if the image is being deleted
|
||||||
|
if ($request->input('image_delete') == 1) {
|
||||||
|
$company->image = null;
|
||||||
|
}
|
||||||
|
|
||||||
if ($request->file('image')) {
|
if ($request->file('image')) {
|
||||||
$image = $request->file('image');
|
$image = $request->file('image');
|
||||||
$file_name = str_random(25).".".$image->getClientOriginalExtension();
|
$file_name = $company->id.'-'.str_slug($image->getClientOriginalName()) . "." . $image->getClientOriginalExtension();
|
||||||
$path = public_path('uploads/companies/'.$file_name);
|
|
||||||
Image::make($image->getRealPath())->resize(200, null, function ($constraint) {
|
if ($image->getClientOriginalExtension()!='svg') {
|
||||||
|
Image::make($image->getRealPath())->resize(500, null, function ($constraint) {
|
||||||
$constraint->aspectRatio();
|
$constraint->aspectRatio();
|
||||||
$constraint->upsize();
|
$constraint->upsize();
|
||||||
})->save($path);
|
})->save(app('companies_upload_path').$file_name);
|
||||||
|
} else {
|
||||||
|
$image->move(app('companies_upload_path'), $file_name);
|
||||||
|
}
|
||||||
$company->image = $file_name;
|
$company->image = $file_name;
|
||||||
} elseif ($request->input('image_delete')=='1') {
|
|
||||||
$company->image = null;
|
}
|
||||||
|
|
||||||
|
if ((($request->file('image')) && (isset($old_image)) && ($old_image!='')) || ($request->input('image_delete') == 1)) {
|
||||||
|
try {
|
||||||
|
unlink(app('companies_upload_path').$old_image);
|
||||||
|
} catch (\Exception $e) {
|
||||||
|
\Log::error($e);
|
||||||
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
|
|
|
@ -152,21 +152,38 @@ class DepartmentsController extends Controller
|
||||||
}
|
}
|
||||||
|
|
||||||
$department->fill($request->all());
|
$department->fill($request->all());
|
||||||
|
$department->manager_id = ($request->has('manager_id' ) ? $request->input('manager_id') : null);
|
||||||
|
|
||||||
if ($request->file('image')) {
|
$old_image = $department->image;
|
||||||
$image = $request->file('image');
|
|
||||||
$file_name = str_random(25).".".$image->getClientOriginalExtension();
|
// Set the model's image property to null if the image is being deleted
|
||||||
$path = public_path('uploads/departments/'.$file_name);
|
if ($request->input('image_delete') == 1) {
|
||||||
Image::make($image->getRealPath())->resize(200, null, function ($constraint) {
|
|
||||||
$constraint->aspectRatio();
|
|
||||||
$constraint->upsize();
|
|
||||||
})->save($path);
|
|
||||||
$department->image = $file_name;
|
|
||||||
} elseif ($request->input('image_delete')=='1') {
|
|
||||||
$department->image = null;
|
$department->image = null;
|
||||||
}
|
}
|
||||||
|
|
||||||
$department->manager_id = ($request->has('manager_id' ) ? $request->input('manager_id') : null);
|
if ($request->file('image')) {
|
||||||
|
$image = $request->file('image');
|
||||||
|
$file_name = $department->id.'-'.str_slug($image->getClientOriginalName()) . "." . $image->getClientOriginalExtension();
|
||||||
|
|
||||||
|
if ($image->getClientOriginalExtension()!='svg') {
|
||||||
|
Image::make($image->getRealPath())->resize(500, null, function ($constraint) {
|
||||||
|
$constraint->aspectRatio();
|
||||||
|
$constraint->upsize();
|
||||||
|
})->save(app('departments_upload_path').$file_name);
|
||||||
|
} else {
|
||||||
|
$image->move(app('departments_upload_path'), $file_name);
|
||||||
|
}
|
||||||
|
$department->image = $file_name;
|
||||||
|
|
||||||
|
}
|
||||||
|
|
||||||
|
if ((($request->file('image')) && (isset($old_image)) && ($old_image!='')) || ($request->input('image_delete') == 1)) {
|
||||||
|
try {
|
||||||
|
unlink(app('departments_upload_path').$old_image);
|
||||||
|
} catch (\Exception $e) {
|
||||||
|
\Log::error($e);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
if ($department->save()) {
|
if ($department->save()) {
|
||||||
return redirect()->route("departments.index")->with('success', trans('admin/departments/message.update.success'));
|
return redirect()->route("departments.index")->with('success', trans('admin/departments/message.update.success'));
|
||||||
|
|
|
@ -204,17 +204,35 @@ class LocationsController extends Controller
|
||||||
$location->ldap_ou = $request->input('ldap_ou');
|
$location->ldap_ou = $request->input('ldap_ou');
|
||||||
$location->manager_id = $request->input('manager_id');
|
$location->manager_id = $request->input('manager_id');
|
||||||
|
|
||||||
|
$old_image = $location->image;
|
||||||
|
|
||||||
|
// Set the model's image property to null if the image is being deleted
|
||||||
|
if ($request->input('image_delete') == 1) {
|
||||||
|
$location->image = null;
|
||||||
|
}
|
||||||
|
|
||||||
if ($request->file('image')) {
|
if ($request->file('image')) {
|
||||||
$image = $request->file('image');
|
$image = $request->file('image');
|
||||||
$file_name = str_random(25).".".$image->getClientOriginalExtension();
|
$file_name = $location->id.'-'.str_slug($image->getClientOriginalName()) . "." . $image->getClientOriginalExtension();
|
||||||
$path = public_path('uploads/locations/'.$file_name);
|
|
||||||
Image::make($image->getRealPath())->resize(200, null, function ($constraint) {
|
if ($image->getClientOriginalExtension()!='svg') {
|
||||||
|
Image::make($image->getRealPath())->resize(500, null, function ($constraint) {
|
||||||
$constraint->aspectRatio();
|
$constraint->aspectRatio();
|
||||||
$constraint->upsize();
|
$constraint->upsize();
|
||||||
})->save($path);
|
})->save(app('locations_upload_path').$file_name);
|
||||||
|
} else {
|
||||||
|
$image->move(app('locations_upload_path'), $file_name);
|
||||||
|
}
|
||||||
$location->image = $file_name;
|
$location->image = $file_name;
|
||||||
} elseif ($request->input('image_delete')=='1') {
|
|
||||||
$location->image = null;
|
}
|
||||||
|
|
||||||
|
if ((($request->file('image')) && (isset($old_image)) && ($old_image!='')) || ($request->input('image_delete') == 1)) {
|
||||||
|
try {
|
||||||
|
unlink(app('locations_upload_path').$old_image);
|
||||||
|
} catch (\Exception $e) {
|
||||||
|
\Log::error($e);
|
||||||
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
|
|
|
@ -138,26 +138,35 @@ class ManufacturersController extends Controller
|
||||||
$manufacturer->support_phone = $request->input('support_phone');
|
$manufacturer->support_phone = $request->input('support_phone');
|
||||||
$manufacturer->support_email = $request->input('support_email');
|
$manufacturer->support_email = $request->input('support_email');
|
||||||
|
|
||||||
|
$old_image = $manufacturer->image;
|
||||||
|
|
||||||
|
// Set the model's image property to null if the image is being deleted
|
||||||
|
if ($request->input('image_delete') == 1) {
|
||||||
|
$manufacturer->image = null;
|
||||||
|
}
|
||||||
|
|
||||||
if ($request->file('image')) {
|
if ($request->file('image')) {
|
||||||
$image = $request->file('image');
|
$image = $request->file('image');
|
||||||
$file_name = str_slug($image->getClientOriginalName()).".".$image->getClientOriginalExtension();
|
$file_name = $manufacturer->id.'-'.str_slug($image->getClientOriginalName()) . "." . $image->getClientOriginalExtension();
|
||||||
$path = public_path('uploads/manufacturers/'.$file_name);
|
|
||||||
$old_image = $path.$manufacturer->image;
|
|
||||||
|
|
||||||
|
if ($image->getClientOriginalExtension()!='svg') {
|
||||||
|
Image::make($image->getRealPath())->resize(500, null, function ($constraint) {
|
||||||
|
$constraint->aspectRatio();
|
||||||
|
$constraint->upsize();
|
||||||
|
})->save(app('manufacturers_upload_path').$file_name);
|
||||||
|
} else {
|
||||||
|
$image->move(app('manufacturers_upload_path'), $file_name);
|
||||||
|
}
|
||||||
|
$manufacturer->image = $file_name;
|
||||||
|
|
||||||
|
}
|
||||||
|
|
||||||
|
if ((($request->file('image')) && (isset($old_image)) && ($old_image!='')) || ($request->input('image_delete') == 1)) {
|
||||||
try {
|
try {
|
||||||
unlink($old_image);
|
unlink(app('manufacturers_upload_path').$old_image);
|
||||||
} catch (\Exception $e) {
|
} catch (\Exception $e) {
|
||||||
\Log::error($e);
|
\Log::error($e);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
Image::make($image->getRealPath())->resize(200, null, function ($constraint) {
|
|
||||||
$constraint->aspectRatio();
|
|
||||||
$constraint->upsize();
|
|
||||||
})->save($path);
|
|
||||||
$manufacturer->image = $file_name;
|
|
||||||
} elseif ($request->input('image_delete')=='1') {
|
|
||||||
$manufacturer->image = null;
|
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
|
|
|
@ -159,19 +159,38 @@ class SuppliersController extends Controller
|
||||||
$supplier->notes = request('notes');
|
$supplier->notes = request('notes');
|
||||||
|
|
||||||
|
|
||||||
if ($request->file('image')) {
|
$old_image = $supplier->image;
|
||||||
$image = $request->file('image');
|
|
||||||
$file_name = str_random(25).".".$image->getClientOriginalExtension();
|
// Set the model's image property to null if the image is being deleted
|
||||||
$path = public_path('uploads/suppliers/'.$file_name);
|
if ($request->input('image_delete') == 1) {
|
||||||
Image::make($image->getRealPath())->resize(200, null, function ($constraint) {
|
|
||||||
$constraint->aspectRatio();
|
|
||||||
$constraint->upsize();
|
|
||||||
})->save($path);
|
|
||||||
$supplier->image = $file_name;
|
|
||||||
} elseif ($request->input('image_delete')=='1') {
|
|
||||||
$supplier->image = null;
|
$supplier->image = null;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
if ($request->file('image')) {
|
||||||
|
$image = $request->file('image');
|
||||||
|
$file_name = $supplier->id.'-'.str_slug($image->getClientOriginalName()) . "." . $image->getClientOriginalExtension();
|
||||||
|
|
||||||
|
if ($image->getClientOriginalExtension()!='svg') {
|
||||||
|
Image::make($image->getRealPath())->resize(500, null, function ($constraint) {
|
||||||
|
$constraint->aspectRatio();
|
||||||
|
$constraint->upsize();
|
||||||
|
})->save(app('suppliers_upload_path').$file_name);
|
||||||
|
} else {
|
||||||
|
$image->move(app('suppliers_upload_path'), $file_name);
|
||||||
|
}
|
||||||
|
$supplier->image = $file_name;
|
||||||
|
|
||||||
|
}
|
||||||
|
|
||||||
|
if ((($request->file('image')) && (isset($old_image)) && ($old_image!='')) || ($request->input('image_delete') == 1)) {
|
||||||
|
try {
|
||||||
|
unlink(app('suppliers_upload_path').$old_image);
|
||||||
|
} catch (\Exception $e) {
|
||||||
|
\Log::error($e);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
|
||||||
if ($supplier->save()) {
|
if ($supplier->save()) {
|
||||||
return redirect()->route('suppliers.index')->with('success', trans('admin/suppliers/message.update.success'));
|
return redirect()->route('suppliers.index')->with('success', trans('admin/suppliers/message.update.success'));
|
||||||
}
|
}
|
||||||
|
|
|
@ -102,6 +102,16 @@ class SettingsServiceProvider extends ServiceProvider
|
||||||
return url('/').'/uploads/departments/';
|
return url('/').'/uploads/departments/';
|
||||||
});
|
});
|
||||||
|
|
||||||
|
// Company paths and URLs
|
||||||
|
\App::singleton('companies_upload_path', function(){
|
||||||
|
return public_path('/uploads/companies/');
|
||||||
|
});
|
||||||
|
|
||||||
|
\App::singleton('companies_upload_url', function(){
|
||||||
|
return url('/').'/uploads/companies/';
|
||||||
|
});
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
// Set the monetary locale to the configured locale to make helper::parseFloat work.
|
// Set the monetary locale to the configured locale to make helper::parseFloat work.
|
||||||
setlocale(LC_MONETARY, config('app.locale'));
|
setlocale(LC_MONETARY, config('app.locale'));
|
||||||
|
|
Loading…
Reference in a new issue