v2 first commit
This commit is contained in:
@ -2,14 +2,16 @@
|
||||
|
||||
namespace App\Http\Controllers\Auth;
|
||||
|
||||
use App\Http\Controllers\Controller;
|
||||
use App\Abstracts\Http\Controller;
|
||||
use App\Http\Requests\Auth\Role as Request;
|
||||
use App\Jobs\Auth\CreateRole;
|
||||
use App\Jobs\Auth\DeleteRole;
|
||||
use App\Jobs\Auth\UpdateRole;
|
||||
use App\Models\Auth\Permission;
|
||||
use App\Models\Auth\Role;
|
||||
|
||||
class Roles extends Controller
|
||||
{
|
||||
|
||||
/**
|
||||
* Display a listing of the resource.
|
||||
*
|
||||
@ -55,17 +57,23 @@ class Roles extends Controller
|
||||
*/
|
||||
public function store(Request $request)
|
||||
{
|
||||
// Create role
|
||||
$role = Role::create($request->all());
|
||||
$response = $this->ajaxDispatch(new CreateRole($request));
|
||||
|
||||
// Attach permissions
|
||||
$role->permissions()->attach($request['permissions']);
|
||||
if ($response['success']) {
|
||||
$response['redirect'] = route('roles.index');
|
||||
|
||||
$message = trans('messages.success.added', ['type' => trans_choice('general.roles', 1)]);
|
||||
$message = trans('messages.success.added', ['type' => trans_choice('general.roles', 1)]);
|
||||
|
||||
flash($message)->success();
|
||||
flash($message)->success();
|
||||
} else {
|
||||
$response['redirect'] = route('roles.create');
|
||||
|
||||
return redirect('auth/roles');
|
||||
$message = $response['message'];
|
||||
|
||||
flash($message)->error();
|
||||
}
|
||||
|
||||
return response()->json($response);
|
||||
}
|
||||
|
||||
/**
|
||||
@ -100,41 +108,55 @@ class Roles extends Controller
|
||||
/**
|
||||
* Update the specified resource in storage.
|
||||
*
|
||||
* @param Role $role
|
||||
* @param Role $role
|
||||
* @param Request $request
|
||||
*
|
||||
* @return Response
|
||||
*/
|
||||
public function update(Role $role, Request $request)
|
||||
{
|
||||
// Update role
|
||||
$role->update($request->all());
|
||||
$response = $this->ajaxDispatch(new UpdateRole($role, $request));
|
||||
|
||||
// Sync permissions
|
||||
$role->permissions()->sync($request['permissions']);
|
||||
if ($response['success']) {
|
||||
$response['redirect'] = route('roles.index');
|
||||
|
||||
$message = trans('messages.success.updated', ['type' => trans_choice('general.roles', 1)]);
|
||||
$message = trans('messages.success.updated', ['type' => $role->display_name]);
|
||||
|
||||
flash($message)->success();
|
||||
flash($message)->success();
|
||||
} else {
|
||||
$response['redirect'] = route('roles.edit', $role->id);
|
||||
|
||||
return redirect('auth/roles');
|
||||
$message = $response['message'];
|
||||
|
||||
flash($message)->error();
|
||||
}
|
||||
|
||||
return response()->json($response);
|
||||
}
|
||||
|
||||
/**
|
||||
* Remove the specified resource from storage.
|
||||
*
|
||||
* @param Role $role
|
||||
* @param Role $role
|
||||
*
|
||||
* @return Response
|
||||
*/
|
||||
public function destroy(Role $role)
|
||||
{
|
||||
$role->delete();
|
||||
$response = $this->ajaxDispatch(new DeleteRole($role));
|
||||
|
||||
$message = trans('messages.success.deleted', ['type' => trans_choice('general.roles', 1)]);
|
||||
$response['redirect'] = route('roles.index');
|
||||
|
||||
flash($message)->success();
|
||||
if ($response['success']) {
|
||||
$message = trans('messages.success.deleted', ['type' => $role->display_name]);
|
||||
|
||||
return redirect('auth/roles');
|
||||
flash($message)->success();
|
||||
} else {
|
||||
$message = $response['message'];
|
||||
|
||||
flash($message)->error();
|
||||
}
|
||||
|
||||
return response()->json($response);
|
||||
}
|
||||
}
|
||||
|
Reference in New Issue
Block a user