mirror of
https://github.com/flarum/framework.git
synced 2025-02-19 16:12:45 +08:00
122 lines
3.2 KiB
PHP
122 lines
3.2 KiB
PHP
![]() |
<?php
|
||
|
/*
|
||
|
* This file is part of Flarum.
|
||
|
*
|
||
|
* (c) Toby Zerner <toby.zerner@gmail.com>
|
||
|
*
|
||
|
* For the full copyright and license information, please view the LICENSE
|
||
|
* file that was distributed with this source code.
|
||
|
*/
|
||
|
|
||
|
namespace Flarum\Core\Access;
|
||
|
|
||
|
use Carbon\Carbon;
|
||
|
use Flarum\Core\Post;
|
||
|
use Flarum\Core\User;
|
||
|
use Flarum\Event\ScopePostVisibility;
|
||
|
use Flarum\Settings\SettingsRepository;
|
||
|
use Illuminate\Contracts\Events\Dispatcher;
|
||
|
|
||
|
class PostPolicy extends AbstractPolicy
|
||
|
{
|
||
|
/**
|
||
|
* {@inheritdoc}
|
||
|
*/
|
||
|
protected $model = Post::class;
|
||
|
|
||
|
/**
|
||
|
* @var SettingsRepository
|
||
|
*/
|
||
|
protected $settings;
|
||
|
|
||
|
/**
|
||
|
* @var Gate
|
||
|
*/
|
||
|
protected $gate;
|
||
|
|
||
|
/**
|
||
|
* @param SettingsRepository $settings
|
||
|
* @param Gate $gate
|
||
|
*/
|
||
|
public function __construct(SettingsRepository $settings, Gate $gate)
|
||
|
{
|
||
|
$this->settings = $settings;
|
||
|
$this->gate = $gate;
|
||
|
}
|
||
|
|
||
|
/**
|
||
|
* @inheritDoc
|
||
|
*/
|
||
|
public function subscribe(Dispatcher $events)
|
||
|
{
|
||
|
parent::subscribe($events);
|
||
|
|
||
|
$events->listen(ScopePostVisibility::class, [$this, 'scopePostVisibility']);
|
||
|
}
|
||
|
|
||
|
/**
|
||
|
* @param User $actor
|
||
|
* @param string $ability
|
||
|
* @param Post $post
|
||
|
* @return bool|null
|
||
|
*/
|
||
|
public function before(User $actor, $ability, Post $post)
|
||
|
{
|
||
|
if ($this->discussionAllows($actor, $ability, $post)) {
|
||
|
return true;
|
||
|
}
|
||
|
}
|
||
|
|
||
|
/**
|
||
|
* @param ScopePostVisibility $event
|
||
|
*/
|
||
|
public function scopePostVisibility(ScopePostVisibility $event)
|
||
|
{
|
||
|
// When fetching a discussion's posts: if the user doesn't have permission
|
||
|
// to moderate the discussion, then they can't see posts that have been
|
||
|
// hidden by someone other than themself.
|
||
|
if ($this->gate->forUser($event->actor)->denies('editPosts', $event->discussion)) {
|
||
|
$event->query->where(function ($query) use ($event) {
|
||
|
$query->whereNull('hide_time')
|
||
|
->orWhere('user_id', $event->actor->id);
|
||
|
});
|
||
|
}
|
||
|
}
|
||
|
|
||
|
/**
|
||
|
* @param User $actor
|
||
|
* @param Post $post
|
||
|
* @return bool|null
|
||
|
*/
|
||
|
public function edit(User $actor, Post $post)
|
||
|
{
|
||
|
if ($this->discussionAllows($actor, 'edit', $post)) {
|
||
|
return true;
|
||
|
}
|
||
|
|
||
|
// A post is allowed to be edited if the user has permission to moderate
|
||
|
// the discussion which it's in, or if they are the author and the post
|
||
|
// hasn't been deleted by someone else.
|
||
|
if ($post->user_id == $actor->id && (! $post->hide_time || $post->hide_user_id == $actor->id)) {
|
||
|
$allowEditing = $this->settings->get('allow_post_editing');
|
||
|
|
||
|
if ($allowEditing === '-1'
|
||
|
|| ($allowEditing === 'reply' && $post->number >= $post->discussion->last_post_number)
|
||
|
|| ($post->time->diffInMinutes(new Carbon) < $allowEditing)) {
|
||
|
return true;
|
||
|
}
|
||
|
}
|
||
|
}
|
||
|
|
||
|
/**
|
||
|
* @param User $actor
|
||
|
* @param string $ability
|
||
|
* @param Post $post
|
||
|
* @return bool
|
||
|
*/
|
||
|
protected function discussionAllows(User $actor, $ability, Post $post)
|
||
|
{
|
||
|
return $this->gate->forUser($actor)->allows($ability.'Posts', $post->discussion);
|
||
|
}
|
||
|
}
|