mirror of
https://github.com/flarum/framework.git
synced 2025-01-08 11:43:37 +08:00
237076e5b7
* chore: use subscribers * Apply fixes from StyleCI * Un-static Co-authored-by: StyleCI Bot <bot@styleci.io>
69 lines
2.2 KiB
PHP
69 lines
2.2 KiB
PHP
<?php
|
|
|
|
/*
|
|
* This file is part of Flarum.
|
|
*
|
|
* For detailed copyright and license information, please view the
|
|
* LICENSE file that was distributed with this source code.
|
|
*/
|
|
|
|
use Flarum\Api\Serializer\BasicDiscussionSerializer;
|
|
use Flarum\Api\Serializer\PostSerializer;
|
|
use Flarum\Approval\Access;
|
|
use Flarum\Approval\Listener;
|
|
use Flarum\Discussion\Discussion;
|
|
use Flarum\Extend;
|
|
use Flarum\Post\CommentPost;
|
|
use Flarum\Post\Post;
|
|
use Flarum\Tags\Tag;
|
|
|
|
return [
|
|
(new Extend\Frontend('forum'))
|
|
->js(__DIR__.'/js/dist/forum.js')
|
|
->css(__DIR__.'/less/forum.less'),
|
|
|
|
(new Extend\Frontend('admin'))
|
|
->js(__DIR__.'/js/dist/admin.js'),
|
|
|
|
// Discussions should be approved by default
|
|
(new Extend\Model(Discussion::class))
|
|
->default('is_approved', true),
|
|
|
|
// Posts should be approved by default
|
|
(new Extend\Model(Post::class))
|
|
->default('is_approved', true),
|
|
|
|
(new Extend\ApiSerializer(BasicDiscussionSerializer::class))
|
|
->attribute('isApproved', function ($serializer, Discussion $discussion) {
|
|
return (bool) $discussion->is_approved;
|
|
}),
|
|
|
|
(new Extend\ApiSerializer(PostSerializer::class))
|
|
->attribute('isApproved', function ($serializer, Post $post) {
|
|
return (bool) $post->is_approved;
|
|
})->attribute('canApprove', function (PostSerializer $serializer, Post $post) {
|
|
return (bool) $serializer->getActor()->can('approvePosts', $post->discussion);
|
|
}),
|
|
|
|
new Extend\Locales(__DIR__.'/locale'),
|
|
|
|
(new Extend\Event())
|
|
->subscribe(Listener\ApproveContent::class)
|
|
->subscribe(Listener\UnapproveNewContent::class),
|
|
|
|
(new Extend\Policy())
|
|
->modelPolicy(Tag::class, Access\TagPolicy::class),
|
|
|
|
(new Extend\ModelVisibility(Post::class))
|
|
->scope(Access\ScopePrivatePostVisibility::class, 'viewPrivate'),
|
|
|
|
(new Extend\ModelVisibility(Discussion::class))
|
|
->scope(Access\ScopePrivateDiscussionVisibility::class, 'viewPrivate'),
|
|
|
|
(new Extend\ModelPrivate(Discussion::class))
|
|
->checker([Listener\UnapproveNewContent::class, 'markUnapprovedContentAsPrivate']),
|
|
|
|
(new Extend\ModelPrivate(CommentPost::class))
|
|
->checker([Listener\UnapproveNewContent::class, 'markUnapprovedContentAsPrivate']),
|
|
];
|