web.php 42 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360361362363364365366367368369370371372373374375376377378379380381382383384385386387388389390391392393394395396397398399400401402403404405406407408409410411412413414415416417418419420421422423424425426427428429430431432433434435436437438439440441442443444445446447448449450451452453454455456457458459460461462463464465466467468469470471472473474475476477478479480481482483484485486487488489490491492493494495496497498499500501502503504505506507508509510511512513514515516517518519520521522523524525526527528529530531532533534535536537538539540541542543544545546547548549550551552553554555556557558559560561562563564565566567568569570571572573574575576577578579580581582583584585586587588589590591592593594595596597598599600601602603604605606607608609610611612613614615616617618619620621622623624625626627628629630631632633634635636637638639640641642643644645646647648649650651652653654655656657658659660661662663664665666667668669670671672673674675676677678679680681682683684685686687688
  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('stats', 'AdminController@stats')->name('admin.stats');
  7. Route::get('reports', 'AdminController@reports')->name('admin.reports');
  8. Route::get('reports/show/{id}', 'AdminController@showReport');
  9. Route::post('reports/show/{id}', 'AdminController@updateReport');
  10. Route::post('reports/bulk', 'AdminController@bulkUpdateReport');
  11. Route::get('reports/autospam/{id}', 'AdminController@showSpam');
  12. Route::post('reports/autospam/sync', 'AdminController@fixUncategorizedSpam');
  13. Route::post('reports/autospam/{id}', 'AdminController@updateSpam');
  14. Route::get('reports/autospam', 'AdminController@spam');
  15. Route::get('reports/appeals', 'AdminController@appeals');
  16. Route::get('reports/appeal/{id}', 'AdminController@showAppeal');
  17. Route::post('reports/appeal/{id}', 'AdminController@updateAppeal');
  18. Route::get('reports/email-verifications', 'AdminController@reportMailVerifications');
  19. Route::post('reports/email-verifications/ignore', 'AdminController@reportMailVerifyIgnore');
  20. Route::post('reports/email-verifications/approve', 'AdminController@reportMailVerifyApprove');
  21. Route::post('reports/email-verifications/clear-ignored', 'AdminController@reportMailVerifyClearIgnored');
  22. Route::redirect('stories', '/stories/list');
  23. Route::get('stories/list', 'AdminController@stories')->name('admin.stories');
  24. Route::redirect('statuses', '/statuses/list');
  25. Route::get('statuses/list', 'AdminController@statuses')->name('admin.statuses');
  26. Route::get('statuses/show/{id}', 'AdminController@showStatus');
  27. Route::redirect('profiles', '/i/admin/profiles/list');
  28. Route::get('profiles/list', 'AdminController@profiles')->name('admin.profiles');
  29. Route::get('profiles/edit/{id}', 'AdminController@profileShow');
  30. Route::redirect('users', '/users/list');
  31. Route::get('users/list', 'AdminController@users')->name('admin.users');
  32. Route::get('users/show/{id}', 'AdminController@userShow');
  33. Route::get('users/edit/{id}', 'AdminController@userEdit');
  34. Route::post('users/edit/{id}', 'AdminController@userEditSubmit');
  35. Route::get('users/activity/{id}', 'AdminController@userActivity');
  36. Route::get('users/message/{id}', 'AdminController@userMessage');
  37. Route::post('users/message/{id}', 'AdminController@userMessageSend');
  38. Route::get('users/modtools/{id}', 'AdminController@userModTools');
  39. Route::get('users/modlogs/{id}', 'AdminController@userModLogs');
  40. Route::post('users/modlogs/{id}', 'AdminController@userModLogsMessage');
  41. Route::post('users/modlogs/{id}/delete', 'AdminController@userModLogDelete');
  42. Route::get('users/delete/{id}', 'AdminController@userDelete');
  43. Route::post('users/delete/{id}', 'AdminController@userDeleteProcess');
  44. Route::post('users/moderation/update', 'AdminController@userModerate');
  45. Route::get('media', 'AdminController@media')->name('admin.media');
  46. Route::redirect('media/list', '/i/admin/media');
  47. Route::get('media/show/{id}', 'AdminController@mediaShow');
  48. Route::get('settings', 'AdminController@settings')->name('admin.settings');
  49. Route::post('settings', 'AdminController@settingsHomeStore');
  50. Route::get('settings/features', 'AdminController@settingsFeatures')->name('admin.settings.features');
  51. Route::get('settings/pages', 'AdminController@settingsPages')->name('admin.settings.pages');
  52. Route::get('settings/pages/edit', 'PageController@edit')->name('admin.settings.pages.edit');
  53. Route::post('settings/pages/edit', 'PageController@store');
  54. Route::post('settings/pages/delete', 'PageController@delete');
  55. Route::post('settings/pages/create', 'PageController@generatePage');
  56. Route::get('settings/maintenance', 'AdminController@settingsMaintenance')->name('admin.settings.maintenance');
  57. Route::get('settings/backups', 'AdminController@settingsBackups')->name('admin.settings.backups');
  58. Route::get('settings/storage', 'AdminController@settingsStorage')->name('admin.settings.storage');
  59. Route::get('settings/system', 'AdminController@settingsSystem')->name('admin.settings.system');
  60. Route::get('instances', 'AdminController@instances')->name('admin.instances');
  61. Route::post('instances', 'AdminController@instanceScan');
  62. Route::get('instances/show/{id}', 'AdminController@instanceShow');
  63. Route::post('instances/edit/{id}', 'AdminController@instanceEdit');
  64. Route::get('apps/home', 'AdminController@appsHome')->name('admin.apps');
  65. Route::get('hashtags/home', 'AdminController@hashtagsHome')->name('admin.hashtags');
  66. Route::get('discover/home', 'AdminController@discoverHome')->name('admin.discover');
  67. Route::get('discover/category/create', 'AdminController@discoverCreateCategory')->name('admin.discover.create-category');
  68. Route::post('discover/category/create', 'AdminController@discoverCreateCategoryStore');
  69. Route::get('discover/category/edit/{id}', 'AdminController@discoverCategoryEdit');
  70. Route::post('discover/category/edit/{id}', 'AdminController@discoverCategoryUpdate');
  71. Route::post('discover/category/hashtag/create', 'AdminController@discoveryCategoryTagStore')->name('admin.discover.create-hashtag');
  72. Route::get('messages/home', 'AdminController@messagesHome')->name('admin.messages');
  73. Route::get('messages/show/{id}', 'AdminController@messagesShow');
  74. Route::post('messages/mark-read', 'AdminController@messagesMarkRead');
  75. Route::redirect('site-news', '/i/admin/newsroom');
  76. Route::get('newsroom', 'AdminController@newsroomHome')->name('admin.newsroom.home');
  77. Route::get('newsroom/create', 'AdminController@newsroomCreate')->name('admin.newsroom.create');
  78. Route::get('newsroom/edit/{id}', 'AdminController@newsroomEdit');
  79. Route::post('newsroom/edit/{id}', 'AdminController@newsroomUpdate');
  80. Route::delete('newsroom/edit/{id}', 'AdminController@newsroomDelete');
  81. Route::post('newsroom/create', 'AdminController@newsroomStore');
  82. Route::get('diagnostics/home', 'AdminController@diagnosticsHome')->name('admin.diagnostics');
  83. Route::post('diagnostics/decrypt', 'AdminController@diagnosticsDecrypt')->name('admin.diagnostics.decrypt');
  84. Route::get('custom-emoji/home', 'AdminController@customEmojiHome')->name('admin.custom-emoji');
  85. Route::post('custom-emoji/toggle-active/{id}', 'AdminController@customEmojiToggleActive');
  86. Route::get('custom-emoji/new', 'AdminController@customEmojiAdd');
  87. Route::post('custom-emoji/new', 'AdminController@customEmojiStore');
  88. Route::post('custom-emoji/delete/{id}', 'AdminController@customEmojiDelete');
  89. Route::get('custom-emoji/duplicates/{id}', 'AdminController@customEmojiShowDuplicates');
  90. Route::get('directory/home', 'AdminController@directoryHome')->name('admin.directory');
  91. Route::get('autospam/home', 'AdminController@autospamHome')->name('admin.autospam');
  92. Route::redirect('asf/', 'asf/home');
  93. Route::get('asf/home', 'AdminShadowFilterController@home');
  94. Route::get('asf/create', 'AdminShadowFilterController@create');
  95. Route::get('asf/edit/{id}', 'AdminShadowFilterController@edit');
  96. Route::post('asf/edit/{id}', 'AdminShadowFilterController@storeEdit');
  97. Route::post('asf/create', 'AdminShadowFilterController@store');
  98. Route::prefix('api')->group(function() {
  99. Route::get('stats', 'AdminController@getStats');
  100. Route::get('accounts', 'AdminController@getAccounts');
  101. Route::get('posts', 'AdminController@getPosts');
  102. Route::get('instances', 'AdminController@getInstances');
  103. Route::post('directory/save', 'AdminController@directoryStore');
  104. Route::get('directory/initial-data', 'AdminController@directoryInitialData');
  105. Route::get('directory/popular-posts', 'AdminController@directoryGetPopularPosts');
  106. Route::post('directory/add-by-id', 'AdminController@directoryGetAddPostByIdSearch');
  107. Route::delete('directory/banner-image', 'AdminController@directoryDeleteBannerImage');
  108. Route::post('directory/submit', 'AdminController@directoryHandleServerSubmission');
  109. Route::post('directory/testimonial/save', 'AdminController@directorySaveTestimonial');
  110. Route::post('directory/testimonial/delete', 'AdminController@directoryDeleteTestimonial');
  111. Route::post('directory/testimonial/update', 'AdminController@directoryUpdateTestimonial');
  112. Route::get('hashtags/stats', 'AdminController@hashtagsStats');
  113. Route::get('hashtags/query', 'AdminController@hashtagsApi');
  114. Route::get('hashtags/get', 'AdminController@hashtagsGet');
  115. Route::post('hashtags/update', 'AdminController@hashtagsUpdate');
  116. Route::post('hashtags/clear-trending-cache', 'AdminController@hashtagsClearTrendingCache');
  117. Route::get('instances/get', 'AdminController@getInstancesApi');
  118. Route::get('instances/stats', 'AdminController@getInstancesStatsApi');
  119. Route::get('instances/query', 'AdminController@getInstancesQueryApi');
  120. Route::post('instances/update', 'AdminController@postInstanceUpdateApi');
  121. Route::post('instances/create', 'AdminController@postInstanceCreateNewApi');
  122. Route::post('instances/delete', 'AdminController@postInstanceDeleteApi');
  123. Route::post('instances/refresh-stats', 'AdminController@postInstanceRefreshStatsApi');
  124. Route::get('instances/download-backup', 'AdminController@downloadBackup');
  125. Route::post('instances/import-data', 'AdminController@importBackup');
  126. Route::get('reports/stats', 'AdminController@reportsStats');
  127. Route::get('reports/all', 'AdminController@reportsApiAll');
  128. Route::get('reports/get/{id}', 'AdminController@reportsApiGet');
  129. Route::post('reports/handle', 'AdminController@reportsApiHandle');
  130. Route::get('reports/spam/all', 'AdminController@reportsApiSpamAll');
  131. Route::get('reports/spam/get/{id}', 'AdminController@reportsApiSpamGet');
  132. Route::post('reports/spam/handle', 'AdminController@reportsApiSpamHandle');
  133. Route::post('autospam/config', 'AdminController@getAutospamConfigApi');
  134. Route::post('autospam/reports/closed', 'AdminController@getAutospamReportsClosedApi');
  135. Route::post('autospam/train', 'AdminController@postAutospamTrainSpamApi');
  136. Route::post('autospam/search/non-spam', 'AdminController@postAutospamTrainNonSpamSearchApi');
  137. Route::post('autospam/train/non-spam', 'AdminController@postAutospamTrainNonSpamSubmitApi');
  138. Route::post('autospam/tokens/custom', 'AdminController@getAutospamCustomTokensApi');
  139. Route::post('autospam/tokens/store', 'AdminController@saveNewAutospamCustomTokensApi');
  140. Route::post('autospam/tokens/update', 'AdminController@updateAutospamCustomTokensApi');
  141. Route::post('autospam/tokens/export', 'AdminController@exportAutospamCustomTokensApi');
  142. Route::post('autospam/config/enable', 'AdminController@enableAutospamApi');
  143. Route::post('autospam/config/disable', 'AdminController@disableAutospamApi');
  144. });
  145. });
  146. Route::domain(config('portfolio.domain'))->group(function () {
  147. Route::redirect('redirect/home', config('app.url'));
  148. Route::get('/', 'PortfolioController@index');
  149. Route::post('api/portfolio/self/curated.json', 'PortfolioController@storeCurated');
  150. Route::post('api/portfolio/self/settings.json', 'PortfolioController@getSettings');
  151. Route::get('api/portfolio/account/settings.json', 'PortfolioController@getAccountSettings');
  152. Route::post('api/portfolio/self/update-settings.json', 'PortfolioController@storeSettings');
  153. Route::get('api/portfolio/{username}/feed', 'PortfolioController@getFeed');
  154. Route::prefix(config('portfolio.path'))->group(function() {
  155. Route::get('/', 'PortfolioController@index');
  156. Route::get('settings', 'PortfolioController@settings')->name('portfolio.settings');
  157. Route::post('settings', 'PortfolioController@store');
  158. Route::get('{username}/{id}', 'PortfolioController@showPost');
  159. Route::get('{username}', 'PortfolioController@show');
  160. Route::fallback(function () {
  161. return view('errors.404');
  162. });
  163. });
  164. });
  165. Route::domain(config('pixelfed.domain.app'))->middleware(['validemail', 'twofactor', 'localization'])->group(function () {
  166. Route::get('/', 'SiteController@home')->name('timeline.personal');
  167. Route::redirect('/home', '/')->name('home');
  168. Route::get('web/directory', 'LandingController@directoryRedirect');
  169. Route::get('web/explore', 'LandingController@exploreRedirect');
  170. Auth::routes();
  171. Route::get('auth/raw/mastodon/start', 'RemoteAuthController@startRedirect');
  172. Route::post('auth/raw/mastodon/config', 'RemoteAuthController@getConfig');
  173. Route::post('auth/raw/mastodon/domains', 'RemoteAuthController@getAuthDomains');
  174. Route::post('auth/raw/mastodon/start', 'RemoteAuthController@start');
  175. Route::post('auth/raw/mastodon/redirect', 'RemoteAuthController@redirect');
  176. Route::get('auth/raw/mastodon/preflight', 'RemoteAuthController@preflight');
  177. Route::get('auth/mastodon/callback', 'RemoteAuthController@handleCallback');
  178. Route::get('auth/mastodon/getting-started', 'RemoteAuthController@onboarding');
  179. Route::post('auth/raw/mastodon/s/check', 'RemoteAuthController@sessionCheck');
  180. Route::post('auth/raw/mastodon/s/prefill', 'RemoteAuthController@sessionGetMastodonData');
  181. Route::post('auth/raw/mastodon/s/username-check', 'RemoteAuthController@sessionValidateUsername');
  182. Route::post('auth/raw/mastodon/s/email-check', 'RemoteAuthController@sessionValidateEmail');
  183. Route::post('auth/raw/mastodon/s/following', 'RemoteAuthController@sessionGetMastodonFollowers');
  184. Route::post('auth/raw/mastodon/s/submit', 'RemoteAuthController@handleSubmit');
  185. Route::post('auth/raw/mastodon/s/store-bio', 'RemoteAuthController@storeBio');
  186. Route::post('auth/raw/mastodon/s/store-avatar', 'RemoteAuthController@storeAvatar');
  187. Route::post('auth/raw/mastodon/s/account-to-id', 'RemoteAuthController@accountToId');
  188. Route::post('auth/raw/mastodon/s/finish-up', 'RemoteAuthController@finishUp');
  189. Route::post('auth/raw/mastodon/s/login', 'RemoteAuthController@handleLogin');
  190. Route::get('auth/pci/{id}/{code}', 'ParentalControlsController@inviteRegister');
  191. Route::post('auth/pci/{id}/{code}', 'ParentalControlsController@inviteRegisterStore');
  192. Route::get('discover', 'DiscoverController@home')->name('discover');
  193. Route::group(['prefix' => 'api'], function () {
  194. Route::get('search', 'SearchController@searchAPI');
  195. Route::post('status/view', 'StatusController@storeView');
  196. Route::get('v1/polls/{id}', 'PollController@getPoll');
  197. Route::post('v1/polls/{id}/votes', 'PollController@vote');
  198. Route::group(['prefix' => 'compose'], function() {
  199. Route::group(['prefix' => 'v0'], function() {
  200. Route::post('/media/upload', 'ComposeController@mediaUpload');
  201. Route::post('/media/update', 'ComposeController@mediaUpdate');
  202. Route::delete('/media/delete', 'ComposeController@mediaDelete');
  203. Route::get('/search/tag', 'ComposeController@searchTag');
  204. Route::get('/search/location', 'ComposeController@searchLocation');
  205. Route::get('/search/mention', 'ComposeController@searchMentionAutocomplete');
  206. Route::get('/search/hashtag', 'ComposeController@searchHashtagAutocomplete');
  207. Route::post('/publish', 'ComposeController@store');
  208. Route::post('/publish/text', 'ComposeController@storeText');
  209. Route::get('/media/processing', 'ComposeController@mediaProcessingCheck');
  210. Route::get('/settings', 'ComposeController@composeSettings');
  211. Route::post('/poll', 'ComposeController@createPoll');
  212. });
  213. });
  214. Route::group(['prefix' => 'direct'], function () {
  215. Route::get('browse', 'DirectMessageController@browse');
  216. Route::post('create', 'DirectMessageController@create');
  217. Route::get('thread', 'DirectMessageController@thread');
  218. Route::post('mute', 'DirectMessageController@mute');
  219. Route::post('unmute', 'DirectMessageController@unmute');
  220. Route::delete('message', 'DirectMessageController@delete');
  221. Route::post('media', 'DirectMessageController@mediaUpload');
  222. Route::post('lookup', 'DirectMessageController@composeLookup');
  223. Route::post('read', 'DirectMessageController@read');
  224. });
  225. Route::group(['prefix' => 'v2'], function() {
  226. Route::get('config', 'ApiController@siteConfiguration');
  227. Route::get('discover', 'InternalApiController@discover');
  228. Route::get('discover/posts', 'InternalApiController@discoverPosts')->middleware('auth:api');
  229. Route::get('profile/{username}/status/{postid}', 'PublicApiController@status');
  230. Route::get('profile/{username}/status/{postid}/state', 'PublicApiController@statusState');
  231. Route::get('comments/{username}/status/{postId}', 'PublicApiController@statusComments');
  232. Route::get('status/{id}/replies', 'InternalApiController@statusReplies');
  233. Route::post('moderator/action', 'InternalApiController@modAction');
  234. Route::get('discover/categories', 'InternalApiController@discoverCategories');
  235. Route::get('loops', 'DiscoverController@loopsApi');
  236. Route::post('loops/watch', 'DiscoverController@loopWatch');
  237. Route::get('discover/tag', 'DiscoverController@getHashtags');
  238. Route::get('statuses/{id}/replies', 'Api\ApiV1Controller@statusReplies');
  239. Route::get('statuses/{id}/state', 'Api\ApiV1Controller@statusState');
  240. });
  241. Route::group(['prefix' => 'pixelfed'], function() {
  242. Route::group(['prefix' => 'v1'], function() {
  243. Route::get('accounts/verify_credentials', 'ApiController@verifyCredentials');
  244. Route::get('accounts/relationships', 'Api\ApiV1Controller@accountRelationshipsById');
  245. Route::get('accounts/search', 'Api\ApiV1Controller@accountSearch');
  246. Route::get('accounts/{id}/statuses', 'PublicApiController@accountStatuses');
  247. Route::post('accounts/{id}/block', 'Api\ApiV1Controller@accountBlockById');
  248. Route::post('accounts/{id}/unblock', 'Api\ApiV1Controller@accountUnblockById');
  249. Route::get('statuses/{id}', 'PublicApiController@getStatus');
  250. Route::get('accounts/{id}', 'PublicApiController@account');
  251. Route::post('avatar/update', 'ApiController@avatarUpdate');
  252. Route::get('custom_emojis', 'Api\ApiV1Controller@customEmojis');
  253. Route::get('notifications', 'ApiController@notifications');
  254. Route::get('timelines/public', 'PublicApiController@publicTimelineApi');
  255. Route::get('timelines/home', 'PublicApiController@homeTimelineApi');
  256. Route::get('timelines/network', 'PublicApiController@networkTimelineApi');
  257. Route::get('newsroom/timeline', 'NewsroomController@timelineApi');
  258. Route::post('newsroom/markasread', 'NewsroomController@markAsRead');
  259. Route::get('favourites', 'Api\BaseApiController@accountLikes');
  260. Route::get('mutes', 'AccountController@accountMutes');
  261. Route::get('blocks', 'AccountController@accountBlocks');
  262. });
  263. Route::group(['prefix' => 'v2'], function() {
  264. Route::get('config', 'ApiController@siteConfiguration');
  265. Route::get('discover', 'InternalApiController@discover');
  266. Route::get('discover/posts', 'InternalApiController@discoverPosts');
  267. Route::get('discover/profiles', 'DiscoverController@profilesDirectoryApi');
  268. Route::get('profile/{username}/status/{postid}', 'PublicApiController@status');
  269. Route::get('comments/{username}/status/{postId}', 'PublicApiController@statusComments');
  270. Route::post('moderator/action', 'InternalApiController@modAction');
  271. Route::get('discover/categories', 'InternalApiController@discoverCategories');
  272. Route::get('loops', 'DiscoverController@loopsApi');
  273. Route::post('loops/watch', 'DiscoverController@loopWatch');
  274. Route::get('discover/tag', 'DiscoverController@getHashtags');
  275. Route::get('discover/posts/trending', 'DiscoverController@trendingApi');
  276. Route::get('discover/posts/hashtags', 'DiscoverController@trendingHashtags');
  277. Route::get('discover/posts/places', 'DiscoverController@trendingPlaces');
  278. Route::get('seasonal/yir', 'SeasonalController@getData');
  279. Route::post('seasonal/yir', 'SeasonalController@store');
  280. Route::get('mutes', 'AccountController@accountMutesV2');
  281. Route::get('blocks', 'AccountController@accountBlocksV2');
  282. Route::get('filters', 'AccountController@accountFiltersV2');
  283. Route::post('status/compose', 'InternalApiController@composePost');
  284. Route::get('status/{id}/replies', 'InternalApiController@statusReplies');
  285. Route::post('status/{id}/archive', 'ApiController@archive');
  286. Route::post('status/{id}/unarchive', 'ApiController@unarchive');
  287. Route::get('statuses/archives', 'ApiController@archivedPosts');
  288. Route::get('discover/memories', 'DiscoverController@myMemories');
  289. Route::get('discover/account-insights', 'DiscoverController@accountInsightsPopularPosts');
  290. Route::get('discover/server-timeline', 'DiscoverController@serverTimeline');
  291. Route::get('discover/meta', 'DiscoverController@enabledFeatures');
  292. Route::post('discover/admin/features', 'DiscoverController@updateFeatures');
  293. });
  294. Route::get('discover/accounts/popular', 'Api\ApiV1Controller@discoverAccountsPopular');
  295. Route::post('web/change-language.json', 'SpaController@updateLanguage');
  296. });
  297. Route::group(['prefix' => 'local'], function () {
  298. // Route::post('status/compose', 'InternalApiController@composePost')->middleware('throttle:maxPostsPerHour,60')->middleware('throttle:maxPostsPerDay,1440');
  299. Route::get('exp/rec', 'ApiController@userRecommendations');
  300. Route::post('discover/tag/subscribe', 'HashtagFollowController@store');
  301. Route::get('discover/tag/list', 'HashtagFollowController@getTags');
  302. // Route::get('profile/sponsor/{id}', 'ProfileSponsorController@get');
  303. Route::get('bookmarks', 'InternalApiController@bookmarks');
  304. Route::get('collection/items/{id}', 'CollectionController@getItems');
  305. Route::post('collection/item', 'CollectionController@storeId');
  306. Route::delete('collection/item', 'CollectionController@deleteId');
  307. Route::get('collection/{id}', 'CollectionController@getCollection');
  308. Route::post('collection/{id}', 'CollectionController@store');
  309. Route::delete('collection/{id}', 'CollectionController@delete');
  310. Route::post('collection/{id}/publish', 'CollectionController@publish');
  311. Route::get('profile/collections/{id}', 'CollectionController@getUserCollections');
  312. Route::post('compose/tag/untagme', 'MediaTagController@untagProfile');
  313. Route::post('import/ig', 'ImportPostController@store');
  314. Route::get('import/ig/config', 'ImportPostController@getConfig');
  315. Route::post('import/ig/media', 'ImportPostController@storeMedia');
  316. Route::post('import/ig/existing', 'ImportPostController@getImportedFiles');
  317. Route::post('import/ig/posts', 'ImportPostController@getImportedPosts');
  318. Route::post('import/ig/processing', 'ImportPostController@getProcessingCount');
  319. });
  320. Route::group(['prefix' => 'web/stories'], function () {
  321. Route::get('v1/recent', 'StoryController@recent');
  322. Route::get('v1/viewers', 'StoryController@viewers');
  323. Route::get('v1/profile/{id}', 'StoryController@profile');
  324. Route::get('v1/exists/{id}', 'StoryController@exists');
  325. Route::get('v1/poll/results', 'StoryController@pollResults');
  326. Route::post('v1/viewed', 'StoryController@viewed');
  327. Route::post('v1/react', 'StoryController@react');
  328. Route::post('v1/comment', 'StoryController@comment');
  329. Route::post('v1/publish/poll', 'StoryController@publishStoryPoll');
  330. Route::post('v1/poll/vote', 'StoryController@storyPollVote');
  331. Route::post('v1/report', 'StoryController@storeReport');
  332. Route::post('v1/add', 'StoryController@apiV1Add');
  333. Route::post('v1/crop', 'StoryController@cropPhoto');
  334. Route::post('v1/publish', 'StoryController@publishStory');
  335. Route::delete('v1/delete/{id}', 'StoryController@apiV1Delete');
  336. });
  337. Route::group(['prefix' => 'portfolio'], function () {
  338. Route::post('self/curated.json', 'PortfolioController@storeCurated');
  339. Route::post('self/settings.json', 'PortfolioController@getSettings');
  340. Route::get('account/settings.json', 'PortfolioController@getAccountSettings');
  341. Route::post('self/update-settings.json', 'PortfolioController@storeSettings');
  342. Route::get('{username}/feed', 'PortfolioController@getFeed');
  343. });
  344. });
  345. Route::get('discover/tags/{hashtag}', 'DiscoverController@showTags');
  346. Route::get('discover/places', 'PlaceController@directoryHome')->name('discover.places');
  347. Route::get('discover/places/{id}/{slug}', 'PlaceController@show');
  348. Route::get('discover/location/country/{country}', 'PlaceController@directoryCities');
  349. Route::group(['prefix' => 'i'], function () {
  350. Route::redirect('/', '/');
  351. Route::get('compose', 'StatusController@compose')->name('compose');
  352. Route::post('comment', 'CommentController@store');
  353. Route::post('delete', 'StatusController@delete');
  354. Route::post('mute', 'AccountController@mute');
  355. Route::post('unmute', 'AccountController@unmute');
  356. Route::post('block', 'AccountController@block');
  357. Route::post('unblock', 'AccountController@unblock');
  358. Route::post('like', 'LikeController@store');
  359. Route::post('share', 'StatusController@storeShare');
  360. Route::post('follow', 'FollowerController@store');
  361. Route::post('bookmark', 'BookmarkController@store');
  362. Route::get('lang/{locale}', 'SiteController@changeLocale');
  363. Route::get('restored', 'AccountController@accountRestored');
  364. Route::get('verify-email', 'AccountController@verifyEmail');
  365. Route::post('verify-email', 'AccountController@sendVerifyEmail');
  366. Route::get('verify-email/request', 'InternalApiController@requestEmailVerification');
  367. Route::post('verify-email/request', 'InternalApiController@requestEmailVerificationStore');
  368. Route::get('confirm-email/{userToken}/{randomToken}', 'AccountController@confirmVerifyEmail');
  369. Route::get('auth/sudo', 'AccountController@sudoMode');
  370. Route::post('auth/sudo', 'AccountController@sudoModeVerify');
  371. Route::get('auth/checkpoint', 'AccountController@twoFactorCheckpoint');
  372. Route::post('auth/checkpoint', 'AccountController@twoFactorVerify');
  373. Route::get('results', 'SearchController@results');
  374. Route::post('visibility', 'StatusController@toggleVisibility');
  375. Route::post('metro/dark-mode', 'SettingsController@metroDarkMode');
  376. Route::group(['prefix' => 'report'], function () {
  377. Route::get('/', 'ReportController@showForm')->name('report.form');
  378. Route::post('/', 'ReportController@formStore');
  379. Route::get('not-interested', 'ReportController@notInterestedForm')->name('report.not-interested');
  380. Route::get('spam', 'ReportController@spamForm')->name('report.spam');
  381. Route::get('spam/comment', 'ReportController@spamCommentForm')->name('report.spam.comment');
  382. Route::get('spam/post', 'ReportController@spamPostForm')->name('report.spam.post');
  383. Route::get('spam/profile', 'ReportController@spamProfileForm')->name('report.spam.profile');
  384. Route::get('sensitive/comment', 'ReportController@sensitiveCommentForm')->name('report.sensitive.comment');
  385. Route::get('sensitive/post', 'ReportController@sensitivePostForm')->name('report.sensitive.post');
  386. Route::get('sensitive/profile', 'ReportController@sensitiveProfileForm')->name('report.sensitive.profile');
  387. Route::get('abusive/comment', 'ReportController@abusiveCommentForm')->name('report.abusive.comment');
  388. Route::get('abusive/post', 'ReportController@abusivePostForm')->name('report.abusive.post');
  389. Route::get('abusive/profile', 'ReportController@abusiveProfileForm')->name('report.abusive.profile');
  390. });
  391. Route::get('collections/create', 'CollectionController@create');
  392. Route::get('me', 'ProfileController@meRedirect');
  393. Route::get('intent/follow', 'SiteController@followIntent');
  394. Route::get('rs/{id}', 'StoryController@remoteStory');
  395. Route::get('stories/new', 'StoryController@compose');
  396. Route::get('my/story', 'StoryController@iRedirect');
  397. Route::get('web/profile/_/{id}', 'InternalApiController@remoteProfile');
  398. Route::get('web/post/_/{profileId}/{statusid}', 'InternalApiController@remoteStatus');
  399. Route::group(['prefix' => 'import', 'middleware' => 'dangerzone'], function() {
  400. Route::get('job/{uuid}/1', 'ImportController@instagramStepOne');
  401. Route::post('job/{uuid}/1', 'ImportController@instagramStepOneStore');
  402. Route::get('job/{uuid}/2', 'ImportController@instagramStepTwo');
  403. Route::post('job/{uuid}/2', 'ImportController@instagramStepTwoStore');
  404. Route::get('job/{uuid}/3', 'ImportController@instagramStepThree');
  405. Route::post('job/{uuid}/3', 'ImportController@instagramStepThreeStore');
  406. });
  407. Route::get('redirect', 'SiteController@redirectUrl');
  408. Route::post('admin/media/block/add', 'MediaBlocklistController@add');
  409. Route::post('admin/media/block/delete', 'MediaBlocklistController@delete');
  410. Route::get('warning', 'AccountInterstitialController@get');
  411. Route::post('warning', 'AccountInterstitialController@read');
  412. Route::get('my2020', 'SeasonalController@yearInReview');
  413. Route::get('web/my-portfolio', 'PortfolioController@myRedirect');
  414. Route::get('web/hashtag/{tag}', 'SpaController@hashtagRedirect');
  415. Route::get('web/username/{id}', 'SpaController@usernameRedirect');
  416. Route::get('web/post/{id}', 'SpaController@webPost');
  417. Route::get('web/profile/{id}', 'SpaController@webProfile');
  418. Route::get('web/{q}', 'SpaController@index')->where('q', '.*');
  419. Route::get('web', 'SpaController@index');
  420. });
  421. Route::group(['prefix' => 'account'], function () {
  422. Route::redirect('/', '/');
  423. Route::get('direct', 'AccountController@direct');
  424. Route::get('direct/t/{id}', 'AccountController@directMessage');
  425. Route::get('activity', 'AccountController@notifications')->name('notifications');
  426. Route::get('follow-requests', 'AccountController@followRequests')->name('follow-requests');
  427. Route::post('follow-requests', 'AccountController@followRequestHandle');
  428. Route::get('follow-requests.json', 'AccountController@followRequestsJson');
  429. Route::get('portfolio/{username}.json', 'PortfolioController@getApFeed');
  430. Route::get('portfolio/{username}.rss', 'PortfolioController@getRssFeed');
  431. });
  432. Route::group(['prefix' => 'settings'], function () {
  433. Route::redirect('/', '/settings/home');
  434. Route::get('home', 'SettingsController@home')
  435. ->name('settings');
  436. Route::post('home', 'SettingsController@homeUpdate');
  437. Route::get('avatar', 'SettingsController@avatar')->name('settings.avatar');
  438. Route::post('avatar', 'AvatarController@store');
  439. Route::delete('avatar', 'AvatarController@deleteAvatar');
  440. Route::get('password', 'SettingsController@password')->name('settings.password')->middleware('dangerzone');
  441. Route::post('password', 'SettingsController@passwordUpdate')->middleware('dangerzone');
  442. Route::get('email', 'SettingsController@email')->name('settings.email')->middleware('dangerzone');
  443. Route::post('email', 'SettingsController@emailUpdate')->middleware('dangerzone');
  444. Route::get('notifications', 'SettingsController@notifications')->name('settings.notifications');
  445. Route::get('privacy', 'SettingsController@privacy')->name('settings.privacy');
  446. Route::post('privacy', 'SettingsController@privacyStore');
  447. Route::get('privacy/muted-users', 'SettingsController@mutedUsers')->name('settings.privacy.muted-users');
  448. Route::post('privacy/muted-users', 'SettingsController@mutedUsersUpdate');
  449. Route::get('privacy/blocked-users', 'SettingsController@blockedUsers')->name('settings.privacy.blocked-users');
  450. Route::post('privacy/blocked-users', 'SettingsController@blockedUsersUpdate');
  451. Route::get('privacy/domain-blocks', 'SettingsController@domainBlocks')->name('settings.privacy.domain-blocks');
  452. Route::get('privacy/blocked-instances', 'SettingsController@blockedInstances')->name('settings.privacy.blocked-instances');
  453. Route::post('privacy/blocked-instances', 'SettingsController@blockedInstanceStore');
  454. Route::post('privacy/blocked-instances/unblock', 'SettingsController@blockedInstanceUnblock')->name('settings.privacy.blocked-instances.unblock');
  455. Route::get('privacy/blocked-keywords', 'SettingsController@blockedKeywords')->name('settings.privacy.blocked-keywords');
  456. Route::post('privacy/account', 'SettingsController@privateAccountOptions')->name('settings.privacy.account');
  457. Route::group(['prefix' => 'remove', 'middleware' => 'dangerzone'], function() {
  458. Route::get('request/temporary', 'SettingsController@removeAccountTemporary')->name('settings.remove.temporary');
  459. Route::post('request/temporary', 'SettingsController@removeAccountTemporarySubmit');
  460. Route::get('request/permanent', 'SettingsController@removeAccountPermanent')->name('settings.remove.permanent');
  461. Route::post('request/permanent', 'SettingsController@removeAccountPermanentSubmit');
  462. });
  463. Route::group(['prefix' => 'security', 'middleware' => 'dangerzone'], function() {
  464. Route::get(
  465. '/',
  466. 'SettingsController@security'
  467. )->name('settings.security');
  468. Route::get(
  469. '2fa/setup',
  470. 'SettingsController@securityTwoFactorSetup'
  471. )->name('settings.security.2fa.setup');
  472. Route::post(
  473. '2fa/setup',
  474. 'SettingsController@securityTwoFactorSetupStore'
  475. );
  476. Route::get(
  477. '2fa/edit',
  478. 'SettingsController@securityTwoFactorEdit'
  479. )->name('settings.security.2fa.edit');
  480. Route::post(
  481. '2fa/edit',
  482. 'SettingsController@securityTwoFactorUpdate'
  483. );
  484. Route::get(
  485. '2fa/recovery-codes',
  486. 'SettingsController@securityTwoFactorRecoveryCodes'
  487. )->name('settings.security.2fa.recovery');
  488. Route::post(
  489. '2fa/recovery-codes',
  490. 'SettingsController@securityTwoFactorRecoveryCodesRegenerate'
  491. );
  492. });
  493. Route::get('parental-controls', 'ParentalControlsController@index')->name('settings.parental-controls')->middleware('dangerzone');
  494. Route::get('parental-controls/add', 'ParentalControlsController@add')->name('settings.pc.add')->middleware('dangerzone');
  495. Route::post('parental-controls/add', 'ParentalControlsController@store')->middleware('dangerzone');
  496. Route::get('parental-controls/manage/{id}', 'ParentalControlsController@view')->middleware('dangerzone');
  497. Route::post('parental-controls/manage/{id}', 'ParentalControlsController@update')->middleware('dangerzone');
  498. Route::get('parental-controls/manage/{id}/cancel-invite', 'ParentalControlsController@cancelInvite')->name('settings.pc.cancel-invite')->middleware('dangerzone');
  499. Route::post('parental-controls/manage/{id}/cancel-invite', 'ParentalControlsController@cancelInviteHandle')->middleware('dangerzone');
  500. Route::get('parental-controls/manage/{id}/stop-managing', 'ParentalControlsController@stopManaging')->name('settings.pc.stop-managing')->middleware('dangerzone');
  501. Route::post('parental-controls/manage/{id}/stop-managing', 'ParentalControlsController@stopManagingHandle')->middleware('dangerzone');
  502. Route::get('applications', 'SettingsController@applications')->name('settings.applications')->middleware('dangerzone');
  503. Route::get('data-export', 'SettingsController@dataExport')->name('settings.dataexport')->middleware('dangerzone');
  504. Route::post('data-export/following', 'SettingsController@exportFollowing')->middleware('dangerzone');
  505. Route::post('data-export/followers', 'SettingsController@exportFollowers')->middleware('dangerzone');
  506. Route::post('data-export/mute-block-list', 'SettingsController@exportMuteBlockList')->middleware('dangerzone');
  507. Route::post('data-export/account', 'SettingsController@exportAccount')->middleware('dangerzone');
  508. Route::post('data-export/statuses', 'SettingsController@exportStatuses')->middleware('dangerzone');
  509. Route::get('developers', 'SettingsController@developers')->name('settings.developers')->middleware('dangerzone');
  510. Route::get('labs', 'SettingsController@labs')->name('settings.labs');
  511. Route::post('labs', 'SettingsController@labsStore');
  512. Route::get('accessibility', 'SettingsController@accessibility')->name('settings.accessibility');
  513. Route::post('accessibility', 'SettingsController@accessibilityStore');
  514. Route::group(['prefix' => 'relationships'], function() {
  515. Route::redirect('/', '/settings/relationships/home');
  516. Route::get('home', 'SettingsController@relationshipsHome')->name('settings.relationships');
  517. });
  518. Route::get('invites/create', 'UserInviteController@create')->name('settings.invites.create');
  519. Route::post('invites/create', 'UserInviteController@store');
  520. Route::get('invites', 'UserInviteController@show')->name('settings.invites');
  521. // Route::get('sponsor', 'SettingsController@sponsor')->name('settings.sponsor');
  522. // Route::post('sponsor', 'SettingsController@sponsorStore');
  523. Route::group(['prefix' => 'import', 'middleware' => 'dangerzone'], function() {
  524. Route::get('/', 'SettingsController@dataImport')->name('settings.import');
  525. Route::prefix('instagram')->group(function() {
  526. Route::get('/', 'ImportController@instagram')->name('settings.import.ig');
  527. Route::post('/', 'ImportController@instagramStart');
  528. });
  529. Route::prefix('mastodon')->group(function() {
  530. Route::get('/', 'ImportController@mastodon')->name('settings.import.mastodon');
  531. });
  532. });
  533. Route::get('timeline', 'SettingsController@timelineSettings')->name('settings.timeline');
  534. Route::post('timeline', 'SettingsController@updateTimelineSettings');
  535. Route::get('media', 'SettingsController@mediaSettings')->name('settings.media');
  536. Route::post('media', 'SettingsController@updateMediaSettings');
  537. Route::group(['prefix' => 'account/aliases', 'middleware' => 'dangerzone'], function() {
  538. Route::get('manage', 'ProfileAliasController@index');
  539. Route::post('manage', 'ProfileAliasController@store');
  540. Route::post('manage/delete', 'ProfileAliasController@delete');
  541. });
  542. });
  543. Route::group(['prefix' => 'site'], function () {
  544. Route::redirect('/', '/');
  545. Route::get('about', 'SiteController@about')->name('site.about');
  546. Route::view('help', 'site.help')->name('site.help');
  547. Route::view('developer-api', 'site.developer')->name('site.developers');
  548. Route::view('fediverse', 'site.fediverse')->name('site.fediverse');
  549. Route::view('open-source', 'site.opensource')->name('site.opensource');
  550. Route::view('banned-instances', 'site.bannedinstances')->name('site.bannedinstances');
  551. Route::get('terms', 'SiteController@terms')->name('site.terms');
  552. Route::get('privacy', 'SiteController@privacy')->name('site.privacy');
  553. Route::view('platform', 'site.platform')->name('site.platform');
  554. Route::view('language', 'site.language')->name('site.language');
  555. Route::get('contact', 'ContactController@show')->name('site.contact');
  556. Route::post('contact', 'ContactController@store');
  557. Route::group(['prefix'=>'kb'], function() {
  558. Route::view('getting-started', 'site.help.getting-started')->name('help.getting-started');
  559. Route::view('sharing-media', 'site.help.sharing-media')->name('help.sharing-media');
  560. Route::view('your-profile', 'site.help.your-profile')->name('help.your-profile');
  561. Route::view('stories', 'site.help.stories')->name('help.stories');
  562. Route::view('embed', 'site.help.embed')->name('help.embed');
  563. Route::view('hashtags', 'site.help.hashtags')->name('help.hashtags');
  564. Route::view('instance-actor', 'site.help.instance-actor')->name('help.instance-actor');
  565. Route::view('discover', 'site.help.discover')->name('help.discover');
  566. Route::view('direct-messages', 'site.help.dm')->name('help.dm');
  567. Route::view('timelines', 'site.help.timelines')->name('help.timelines');
  568. Route::view('what-is-the-fediverse', 'site.help.what-is-fediverse')->name('help.what-is-fediverse');
  569. Route::view('safety-tips', 'site.help.safety-tips')->name('help.safety-tips');
  570. Route::get('community-guidelines', 'SiteController@communityGuidelines')->name('help.community-guidelines');
  571. Route::view('controlling-visibility', 'site.help.controlling-visibility')->name('help.controlling-visibility');
  572. Route::view('blocking-accounts', 'site.help.blocking-accounts')->name('help.blocking-accounts');
  573. Route::view('report-something', 'site.help.report-something')->name('help.report-something');
  574. Route::view('data-policy', 'site.help.data-policy')->name('help.data-policy');
  575. Route::view('labs-deprecation', 'site.help.labs-deprecation')->name('help.labs-deprecation');
  576. Route::view('tagging-people', 'site.help.tagging-people')->name('help.tagging-people');
  577. Route::view('licenses', 'site.help.licenses')->name('help.licenses');
  578. Route::view('instance-max-users-limit', 'site.help.instance-max-users')->name('help.instance-max-users-limit');
  579. Route::view('import', 'site.help.import')->name('help.import');
  580. Route::view('parental-controls', 'site.help.parental-controls');
  581. });
  582. Route::get('newsroom/{year}/{month}/{slug}', 'NewsroomController@show');
  583. Route::get('newsroom/archive', 'NewsroomController@archive');
  584. Route::get('newsroom/search', 'NewsroomController@search');
  585. Route::get('newsroom', 'NewsroomController@index');
  586. Route::get('legal-notice', 'SiteController@legalNotice');
  587. });
  588. Route::group(['prefix' => 'timeline'], function () {
  589. Route::redirect('/', '/');
  590. Route::get('public', 'TimelineController@local')->name('timeline.public');
  591. Route::get('network', 'TimelineController@network')->name('timeline.network');
  592. });
  593. Route::group(['prefix' => 'users'], function () {
  594. Route::redirect('/', '/');
  595. Route::get('{user}.atom', 'ProfileController@showAtomFeed')->where('user', '.*');
  596. Route::get('{username}/outbox', 'FederationController@userOutbox');
  597. Route::get('{username}/followers', 'FederationController@userFollowers');
  598. Route::get('{username}/following', 'FederationController@userFollowing');
  599. Route::get('{username}', 'ProfileController@permalinkRedirect');
  600. });
  601. Route::group(['prefix' => 'installer'], function() {
  602. Route::get('api/requirements', 'InstallController@getRequirements')->withoutMiddleware(['web']);
  603. Route::post('precheck/database', 'InstallController@precheckDatabase')->withoutMiddleware(['web']);
  604. Route::post('store', 'InstallController@store')->withoutMiddleware(['web']);
  605. Route::get('/', 'InstallController@index')->withoutMiddleware(['web']);
  606. Route::get('/{q}', 'InstallController@index')->withoutMiddleware(['web'])->where('q', '.*');
  607. });
  608. Route::group(['prefix' => 'e'], function() {
  609. Route::get('terms', 'MobileController@terms');
  610. Route::get('privacy', 'MobileController@privacy');
  611. });
  612. Route::get('auth/invite/a/{code}', 'AdminInviteController@index');
  613. Route::post('api/v1.1/auth/invite/admin/re', 'AdminInviteController@apiRegister')->middleware('throttle:5,1440');
  614. Route::get('storage/m/_v2/{pid}/{mhash}/{uhash}/{f}', 'MediaController@fallbackRedirect');
  615. Route::get('stories/{username}', 'ProfileController@stories');
  616. Route::get('p/{id}', 'StatusController@shortcodeRedirect');
  617. Route::get('c/{collection}', 'CollectionController@show');
  618. Route::get('p/{username}/{id}/c', 'CommentController@showAll');
  619. Route::get('p/{username}/{id}/embed', 'StatusController@showEmbed');
  620. Route::get('p/{username}/{id}/edit', 'StatusController@edit');
  621. Route::post('p/{username}/{id}/edit', 'StatusController@editStore');
  622. Route::get('p/{username}/{id}.json', 'StatusController@showObject');
  623. Route::get('p/{username}/{id}', 'StatusController@show');
  624. Route::get('{username}/embed', 'ProfileController@embed');
  625. Route::get('{username}/live', 'LiveStreamController@showProfilePlayer');
  626. Route::get('@{username}@{domain}', 'SiteController@legacyWebfingerRedirect');
  627. Route::get('@{username}', 'SiteController@legacyProfileRedirect');
  628. Route::get('{username}', 'ProfileController@show');
  629. });