mirror of
https://github.com/flarum/framework.git
synced 2025-05-26 08:39:56 +08:00

- Return all discussion post IDs from API requests which add/remove posts, so the post stream updates appropriately. Related to #146 - Always unload posts that are two pages away, no matter how fast you’re scrolling - Retrieve posts from cache instead of reloading them - Fix various bugs. Maybe #152, needs confirmation
102 lines
2.5 KiB
PHP
102 lines
2.5 KiB
PHP
<?php namespace Flarum\Api\Actions\Discussions;
|
|
|
|
use Flarum\Core\Discussions\Commands\EditDiscussion;
|
|
use Flarum\Core\Discussions\Commands\ReadDiscussion;
|
|
use Flarum\Api\Actions\SerializeResourceAction;
|
|
use Flarum\Api\JsonApiRequest;
|
|
use Illuminate\Contracts\Bus\Dispatcher;
|
|
use Tobscure\JsonApi\Document;
|
|
|
|
class UpdateAction extends SerializeResourceAction
|
|
{
|
|
/**
|
|
* @var Dispatcher
|
|
*/
|
|
protected $bus;
|
|
|
|
/**
|
|
* @inheritdoc
|
|
*/
|
|
public static $serializer = 'Flarum\Api\Serializers\DiscussionSerializer';
|
|
|
|
/**
|
|
* @inheritdoc
|
|
*/
|
|
public static $include = [];
|
|
|
|
/**
|
|
* @inheritdoc
|
|
*/
|
|
public static $link = [];
|
|
|
|
/**
|
|
* @inheritdoc
|
|
*/
|
|
public static $limitMax = 50;
|
|
|
|
/**
|
|
* @inheritdoc
|
|
*/
|
|
public static $limit = 20;
|
|
|
|
/**
|
|
* @inheritdoc
|
|
*/
|
|
public static $sortFields = [];
|
|
|
|
/**
|
|
* @inheritdoc
|
|
*/
|
|
public static $sort;
|
|
|
|
/**
|
|
* @param Dispatcher $bus
|
|
*/
|
|
public function __construct(Dispatcher $bus)
|
|
{
|
|
$this->bus = $bus;
|
|
}
|
|
|
|
/**
|
|
* Update a discussion according to input from the API request, and return
|
|
* it ready to be serialized and assigned to the JsonApi response.
|
|
*
|
|
* @param JsonApiRequest $request
|
|
* @param Document $document
|
|
* @return \Flarum\Core\Discussions\Discussion
|
|
*/
|
|
protected function data(JsonApiRequest $request, Document $document)
|
|
{
|
|
$actor = $request->actor;
|
|
$discussionId = $request->get('id');
|
|
$data = $request->get('data');
|
|
|
|
$discussion = $this->bus->dispatch(
|
|
new EditDiscussion($discussionId, $actor, $data)
|
|
);
|
|
|
|
// TODO: Refactor the ReadDiscussion (state) command into EditDiscussion?
|
|
// That's what extensions will do anyway.
|
|
if ($readNumber = array_get($data, 'attributes.readNumber')) {
|
|
$state = $this->bus->dispatch(
|
|
new ReadDiscussion($discussionId, $actor, $readNumber)
|
|
);
|
|
|
|
$discussion = $state->discussion;
|
|
}
|
|
|
|
if ($posts = $discussion->getModifiedPosts()) {
|
|
$discussion->posts_ids = $discussion->postsVisibleTo($actor)->orderBy('time')->lists('id');
|
|
|
|
$discussion->posts = array_filter($posts, function ($post) {
|
|
return $post->exists;
|
|
});
|
|
|
|
$request->include = array_merge($request->include, ['posts']);
|
|
$request->link = array_merge($request->include, ['posts', 'posts.discussion', 'posts.user']);
|
|
}
|
|
|
|
return $discussion;
|
|
}
|
|
}
|