mirror of
https://github.com/flarum/core.git
synced 2025-07-17 14:51:19 +02:00
Get rid of event subscribers that resolve services too early
Refs flarum/core#1578.
This commit is contained in:
@@ -9,6 +9,8 @@
|
|||||||
* file that was distributed with this source code.
|
* file that was distributed with this source code.
|
||||||
*/
|
*/
|
||||||
|
|
||||||
|
use Flarum\Api\Event\Serializing;
|
||||||
|
use Flarum\Event\ConfigureModelDates;
|
||||||
use Flarum\Extend;
|
use Flarum\Extend;
|
||||||
use Flarum\Flags\Api\Controller\CreateFlagController;
|
use Flarum\Flags\Api\Controller\CreateFlagController;
|
||||||
use Flarum\Flags\Api\Controller\DeleteFlagsController;
|
use Flarum\Flags\Api\Controller\DeleteFlagsController;
|
||||||
@@ -30,7 +32,9 @@ return [
|
|||||||
->delete('/posts/{id}/flags', 'flags.delete', DeleteFlagsController::class),
|
->delete('/posts/{id}/flags', 'flags.delete', DeleteFlagsController::class),
|
||||||
|
|
||||||
function (Dispatcher $events) {
|
function (Dispatcher $events) {
|
||||||
$events->subscribe(Listener\AddFlagsApi::class);
|
$events->listen(ConfigureModelDates::class, Listener\AddFlagsApiDates::class);
|
||||||
|
$events->listen(Serializing::class, Listener\AddFlagsApiAttributes::class);
|
||||||
|
|
||||||
$events->subscribe(Listener\AddPostFlagsRelationship::class);
|
$events->subscribe(Listener\AddPostFlagsRelationship::class);
|
||||||
},
|
},
|
||||||
];
|
];
|
||||||
|
@@ -15,13 +15,11 @@ use Flarum\Api\Event\Serializing;
|
|||||||
use Flarum\Api\Serializer\CurrentUserSerializer;
|
use Flarum\Api\Serializer\CurrentUserSerializer;
|
||||||
use Flarum\Api\Serializer\ForumSerializer;
|
use Flarum\Api\Serializer\ForumSerializer;
|
||||||
use Flarum\Api\Serializer\PostSerializer;
|
use Flarum\Api\Serializer\PostSerializer;
|
||||||
use Flarum\Event\ConfigureModelDates;
|
|
||||||
use Flarum\Flags\Flag;
|
use Flarum\Flags\Flag;
|
||||||
use Flarum\Settings\SettingsRepositoryInterface;
|
use Flarum\Settings\SettingsRepositoryInterface;
|
||||||
use Flarum\User\User;
|
use Flarum\User\User;
|
||||||
use Illuminate\Contracts\Events\Dispatcher;
|
|
||||||
|
|
||||||
class AddFlagsApi
|
class AddFlagsApiAttributes
|
||||||
{
|
{
|
||||||
/**
|
/**
|
||||||
* @var SettingsRepositoryInterface
|
* @var SettingsRepositoryInterface
|
||||||
@@ -36,29 +34,7 @@ class AddFlagsApi
|
|||||||
$this->settings = $settings;
|
$this->settings = $settings;
|
||||||
}
|
}
|
||||||
|
|
||||||
/**
|
public function handle(Serializing $event)
|
||||||
* @param Dispatcher $events
|
|
||||||
*/
|
|
||||||
public function subscribe(Dispatcher $events)
|
|
||||||
{
|
|
||||||
$events->listen(ConfigureModelDates::class, [$this, 'configureModelDates']);
|
|
||||||
$events->listen(Serializing::class, [$this, 'prepareApiAttributes']);
|
|
||||||
}
|
|
||||||
|
|
||||||
/**
|
|
||||||
* @param ConfigureModelDates $event
|
|
||||||
*/
|
|
||||||
public function configureModelDates(ConfigureModelDates $event)
|
|
||||||
{
|
|
||||||
if ($event->isModel(User::class)) {
|
|
||||||
$event->dates[] = 'read_flags_at';
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
/**
|
|
||||||
* @param Serializing $event
|
|
||||||
*/
|
|
||||||
public function prepareApiAttributes(Serializing $event)
|
|
||||||
{
|
{
|
||||||
if ($event->isSerializer(ForumSerializer::class)) {
|
if ($event->isSerializer(ForumSerializer::class)) {
|
||||||
$event->attributes['canViewFlags'] = $event->actor->hasPermissionLike('discussion.viewFlags');
|
$event->attributes['canViewFlags'] = $event->actor->hasPermissionLike('discussion.viewFlags');
|
25
extensions/flags/src/Listener/AddFlagsApiDates.php
Executable file
25
extensions/flags/src/Listener/AddFlagsApiDates.php
Executable file
@@ -0,0 +1,25 @@
|
|||||||
|
<?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\Flags\Listener;
|
||||||
|
|
||||||
|
use Flarum\Event\ConfigureModelDates;
|
||||||
|
use Flarum\User\User;
|
||||||
|
|
||||||
|
class AddFlagsApiDates
|
||||||
|
{
|
||||||
|
public function handle(ConfigureModelDates $event)
|
||||||
|
{
|
||||||
|
if ($event->isModel(User::class)) {
|
||||||
|
$event->dates[] = 'read_flags_at';
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
Reference in New Issue
Block a user