web.php 30 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360361362363364365366367368369370371372373374375376377378379380381382383384385386387388389390391392393394395396397398399400401402403404405406407408409410411412413414415416
  1. <?php
  2. Route::domain(config('pixelfed.domain.admin'))->prefix('i/admin')->group(function () {
  3. Route::redirect('/', '/dashboard');
  4. Route::redirect('timeline', config('app.url').'/timeline');
  5. Route::get('dashboard', 'AdminController@home')->name('admin.home');
  6. Route::get('reports', 'AdminController@reports')->name('admin.reports');
  7. Route::get('reports/show/{id}', 'AdminController@showReport');
  8. Route::post('reports/show/{id}', 'AdminController@updateReport');
  9. Route::post('reports/bulk', 'AdminController@bulkUpdateReport');
  10. Route::redirect('statuses', '/statuses/list');
  11. Route::get('statuses/list', 'AdminController@statuses')->name('admin.statuses');
  12. Route::get('statuses/show/{id}', 'AdminController@showStatus');
  13. Route::redirect('profiles', '/i/admin/profiles/list');
  14. Route::get('profiles/list', 'AdminController@profiles')->name('admin.profiles');
  15. Route::get('profiles/edit/{id}', 'AdminController@profileShow');
  16. Route::redirect('users', '/users/list');
  17. Route::get('users/list', 'AdminController@users')->name('admin.users');
  18. Route::get('users/edit/{id}', 'AdminController@editUser');
  19. Route::get('media', 'AdminController@media')->name('admin.media');
  20. Route::redirect('media/list', '/i/admin/media');
  21. Route::get('media/show/{id}', 'AdminController@mediaShow');
  22. Route::get('settings', 'AdminController@settings')->name('admin.settings');
  23. Route::post('settings', 'AdminController@settingsHomeStore');
  24. Route::get('settings/config', 'AdminController@settingsConfig')->name('admin.settings.config');
  25. Route::post('settings/config', 'AdminController@settingsConfigStore');
  26. Route::post('settings/config/restore', 'AdminController@settingsConfigRestore');
  27. Route::get('settings/features', 'AdminController@settingsFeatures')->name('admin.settings.features');
  28. Route::get('settings/pages', 'AdminController@settingsPages')->name('admin.settings.pages');
  29. Route::get('settings/pages/edit', 'PageController@edit')->name('admin.settings.pages.edit');
  30. Route::post('settings/pages/edit', 'PageController@store');
  31. Route::post('settings/pages/delete', 'PageController@delete');
  32. Route::post('settings/pages/create', 'PageController@generatePage');
  33. Route::get('settings/maintenance', 'AdminController@settingsMaintenance')->name('admin.settings.maintenance');
  34. Route::get('settings/backups', 'AdminController@settingsBackups')->name('admin.settings.backups');
  35. Route::get('settings/storage', 'AdminController@settingsStorage')->name('admin.settings.storage');
  36. Route::get('settings/system', 'AdminController@settingsSystem')->name('admin.settings.system');
  37. Route::get('instances', 'AdminController@instances')->name('admin.instances');
  38. Route::post('instances', 'AdminController@instanceScan');
  39. Route::get('instances/show/{id}', 'AdminController@instanceShow');
  40. Route::post('instances/edit/{id}', 'AdminController@instanceEdit');
  41. Route::get('apps/home', 'AdminController@appsHome')->name('admin.apps');
  42. Route::get('hashtags/home', 'AdminController@hashtagsHome')->name('admin.hashtags');
  43. Route::get('discover/home', 'AdminController@discoverHome')->name('admin.discover');
  44. Route::get('discover/category/create', 'AdminController@discoverCreateCategory')->name('admin.discover.create-category');
  45. Route::post('discover/category/create', 'AdminController@discoverCreateCategoryStore');
  46. Route::get('discover/category/edit/{id}', 'AdminController@discoverCategoryEdit');
  47. Route::post('discover/category/edit/{id}', 'AdminController@discoverCategoryUpdate');
  48. Route::post('discover/category/hashtag/create', 'AdminController@discoveryCategoryTagStore')->name('admin.discover.create-hashtag');
  49. Route::get('messages/home', 'AdminController@messagesHome')->name('admin.messages');
  50. Route::get('messages/show/{id}', 'AdminController@messagesShow');
  51. Route::post('messages/mark-read', 'AdminController@messagesMarkRead');
  52. });
  53. Route::domain(config('pixelfed.domain.app'))->middleware(['validemail', 'twofactor', 'localization'])->group(function () {
  54. Route::get('/', 'SiteController@home')->name('timeline.personal');
  55. Route::post('/', 'StatusController@store');
  56. Auth::routes();
  57. Route::get('.well-known/webfinger', 'FederationController@webfinger')->name('well-known.webfinger');
  58. Route::get('.well-known/nodeinfo', 'FederationController@nodeinfoWellKnown')->name('well-known.nodeinfo');
  59. Route::get('.well-known/host-meta', 'FederationController@hostMeta')->name('well-known.hostMeta');
  60. Route::redirect('.well-known/change-password', '/settings/password');
  61. Route::get('/home', 'HomeController@index')->name('home');
  62. Route::get('discover/c/{slug}', 'DiscoverController@showCategory');
  63. Route::redirect('discover/personal', '/discover');
  64. Route::get('discover', 'DiscoverController@home')->name('discover');
  65. Route::get('discover/loops', 'DiscoverController@showLoops');
  66. Route::group(['prefix' => 'api'], function () {
  67. Route::get('search', 'SearchController@searchAPI');
  68. Route::get('nodeinfo/2.0.json', 'FederationController@nodeinfo');
  69. Route::group(['prefix' => 'v1'], function () {
  70. Route::get('accounts/verify_credentials', 'ApiController@verifyCredentials')->middleware('auth:api');
  71. Route::patch('accounts/update_credentials', 'Api\ApiV1Controller@accountUpdateCredentials')->middleware('auth:api');
  72. Route::get('accounts/relationships', 'Api\ApiV1Controller@accountRelationshipsById')->middleware('auth:api');
  73. Route::get('accounts/search', 'Api\ApiV1Controller@accountSearch')->middleware('auth:api');
  74. Route::get('accounts/{id}/statuses', 'Api\ApiV1Controller@accountStatusesById')->middleware('auth:api');
  75. Route::get('accounts/{id}/following', 'Api\ApiV1Controller@accountFollowingById')->middleware('auth:api');
  76. Route::get('accounts/{id}/followers', 'Api\ApiV1Controller@accountFollowersById')->middleware('auth:api');
  77. Route::post('accounts/{id}/follow', 'Api\ApiV1Controller@accountFollowById')->middleware('auth:api');
  78. Route::post('accounts/{id}/unfollow', 'Api\ApiV1Controller@accountUnfollowById')->middleware('auth:api');
  79. Route::post('accounts/{id}/block', 'Api\ApiV1Controller@accountBlockById')->middleware('auth:api');
  80. Route::post('accounts/{id}/unblock', 'Api\ApiV1Controller@accountUnblockById')->middleware('auth:api');
  81. Route::post('accounts/{id}/pin', 'Api\ApiV1Controller@accountEndorsements')->middleware('auth:api');
  82. Route::post('accounts/{id}/unpin', 'Api\ApiV1Controller@accountEndorsements')->middleware('auth:api');
  83. // Route::get('accounts/{id}', 'PublicApiController@account');
  84. Route::post('avatar/update', 'ApiController@avatarUpdate')->middleware('auth:api');
  85. Route::get('domain_blocks', 'Api\ApiV1Controller@accountDomainBlocks')->middleware('auth:api');
  86. Route::post('domain_blocks', 'Api\ApiV1Controller@accountDomainBlocks')->middleware('auth:api');
  87. Route::delete('domain_blocks', 'Api\ApiV1Controller@accountDomainBlocks')->middleware('auth:api');
  88. Route::get('endorsements', 'Api\ApiV1Controller@accountEndorsements')->middleware('auth:api');
  89. Route::get('blocks', 'Api\ApiV1Controller@accountBlocks')->middleware('auth:api');
  90. Route::get('custom_emojis', 'Api\ApiV1Controller@customEmojis');
  91. Route::get('favourites', 'Api\ApiV1Controller@accountFavourites')->middleware('auth:api');
  92. Route::post('statuses/{id}/favourite', 'Api\ApiV1Controller@statusFavouriteById')->middleware('auth:api');
  93. Route::post('statuses/{id}/unfavourite', 'Api\ApiV1Controller@statusUnfavouriteById')->middleware('auth:api');
  94. Route::get('filters', 'Api\ApiV1Controller@accountFilters')->middleware('auth:api');
  95. Route::get('follow_requests', 'Api\ApiV1Controller@accountFollowRequests')->middleware('auth:api');
  96. Route::post('follow_requests/{id}/authorize', 'Api\ApiV1Controller@accountFollowRequestAccept')->middleware('auth:api');
  97. Route::post('follow_requests/{id}/reject', 'Api\ApiV1Controller@accountFollowRequestReject')->middleware('auth:api');
  98. Route::get('suggestions', 'Api\ApiV1Controller@accountSuggestions')->middleware('auth:api');
  99. Route::get('lists', 'Api\ApiV1Controller@accountLists')->middleware('auth:api');
  100. Route::get('accounts/{id}/lists', 'Api\ApiV1Controller@accountListsById')->middleware('auth:api');
  101. Route::get('lists/{id}/accounts', 'Api\ApiV1Controller@accountListsById')->middleware('auth:api');
  102. Route::post('media', 'Api\ApiV1Controller@mediaUpload')->middleware('auth:api');
  103. Route::put('media/{id}', 'Api\ApiV1Controller@mediaUpdate')->middleware('auth:api');
  104. Route::get('mutes', 'Api\ApiV1Controller@accountMutes')->middleware('auth:api');
  105. Route::post('accounts/{id}/mute', 'Api\ApiV1Controller@accountMuteById')->middleware('auth:api');
  106. Route::post('accounts/{id}/unmute', 'Api\ApiV1Controller@accountUnmuteById')->middleware('auth:api');
  107. Route::get('notifications', 'Api\ApiV1Controller@accountNotifications')->middleware('auth:api');
  108. Route::get('timelines/home', 'Api\ApiV1Controller@timelineHome')->middleware('auth:api');
  109. Route::get('conversations', 'Api\ApiV1Controller@conversations')->middleware('auth:api');
  110. Route::get('timelines/public', 'Api\ApiV1Controller@timelinePublic');
  111. // Route::get('likes', 'ApiController@hydrateLikes');
  112. // Route::post('media', 'ApiController@uploadMedia')->middleware('auth:api');
  113. // Route::delete('media', 'ApiController@deleteMedia')->middleware('auth:api');
  114. // Route::get('notifications', 'ApiController@notifications')->middleware('auth:api');
  115. // Route::get('timelines/public', 'PublicApiController@publicTimelineApi');
  116. // Route::post('status', 'Api\ApiV1Controller@createStatus')->middleware('auth:api');
  117. Route::get('accounts/{id}', 'Api\ApiV1Controller@accountById')->middleware('auth:api');
  118. });
  119. Route::group(['prefix' => 'v2'], function() {
  120. Route::get('config', 'ApiController@siteConfiguration');
  121. Route::get('discover', 'InternalApiController@discover');
  122. Route::get('discover/posts', 'InternalApiController@discoverPosts');
  123. Route::get('profile/{username}/status/{postid}', 'PublicApiController@status');
  124. Route::get('comments/{username}/status/{postId}', 'PublicApiController@statusComments');
  125. Route::get('likes/profile/{username}/status/{id}', 'PublicApiController@statusLikes');
  126. Route::get('shares/profile/{username}/status/{id}', 'PublicApiController@statusShares');
  127. Route::get('status/{id}/replies', 'InternalApiController@statusReplies');
  128. Route::post('moderator/action', 'InternalApiController@modAction');
  129. Route::get('discover/categories', 'InternalApiController@discoverCategories');
  130. Route::get('loops', 'DiscoverController@loopsApi');
  131. Route::post('loops/watch', 'DiscoverController@loopWatch');
  132. Route::get('discover/tag', 'DiscoverController@getHashtags');
  133. Route::post('status/compose', 'InternalApiController@composePost')->middleware('throttle:maxPostsPerHour,60')->middleware('throttle:maxPostsPerDay,1440');
  134. });
  135. Route::group(['prefix' => 'pixelfed'], function() {
  136. Route::group(['prefix' => 'v1'], function() {
  137. Route::get('accounts/verify_credentials', 'ApiController@verifyCredentials');
  138. Route::get('accounts/relationships', 'Api\ApiV1Controller@accountRelationshipsById');
  139. Route::get('accounts/search', 'Api\ApiV1Controller@accountSearch');
  140. Route::get('accounts/{id}/statuses', 'PublicApiController@accountStatuses');
  141. Route::get('accounts/{id}/following', 'PublicApiController@accountFollowing');
  142. Route::get('accounts/{id}/followers', 'PublicApiController@accountFollowers');
  143. Route::post('accounts/{id}/block', 'Api\ApiV1Controller@accountBlockById');
  144. Route::post('accounts/{id}/unblock', 'Api\ApiV1Controller@accountUnblockById');
  145. Route::get('accounts/{id}', 'PublicApiController@account');
  146. Route::post('avatar/update', 'ApiController@avatarUpdate');
  147. Route::get('custom_emojis', 'Api\ApiV1Controller@customEmojis');
  148. Route::get('likes', 'ApiController@hydrateLikes');
  149. Route::post('media', 'ApiController@uploadMedia');
  150. Route::delete('media', 'ApiController@deleteMedia');
  151. Route::get('notifications', 'ApiController@notifications');
  152. Route::get('timelines/public', 'PublicApiController@publicTimelineApi');
  153. Route::get('timelines/home', 'PublicApiController@homeTimelineApi');
  154. });
  155. });
  156. Route::group(['prefix' => 'local'], function () {
  157. // Route::get('accounts/verify_credentials', 'ApiController@verifyCredentials');
  158. // Route::get('accounts/relationships', 'PublicApiController@relationships');
  159. // Route::get('accounts/{id}/statuses', 'PublicApiController@accountStatuses');
  160. // Route::get('accounts/{id}/following', 'PublicApiController@accountFollowing');
  161. // Route::get('accounts/{id}/followers', 'PublicApiController@accountFollowers');
  162. // Route::get('accounts/{id}', 'PublicApiController@account');
  163. // Route::post('avatar/update', 'ApiController@avatarUpdate');
  164. // Route::get('likes', 'ApiController@hydrateLikes');
  165. // Route::post('media', 'ApiController@uploadMedia');
  166. // Route::delete('media', 'ApiController@deleteMedia');
  167. // Route::get('notifications', 'ApiController@notifications');
  168. // Route::get('timelines/public', 'PublicApiController@publicTimelineApi');
  169. // Route::get('timelines/home', 'PublicApiController@homeTimelineApi');
  170. Route::post('status/compose', 'InternalApiController@composePost')->middleware('throttle:maxPostsPerHour,60')->middleware('throttle:maxPostsPerDay,1440');
  171. Route::get('exp/rec', 'ApiController@userRecommendations');
  172. Route::post('discover/tag/subscribe', 'HashtagFollowController@store')->middleware('throttle:maxHashtagFollowsPerHour,60')->middleware('throttle:maxHashtagFollowsPerDay,1440');;
  173. Route::get('discover/tag/list', 'HashtagFollowController@getTags');
  174. Route::get('profile/sponsor/{id}', 'ProfileSponsorController@get');
  175. Route::get('bookmarks', 'InternalApiController@bookmarks');
  176. Route::get('collection/items/{id}', 'CollectionController@getItems');
  177. Route::post('collection/item', 'CollectionController@storeId');
  178. Route::get('collection/{id}', 'CollectionController@get');
  179. Route::post('collection/{id}', 'CollectionController@store');
  180. Route::delete('collection/{id}', 'CollectionController@delete')->middleware('throttle:maxCollectionsPerHour,60')->middleware('throttle:maxCollectionsPerDay,1440')->middleware('throttle:maxCollectionsPerMonth,43800');
  181. Route::post('collection/{id}/publish', 'CollectionController@publish')->middleware('throttle:maxCollectionsPerHour,60')->middleware('throttle:maxCollectionsPerDay,1440')->middleware('throttle:maxCollectionsPerMonth,43800');
  182. Route::get('profile/collections/{id}', 'CollectionController@getUserCollections');
  183. Route::post('compose/media/update/{id}', 'MediaController@composeUpdate')->middleware('throttle:maxComposeMediaUpdatesPerHour,60')->middleware('throttle:maxComposeMediaUpdatesPerDay,1440')->middleware('throttle:maxComposeMediaUpdatesPerMonth,43800');
  184. Route::get('compose/location/search', 'ApiController@composeLocationSearch');
  185. });
  186. Route::group(['prefix' => 'admin'], function () {
  187. Route::post('moderate', 'Api\AdminApiController@moderate');
  188. });
  189. });
  190. Route::get('discover/tags/{hashtag}', 'DiscoverController@showTags');
  191. Route::get('discover/places', 'PlaceController@directoryHome')->name('discover.places');
  192. Route::get('discover/places/{id}/{slug}', 'PlaceController@show');
  193. Route::get('discover/location/country/{country}', 'PlaceController@directoryCities');
  194. Route::group(['prefix' => 'i'], function () {
  195. Route::redirect('/', '/');
  196. Route::get('compose', 'StatusController@compose')->name('compose');
  197. Route::post('comment', 'CommentController@store')->middleware('throttle:maxCommentsPerHour,60')->middleware('throttle:maxCommentsPerDay,1440');
  198. Route::post('delete', 'StatusController@delete');
  199. Route::post('mute', 'AccountController@mute');
  200. Route::post('unmute', 'AccountController@unmute');
  201. Route::post('block', 'AccountController@block');
  202. Route::post('unblock', 'AccountController@unblock');
  203. Route::post('like', 'LikeController@store')->middleware('throttle:maxLikesPerHour,60')->middleware('throttle:maxLikesPerDay,1440');
  204. Route::post('share', 'StatusController@storeShare')->middleware('throttle:maxSharesPerHour,60')->middleware('throttle:maxSharesPerDay,1440');
  205. Route::post('follow', 'FollowerController@store');
  206. Route::post('bookmark', 'BookmarkController@store');
  207. Route::get('lang/{locale}', 'SiteController@changeLocale');
  208. Route::get('restored', 'AccountController@accountRestored');
  209. Route::get('verify-email', 'AccountController@verifyEmail');
  210. Route::post('verify-email', 'AccountController@sendVerifyEmail');
  211. Route::get('confirm-email/{userToken}/{randomToken}', 'AccountController@confirmVerifyEmail');
  212. Route::get('auth/sudo', 'AccountController@sudoMode');
  213. Route::post('auth/sudo', 'AccountController@sudoModeVerify');
  214. Route::get('auth/checkpoint', 'AccountController@twoFactorCheckpoint');
  215. Route::post('auth/checkpoint', 'AccountController@twoFactorVerify');
  216. Route::get('media/preview/{profileId}/{mediaId}', 'ApiController@showTempMedia')->name('temp-media');
  217. Route::get('results', 'SearchController@results');
  218. Route::post('visibility', 'StatusController@toggleVisibility');
  219. Route::post('metro/dark-mode', 'SettingsController@metroDarkMode');
  220. Route::group(['prefix' => 'report'], function () {
  221. Route::get('/', 'ReportController@showForm')->name('report.form');
  222. Route::post('/', 'ReportController@formStore');
  223. Route::get('not-interested', 'ReportController@notInterestedForm')->name('report.not-interested');
  224. Route::get('spam', 'ReportController@spamForm')->name('report.spam');
  225. Route::get('spam/comment', 'ReportController@spamCommentForm')->name('report.spam.comment');
  226. Route::get('spam/post', 'ReportController@spamPostForm')->name('report.spam.post');
  227. Route::get('spam/profile', 'ReportController@spamProfileForm')->name('report.spam.profile');
  228. Route::get('sensitive/comment', 'ReportController@sensitiveCommentForm')->name('report.sensitive.comment');
  229. Route::get('sensitive/post', 'ReportController@sensitivePostForm')->name('report.sensitive.post');
  230. Route::get('sensitive/profile', 'ReportController@sensitiveProfileForm')->name('report.sensitive.profile');
  231. Route::get('abusive/comment', 'ReportController@abusiveCommentForm')->name('report.abusive.comment');
  232. Route::get('abusive/post', 'ReportController@abusivePostForm')->name('report.abusive.post');
  233. Route::get('abusive/profile', 'ReportController@abusiveProfileForm')->name('report.abusive.profile');
  234. });
  235. Route::get('collections/create', 'CollectionController@create');
  236. Route::get('me', 'ProfileController@meRedirect');
  237. });
  238. Route::group(['prefix' => 'account'], function () {
  239. Route::redirect('/', '/');
  240. Route::get('activity', 'AccountController@notifications')->name('notifications');
  241. Route::get('follow-requests', 'AccountController@followRequests')->name('follow-requests');
  242. Route::post('follow-requests', 'AccountController@followRequestHandle');
  243. });
  244. Route::group(['prefix' => 'settings'], function () {
  245. Route::redirect('/', '/settings/home');
  246. Route::get('home', 'SettingsController@home')
  247. ->name('settings');
  248. Route::post('home', 'SettingsController@homeUpdate');
  249. Route::get('avatar', 'SettingsController@avatar')->name('settings.avatar');
  250. Route::post('avatar', 'AvatarController@store');
  251. Route::delete('avatar', 'AvatarController@deleteAvatar');
  252. Route::get('password', 'SettingsController@password')->name('settings.password')->middleware('dangerzone');
  253. Route::post('password', 'SettingsController@passwordUpdate')->middleware('dangerzone');
  254. Route::get('email', 'SettingsController@email')->name('settings.email');
  255. Route::post('email', 'SettingsController@emailUpdate');
  256. Route::get('notifications', 'SettingsController@notifications')->name('settings.notifications');
  257. Route::get('privacy', 'SettingsController@privacy')->name('settings.privacy');
  258. Route::post('privacy', 'SettingsController@privacyStore');
  259. Route::get('privacy/muted-users', 'SettingsController@mutedUsers')->name('settings.privacy.muted-users');
  260. Route::post('privacy/muted-users', 'SettingsController@mutedUsersUpdate');
  261. Route::get('privacy/blocked-users', 'SettingsController@blockedUsers')->name('settings.privacy.blocked-users');
  262. Route::post('privacy/blocked-users', 'SettingsController@blockedUsersUpdate');
  263. Route::get('privacy/blocked-instances', 'SettingsController@blockedInstances')->name('settings.privacy.blocked-instances');
  264. Route::post('privacy/blocked-instances', 'SettingsController@blockedInstanceStore')->middleware('throttle:maxInstanceBansPerDay,1440');
  265. Route::post('privacy/blocked-instances/unblock', 'SettingsController@blockedInstanceUnblock')->name('settings.privacy.blocked-instances.unblock');
  266. Route::get('privacy/blocked-keywords', 'SettingsController@blockedKeywords')->name('settings.privacy.blocked-keywords');
  267. Route::post('privacy/account', 'SettingsController@privateAccountOptions')->name('settings.privacy.account');
  268. Route::get('reports', 'SettingsController@reportsHome')->name('settings.reports');
  269. Route::group(['prefix' => 'remove', 'middleware' => 'dangerzone'], function() {
  270. Route::get('request/temporary', 'SettingsController@removeAccountTemporary')->name('settings.remove.temporary');
  271. Route::post('request/temporary', 'SettingsController@removeAccountTemporarySubmit');
  272. Route::get('request/permanent', 'SettingsController@removeAccountPermanent')->name('settings.remove.permanent');
  273. Route::post('request/permanent', 'SettingsController@removeAccountPermanentSubmit');
  274. });
  275. Route::group(['prefix' => 'security', 'middleware' => 'dangerzone'], function() {
  276. Route::get(
  277. '/',
  278. 'SettingsController@security'
  279. )->name('settings.security');
  280. Route::get(
  281. '2fa/setup',
  282. 'SettingsController@securityTwoFactorSetup'
  283. )->name('settings.security.2fa.setup');
  284. Route::post(
  285. '2fa/setup',
  286. 'SettingsController@securityTwoFactorSetupStore'
  287. );
  288. Route::get(
  289. '2fa/edit',
  290. 'SettingsController@securityTwoFactorEdit'
  291. )->name('settings.security.2fa.edit');
  292. Route::post(
  293. '2fa/edit',
  294. 'SettingsController@securityTwoFactorUpdate'
  295. );
  296. Route::get(
  297. '2fa/recovery-codes',
  298. 'SettingsController@securityTwoFactorRecoveryCodes'
  299. )->name('settings.security.2fa.recovery');
  300. Route::post(
  301. '2fa/recovery-codes',
  302. 'SettingsController@securityTwoFactorRecoveryCodesRegenerate'
  303. );
  304. });
  305. Route::get('applications', 'SettingsController@applications')->name('settings.applications')->middleware('dangerzone');
  306. Route::get('data-export', 'SettingsController@dataExport')->name('settings.dataexport')->middleware('dangerzone');
  307. Route::post('data-export/following', 'SettingsController@exportFollowing')->middleware('dangerzone');
  308. Route::post('data-export/followers', 'SettingsController@exportFollowers')->middleware('dangerzone');
  309. Route::post('data-export/mute-block-list', 'SettingsController@exportMuteBlockList')->middleware('dangerzone');
  310. Route::post('data-export/account', 'SettingsController@exportAccount')->middleware('dangerzone');
  311. Route::post('data-export/statuses', 'SettingsController@exportStatuses')->middleware('dangerzone');
  312. Route::get('developers', 'SettingsController@developers')->name('settings.developers')->middleware('dangerzone');
  313. Route::get('labs', 'SettingsController@labs')->name('settings.labs');
  314. Route::post('labs', 'SettingsController@labsStore');
  315. Route::get('accessibility', 'SettingsController@accessibility')->name('settings.accessibility');
  316. Route::post('accessibility', 'SettingsController@accessibilityStore');
  317. Route::group(['prefix' => 'relationships'], function() {
  318. Route::redirect('/', '/settings/relationships/home');
  319. Route::get('home', 'SettingsController@relationshipsHome')->name('settings.relationships');
  320. });
  321. Route::get('invites/create', 'UserInviteController@create')->name('settings.invites.create');
  322. Route::post('invites/create', 'UserInviteController@store');
  323. Route::get('invites', 'UserInviteController@show')->name('settings.invites');
  324. Route::get('sponsor', 'SettingsController@sponsor')->name('settings.sponsor');
  325. Route::post('sponsor', 'SettingsController@sponsorStore');
  326. });
  327. Route::group(['prefix' => 'site'], function () {
  328. Route::redirect('/', '/');
  329. Route::get('about', 'SiteController@about')->name('site.about');
  330. Route::view('help', 'site.help')->name('site.help');
  331. Route::view('developer-api', 'site.developer')->name('site.developers');
  332. Route::view('fediverse', 'site.fediverse')->name('site.fediverse');
  333. Route::view('open-source', 'site.opensource')->name('site.opensource');
  334. Route::view('banned-instances', 'site.bannedinstances')->name('site.bannedinstances');
  335. Route::get('terms', 'SiteController@terms')->name('site.terms');
  336. Route::get('privacy', 'SiteController@privacy')->name('site.privacy');
  337. Route::view('platform', 'site.platform')->name('site.platform');
  338. Route::view('language', 'site.language')->name('site.language');
  339. Route::get('contact', 'ContactController@show')->name('site.contact');
  340. Route::post('contact', 'ContactController@store');
  341. Route::group(['prefix'=>'kb'], function() {
  342. Route::view('getting-started', 'site.help.getting-started')->name('help.getting-started');
  343. Route::view('sharing-media', 'site.help.sharing-media')->name('help.sharing-media');
  344. Route::view('your-profile', 'site.help.your-profile')->name('help.your-profile');
  345. Route::view('stories', 'site.help.stories')->name('help.stories');
  346. Route::view('embed', 'site.help.embed')->name('help.embed');
  347. Route::view('hashtags', 'site.help.hashtags')->name('help.hashtags');
  348. Route::view('discover', 'site.help.discover')->name('help.discover');
  349. Route::view('direct-messages', 'site.help.dm')->name('help.dm');
  350. Route::view('timelines', 'site.help.timelines')->name('help.timelines');
  351. Route::view('what-is-the-fediverse', 'site.help.what-is-fediverse')->name('help.what-is-fediverse');
  352. Route::view('safety-tips', 'site.help.safety-tips')->name('help.safety-tips');
  353. Route::get('community-guidelines', 'SiteController@communityGuidelines')->name('help.community-guidelines');
  354. Route::view('controlling-visibility', 'site.help.controlling-visibility')->name('help.controlling-visibility');
  355. Route::view('blocking-accounts', 'site.help.blocking-accounts')->name('help.blocking-accounts');
  356. Route::view('report-something', 'site.help.report-something')->name('help.report-something');
  357. Route::view('data-policy', 'site.help.data-policy')->name('help.data-policy');
  358. });
  359. });
  360. Route::group(['prefix' => 'timeline'], function () {
  361. Route::redirect('/', '/');
  362. Route::get('public', 'TimelineController@local')->name('timeline.public');
  363. });
  364. Route::group(['prefix' => 'users'], function () {
  365. Route::redirect('/', '/');
  366. Route::get('{user}.atom', 'ProfileController@showAtomFeed');
  367. Route::get('{username}/outbox', 'FederationController@userOutbox');
  368. Route::get('{username}/followers', 'FederationController@userFollowers');
  369. Route::get('{username}/following', 'FederationController@userFollowing');
  370. Route::get('{username}', 'ProfileController@permalinkRedirect');
  371. });
  372. Route::get('c/{collection}', 'CollectionController@show');
  373. Route::get('p/{username}/{id}/c', 'CommentController@showAll');
  374. Route::get('p/{username}/{id}/edit', 'StatusController@edit');
  375. Route::post('p/{username}/{id}/edit', 'StatusController@editStore');
  376. Route::get('p/{username}/{id}.json', 'StatusController@showObject');
  377. Route::get('p/{username}/{id}', 'StatusController@show');
  378. Route::get('{username}', 'ProfileController@show');
  379. });