-
Notifications
You must be signed in to change notification settings - Fork 3
Expand file tree
/
Copy pathapi.php
More file actions
62 lines (56 loc) · 3.58 KB
/
api.php
File metadata and controls
62 lines (56 loc) · 3.58 KB
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
<?php
use App\Http\Middleware\AuthorisedUsersForDeletedWikiMetricsMiddleware;
use Illuminate\Routing\Router;
use Illuminate\Support\Facades\Config;
/**
* This route file is loaded in the RouteServiceProvider optionally when an env var is set.
* You'll find that service in the Providers directory.
*
* @var Router $router
*/
$router->group(['middleware' => ['throttle:45,1']], function () use ($router): void {
// TODO actually use logout route in VUE app..
$router->post('user/register', [
'middleware' => ['throttle.signup:' . Config::get('wbstack.signup_throttling_limit') . ',' . Config::get('wbstack.signup_throttling_range')],
'uses' => 'Auth\RegisterController@register',
]);
$router->post('user/verifyEmail', ['uses' => 'UserVerificationTokenController@verify']);
$router->post('user/forgotPassword', ['uses' => 'Auth\ForgotPasswordController@sendResetLinkEmail']);
$router->post('user/resetPassword', ['uses' => 'Auth\ResetPasswordController@reset']);
$router->post('contact/sendMessage', ['uses' => 'ContactController@sendMessage']);
$router->post('complaint/sendMessage', ['uses' => 'ComplaintController@sendMessage']);
$router->post('auth/login', ['uses' => 'Auth\LoginController@postLogin'])->name('login');
// Authed
$router->group(['middleware' => ['auth:api']], function () use ($router): void {
$router->get('auth/login', ['uses' => 'Auth\LoginController@getLogin']);
$router->delete('auth/login', ['uses' => 'Auth\LoginController@deleteLogin']);
// user
$router->group(['prefix' => 'user'], function () use ($router): void {
$router->post('sendVerifyEmail', ['uses' => 'UserVerificationTokenController@createAndSendForUser']);
});
// wiki
// TODO wiki id should probably be in the path of most of these routes...
$router->group(['prefix' => 'wiki'], function () use ($router): void {
// TODO maybe the UI just shouldn't make this request if users are not verified...
$router->post('mine', ['uses' => 'WikisController@getWikisOwnedByCurrentUser']);
});
$router->group(['prefix' => 'wiki', 'middleware' => ['verified']], function () use ($router): void {
$router->post('create', ['uses' => 'WikiController@create']);
$router->group(['middleware' => 'limit_wiki_access'], function () use ($router): void {
$router->post('delete', ['uses' => 'WikiController@delete']);
$router->post('details', ['uses' => 'WikiController@getWikiDetailsForIdForOwner']);
$router->get('details', ['uses' => 'WikiController@getWikiDetailsForIdForOwner']);
$router->post('logo/update', ['uses' => 'WikiLogoController@update']);
$router->post('setting/{setting}/update', ['uses' => 'WikiSettingController@update']);
$router->get('entityImport', ['uses' => 'WikiEntityImportController@get']);
$router->post('entityImport', ['uses' => 'WikiEntityImportController@create']);
$router->post('profile', ['uses' => 'WikiProfileController@create']);
});
});
$router->apiResource('deletedWikiMetrics', 'DeletedWikiMetricsController')->only(['index'])
->middleware(AuthorisedUsersForDeletedWikiMetricsMiddleware::class);
});
$router->apiResource('wiki', 'PublicWikiController')->only(['index', 'show']);
$router->apiResource('reusePrototype', 'PublicWikiController')->only(['index', 'show']);
$router->apiResource('wikiConversionData', 'ConversionMetricController')->only(['index']);
});