routes.php 18 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282
  1. <?php
  2. declare(strict_types=1);
  3. use App\Middleware\Admin;
  4. use App\Middleware\Auth;
  5. use App\Middleware\AuthorizationBearer;
  6. use App\Middleware\Guest;
  7. use App\Middleware\NodeToken;
  8. use Slim\Routing\RouteCollectorProxy;
  9. return function (Slim\App $app): void {
  10. // Home
  11. $app->get('/', App\Controllers\HomeController::class . ':index');
  12. $app->get('/404', App\Controllers\HomeController::class . ':page404');
  13. $app->get('/405', App\Controllers\HomeController::class . ':page405');
  14. $app->get('/500', App\Controllers\HomeController::class . ':page500');
  15. $app->get('/tos', App\Controllers\HomeController::class . ':tos');
  16. $app->get('/staff', App\Controllers\HomeController::class . ':staff');
  17. // other
  18. $app->post('/notify', App\Controllers\HomeController::class . ':notify');
  19. // Telegram
  20. $app->post('/telegram_callback', App\Controllers\HomeController::class . ':telegram');
  21. // User Center
  22. $app->group('/user', function (RouteCollectorProxy $group): void {
  23. $group->get('', App\Controllers\UserController::class . ':index');
  24. $group->get('/', App\Controllers\UserController::class . ':index');
  25. $group->post('/checkin', App\Controllers\UserController::class . ':doCheckin');
  26. $group->get('/announcement', App\Controllers\UserController::class . ':announcement');
  27. $group->get('/docs', App\Controllers\UserController::class . ':docs');
  28. $group->get('/media', App\Controllers\UserController::class . ':media');
  29. $group->get('/profile', App\Controllers\UserController::class . ':profile');
  30. $group->get('/invite', App\Controllers\UserController::class . ':invite');
  31. $group->get('/banned', App\Controllers\UserController::class . ':banned');
  32. $group->get('/server', App\Controllers\User\ServerController::class . ':userServerPage');
  33. $group->get('/detect', App\Controllers\User\DetectController::class . ':detectIndex');
  34. $group->get('/detect/log', App\Controllers\User\DetectController::class . ':detectLog');
  35. $group->get('/shop', App\Controllers\User\ShopController::class . ':shop');
  36. $group->post('/coupon_check', App\Controllers\User\ShopController::class . ':couponCheck');
  37. $group->post('/buy', App\Controllers\User\ShopController::class . ':buy');
  38. $group->post('/buy_traffic_package', App\Controllers\User\ShopController::class . ':buyTrafficPackage');
  39. $group->get('/ticket', App\Controllers\User\TicketController::class . ':ticket');
  40. $group->get('/ticket/create', App\Controllers\User\TicketController::class . ':ticketCreate');
  41. $group->post('/ticket', App\Controllers\User\TicketController::class . ':ticketAdd');
  42. $group->get('/ticket/{id}/view', App\Controllers\User\TicketController::class . ':ticketView');
  43. $group->put('/ticket/{id}', App\Controllers\User\TicketController::class . ':ticketUpdate');
  44. $group->post('/buy_invite', App\Controllers\UserController::class . ':buyInvite');
  45. $group->post('/custom_invite', App\Controllers\UserController::class . ':customInvite');
  46. $group->get('/edit', App\Controllers\UserController::class . ':edit');
  47. $group->post('/email', App\Controllers\UserController::class . ':updateEmail');
  48. $group->post('/username', App\Controllers\UserController::class . ':updateUsername');
  49. $group->post('/password', App\Controllers\UserController::class . ':updatePassword');
  50. $group->post('/send', App\Controllers\AuthController::class . ':sendVerify');
  51. $group->post('/contact_update', App\Controllers\UserController::class . ':updateContact');
  52. $group->post('/ssr', App\Controllers\UserController::class . ':updateSSR');
  53. $group->post('/theme', App\Controllers\UserController::class . ':updateTheme');
  54. $group->post('/mail', App\Controllers\UserController::class . ':updateMail');
  55. $group->post('/passwd_reset', App\Controllers\UserController::class . ':resetPasswd');
  56. $group->post('/method', App\Controllers\UserController::class . ':updateMethod');
  57. $group->get('/trafficlog', App\Controllers\UserController::class . ':trafficLog');
  58. $group->get('/kill', App\Controllers\UserController::class . ':kill');
  59. $group->post('/kill', App\Controllers\UserController::class . ':handleKill');
  60. $group->get('/logout', App\Controllers\UserController::class . ':logout');
  61. $group->get('/backtoadmin', App\Controllers\UserController::class . ':backtoadmin');
  62. $group->get('/code', App\Controllers\UserController::class . ':code');
  63. $group->get('/code_check', App\Controllers\UserController::class . ':codeCheck');
  64. $group->post('/code', App\Controllers\UserController::class . ':codePost');
  65. $group->post('/ga_check', App\Controllers\UserController::class . ':checkGa');
  66. $group->post('/ga_set', App\Controllers\UserController::class . ':setGa');
  67. $group->get('/ga_reset', App\Controllers\UserController::class . ':resetGa');
  68. $group->post('/telegram_reset', App\Controllers\UserController::class . ':resetTelegram');
  69. $group->post('/unblock', App\Controllers\UserController::class . ':unblock');
  70. $group->get('/bought', App\Controllers\UserController::class . ':bought');
  71. $group->delete('/bought', App\Controllers\UserController::class . ':deleteBoughtGet');
  72. $group->post('/url_reset', App\Controllers\UserController::class . ':resetURL');
  73. $group->put('/invite', App\Controllers\UserController::class . ':resetInviteURL');
  74. //深色模式
  75. $group->post('/switch_theme_mode', App\Controllers\UserController::class . ':switchThemeMode');
  76. // 订阅记录
  77. $group->get('/subscribe_log', App\Controllers\UserController::class . ':subscribeLog');
  78. // getUserAllURL
  79. $group->get('/getUserAllURL', App\Controllers\UserController::class . ':getUserAllURL');
  80. //Reconstructed Payment System
  81. $group->post('/payment/purchase/{type}', App\Services\Payment::class . ':purchase');
  82. $group->get('/payment/purchase/{type}', App\Services\Payment::class . ':purchase');
  83. $group->get('/payment/return/{type}', App\Services\Payment::class . ':returnHTML');
  84. })->add(new Auth());
  85. $app->group('/payment', function (RouteCollectorProxy $group): void {
  86. $group->get('/notify/{type}', App\Services\Payment::class . ':notify');
  87. $group->post('/notify/{type}', App\Services\Payment::class . ':notify');
  88. $group->post('/status/{type}', App\Services\Payment::class . ':getStatus');
  89. });
  90. // Auth
  91. $app->group('/auth', function (RouteCollectorProxy $group): void {
  92. $group->get('/login', App\Controllers\AuthController::class . ':login');
  93. $group->post('/qrcode_check', App\Controllers\AuthController::class . ':qrcodeCheck');
  94. $group->post('/login', App\Controllers\AuthController::class . ':loginHandle');
  95. $group->post('/qrcode_login', App\Controllers\AuthController::class . ':qrcodeLoginHandle');
  96. $group->get('/register', App\Controllers\AuthController::class . ':register');
  97. $group->post('/register', App\Controllers\AuthController::class . ':registerHandle');
  98. $group->post('/send', App\Controllers\AuthController::class . ':sendVerify');
  99. $group->get('/logout', App\Controllers\AuthController::class . ':logout');
  100. $group->get('/telegram_oauth', App\Controllers\AuthController::class . ':telegramOauth');
  101. })->add(new Guest());
  102. // Password
  103. $app->group('/password', function (RouteCollectorProxy $group): void {
  104. $group->get('/reset', App\Controllers\PasswordController::class . ':reset');
  105. $group->post('/reset', App\Controllers\PasswordController::class . ':handleReset');
  106. $group->get('/token/{token}', App\Controllers\PasswordController::class . ':token');
  107. $group->post('/token/{token}', App\Controllers\PasswordController::class . ':handleToken');
  108. })->add(new Guest());
  109. // Admin
  110. $app->group('/admin', function (RouteCollectorProxy $group): void {
  111. $group->get('', App\Controllers\AdminController::class . ':index');
  112. $group->get('/', App\Controllers\AdminController::class . ':index');
  113. $group->get('/sys', App\Controllers\AdminController::class . ':sys');
  114. $group->get('/invite', App\Controllers\AdminController::class . ':invite');
  115. $group->post('/invite', App\Controllers\AdminController::class . ':addInvite');
  116. $group->post('/chginvite', App\Controllers\AdminController::class . ':chgInvite');
  117. $group->post('/payback/ajax', App\Controllers\AdminController::class . ':ajaxPayback');
  118. // Node Mange
  119. $group->get('/node', App\Controllers\Admin\NodeController::class . ':index');
  120. $group->get('/node/create', App\Controllers\Admin\NodeController::class . ':create');
  121. $group->post('/node', App\Controllers\Admin\NodeController::class . ':add');
  122. $group->get('/node/{id}/edit', App\Controllers\Admin\NodeController::class . ':edit');
  123. $group->post('/node/{id}/password_reset', App\Controllers\Admin\NodeController::class . ':resetNodePassword');
  124. $group->post('/node/{id}/copy', App\Controllers\Admin\NodeController::class . ':copy');
  125. $group->put('/node/{id}', App\Controllers\Admin\NodeController::class . ':update');
  126. $group->delete('/node/{id}', App\Controllers\Admin\NodeController::class . ':delete');
  127. $group->post('/node/ajax', App\Controllers\Admin\NodeController::class . ':ajax');
  128. // Ticket Mange
  129. $group->get('/ticket', App\Controllers\Admin\TicketController::class . ':index');
  130. $group->post('/ticket', App\Controllers\Admin\TicketController::class . ':add');
  131. $group->get('/ticket/{id}/view', App\Controllers\Admin\TicketController::class . ':ticketView');
  132. $group->put('/ticket/{id}/close', App\Controllers\Admin\TicketController::class . ':close');
  133. $group->put('/ticket/{id}', App\Controllers\Admin\TicketController::class . ':update');
  134. $group->delete('/ticket/{id}', App\Controllers\Admin\TicketController::class . ':delete');
  135. $group->post('/ticket/ajax', App\Controllers\Admin\TicketController::class . ':ajax');
  136. // Shop Mange
  137. $group->get('/shop', App\Controllers\Admin\ShopController::class . ':index');
  138. $group->post('/shop/ajax', App\Controllers\Admin\ShopController::class . ':ajaxShop');
  139. $group->get('/shop/create', App\Controllers\Admin\ShopController::class . ':create');
  140. $group->post('/shop', App\Controllers\Admin\ShopController::class . ':add');
  141. $group->get('/shop/{id}/edit', App\Controllers\Admin\ShopController::class . ':edit');
  142. $group->put('/shop/{id}', App\Controllers\Admin\ShopController::class . ':update');
  143. $group->delete('/shop', App\Controllers\Admin\ShopController::class . ':deleteGet');
  144. // Bought Mange
  145. $group->get('/bought', App\Controllers\Admin\ShopController::class . ':bought');
  146. $group->delete('/bought', App\Controllers\Admin\ShopController::class . ':deleteBoughtGet');
  147. $group->post('/bought/ajax', App\Controllers\Admin\ShopController::class . ':ajaxBought');
  148. // Ann Mange
  149. $group->get('/announcement', App\Controllers\Admin\AnnController::class . ':index');
  150. $group->get('/announcement/create', App\Controllers\Admin\AnnController::class . ':create');
  151. $group->post('/announcement', App\Controllers\Admin\AnnController::class . ':add');
  152. $group->get('/announcement/{id}/edit', App\Controllers\Admin\AnnController::class . ':edit');
  153. $group->put('/announcement/{id}', App\Controllers\Admin\AnnController::class . ':update');
  154. $group->delete('/announcement/{id}', App\Controllers\Admin\AnnController::class . ':delete');
  155. $group->post('/announcement/ajax', App\Controllers\Admin\AnnController::class . ':ajax');
  156. // Detect Mange
  157. $group->get('/detect', App\Controllers\Admin\DetectController::class . ':index');
  158. $group->get('/detect/create', App\Controllers\Admin\DetectController::class . ':create');
  159. $group->post('/detect', App\Controllers\Admin\DetectController::class . ':add');
  160. $group->get('/detect/{id}/edit', App\Controllers\Admin\DetectController::class . ':edit');
  161. $group->put('/detect/{id}', App\Controllers\Admin\DetectController::class . ':update');
  162. $group->delete('/detect', App\Controllers\Admin\DetectController::class . ':delete');
  163. $group->get('/detect/log', App\Controllers\Admin\DetectController::class . ':log');
  164. $group->post('/detect/ajax', App\Controllers\Admin\DetectController::class . ':ajaxRule');
  165. $group->post('/detect/log/ajax', App\Controllers\Admin\DetectController::class . ':ajaxLog');
  166. // IP Mange
  167. $group->get('/login', App\Controllers\Admin\IpController::class . ':login');
  168. $group->get('/alive', App\Controllers\Admin\IpController::class . ':alive');
  169. $group->post('/login/ajax', App\Controllers\Admin\IpController::class . ':ajaxLogin');
  170. $group->post('/alive/ajax', App\Controllers\Admin\IpController::class . ':ajaxAlive');
  171. // Code Mange
  172. $group->get('/code', App\Controllers\Admin\CodeController::class . ':index');
  173. $group->get('/code/create', App\Controllers\Admin\CodeController::class . ':create');
  174. $group->post('/code', App\Controllers\Admin\CodeController::class . ':add');
  175. $group->post('/code/ajax', App\Controllers\Admin\CodeController::class . ':ajaxCode');
  176. // User Mange
  177. $group->get('/user', App\Controllers\Admin\UserController::class . ':index');
  178. $group->get('/user/{id}/edit', App\Controllers\Admin\UserController::class . ':edit');
  179. $group->put('/user/{id}', App\Controllers\Admin\UserController::class . ':update');
  180. $group->post('/user/changetouser', App\Controllers\Admin\UserController::class . ':changetouser');
  181. $group->post('/user/create', App\Controllers\Admin\UserController::class . ':createNewUser');
  182. $group->delete('/user/{id}', App\Controllers\Admin\UserController::class . ':delete');
  183. $group->post('/user/ajax', App\Controllers\Admin\UserController::class . ':ajax');
  184. // Coupon Mange
  185. $group->get('/coupon', App\Controllers\AdminController::class . ':coupon');
  186. $group->post('/coupon', App\Controllers\AdminController::class . ':addCoupon');
  187. $group->post('/coupon/ajax', App\Controllers\AdminController::class . ':ajaxCoupon');
  188. // Subscribe Log Mange
  189. $group->get('/subscribe', App\Controllers\Admin\SubscribeLogController::class . ':index');
  190. $group->post('/subscribe/ajax', App\Controllers\Admin\SubscribeLogController::class . ':ajaxSubscribeLog');
  191. // Traffic Log Mange
  192. $group->get('/trafficlog', App\Controllers\Admin\TrafficLogController::class . ':index');
  193. $group->post('/trafficlog/ajax', App\Controllers\Admin\TrafficLogController::class . ':ajaxTrafficLog');
  194. // Detect Ban Mange
  195. $group->get('/detect/ban', App\Controllers\Admin\DetectBanLogController::class . ':index');
  196. $group->post('/detect/ban/ajax', App\Controllers\Admin\DetectBanLogController::class . ':ajaxLog');
  197. // 设置中心
  198. $group->get('/setting', App\Controllers\Admin\SettingController::class . ':index');
  199. $group->post('/setting', App\Controllers\Admin\SettingController::class . ':save');
  200. $group->post('/setting/email', App\Controllers\Admin\SettingController::class . ':test');
  201. $group->post('/setting/payment', App\Controllers\Admin\SettingController::class . ':payment');
  202. })->add(new Admin());
  203. if ($_ENV['enableAdminApi']) {
  204. $app->group('/admin/api', function (RouteCollectorProxy $group): void {
  205. $group->get('/nodes', App\Controllers\Admin\ApiController::class . ':getNodeList');
  206. $group->get('/node/{id}', App\Controllers\Admin\ApiController::class . ':getNodeInfo');
  207. $group->get('/ping', App\Controllers\Admin\ApiController::class . ':ping');
  208. // Re-bind controller, bypass admin token require
  209. $group->post('/node', App\Controllers\Admin\NodeController::class . ':add');
  210. $group->put('/node/{id}', App\Controllers\Admin\NodeController::class . ':update');
  211. $group->delete('/node', App\Controllers\Admin\NodeController::class . ':delete');
  212. })->add(new AuthorizationBearer($_ENV['adminApiToken']));
  213. }
  214. // mu
  215. $app->group('/mod_mu', function (RouteCollectorProxy $group): void {
  216. // 流媒体检测
  217. $group->post('/media/saveReport', App\Controllers\Node\NodeController::class . ':saveReport');
  218. // 节点
  219. $group->get('/nodes', App\Controllers\Node\NodeController::class . ':getAllInfo');
  220. $group->get('/nodes/{id}/info', App\Controllers\Node\NodeController::class . ':getInfo');
  221. $group->post('/nodes/{id}/info', App\Controllers\Node\NodeController::class . ':info');
  222. // 用户
  223. $group->get('/users', App\Controllers\Node\UserController::class . ':index');
  224. $group->post('/users/traffic', App\Controllers\Node\UserController::class . ':addTraffic');
  225. $group->post('/users/aliveip', App\Controllers\Node\UserController::class . ':addAliveIp');
  226. $group->post('/users/detectlog', App\Controllers\Node\UserController::class . ':addDetectLog');
  227. // 审计 & 杂七杂八的功能
  228. $group->get('/func/detect_rules', App\Controllers\Node\FuncController::class . ':getDetectLogs');
  229. $group->get('/func/ping', App\Controllers\Node\FuncController::class . ':ping');
  230. // Dummy API for old version
  231. $group->post('/func/block_ip', App\Controllers\Node\FuncController::class . ':addBlockIp');
  232. $group->get('/func/block_ip', App\Controllers\Node\FuncController::class . ':getBlockip');
  233. $group->get('/func/unblock_ip', App\Controllers\Node\FuncController::class . ':getUnblockip');
  234. })->add(new NodeToken());
  235. $app->get('/link/{token}', App\Controllers\LinkController::class . ':getContent');
  236. //通用訂閲
  237. $app->get('/sub/{token}/{subtype}', App\Controllers\SubController::class . ':getContent');
  238. };