Cartalyst Sentinel Laravel - 你如何创造角色?

时间:2014-10-02 05:47:01

标签: laravel-4 acl sentinel

我是Cartalyst Sentinel的新手和ACL的概念。我设法创建了一个用户,执行激活,登录和注销。

我想把我的学习提升到一个新的水平。我想在这个laravel应用程序上有两种类型的用户。 1是管理员另一个是订阅者。我假设我的帐户创建方法默认情况下应该为用户创建一个订阅者。

public function postCreate() {

        /* Validation */
        $validation = Validator::make(Input::all(), [
            'email' => 'required|email|max:50|unique:users',
            'username' => 'required|min:3|max:20|unique:users',
            'password' => 'required|min:6',
            'password_repeat' => 'required|same:password',
        ]);

        if ($validation->fails()) {

            return Redirect('login')->withErrors($validation)->withInput();

        } else {

            $credentials = Input::all();
            $user = Sentinel::register($credentials);

            $activation = Activation::create($user);

            $activation_code = $activation->code;

            if ($user) {

                Mail::send('emails.auth.activate', ['link' => URL::route('account-activate', [$user->id, $activation_code]), 'username' => $user->username], function($message) use ($user) {

                    $message->to($user->email, $user->username)->subject('Activate your account');

                });

                return Redirect::route('home')->with('global', 'Thank you for registering! We have sent you an email to activate your account');

            }

        }       

    }

我是否像这样改变代码

$user = Sentinel::register($credentials);

$user = Sentinel::findById(1);

$role = Sentinel::findRoleByName('Subscribers');

$role->users()->attach($user);

事情是我甚至没有创建任何角色。我们在哪里写这个功能?现在我有以下控制器

  1. AccountController - 处理激活
  2. AuthController - 处理登录/注销
  3. RegistrationController - 处理用户注册
  4. RolesController - 我还没有在这里写任何东西。我有点失落。
  5. 请指导我。非常感谢任何帮助。

1 个答案:

答案 0 :(得分:5)

如果您已经注册了用户,则无需搜索用户,注册方法会返回用户。 您可以执行以下操作将角色附加到用户:

$user = Sentinel::register($credentials);
$role = Sentinel::findRoleByName('Subscribers');
$role->users()->attach($user);
// OR
$user->roles()->attach($role); 

你同时拥有一个用户和一个角色对象,并且他们有多对多的关系,所以你使用哪一个并不重要。

您需要创建数据库浏览器或方法来创建权限。但要创建订阅者角色,您需要执行以下操作:

Sentinel::getRoleRepository()->createModel()->create([
    'name' => 'Subscribers',
    'slug' => 'subscribers',
    'permissions' => [
       'user.view'   => true,
       'user.delete' => false,
       // any other permissions you want your Subscribers to have
    ]
]);

类似的调用也可以构建您的管理员角色。

您的角色模型和控制器已经为您构建,您只需通过已经Sentinel::findRoleByName('Subscribers');呼叫的Sentinel访问它们。

Cartalyst提供了一些关于为用户设置角色和权限的相当不错的文档:

只需要弄清楚你希望每个角色做什么或不做什么。 此外,您可以为每个用户设置特定权限以覆盖角色权限。