-
-
Notifications
You must be signed in to change notification settings - Fork 12
/
Copy pathextend.php
112 lines (90 loc) · 4.59 KB
/
extend.php
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
<?php
namespace FoF\Masquerade;
use Flarum\Api\Controller\CreateUserController;
use Flarum\Api\Controller\ListPostsController;
use Flarum\Api\Controller\ListUsersController;
use Flarum\Api\Controller\ShowDiscussionController;
use Flarum\Api\Controller\ShowForumController;
use Flarum\Api\Controller\ShowUserController;
use Flarum\Api\Controller\UpdateUserController;
use Flarum\Api\Serializer\BasicUserSerializer;
use Flarum\Api\Serializer\ForumSerializer;
use Flarum\Api\Serializer\UserSerializer;
use Flarum\User\Filter\UserFilterer;
use Flarum\User\Search\UserSearcher;
use Flarum\User\User;
use FoF\Masquerade\Api\Controllers as Api;
use Flarum\Extend;
use FoF\Masquerade\Api\Serializers\AnswerSerializer;
use FoF\Masquerade\Api\Serializers\FieldSerializer;
return [
(new Extend\Frontend('forum'))
->js(__DIR__ . '/js/dist/forum.js')
->css(__DIR__ . '/resources/less/forum.less'),
(new Extend\Frontend('admin'))
->js(__DIR__ . '/js/dist/admin.js')
->css(__DIR__ . '/resources/less/admin.less'),
(new Extend\Routes('api'))
->get('/masquerade/fields', 'masquerade.api.fields.index', Api\FieldIndexController::class)
->post('/masquerade/fields/order', 'masquerade.api.fields.order', Api\OrderFieldController::class)
->post('/masquerade/fields', 'masquerade.api.fields.create', Api\StoreFieldController::class)
->patch('/masquerade/fields/{id:[0-9]+}', 'masquerade.api.fields.update', Api\UpdateFieldController::class)
->delete('/masquerade/fields[/{id:[0-9]+}]', 'masquerade.api.fields.delete', Api\DeleteFieldController::class)
->get('/masquerade/profile/{id:[0-9]+}', 'masquerade.api.profile', Api\UserProfileController::class)
->get('/masquerade/configure/{id:[0-9]+}', 'masquerade.api.configure', Api\UserConfigureController::class)
->post('/masquerade/configure/{id:[0-9]+}', 'masquerade.api.configure.save', Api\UserConfigureController::class),
(new Extend\Middleware('forum'))
->add(Middleware\DemandProfileCompletion::class),
(new Extend\Locales(__DIR__ . '/resources/locale')),
(new Extend\ApiController(ShowForumController::class))
->prepareDataForSerialization(LoadAllMasqueradeFieldsRelationship::class)
->addInclude('masqueradeFields'),
(new Extend\ApiController(ShowUserController::class))
->addInclude('bioFields.field')
->addInclude('masqueradeAnswers'),
(new Extend\ApiController(UpdateUserController::class))
->addInclude('bioFields.field')
->addInclude('masqueradeAnswers'),
(new Extend\ApiController(CreateUserController::class))
->addInclude('bioFields.field')
->addInclude('masqueradeAnswers'),
(new Extend\ApiController(ListUsersController::class))
->addInclude('bioFields.field')
->addInclude('masqueradeAnswers'),
(new Extend\ApiController(ListPostsController::class))
->addInclude('user.bioFields.field')
->addInclude('user.masqueradeAnswers'),
(new Extend\ApiController(ShowDiscussionController::class))
->addInclude('posts.user.bioFields.field')
->addInclude('posts.user.masqueradeAnswers'),
(new Extend\Model(User::class))
->relationship('bioFields', function (User $model) {
return $model->hasMany(Answer::class)
->whereHas('field', function ($q) {
$q->where('on_bio', true);
});
})
->hasMany('masqueradeAnswers', Answer::class),
(new Extend\ApiSerializer(BasicUserSerializer::class))
->hasMany('bioFields', AnswerSerializer::class)
->hasMany('masqueradeAnswers', AnswerSerializer::class)
->attributes(function (BasicUserSerializer $serializer, User $user): array {
$actor = $serializer->getActor();
if ($actor->cannot('fof.masquerade.view-profile')) {
// When the relationships are auto-loaded later,
// this one will be skipped because it has already been set to null
$user->setRelation('bioFields', null);
$user->setRelation('masqueradeAnswers', null);
}
return [];
}),
(new Extend\ApiSerializer(ForumSerializer::class))
->attributes(ForumAttributes::class)
->hasMany('masqueradeFields', FieldSerializer::class),
(new Extend\ApiSerializer(UserSerializer::class))
->attributes(UserAttributes::class),
(new Extend\SimpleFlarumSearch(UserSearcher::class))
->addGambit(Gambits\AnswerGambit::class),
(new Extend\Filter(UserFilterer::class))
->addFilter(Gambits\AnswerGambit::class),
];