在Eloquent存储库设置中设置关系模型的正确方法

时间:2015-08-31 18:25:32

标签: php laravel laravel-5

我正在尝试弄清楚如何在我的应用中从管理员创建用户时使用模型关系创建用户角色。

我有以下表格:

用户

users表包含用户列表。

users_roles

users_roles表是一个将rolesusers相关联的数据透视表。

角色

roles表包含角色列表。

我正在尝试使用存储库设置,以便我的控制器没有提及雄辩。

这是我的控制者:

class ContractorController extends Controller
{
    private $user;

    /**
     * Create a new instance.
     *
     * @return Middleware
     */
    public function __construct(UserRepoInterface $user, TimesheetRepoInterface $timesheet)
    {
        $this->middleware('actions');

        $this->user = $user;
        $this->timesheet = $timesheet;
    }

    /**
     * Store a newly created resource in storage.
     *
     * @param  Request  $request
     * @return Response
     */
    public function store(CreateUserRequest $request)
    {
        // create user
        $user = $this->user->createUser($request->except('_token'));

        // user was created above so we can use $user object
        $this->user->createUserRole($user);

        return Redirect::back()->withMessage('New user created.');
    }
}

我的存储库:

/**
 * Create new user role.
 *
 * @param $request
 * @return mixed
 */
public function createUserRole($user)
{
    return $this->user->roles()->attach($user);
}

我的用户模型:

/**
 * Get the roles associated with the user.
 *
 * @return Object
 */
public function roles()
{
    return $this->belongsToMany('App\Models\User\UsersRoles', 'users_roles', 'role_id', 'user_id');
}

上面的代码导致在users_roles表中创建的记录是正确的,但是我不知道如何在表中关联正确的role_id。

以下是插入users_roles的数据:

id    user_id    role_id
1     1          0

正如你所看到的那样,没有role_id,因为我不知道如何通过它。我知道如果我在roles表中创建一个新角色,那么我就可以使用这个对象。但是角色已经存在,所以我只需要将这个新用户与我指定的角色相关联。

请有人指点我如何做到这一点或如何调整我的代码?

提前致谢。

2 个答案:

答案 0 :(得分:1)

您应该传递角色数组而不是用户数组

$this->user->createUserRole($user);

而不是它应该是您想要与用户附加的角色

$this->user->createUserRole($roles);//$roles array

答案 1 :(得分:0)

对于任何想要做同样事情的人,我终于设法通过将user_id和role_id发送到我的存储库来实现它的工作:

$this->user->createUserRole($this->role->findRoleByName('Contractor')->id, $user->id);

然后在我的存储库中,我执行了以下操作:

/**
 * Create new user role.
 *
 * @param $role
 * @param $user
 * @return mixed
 */
public function createUserRole($role, $user)
{
    return $this->user->roles()->attach($role, ['user_id' => $user]);
}

这会将role_id以及user_id添加到users_roles表格。