Laravel Spat ie 403 Пользователь не авторизован - PullRequest
0 голосов
/ 06 мая 2020

Я использую multi auth, следуя этому руководству: https://github.com/sujalpatel2209/LaravelMultiUserAuthentication, и я пытаюсь реализовать spat ie, следуя этому руководству: https://www.itsolutionstuff.com/post/laravel-58-user-roles-and-permissions-tutorialexample.html Но проблема в том, что я не может получить доступ к странице «Управление ролями». В нем говорится, что пользователь 403 не вошел в систему. Я тоже пытаюсь следовать этой инструкции, но все равно застрял https://docs.spatie.be/laravel-permission/v3/basic-usage/multiple-guards/

вы можете решить эту проблему, пожалуйста?

Администратор

class Admin extends Authenticatable {
    use Notifiable, HasRoles;
    use SoftDeletes;

    protected $guard_name = 'admin';
}

Интернет. php

Route::group(['middleware' => 'checkAdminLogin'], function() {
 //Manage Roles
    Route::resource('roles','RoleController');
});

CreateAdminUserSeeder. php

class CreateAdminUserSeeder extends Seeder
{
    /**
    * Run the database seeds.
    *
    * @return void
    */
    public function run()
    {
        $user = Admin::create([
            'id' => '7',
            'name' => 'Hardik Savani', 
            'email' => 'admin@gmail.com',
            'password' => bcrypt('123456'),
            'created_by' => '0',
            'created_at' => '2020-04-29 12:43:27',
            'updated_at' => '2020-04-29 12:43:27',
            'username' => 'hardik',
            'roles' => '["ADMIN"]',
            'avatar' => '',
            'status' => 'ACTIVE'
        ]);

        $role = Role::create(['guard_name' => 'admin', 'name' => 'Admin']);
        $permissions = Permission::pluck('id','id')->all();
        $role->syncPermissions($permissions);   
        $user->assignRole([$role->id]);
    }
}

Auth. php

'guards' => [
        'admin' => [
            'driver' => 'session',
            'provider' => 'admin'
        ],

        'student' => [
            'driver' => 'session',
            'provider' => 'student'
        ],

        'web' => [
            'driver' => 'session',
            'provider' => 'users',
        ],

        'api' => [
            'driver' => 'token',
            'provider' => 'users',
        ],
    ],
'providers' => [
        'admin' => [
            'driver' => 'eloquent',
            'model' => App\Admin::class
        ],

        'student' => [
            'driver' => 'eloquent',
            'model' => App\Student::class
        ],

        'users' => [
            'driver' => 'eloquent',
            'model' => App\User::class,
        ],

        // 'users' => [
        //     'driver' => 'database',
        //     'table' => 'users',
        // ],
    ],

RoleController. php

class RoleController extends Controller
{
    /**
    * Display a listing of the resource.
    *
    * @return \Illuminate\Http\Response
    */
    function __construct() {
        $this->middleware('permission:role-list|role-create|role-edit|role-delete', ['only' => ['index','store']]);
        $this->middleware('permission:role-create', ['only' => ['create','store']]);
        $this->middleware('permission:role-edit', ['only' => ['edit','update']]);
        $this->middleware('permission:role-delete', ['only' => ['destroy']]);
    }

    /**
    * Display a listing of the resource.
    *
    * @return \Illuminate\Http\Response
    */
    public function index(Request $request) {
        $roles = Role::orderBy('id','DESC')->paginate(5);
        return view('roles.index',compact('roles'))->with('i', ($request->input('page', 1) - 1) * 5);
    }
}
...