routes.php 21 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334
  1. <?php
  2. declare(strict_types=1);
  3. use Slim\App as SlimApp;
  4. return function (SlimApp $app): void {
  5. // Home
  6. $app->get('/', App\Controllers\HomeController::class . ':index');
  7. $app->get('/404', App\Controllers\HomeController::class . ':page404');
  8. $app->get('/405', App\Controllers\HomeController::class . ':page405');
  9. $app->get('/500', App\Controllers\HomeController::class . ':page500');
  10. $app->get('/tos', App\Controllers\HomeController::class . ':tos');
  11. $app->get('/staff', App\Controllers\HomeController::class . ':staff');
  12. // other
  13. $app->post('/notify', App\Controllers\HomeController::class . ':notify');
  14. // Telegram
  15. $app->post('/telegram_callback', App\Controllers\HomeController::class . ':telegram');
  16. // User Center
  17. $app->group('/user', function (): void {
  18. $this->get('', App\Controllers\UserController::class . ':index');
  19. $this->get('/', App\Controllers\UserController::class . ':index');
  20. $this->post('/checkin', App\Controllers\UserController::class . ':doCheckin');
  21. $this->get('/announcement', App\Controllers\UserController::class . ':announcement');
  22. $this->get('/media', App\Controllers\UserController::class . ':media');
  23. $this->get('/donate', App\Controllers\UserController::class . ':donate');
  24. $this->get('/profile', App\Controllers\UserController::class . ':profile');
  25. $this->get('/invite', App\Controllers\UserController::class . ':invite');
  26. $this->get('/disable', App\Controllers\UserController::class . ':disable');
  27. $this->get('/node', App\Controllers\User\NodeController::class . ':user_node_page');
  28. $this->get('/node/{id}/ajax', App\Controllers\User\NodeController::class . ':user_node_ajax');
  29. $this->get('/node/{id}', App\Controllers\User\NodeController::class . ':user_node_info');
  30. $this->get('/detect', App\Controllers\UserController::class . ':detect_index');
  31. $this->get('/detect/log', App\Controllers\UserController::class . ':detect_log');
  32. $this->get('/shop', App\Controllers\UserController::class . ':shop');
  33. $this->post('/coupon_check', App\Controllers\UserController::class . ':CouponCheck');
  34. $this->post('/buy', App\Controllers\UserController::class . ':buy');
  35. $this->post('/buy_traffic_package', App\Controllers\UserController::class . ':buy_traffic_package');
  36. $this->get('/ticket', App\Controllers\User\TicketController::class . ':ticket');
  37. $this->get('/ticket/create', App\Controllers\User\TicketController::class . ':ticket_create');
  38. $this->post('/ticket', App\Controllers\User\TicketController::class . ':ticket_add');
  39. $this->get('/ticket/{id}/view', App\Controllers\User\TicketController::class . ':ticket_view');
  40. $this->put('/ticket/{id}', App\Controllers\User\TicketController::class . ':ticket_update');
  41. $this->post('/buy_invite', App\Controllers\UserController::class . ':buyInvite');
  42. $this->post('/custom_invite', App\Controllers\UserController::class . ':customInvite');
  43. $this->get('/edit', App\Controllers\UserController::class . ':edit');
  44. $this->post('/email', App\Controllers\UserController::class . ':updateEmail');
  45. $this->post('/username', App\Controllers\UserController::class . ':updateUsername');
  46. $this->post('/password', App\Controllers\UserController::class . ':updatePassword');
  47. $this->post('/send', App\Controllers\AuthController::class . ':sendVerify');
  48. $this->post('/wechat', App\Controllers\UserController::class . ':updateWechat');
  49. $this->post('/ssr', App\Controllers\UserController::class . ':updateSSR');
  50. $this->post('/theme', App\Controllers\UserController::class . ':updateTheme');
  51. $this->post('/mail', App\Controllers\UserController::class . ':updateMail');
  52. $this->post('/sspwd', App\Controllers\UserController::class . ':updateSsPwd');
  53. $this->post('/method', App\Controllers\UserController::class . ':updateMethod');
  54. $this->post('/hide', App\Controllers\UserController::class . ':updateHide');
  55. $this->get('/sys', App\Controllers\UserController::class . ':sys');
  56. $this->get('/trafficlog', App\Controllers\UserController::class . ':trafficLog');
  57. $this->get('/kill', App\Controllers\UserController::class . ':kill');
  58. $this->post('/kill', App\Controllers\UserController::class . ':handleKill');
  59. $this->get('/logout', App\Controllers\UserController::class . ':logout');
  60. $this->get('/backtoadmin', App\Controllers\UserController::class . ':backtoadmin');
  61. $this->get('/code', App\Controllers\UserController::class . ':code');
  62. $this->get('/code_check', App\Controllers\UserController::class . ':code_check');
  63. $this->post('/code', App\Controllers\UserController::class . ':codepost');
  64. $this->post('/gacheck', App\Controllers\UserController::class . ':GaCheck');
  65. $this->post('/gaset', App\Controllers\UserController::class . ':GaSet');
  66. $this->get('/gareset', App\Controllers\UserController::class . ':GaReset');
  67. $this->get('/telegram_reset', App\Controllers\UserController::class . ':telegram_reset');
  68. $this->post('/resetport', App\Controllers\UserController::class . ':ResetPort');
  69. $this->post('/specifyport', App\Controllers\UserController::class . ':SpecifyPort');
  70. $this->post('/unblock', App\Controllers\UserController::class . ':Unblock');
  71. $this->get('/bought', App\Controllers\UserController::class . ':bought');
  72. $this->delete('/bought', App\Controllers\UserController::class . ':deleteBoughtGet');
  73. $this->get('/url_reset', App\Controllers\UserController::class . ':resetURL');
  74. $this->put('/invite', App\Controllers\UserController::class . ':resetInviteURL');
  75. $this->get('/order', App\Controllers\UserController::class . ':user_order');
  76. $this->get('/product', App\Controllers\UserController::class . ':product_index');
  77. // 订阅记录
  78. $this->get('/subscribe_log', App\Controllers\UserController::class . ':subscribe_log');
  79. // getUserAllURL
  80. $this->get('/getUserAllURL', App\Controllers\UserController::class . ':getUserAllURL');
  81. // getPcClient
  82. $this->get('/getPcClient', App\Controllers\UserController::class . ':getPcClient');
  83. //Reconstructed Payment System
  84. $this->post('/payment/purchase/{type}', App\Services\Payment::class . ':purchase');
  85. $this->get('/payment/purchase/{type}', App\Services\Payment::class . ':purchase');
  86. $this->get('/payment/return/{type}', App\Services\Payment::class . ':returnHTML');
  87. })->add(new Auth());
  88. $app->group('/payment', function (): void {
  89. $this->get('/notify/{type}', App\Services\Payment::class . ':notify');
  90. $this->post('/notify/{type}', App\Services\Payment::class . ':notify');
  91. $this->post('/status/{type}', App\Services\Payment::class . ':getStatus');
  92. // $this->post('/coinpay/notify', App\Services\CoinPayment::class. ':notify');
  93. });
  94. // Auth
  95. $app->group('/auth', function (): void {
  96. $this->get('/login', App\Controllers\AuthController::class . ':login');
  97. $this->post('/qrcode_check', App\Controllers\AuthController::class . ':qrcode_check');
  98. $this->post('/login', App\Controllers\AuthController::class . ':loginHandle');
  99. $this->post('/qrcode_login', App\Controllers\AuthController::class . ':qrcode_loginHandle');
  100. $this->get('/register', App\Controllers\AuthController::class . ':register');
  101. $this->post('/register', App\Controllers\AuthController::class . ':registerHandle');
  102. $this->post('/send', App\Controllers\AuthController::class . ':sendVerify');
  103. $this->get('/logout', App\Controllers\AuthController::class . ':logout');
  104. $this->get('/telegram_oauth', App\Controllers\AuthController::class . ':telegram_oauth');
  105. $this->get('/login_getCaptcha', App\Controllers\AuthController::class . ':getCaptcha');
  106. })->add(new Guest());
  107. // Password
  108. $app->group('/password', function (): void {
  109. $this->get('/reset', App\Controllers\PasswordController::class . ':reset');
  110. $this->post('/reset', App\Controllers\PasswordController::class . ':handleReset');
  111. $this->get('/token/{token}', App\Controllers\PasswordController::class . ':token');
  112. $this->post('/token/{token}', App\Controllers\PasswordController::class . ':handleToken');
  113. })->add(new Guest());
  114. // Admin
  115. $app->group('/admin', function (): void {
  116. $this->get('', App\Controllers\AdminController::class . ':index');
  117. $this->get('/', App\Controllers\AdminController::class . ':index');
  118. $this->get('/sys', App\Controllers\AdminController::class . ':sys');
  119. $this->get('/invite', App\Controllers\AdminController::class . ':invite');
  120. $this->post('/invite', App\Controllers\AdminController::class . ':addInvite');
  121. $this->post('/chginvite', App\Controllers\AdminController::class . ':chgInvite');
  122. $this->post('/payback/ajax', App\Controllers\AdminController::class . ':ajax_payback');
  123. // Node Mange
  124. $this->get('/node', App\Controllers\Admin\NodeController::class . ':index');
  125. $this->get('/node/create', App\Controllers\Admin\NodeController::class . ':create');
  126. $this->post('/node', App\Controllers\Admin\NodeController::class . ':add');
  127. $this->get('/node/{id}/edit', App\Controllers\Admin\NodeController::class . ':edit');
  128. $this->put('/node/{id}', App\Controllers\Admin\NodeController::class . ':update');
  129. $this->delete('/node', App\Controllers\Admin\NodeController::class . ':delete');
  130. $this->post('/node/ajax', App\Controllers\Admin\NodeController::class . ':ajax');
  131. // Ticket Mange
  132. $this->get('/ticket', App\Controllers\Admin\TicketController::class . ':index');
  133. $this->post('/ticket', App\Controllers\Admin\TicketController::class . ':add');
  134. $this->get('/ticket/{id}/view', App\Controllers\Admin\TicketController::class . ':show');
  135. $this->put('/ticket/{id}', App\Controllers\Admin\TicketController::class . ':update');
  136. $this->post('/ticket/ajax', App\Controllers\Admin\TicketController::class . ':ajax');
  137. // Shop Mange
  138. $this->get('/shop', App\Controllers\Admin\ShopController::class . ':index');
  139. $this->post('/shop/ajax', App\Controllers\Admin\ShopController::class . ':ajax_shop');
  140. $this->get('/shop/create', App\Controllers\Admin\ShopController::class . ':create');
  141. $this->post('/shop', App\Controllers\Admin\ShopController::class . ':add');
  142. $this->get('/shop/{id}/edit', App\Controllers\Admin\ShopController::class . ':edit');
  143. $this->put('/shop/{id}', App\Controllers\Admin\ShopController::class . ':update');
  144. $this->delete('/shop', App\Controllers\Admin\ShopController::class . ':deleteGet');
  145. // Bought Mange
  146. $this->get('/bought', App\Controllers\Admin\ShopController::class . ':bought');
  147. $this->delete('/bought', App\Controllers\Admin\ShopController::class . ':deleteBoughtGet');
  148. $this->post('/bought/ajax', App\Controllers\Admin\ShopController::class . ':ajax_bought');
  149. // Product
  150. $this->get('/product', App\Controllers\Admin\ProductController::class . ':index');
  151. $this->get('/product/create', App\Controllers\Admin\ProductController::class . ':create');
  152. $this->post('/product', App\Controllers\Admin\ProductController::class . ':save');
  153. $this->get('/product/{id}/edit', App\Controllers\Admin\ProductController::class . ':edit');
  154. $this->put('/product/{id}', App\Controllers\Admin\ProductController::class . ':update');
  155. $this->delete('/product/{id}', App\Controllers\Admin\ProductController::class . ':delete');
  156. // Ann Mange
  157. $this->get('/announcement', App\Controllers\Admin\AnnController::class . ':index');
  158. $this->get('/announcement/create', App\Controllers\Admin\AnnController::class . ':create');
  159. $this->post('/announcement', App\Controllers\Admin\AnnController::class . ':add');
  160. $this->get('/announcement/{id}/edit', App\Controllers\Admin\AnnController::class . ':edit');
  161. $this->put('/announcement/{id}', App\Controllers\Admin\AnnController::class . ':update');
  162. $this->delete('/announcement', App\Controllers\Admin\AnnController::class . ':delete');
  163. $this->post('/announcement/ajax', App\Controllers\Admin\AnnController::class . ':ajax');
  164. // Detect Mange
  165. $this->get('/detect', App\Controllers\Admin\DetectController::class . ':index');
  166. $this->get('/detect/create', App\Controllers\Admin\DetectController::class . ':create');
  167. $this->post('/detect', App\Controllers\Admin\DetectController::class . ':add');
  168. $this->get('/detect/{id}/edit', App\Controllers\Admin\DetectController::class . ':edit');
  169. $this->put('/detect/{id}', App\Controllers\Admin\DetectController::class . ':update');
  170. $this->delete('/detect', App\Controllers\Admin\DetectController::class . ':delete');
  171. $this->get('/detect/log', App\Controllers\Admin\DetectController::class . ':log');
  172. $this->post('/detect/ajax', App\Controllers\Admin\DetectController::class . ':ajax_rule');
  173. $this->post('/detect/log/ajax', App\Controllers\Admin\DetectController::class . ':ajax_log');
  174. // IP Mange
  175. $this->get('/block', App\Controllers\Admin\IpController::class . ':block');
  176. $this->get('/unblock', App\Controllers\Admin\IpController::class . ':unblock');
  177. $this->post('/unblock', App\Controllers\Admin\IpController::class . ':doUnblock');
  178. $this->get('/login', App\Controllers\Admin\IpController::class . ':index');
  179. $this->get('/alive', App\Controllers\Admin\IpController::class . ':alive');
  180. $this->post('/block/ajax', App\Controllers\Admin\IpController::class . ':ajax_block');
  181. $this->post('/unblock/ajax', App\Controllers\Admin\IpController::class . ':ajax_unblock');
  182. $this->post('/login/ajax', App\Controllers\Admin\IpController::class . ':ajax_login');
  183. $this->post('/alive/ajax', App\Controllers\Admin\IpController::class . ':ajax_alive');
  184. // Code Mange
  185. $this->get('/code', App\Controllers\Admin\CodeController::class . ':index');
  186. $this->get('/code/create', App\Controllers\Admin\CodeController::class . ':create');
  187. $this->post('/code', App\Controllers\Admin\CodeController::class . ':add');
  188. $this->get('/donate/create', App\Controllers\Admin\CodeController::class . ':donate_create');
  189. $this->post('/donate', App\Controllers\Admin\CodeController::class . ':donate_add');
  190. $this->post('/code/ajax', App\Controllers\Admin\CodeController::class . ':ajax_code');
  191. // User Mange
  192. $this->get('/user', App\Controllers\Admin\UserController::class . ':index');
  193. $this->get('/user/{id}/edit', App\Controllers\Admin\UserController::class . ':edit');
  194. $this->put('/user/{id}', App\Controllers\Admin\UserController::class . ':update');
  195. $this->delete('/user', App\Controllers\Admin\UserController::class . ':delete');
  196. $this->post('/user/changetouser', App\Controllers\Admin\UserController::class . ':changetouser');
  197. $this->post('/user/ajax', App\Controllers\Admin\UserController::class . ':ajax');
  198. $this->post('/user/create', App\Controllers\Admin\UserController::class . ':createNewUser');
  199. // Coupon Mange
  200. $this->get('/coupon', App\Controllers\AdminController::class . ':coupon');
  201. $this->post('/coupon', App\Controllers\AdminController::class . ':addCoupon');
  202. $this->post('/coupon/ajax', App\Controllers\AdminController::class . ':ajax_coupon');
  203. // Subscribe Log Mange
  204. $this->get('/subscribe', App\Controllers\Admin\SubscribeLogController::class . ':index');
  205. $this->post('/subscribe/ajax', App\Controllers\Admin\SubscribeLogController::class . ':ajax_subscribe_log');
  206. // Detect Ban Mange
  207. $this->get('/detect/ban', App\Controllers\Admin\DetectBanLogController::class . ':index');
  208. $this->post('/detect/ban/ajax', App\Controllers\Admin\DetectBanLogController::class . ':ajax_log');
  209. // 指定用户购买记录以及添加套餐
  210. $this->get('/user/{id}/bought', App\Controllers\Admin\UserLog\BoughtLogController::class . ':bought');
  211. $this->post('/user/{id}/bought/ajax', App\Controllers\Admin\UserLog\BoughtLogController::class . ':bought_ajax');
  212. $this->delete('/user/bought', App\Controllers\Admin\UserLog\BoughtLogController::class . ':bought_delete');
  213. $this->post('/user/{id}/bought/buy', App\Controllers\Admin\UserLog\BoughtLogController::class . ':bought_add');
  214. // 指定用户充值记录
  215. $this->get('/user/{id}/code', App\Controllers\Admin\UserLog\CodeLogController::class . ':index');
  216. $this->post('/user/{id}/code/ajax', App\Controllers\Admin\UserLog\CodeLogController::class . ':ajax');
  217. // 指定用户订阅记录
  218. $this->get('/user/{id}/sublog', App\Controllers\Admin\UserLog\SubLogController::class . ':index');
  219. $this->post('/user/{id}/sublog/ajax', App\Controllers\Admin\UserLog\SubLogController::class . ':ajax');
  220. // 指定用户审计记录
  221. $this->get('/user/{id}/detect', App\Controllers\Admin\UserLog\DetectLogController::class . ':index');
  222. $this->post('/user/{id}/detect/ajax', App\Controllers\Admin\UserLog\DetectLogController::class . ':ajax');
  223. // 指定用户登录记录
  224. $this->get('/user/{id}/login', App\Controllers\Admin\UserLog\LoginLogController::class . ':index');
  225. $this->post('/user/{id}/login/ajax', App\Controllers\Admin\UserLog\LoginLogController::class . ':ajax');
  226. // 设置中心
  227. $this->get('/setting', App\Controllers\Admin\SettingController::class . ':index');
  228. $this->post('/setting', App\Controllers\Admin\SettingController::class . ':save');
  229. $this->post('/setting/email', App\Controllers\Admin\SettingController::class . ':test');
  230. $this->post('/setting/payment', App\Controllers\Admin\SettingController::class . ':payment');
  231. // Config Mange
  232. $this->group('/config', function (): void {
  233. $this->put('/update/{key}', App\Controllers\Admin\GConfigController::class . ':update');
  234. $this->get('/update/{key}/edit', App\Controllers\Admin\GConfigController::class . ':edit');
  235. $this->get('/telegram', App\Controllers\Admin\GConfigController::class . ':telegram');
  236. $this->post('/telegram/ajax', App\Controllers\Admin\GConfigController::class . ':telegram_ajax');
  237. });
  238. })->add(new Admin());
  239. if ($_ENV['enableAdminApi']) {
  240. $app->group('/admin/api', function (): void {
  241. $this->get('/nodes', App\Controllers\Admin\ApiController::class . ':getNodeList');
  242. $this->get('/node/{id}', App\Controllers\Admin\ApiController::class . ':getNodeInfo');
  243. $this->get('/ping', App\Controllers\Admin\ApiController::class . ':ping');
  244. // Re-bind controller, bypass admin token require
  245. $this->post('/node', App\Controllers\Admin\NodeController::class . ':add');
  246. $this->put('/node/{id}', App\Controllers\Admin\NodeController::class . ':update');
  247. $this->delete('/node', App\Controllers\Admin\NodeController::class . ':delete');
  248. })->add(new AuthorizationBearer($_ENV['adminApiToken']));
  249. }
  250. // mu
  251. $app->group('/mod_mu', function (): void {
  252. // 流媒体检测
  253. $this->post('/media/saveReport', App\Controllers\Mod_Mu\NodeController::class . ':saveReport');
  254. // 其他
  255. $this->get('/nodes/{id}/info', App\Controllers\Mod_Mu\NodeController::class . ':get_info');
  256. $this->post('/nodes/{id}/info', App\Controllers\Mod_Mu\NodeController::class . ':info');
  257. $this->get('/nodes', App\Controllers\Mod_Mu\NodeController::class . ':get_all_info');
  258. $this->post('/nodes/config', App\Controllers\Mod_Mu\NodeController::class . ':getConfig');
  259. $this->get('/users', App\Controllers\Mod_Mu\UserController::class . ':index');
  260. $this->post('/users/traffic', App\Controllers\Mod_Mu\UserController::class . ':addTraffic');
  261. $this->post('/users/aliveip', App\Controllers\Mod_Mu\UserController::class . ':addAliveIp');
  262. $this->post('/users/detectlog', App\Controllers\Mod_Mu\UserController::class . ':addDetectLog');
  263. $this->get('/func/detect_rules', App\Controllers\Mod_Mu\FuncController::class . ':get_detect_logs');
  264. $this->post('/func/block_ip', App\Controllers\Mod_Mu\FuncController::class . ':addBlockIp');
  265. $this->get('/func/block_ip', App\Controllers\Mod_Mu\FuncController::class . ':get_blockip');
  266. $this->get('/func/unblock_ip', App\Controllers\Mod_Mu\FuncController::class . ':get_unblockip');
  267. $this->get('/func/ping', App\Controllers\Mod_Mu\FuncController::class . ':ping');
  268. //============================================
  269. })->add(new Mod_Mu());
  270. $app->group('/link', function (): void {
  271. $this->get('/{token}', App\Controllers\LinkController::class . ':GetContent');
  272. });
  273. //通用訂閲
  274. $app->group('/sub', function (): void {
  275. $this->get('/{token}/{subtype}', App\Controllers\SubController::class . ':getContent');
  276. });
  277. $app->group('/getClient', function (): void {
  278. $this->get('/{token}', App\Controllers\UserController::class . ':getClientfromToken');
  279. });
  280. };