web.php 30 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360361362363364365366367368369370371372373374375376377378379380381382383384385386387388389390391392393394395396397398399400401402403404405406407408409410411412413414415416417418419420421422423424425426427428429430431432433434435436437438439440441442443444445446447448449450451452453454455456457458459460461462463464465466467468469470471472473474475476477478479480481482483484485486487488489490491492493494495496497498499
  1. <?php
  2. Route::domain(config('pixelfed.domain.app'))->middleware(['validemail', 'twofactor', 'localization'])->group(function () {
  3. Route::get('/', 'SiteController@home')->name('timeline.personal');
  4. Route::redirect('/home', '/')->name('home');
  5. Route::get('web/directory', 'LandingController@directoryRedirect');
  6. Route::get('web/explore', 'LandingController@exploreRedirect');
  7. Route::get('authorize_interaction', 'AuthorizeInteractionController@get');
  8. Auth::routes();
  9. Route::get('auth/oidc/start', 'RemoteOidcController@start');
  10. Route::get('auth/oidc/callback', 'RemoteOidcController@handleCallback');
  11. Route::get('auth/raw/mastodon/start', 'RemoteAuthController@startRedirect');
  12. Route::post('auth/raw/mastodon/config', 'RemoteAuthController@getConfig');
  13. Route::post('auth/raw/mastodon/domains', 'RemoteAuthController@getAuthDomains');
  14. Route::post('auth/raw/mastodon/start', 'RemoteAuthController@start');
  15. Route::post('auth/raw/mastodon/redirect', 'RemoteAuthController@redirect');
  16. Route::get('auth/raw/mastodon/preflight', 'RemoteAuthController@preflight');
  17. Route::get('auth/mastodon/callback', 'RemoteAuthController@handleCallback');
  18. Route::get('auth/mastodon/getting-started', 'RemoteAuthController@onboarding');
  19. Route::post('auth/raw/mastodon/s/check', 'RemoteAuthController@sessionCheck');
  20. Route::post('auth/raw/mastodon/s/prefill', 'RemoteAuthController@sessionGetMastodonData');
  21. Route::post('auth/raw/mastodon/s/username-check', 'RemoteAuthController@sessionValidateUsername');
  22. Route::post('auth/raw/mastodon/s/email-check', 'RemoteAuthController@sessionValidateEmail');
  23. Route::post('auth/raw/mastodon/s/following', 'RemoteAuthController@sessionGetMastodonFollowers');
  24. Route::post('auth/raw/mastodon/s/submit', 'RemoteAuthController@handleSubmit');
  25. Route::post('auth/raw/mastodon/s/store-bio', 'RemoteAuthController@storeBio');
  26. Route::post('auth/raw/mastodon/s/store-avatar', 'RemoteAuthController@storeAvatar');
  27. Route::post('auth/raw/mastodon/s/account-to-id', 'RemoteAuthController@accountToId');
  28. Route::post('auth/raw/mastodon/s/finish-up', 'RemoteAuthController@finishUp');
  29. Route::post('auth/raw/mastodon/s/login', 'RemoteAuthController@handleLogin');
  30. Route::get('auth/pci/{id}/{code}', 'ParentalControlsController@inviteRegister');
  31. Route::post('auth/pci/{id}/{code}', 'ParentalControlsController@inviteRegisterStore');
  32. Route::get('auth/sign_up', 'SiteController@curatedOnboarding')->name('auth.curated-onboarding');
  33. Route::post('auth/sign_up', 'CuratedRegisterController@proceed');
  34. Route::get('auth/sign_up/concierge/response-sent', 'CuratedRegisterController@conciergeResponseSent');
  35. Route::get('auth/sign_up/concierge', 'CuratedRegisterController@concierge');
  36. Route::post('auth/sign_up/concierge', 'CuratedRegisterController@conciergeStore');
  37. Route::get('auth/sign_up/concierge/form', 'CuratedRegisterController@conciergeFormShow');
  38. Route::post('auth/sign_up/concierge/form', 'CuratedRegisterController@conciergeFormStore');
  39. Route::get('auth/sign_up/confirm', 'CuratedRegisterController@confirmEmail');
  40. Route::post('auth/sign_up/confirm', 'CuratedRegisterController@confirmEmailHandle');
  41. Route::get('auth/sign_up/confirmed', 'CuratedRegisterController@emailConfirmed');
  42. Route::get('auth/sign_up/resend-confirmation', 'CuratedRegisterController@resendConfirmation');
  43. Route::post('auth/sign_up/resend-confirmation', 'CuratedRegisterController@resendConfirmationProcess');
  44. Route::get('auth/forgot/email', 'UserEmailForgotController@index')->name('email.forgot');
  45. Route::post('auth/forgot/email', 'UserEmailForgotController@store')->middleware('throttle:10,900,forgotEmail');
  46. Route::group([
  47. 'as' => 'passport.',
  48. 'prefix' => config('passport.path', 'oauth'),
  49. ], function () {
  50. Route::post('/token', [
  51. 'uses' => '\Laravel\Passport\Http\Controllers\AccessTokenController@issueToken',
  52. 'as' => 'token',
  53. 'middleware' => 'throttle',
  54. ]);
  55. Route::get('/authorize', [
  56. 'uses' => '\Laravel\Passport\Http\Controllers\AuthorizationController@authorize',
  57. 'as' => 'authorizations.authorize',
  58. 'middleware' => 'web',
  59. ]);
  60. $guard = config('passport.guard', null);
  61. Route::middleware(['web', $guard ? 'auth:'.$guard : 'auth'])->group(function () {
  62. Route::post('/token/refresh', [
  63. 'uses' => '\Laravel\Passport\Http\Controllers\TransientTokenController@refresh',
  64. 'as' => 'token.refresh',
  65. ]);
  66. Route::post('/authorize', [
  67. 'uses' => '\App\Http\Controllers\OAuth\OobAuthorizationController@approve',
  68. 'as' => 'authorizations.approve',
  69. ]);
  70. Route::delete('/authorize', [
  71. 'uses' => '\Laravel\Passport\Http\Controllers\DenyAuthorizationController@deny',
  72. 'as' => 'authorizations.deny',
  73. ]);
  74. Route::get('/tokens', [
  75. 'uses' => '\Laravel\Passport\Http\Controllers\AuthorizedAccessTokenController@forUser',
  76. 'as' => 'tokens.index',
  77. ]);
  78. Route::delete('/tokens/{token_id}', [
  79. 'uses' => '\Laravel\Passport\Http\Controllers\AuthorizedAccessTokenController@destroy',
  80. 'as' => 'tokens.destroy',
  81. ]);
  82. Route::get('/clients', [
  83. 'uses' => '\Laravel\Passport\Http\Controllers\ClientController@forUser',
  84. 'as' => 'clients.index',
  85. ]);
  86. Route::post('/clients', [
  87. 'uses' => '\Laravel\Passport\Http\Controllers\ClientController@store',
  88. 'as' => 'clients.store',
  89. ]);
  90. Route::put('/clients/{client_id}', [
  91. 'uses' => '\Laravel\Passport\Http\Controllers\ClientController@update',
  92. 'as' => 'clients.update',
  93. ]);
  94. Route::delete('/clients/{client_id}', [
  95. 'uses' => '\Laravel\Passport\Http\Controllers\ClientController@destroy',
  96. 'as' => 'clients.destroy',
  97. ]);
  98. Route::get('/scopes', [
  99. 'uses' => '\Laravel\Passport\Http\Controllers\ScopeController@all',
  100. 'as' => 'scopes.index',
  101. ]);
  102. Route::get('/personal-access-tokens', [
  103. 'uses' => '\Laravel\Passport\Http\Controllers\PersonalAccessTokenController@forUser',
  104. 'as' => 'personal.tokens.index',
  105. ]);
  106. Route::post('/personal-access-tokens', [
  107. 'uses' => '\Laravel\Passport\Http\Controllers\PersonalAccessTokenController@store',
  108. 'as' => 'personal.tokens.store',
  109. ]);
  110. Route::delete('/personal-access-tokens/{token_id}', [
  111. 'uses' => '\Laravel\Passport\Http\Controllers\PersonalAccessTokenController@destroy',
  112. 'as' => 'personal.tokens.destroy',
  113. ]);
  114. });
  115. });
  116. Route::get('discover', 'DiscoverController@home')->name('discover');
  117. Route::get('discover/tags/{hashtag}', 'DiscoverController@showTags');
  118. Route::get('discover/places', 'PlaceController@directoryHome')->name('discover.places');
  119. Route::get('discover/places/{id}/{slug}', 'PlaceController@show');
  120. Route::get('discover/location/country/{country}', 'PlaceController@directoryCities');
  121. Route::get('/i/app-email-verify', 'AppRegisterController@index');
  122. Route::post('/i/app-email-verify', 'AppRegisterController@store')->middleware('throttle:app-signup');
  123. Route::get('/i/app-email-resend', 'AppRegisterController@resendVerification');
  124. Route::post('/i/app-email-resend', 'AppRegisterController@resendVerificationStore')->middleware('throttle:app-code-resend');
  125. Route::group(['prefix' => 'i'], function () {
  126. Route::redirect('/', '/');
  127. Route::get('compose', 'StatusController@compose')->name('compose');
  128. Route::post('comment', 'CommentController@store');
  129. Route::post('delete', 'StatusController@delete');
  130. Route::post('mute', 'AccountController@mute');
  131. Route::post('unmute', 'AccountController@unmute');
  132. Route::post('block', 'AccountController@block');
  133. Route::post('unblock', 'AccountController@unblock');
  134. Route::post('like', 'LikeController@store');
  135. Route::post('share', 'StatusController@storeShare');
  136. Route::post('follow', 'FollowerController@store');
  137. Route::post('bookmark', 'BookmarkController@store');
  138. Route::get('lang/{locale}', 'SiteController@changeLocale');
  139. Route::get('restored', 'AccountController@accountRestored');
  140. Route::get('verify-email', 'AccountController@verifyEmail')->name('account.verify_email');
  141. Route::post('verify-email', 'AccountController@sendVerifyEmail');
  142. Route::get('verify-email/request', 'InternalApiController@requestEmailVerification');
  143. Route::post('verify-email/request', 'InternalApiController@requestEmailVerificationStore');
  144. Route::get('confirm-email/{userToken}/{randomToken}', 'AccountController@confirmVerifyEmail');
  145. Route::get('auth/sudo', 'AccountController@sudoMode');
  146. Route::post('auth/sudo', 'AccountController@sudoModeVerify');
  147. Route::get('auth/checkpoint', 'AccountController@twoFactorCheckpoint');
  148. Route::post('auth/checkpoint', 'AccountController@twoFactorVerify');
  149. Route::get('results', 'SearchController@results');
  150. Route::post('visibility', 'StatusController@toggleVisibility');
  151. Route::post('metro/dark-mode', 'SettingsController@metroDarkMode');
  152. Route::group(['prefix' => 'report'], function () {
  153. Route::get('/', 'ReportController@showForm')->name('report.form');
  154. Route::post('/', 'ReportController@formStore');
  155. Route::get('not-interested', 'ReportController@notInterestedForm')->name('report.not-interested');
  156. Route::get('spam', 'ReportController@spamForm')->name('report.spam');
  157. Route::get('spam/comment', 'ReportController@spamCommentForm')->name('report.spam.comment');
  158. Route::get('spam/post', 'ReportController@spamPostForm')->name('report.spam.post');
  159. Route::get('spam/profile', 'ReportController@spamProfileForm')->name('report.spam.profile');
  160. Route::get('sensitive/comment', 'ReportController@sensitiveCommentForm')->name('report.sensitive.comment');
  161. Route::get('sensitive/post', 'ReportController@sensitivePostForm')->name('report.sensitive.post');
  162. Route::get('sensitive/profile', 'ReportController@sensitiveProfileForm')->name('report.sensitive.profile');
  163. Route::get('abusive/comment', 'ReportController@abusiveCommentForm')->name('report.abusive.comment');
  164. Route::get('abusive/post', 'ReportController@abusivePostForm')->name('report.abusive.post');
  165. Route::get('abusive/profile', 'ReportController@abusiveProfileForm')->name('report.abusive.profile');
  166. });
  167. Route::get('collections/create', 'CollectionController@create');
  168. Route::get('me', 'ProfileController@meRedirect');
  169. Route::get('intent/follow', 'SiteController@followIntent');
  170. Route::get('rs/{id}', 'StoryController@remoteStory');
  171. Route::get('stories/new', 'StoryController@compose');
  172. Route::get('my/story', 'StoryController@iRedirect');
  173. Route::get('web/profile/_/{id}', 'InternalApiController@remoteProfile');
  174. Route::get('web/post/_/{profileId}/{statusid}', 'InternalApiController@remoteStatus');
  175. Route::group(['prefix' => 'import', 'middleware' => 'dangerzone'], function() {
  176. Route::get('job/{uuid}/1', 'ImportController@instagramStepOne');
  177. Route::post('job/{uuid}/1', 'ImportController@instagramStepOneStore');
  178. Route::get('job/{uuid}/2', 'ImportController@instagramStepTwo');
  179. Route::post('job/{uuid}/2', 'ImportController@instagramStepTwoStore');
  180. Route::get('job/{uuid}/3', 'ImportController@instagramStepThree');
  181. Route::post('job/{uuid}/3', 'ImportController@instagramStepThreeStore');
  182. });
  183. Route::get('redirect', 'SiteController@redirectUrl');
  184. Route::post('admin/media/block/add', 'MediaBlocklistController@add');
  185. Route::post('admin/media/block/delete', 'MediaBlocklistController@delete');
  186. Route::get('warning', 'AccountInterstitialController@get');
  187. Route::post('warning', 'AccountInterstitialController@read');
  188. Route::get('contact-admin-response/{id}', 'ContactController@showAdminResponse');
  189. Route::get('web/my-portfolio', 'PortfolioController@myRedirect');
  190. Route::get('web/hashtag/{tag}', 'SpaController@hashtagRedirect');
  191. Route::get('web/username/{id}', 'SpaController@usernameRedirect');
  192. Route::get('web/post/{id}', 'SpaController@webPost');
  193. Route::get('web/profile/{id}', 'SpaController@webProfile');
  194. Route::get('web/{q}', 'SpaController@index')->where('q', '.*');
  195. Route::get('web', 'SpaController@index');
  196. });
  197. Route::group(['prefix' => 'account'], function () {
  198. Route::redirect('/', '/');
  199. Route::get('direct', 'AccountController@direct');
  200. Route::get('direct/t/{id}', 'AccountController@directMessage');
  201. Route::get('activity', 'AccountController@notifications')->name('notifications');
  202. Route::get('follow-requests', 'AccountController@followRequests')->name('follow-requests');
  203. Route::post('follow-requests', 'AccountController@followRequestHandle');
  204. Route::get('follow-requests.json', 'AccountController@followRequestsJson');
  205. Route::get('portfolio/{username}.json', 'PortfolioController@getApFeed');
  206. Route::get('portfolio/{username}.rss', 'PortfolioController@getRssFeed');
  207. });
  208. Route::group(['prefix' => 'settings'], function () {
  209. Route::redirect('/', '/settings/home');
  210. Route::get('home', 'SettingsController@home')
  211. ->name('settings');
  212. Route::post('home', 'SettingsController@homeUpdate');
  213. Route::get('avatar', 'SettingsController@avatar')->name('settings.avatar');
  214. Route::post('avatar', 'AvatarController@store');
  215. Route::delete('avatar', 'AvatarController@deleteAvatar');
  216. Route::get('password', 'SettingsController@password')->name('settings.password')->middleware('dangerzone');
  217. Route::post('password', 'SettingsController@passwordUpdate')->middleware('dangerzone');
  218. Route::get('email', 'SettingsController@email')->name('settings.email')->middleware('dangerzone');
  219. Route::post('email', 'SettingsController@emailUpdate')->middleware('dangerzone');
  220. Route::get('notifications', 'SettingsController@notifications')->name('settings.notifications');
  221. Route::get('privacy', 'SettingsController@privacy')->name('settings.privacy');
  222. Route::post('privacy', 'SettingsController@privacyStore');
  223. Route::get('privacy/muted-users', 'SettingsController@mutedUsers')->name('settings.privacy.muted-users');
  224. Route::post('privacy/muted-users', 'SettingsController@mutedUsersUpdate');
  225. Route::get('privacy/blocked-users', 'SettingsController@blockedUsers')->name('settings.privacy.blocked-users');
  226. Route::post('privacy/blocked-users', 'SettingsController@blockedUsersUpdate');
  227. Route::get('privacy/domain-blocks', 'SettingsController@domainBlocks')->name('settings.privacy.domain-blocks');
  228. Route::get('privacy/blocked-instances', 'SettingsController@blockedInstances')->name('settings.privacy.blocked-instances');
  229. Route::post('privacy/blocked-instances', 'SettingsController@blockedInstanceStore');
  230. Route::post('privacy/blocked-instances/unblock', 'SettingsController@blockedInstanceUnblock')->name('settings.privacy.blocked-instances.unblock');
  231. Route::get('privacy/blocked-keywords', 'SettingsController@blockedKeywords')->name('settings.privacy.blocked-keywords');
  232. Route::post('privacy/account', 'SettingsController@privateAccountOptions')->name('settings.privacy.account');
  233. Route::group(['prefix' => 'remove', 'middleware' => 'dangerzone'], function() {
  234. Route::get('request/temporary', 'SettingsController@removeAccountTemporary')->name('settings.remove.temporary');
  235. Route::post('request/temporary', 'SettingsController@removeAccountTemporarySubmit');
  236. Route::get('request/permanent', 'SettingsController@removeAccountPermanent')->name('settings.remove.permanent');
  237. Route::post('request/permanent', 'SettingsController@removeAccountPermanentSubmit');
  238. });
  239. Route::group(['prefix' => 'security', 'middleware' => 'dangerzone'], function() {
  240. Route::get(
  241. '/',
  242. 'SettingsController@security'
  243. )->name('settings.security');
  244. Route::get(
  245. '2fa/setup',
  246. 'SettingsController@securityTwoFactorSetup'
  247. )->name('settings.security.2fa.setup');
  248. Route::post(
  249. '2fa/setup',
  250. 'SettingsController@securityTwoFactorSetupStore'
  251. );
  252. Route::get(
  253. '2fa/edit',
  254. 'SettingsController@securityTwoFactorEdit'
  255. )->name('settings.security.2fa.edit');
  256. Route::post(
  257. '2fa/edit',
  258. 'SettingsController@securityTwoFactorUpdate'
  259. );
  260. Route::get(
  261. '2fa/recovery-codes',
  262. 'SettingsController@securityTwoFactorRecoveryCodes'
  263. )->name('settings.security.2fa.recovery');
  264. Route::post(
  265. '2fa/recovery-codes',
  266. 'SettingsController@securityTwoFactorRecoveryCodesRegenerate'
  267. );
  268. });
  269. Route::get('parental-controls', 'ParentalControlsController@index')->name('settings.parental-controls')->middleware('dangerzone');
  270. Route::get('parental-controls/add', 'ParentalControlsController@add')->name('settings.pc.add')->middleware('dangerzone');
  271. Route::post('parental-controls/add', 'ParentalControlsController@store')->middleware('dangerzone');
  272. Route::get('parental-controls/manage/{id}', 'ParentalControlsController@view')->middleware('dangerzone');
  273. Route::post('parental-controls/manage/{id}', 'ParentalControlsController@update')->middleware('dangerzone');
  274. Route::get('parental-controls/manage/{id}/cancel-invite', 'ParentalControlsController@cancelInvite')->name('settings.pc.cancel-invite')->middleware('dangerzone');
  275. Route::post('parental-controls/manage/{id}/cancel-invite', 'ParentalControlsController@cancelInviteHandle')->middleware('dangerzone');
  276. Route::get('parental-controls/manage/{id}/stop-managing', 'ParentalControlsController@stopManaging')->name('settings.pc.stop-managing')->middleware('dangerzone');
  277. Route::post('parental-controls/manage/{id}/stop-managing', 'ParentalControlsController@stopManagingHandle')->middleware('dangerzone');
  278. Route::get('applications', 'SettingsController@applications')->name('settings.applications')->middleware('dangerzone');
  279. Route::get('data-export', 'SettingsController@dataExport')->name('settings.dataexport')->middleware('dangerzone');
  280. Route::post('data-export/following', 'SettingsController@exportFollowing')->middleware('dangerzone');
  281. Route::post('data-export/followers', 'SettingsController@exportFollowers')->middleware('dangerzone');
  282. Route::post('data-export/mute-block-list', 'SettingsController@exportMuteBlockList')->middleware('dangerzone');
  283. Route::post('data-export/account', 'SettingsController@exportAccount')->middleware('dangerzone');
  284. Route::post('data-export/statuses', 'SettingsController@exportStatuses')->middleware('dangerzone');
  285. Route::get('developers', 'SettingsController@developers')->name('settings.developers')->middleware('dangerzone');
  286. Route::get('labs', 'SettingsController@labs')->name('settings.labs');
  287. Route::post('labs', 'SettingsController@labsStore');
  288. Route::get('accessibility', 'SettingsController@accessibility')->name('settings.accessibility');
  289. Route::post('accessibility', 'SettingsController@accessibilityStore');
  290. Route::group(['prefix' => 'relationships'], function() {
  291. Route::redirect('/', '/settings/relationships/home');
  292. Route::get('home', 'SettingsController@relationshipsHome')->name('settings.relationships');
  293. });
  294. Route::get('invites/create', 'UserInviteController@create')->name('settings.invites.create');
  295. Route::post('invites/create', 'UserInviteController@store');
  296. Route::get('invites', 'UserInviteController@show')->name('settings.invites');
  297. // Route::get('sponsor', 'SettingsController@sponsor')->name('settings.sponsor');
  298. // Route::post('sponsor', 'SettingsController@sponsorStore');
  299. Route::group(['prefix' => 'import', 'middleware' => 'dangerzone'], function() {
  300. Route::get('/', 'SettingsController@dataImport')->name('settings.import');
  301. Route::prefix('instagram')->group(function() {
  302. Route::get('/', 'ImportController@instagram')->name('settings.import.ig');
  303. Route::post('/', 'ImportController@instagramStart');
  304. });
  305. Route::prefix('mastodon')->group(function() {
  306. Route::get('/', 'ImportController@mastodon')->name('settings.import.mastodon');
  307. });
  308. });
  309. Route::get('timeline', 'SettingsController@timelineSettings')->name('settings.timeline');
  310. Route::post('timeline', 'SettingsController@updateTimelineSettings');
  311. Route::get('media', 'SettingsController@mediaSettings')->name('settings.media');
  312. Route::post('media', 'SettingsController@updateMediaSettings');
  313. Route::group(['prefix' => 'account/aliases', 'middleware' => 'dangerzone'], function() {
  314. Route::get('manage', 'ProfileAliasController@index');
  315. Route::post('manage', 'ProfileAliasController@store');
  316. Route::post('manage/delete', 'ProfileAliasController@delete');
  317. });
  318. Route::group(['prefix' => 'account/migration', 'middleware' => 'dangerzone'], function() {
  319. Route::get('manage', 'ProfileMigrationController@index');
  320. Route::post('manage', 'ProfileMigrationController@store');
  321. });
  322. Route::group(['prefix' => 'filters'], function() {
  323. Route::get('/', 'SettingsController@filtersHome')->name('settings.filters');
  324. });
  325. });
  326. Route::group(['prefix' => 'site'], function () {
  327. Route::redirect('/', '/');
  328. Route::get('about', 'SiteController@about')->name('site.about');
  329. Route::view('help', 'site.help')->name('site.help');
  330. Route::view('developer-api', 'site.developer')->name('site.developers');
  331. Route::view('fediverse', 'site.fediverse')->name('site.fediverse');
  332. Route::view('open-source', 'site.opensource')->name('site.opensource');
  333. Route::view('banned-instances', 'site.bannedinstances')->name('site.bannedinstances');
  334. Route::get('terms', 'SiteController@terms')->name('site.terms');
  335. Route::get('privacy', 'SiteController@privacy')->name('site.privacy');
  336. Route::view('platform', 'site.platform')->name('site.platform');
  337. Route::view('language', 'site.language')->name('site.language');
  338. Route::get('contact', 'ContactController@show')->name('site.contact');
  339. Route::post('contact', 'ContactController@store');
  340. Route::group(['prefix'=>'kb'], function() {
  341. Route::view('getting-started', 'site.help.getting-started')->name('help.getting-started');
  342. Route::view('sharing-media', 'site.help.sharing-media')->name('help.sharing-media');
  343. Route::view('your-profile', 'site.help.your-profile')->name('help.your-profile');
  344. Route::view('stories', 'site.help.stories')->name('help.stories');
  345. Route::view('embed', 'site.help.embed')->name('help.embed');
  346. Route::view('hashtags', 'site.help.hashtags')->name('help.hashtags');
  347. Route::view('instance-actor', 'site.help.instance-actor')->name('help.instance-actor');
  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. Route::view('labs-deprecation', 'site.help.labs-deprecation')->name('help.labs-deprecation');
  359. Route::view('tagging-people', 'site.help.tagging-people')->name('help.tagging-people');
  360. Route::view('licenses', 'site.help.licenses')->name('help.licenses');
  361. Route::view('instance-max-users-limit', 'site.help.instance-max-users')->name('help.instance-max-users-limit');
  362. Route::view('import', 'site.help.import')->name('help.import');
  363. Route::view('parental-controls', 'site.help.parental-controls');
  364. Route::view('email-confirmation-issues', 'site.help.email-confirmation-issues')->name('help.email-confirmation-issues');
  365. Route::view('curated-onboarding', 'site.help.curated-onboarding')->name('help.curated-onboarding');
  366. Route::view('account-migration', 'site.help.account-migration')->name('help.account-migration');
  367. });
  368. Route::get('newsroom/{year}/{month}/{slug}', 'NewsroomController@show');
  369. Route::get('newsroom/archive', 'NewsroomController@archive');
  370. Route::get('newsroom/search', 'NewsroomController@search');
  371. Route::get('newsroom', 'NewsroomController@index');
  372. Route::get('legal-notice', 'SiteController@legalNotice');
  373. });
  374. Route::group(['prefix' => 'timeline'], function () {
  375. Route::redirect('/', '/');
  376. Route::get('public', 'TimelineController@local')->name('timeline.public');
  377. Route::get('network', 'TimelineController@network')->name('timeline.network');
  378. });
  379. Route::group(['prefix' => 'users'], function () {
  380. Route::redirect('/', '/');
  381. Route::get('{user}.atom', 'ProfileController@showAtomFeed')->where('user', '.*');
  382. Route::get('{username}/outbox', 'FederationController@userOutbox');
  383. Route::get('{username}/followers', 'FederationController@userFollowers');
  384. Route::get('{username}/following', 'FederationController@userFollowing');
  385. Route::get('{username}', 'ProfileController@permalinkRedirect');
  386. });
  387. Route::group(['prefix' => 'installer'], function() {
  388. Route::get('api/requirements', 'InstallController@getRequirements')->withoutMiddleware(['web']);
  389. Route::post('precheck/database', 'InstallController@precheckDatabase')->withoutMiddleware(['web']);
  390. Route::post('store', 'InstallController@store')->withoutMiddleware(['web']);
  391. Route::get('/', 'InstallController@index')->withoutMiddleware(['web']);
  392. Route::get('/{q}', 'InstallController@index')->withoutMiddleware(['web'])->where('q', '.*');
  393. });
  394. Route::group(['prefix' => 'e'], function() {
  395. Route::get('terms', 'MobileController@terms');
  396. Route::get('privacy', 'MobileController@privacy');
  397. });
  398. Route::get('auth/invite/a/{code}', 'AdminInviteController@index');
  399. Route::post('api/v1.1/auth/invite/admin/re', 'AdminInviteController@apiRegister')->middleware('throttle:5,1440');
  400. Route::redirect('groups/', '/groups/home');
  401. Route::redirect('groups/home', '/groups/feed');
  402. Route::prefix('groups')->group(function() {
  403. // Route::get('feed', 'GroupController@index');
  404. Route::get('{id}/invite/claim', 'GroupController@groupInviteClaim');
  405. Route::get('{id}/invite', 'GroupController@groupInviteLanding');
  406. Route::get('{id}/settings', 'GroupController@groupSettings');
  407. Route::get('{gid}/topics/{topic}', 'Groups\GroupsTopicController@showTopicFeed');
  408. Route::get('{gid}/p/{sid}.json', 'GroupController@getStatusObject');
  409. Route::get('{gid}/p/{sid}', 'GroupController@showStatus');
  410. Route::get('{id}/user/{pid}', 'GroupController@showProfile');
  411. Route::get('{id}/un/{pid}', 'GroupController@showProfile');
  412. Route::get('{id}/username/{pid}', 'GroupController@showProfileByUsername');
  413. Route::get('{id}/{path}', 'GroupController@show');
  414. Route::get('{id}.json', 'GroupController@getGroupObject');
  415. Route::get('feed', 'GroupController@index');
  416. Route::get('create', 'GroupController@index');
  417. Route::get('discover', 'GroupController@index');
  418. Route::get('search', 'GroupController@index');
  419. Route::get('joins', 'GroupController@index');
  420. Route::get('notifications', 'GroupController@index');
  421. Route::get('{id}', 'GroupController@show');
  422. });
  423. Route::get('g/{hid}', 'GroupController@groupShortLinkRedirect');
  424. Route::get('stories/{username}', 'ProfileController@stories');
  425. Route::get('p/{id}', 'StatusController@shortcodeRedirect');
  426. Route::get('c/{collection}', 'CollectionController@show');
  427. Route::get('p/{username}/{id}/c', 'CommentController@showAll');
  428. Route::get('p/{username}/{id}/embed', 'StatusController@showEmbed');
  429. Route::get('p/{username}/{id}/edit', 'StatusController@edit');
  430. Route::post('p/{username}/{id}/edit', 'StatusController@editStore');
  431. Route::get('p/{username}/{id}.json', 'StatusController@showObject');
  432. Route::get('p/{username}/{id}', 'StatusController@show');
  433. Route::get('{username}/embed', 'ProfileController@embed');
  434. Route::get('{username}/live', 'LiveStreamController@showProfilePlayer');
  435. Route::get('@{username}@{domain}', 'SiteController@legacyWebfingerRedirect');
  436. Route::get('@{username}', 'SiteController@legacyProfileRedirect');
  437. Route::get('{username}', 'ProfileController@show');
  438. });