我正在尝试在帖子的评论列表中实施授权门。我想我已经设法做到了,因为它有效。
如果用户是评论的所有者,或者是subreddit中的主持人,则评论会被发布,然后他可以对其进行编辑。如果没有,他将无法看到编辑链接(我正在使用X-Editable进行内联编辑)
一切正常,直到我提交新评论,而不是我收到以下错误。但是注释被提交到数据库,因为我可以在刷新时看到它。
未定义的变量:comment_list.blade.php上的isModerator
很明显,我需要将isModerator
变量传递给视图,所以我做了
$isModerator = $post->subreddit->moderators->where('user_id', Auth::id())->exists();
这会在页面加载时抛出此错误,整个帖子页面崩溃
调用未定义的方法Illuminate \ Database \ Eloquent \ Collection :: exists()
PostsController.php第90行中的CommentController :: view_data()
这是我的Gate
授权。请注意update-post
和update-sub
没有任何故障。
public function boot(GateContract $gate)
{
parent::registerPolicies($gate);
$gate->define('update-comment', function($user, $comment, $isModerator) {
if($user->id === $comment->user_id) {
return true;
}
if ($isModerator) {
return true;
}
});
$gate->define('update-post', function ($user, $post, $isModerator) {
if ($user->id === $post->subreddit->user->id) {
return true;
}
if ($user->id === $post->user_id) {
return true;
}
if ($isModerator) {
return true;
}
return false;
});
$gate->define('update-sub', function($user, $subreddit) {
if($user->id === $subreddit->user->id) {
return true;
}
return false;
});
}
view_data()
CommentController
方法
public static function view_data(Request $request, Post $post) {
$instance = new Self;
$per_page = session('per_page')?session('per_page'):config('constants.per_page');
$post = Post::with('user.votes')->with('subreddit.moderators')->with('comments')->where('id', $post->id)->first();
$comment = $post->comments;
$user = User::where('id', '=', Auth::id())->get();
$isModerator = $post->subreddit->moderators->where('user_id', Auth::id())->exists();
$result['per_page'] = $per_page;
$result['comments'] = $instance->comment_list($per_page, $request, $post, $comment, $user, $isModerator);
$result['total_comments'] = $instance->total_comments($post);
return $result;
}
视图的编辑部分如下所示
@can('update-comment', [$each_comment, $isModerator])
<p>
<a href="#" class="testedit" data-pk="{{ $each_comment->id }}" data-url="{{ url($each_comment->post_id . '/comment/update') }}">
{!! $each_comment->comment !!}
</a>
</p>
@else
<p>
{!! $each_comment->comment !!}
</p>
@endcan
这是show()
PostsController
方法
public function show(Post $post, User $user, Request $request, Comment $comment)
{
$post = Post::with('user.votes')->with('subreddit.moderators')->findOrFail($post->id);
$ids = $post->subreddit;
$isModerator = $ids->moderators()->where('user_id', Auth::id())->exists(); // this is line 90
$modList = Moderator::where('subreddit_id', '=', $post->subreddit->id)->get();
$view_data = CommentController::view_data($request, $post, $comment, $isModerator);
return view('post/show', $view_data)->with('post', $post)
->with('modList', $modList)
->with('isModerator', $isModerator);
}
关系
Comment
模型
public function posts() {
return $this->belongsTo('App\Post');
}
public function user() {
return $this->belongsTo('App\User');
}
public function commentvotes() {
return $this->hasMany('App\CommentVote');
}
Post
模型
public function user() {
return $this->belongsTo('App\User');
}
public function subreddit() {
return $this->belongsTo('App\Subreddit');
}
public function votes() {
return $this->hasMany('App\Vote');
}
public function moderators() {
return $this->hasMany('App\Moderator');
}
public function comments() {
return $this->hasMany('App\Comment');
}
Subreddit
模型
public function user() {
return $this->belongsTo('App\User');
}
public function posts() {
return $this->hasMany('App\Post');
}
public function moderators() {
return $this->hasMany('App\Moderator');
}
Moderator
模型
public function subreddit() {
return $this->belongsTo('App\Subreddit');
}
public function user() {
return $this->belongsTo('App\User', 'user_id');
}
public function posts() {
return $this->belongsTo('App\Post');
}
答案 0 :(得分:1)
由于我不知道->exists()
的用法,但基本前提只是检查当前用户是否为特定Moderator
的{{1}},您可以简单地执行以下操作:
Subreddit
答案 1 :(得分:0)
我认为你$isModerator = $ids->moderators()->where('user_id', Auth::id())
返回NULL而不是集合对象。所以你不能使用->exists()
方法。
您是否尝试使用whereHas \ has方法而不是->where('user_id', Auth::id())
?