mirror of
https://github.com/ProxyPanel/ProxyPanel.git
synced 2026-04-11 23:19:05 +00:00
73 lines
2.7 KiB
PHP
73 lines
2.7 KiB
PHP
<?php
|
|
|
|
namespace App\Http\Controllers\Admin;
|
|
|
|
use App\Http\Controllers\Controller;
|
|
use App\Http\Requests\Admin\PermissionRequest;
|
|
use Exception;
|
|
use Illuminate\Contracts\View\View;
|
|
use Illuminate\Http\JsonResponse;
|
|
use Illuminate\Http\RedirectResponse;
|
|
use Illuminate\Http\Request;
|
|
use Log;
|
|
use Spatie\Permission\Models\Permission;
|
|
|
|
class PermissionController extends Controller
|
|
{
|
|
public function index(Request $request): View
|
|
{
|
|
$query = Permission::query();
|
|
|
|
foreach (['name', 'description'] as $field) {
|
|
$request->whenFilled($field, function ($value) use ($query, $field) {
|
|
$query->where($field, 'like', "%$value%");
|
|
});
|
|
}
|
|
|
|
return view('admin.permission.index', ['permissions' => $query->paginate(20)->appends($request->except('page'))]);
|
|
}
|
|
|
|
public function store(PermissionRequest $request): RedirectResponse
|
|
{
|
|
if ($permission = Permission::create($request->validated())) {
|
|
return redirect()->route('admin.permission.edit', $permission)->with('successMsg', trans('common.success_item', ['attribute' => trans('common.add')]));
|
|
}
|
|
|
|
return redirect()->back()->withInput()->withErrors(trans('common.failed_item', ['attribute' => trans('common.add')]));
|
|
}
|
|
|
|
public function create(): View
|
|
{
|
|
return view('admin.permission.info');
|
|
}
|
|
|
|
public function edit(Permission $permission): View
|
|
{
|
|
return view('admin.permission.info', compact('permission'));
|
|
}
|
|
|
|
public function update(PermissionRequest $request, Permission $permission): RedirectResponse
|
|
{
|
|
if ($permission->update($request->validated())) {
|
|
return redirect()->back()->with('successMsg', trans('common.success_item', ['attribute' => trans('common.update')]));
|
|
}
|
|
|
|
return redirect()->back()->withInput()->withErrors(trans('common.failed_item', ['attribute' => trans('common.update')]));
|
|
}
|
|
|
|
public function destroy(Permission $permission): JsonResponse
|
|
{
|
|
try {
|
|
if ($permission->delete()) {
|
|
return response()->json(['status' => 'success', 'message' => trans('common.success_item', ['attribute' => trans('common.delete')])]);
|
|
}
|
|
} catch (Exception $e) {
|
|
Log::error(trans('common.error_action_item', ['action' => trans('common.delete'), 'attribute' => trans('admin.logs.rule.title')]).': '.$e->getMessage());
|
|
|
|
return response()->json(['status' => 'fail', 'message' => trans('common.failed_item', ['attribute' => trans('common.delete')]).', '.$e->getMessage()]);
|
|
}
|
|
|
|
return response()->json(['status' => 'fail', 'message' => trans('common.failed_item', ['attribute' => trans('common.delete')])]);
|
|
}
|
|
}
|