123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172 |
- <?php
- namespace App\Http\Controllers\Admin;
- use Illuminate\Http\Request;
- use App\Http\Controllers\Controller;
- use App\Models\Permission;
- use App\Models\Role;
- use DB;
- use Artisan;
- class RoleController extends Controller
- {
- /**
- * Create a new controller instance.
- *
- * @return void
- */
- public function __construct()
- {
- $this->middleware('admin');
- }
- /**
- * Display a listing of the resource.
- *
- * @return \Illuminate\Http\Response
- */
- public function index()
- {
- $roles = Role::where('guard_name','admin')->get();
- return view('admin.roles.list',compact('roles'));
- }
- /**
- * Show the form for creating a new resource.
- *
- * @return \Illuminate\Http\Response
- */
- public function create()
- {
- $permissions = array();
- $parent_permissions = Permission::where('guard_name', 'admin')->where('parent', 0)->get();
- foreach ($parent_permissions as $key => $parent) {
- $childs = Permission::where('guard_name', 'admin')->where('parent', $parent->id)->get();
- $permissions[] = array(
- 'parent' => $parent,
- 'childs' => $childs
- );
- }
- return view('admin.roles.add',compact('permissions'));
- }
- /**
- * Store a newly created resource in storage.
- *
- * @param \Illuminate\Http\Request $request
- * @return \Illuminate\Http\Response
- */
- public function store(Request $request)
- {
- $this->validate($request,[
- 'name' => 'required|unique:roles,name',
- 'permissions' => 'required'
- ]);
- $role = new Role;
- $role->name = $request->name;
- $role->guard_name = 'admin';
- $role->save();
- foreach ($request->input('permissions') as $key => $value) {
- $role->givePermissionTo($value);
- }
-
- return redirect()->action('Admin\RoleController@index')->with('success','Successfully Created!');
- }
- /**
- * Display the specified resource.
- *
- * @param int $id
- * @return \Illuminate\Http\Response
- */
- public function show($id)
- {
- $role = Role::find($id);
- $rolePermissions = DB::table("role_has_permissions")->where("role_has_permissions.role_id",$id)
- ->pluck('role_has_permissions.permission_id')->toArray();
- $permissions = array();
- $parent_permissions = Permission::where('guard_name', 'admin')->where('parent', 0)->whereIn('id',$rolePermissions)->get();
- foreach ($parent_permissions as $key => $parent) {
- $childs = Permission::where('guard_name', 'admin')->where('parent', $parent->id)->whereIn('id',$rolePermissions)->get();
- $permissions[] = array(
- 'parent' => $parent,
- 'childs' => $childs,
- );
- }
- return view('admin.roles.view',compact('role','permissions'));
- }
- /**
- * Show the form for editing the specified resource.
- *
- * @param int $id
- * @return \Illuminate\Http\Response
- */
- public function edit($id)
- {
- $role = Role::find($id);
- $permissions = array();
- $parent_permissions = Permission::where('guard_name', 'admin')->where('parent', 0)->get();
- foreach ($parent_permissions as $key => $parent) {
- $childs = Permission::where('guard_name', 'admin')->where('parent', $parent->id)->get();
- $permissions[] = array(
- 'parent' => $parent,
- 'childs' => $childs
- );
- }
- $rolePermissions = DB::table("role_has_permissions")->where("role_has_permissions.role_id",$id)
- ->pluck('role_has_permissions.permission_id','role_has_permissions.permission_id')->toArray();
- return view('admin.roles.edit',compact('role','permissions','rolePermissions'));
- }
- /**
- * Update the specified resource in storage.
- *
- * @param \Illuminate\Http\Request $request
- * @param int $id
- * @return \Illuminate\Http\Response
- */
- public function update(Request $request, $id)
- {
- $this->validate($request,[
- 'name' => 'required',
- 'permissions' => 'required'
- ]);
- $role = Role::find($id);
- $role->name = $request->name;
- $role->update();
- DB::table("role_has_permissions")->where("role_has_permissions.role_id",$id)->delete();
- foreach ($request->input('permissions') as $key => $value) {
- $role->givePermissionTo($value);
- }
- return redirect()->action('Admin\RoleController@index')->with('success','Successfully Updated!');
- }
- /**
- * Remove the specified resource from storage.
- *
- * @param int $id
- * @return \Illuminate\Http\Response
- */
- public function destroy($id)
- {
- DB::beginTransaction();
- try {
- Role::whereId($id)->delete();
- DB::table("role_has_permissions")->where("role_has_permissions.role_id",$id)->delete();
- DB::commit();
- return redirect()->action('Admin\RoleController@index')->with('success','Successfully Deleted!');
- }catch (\Exception $e) {
- DB::rollBack();
- return redirect()->action('Admin\RoleController@index')->with('error', 'Something went wrong!');
- }
- }
- }
|