routes.php 19 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319
  1. <?php
  2. declare(strict_types=1);
  3. use App\Middleware\Admin;
  4. use App\Middleware\Auth;
  5. use App\Middleware\Guest;
  6. use App\Middleware\NodeToken;
  7. use Slim\App as SlimApp;
  8. return function (SlimApp $app): void {
  9. // Home
  10. $app->get('/', App\Controllers\HomeController::class . ':index');
  11. $app->get('/404', App\Controllers\HomeController::class . ':page404');
  12. $app->get('/405', App\Controllers\HomeController::class . ':page405');
  13. $app->get('/500', App\Controllers\HomeController::class . ':page500');
  14. $app->get('/tos', App\Controllers\HomeController::class . ':tos');
  15. $app->get('/staff', App\Controllers\HomeController::class . ':staff');
  16. // other
  17. $app->post('/notify', App\Controllers\HomeController::class . ':notify');
  18. // Telegram
  19. $app->post('/telegram_callback', App\Controllers\HomeController::class . ':telegram');
  20. // User Center
  21. $app->group('/user', function (): void {
  22. $this->get('', App\Controllers\UserController::class . ':index');
  23. $this->get('/', App\Controllers\UserController::class . ':index');
  24. // 签到
  25. $this->post('/checkin', App\Controllers\UserController::class . ':doCheckin');
  26. // 公告
  27. $this->get('/announcement', App\Controllers\UserController::class . ':announcement');
  28. // 文档
  29. $this->get('/docs', App\Controllers\UserController::class . ':docs');
  30. //流媒体解锁
  31. $this->get('/media', App\Controllers\UserController::class . ':media');
  32. $this->get('/profile', App\Controllers\UserController::class . ':profile');
  33. $this->get('/invite', App\Controllers\UserController::class . ':invite');
  34. // 封禁
  35. $this->get('/banned', App\Controllers\UserController::class . ':banned');
  36. // 节点
  37. $this->get('/server', App\Controllers\User\ServerController::class . ':userServerPage');
  38. // 审计
  39. $this->get('/detect', App\Controllers\User\DetectController::class . ':index');
  40. $this->get('/detect/log', App\Controllers\User\DetectController::class . ':log');
  41. $this->get('/shop', App\Controllers\User\ShopController::class . ':shop');
  42. $this->post('/coupon_check', App\Controllers\User\ShopController::class . ':couponCheck');
  43. $this->post('/buy', App\Controllers\User\ShopController::class . ':buy');
  44. $this->post('/buy_traffic_package', App\Controllers\User\ShopController::class . ':buyTrafficPackage');
  45. // 工单
  46. $this->get('/ticket', App\Controllers\User\TicketController::class . ':ticket');
  47. $this->get('/ticket/create', App\Controllers\User\TicketController::class . ':ticketCreate');
  48. $this->post('/ticket', App\Controllers\User\TicketController::class . ':ticketAdd');
  49. $this->get('/ticket/{id}/view', App\Controllers\User\TicketController::class . ':ticketView');
  50. $this->put('/ticket/{id}', App\Controllers\User\TicketController::class . ':ticketUpdate');
  51. $this->post('/buy_invite', App\Controllers\UserController::class . ':buyInvite');
  52. $this->post('/custom_invite', App\Controllers\UserController::class . ':customInvite');
  53. $this->get('/edit', App\Controllers\UserController::class . ':edit');
  54. $this->post('/email', App\Controllers\UserController::class . ':updateEmail');
  55. $this->post('/username', App\Controllers\UserController::class . ':updateUsername');
  56. $this->post('/password', App\Controllers\UserController::class . ':updatePassword');
  57. $this->post('/send', App\Controllers\AuthController::class . ':sendVerify');
  58. $this->post('/contact_update', App\Controllers\UserController::class . ':updateContact');
  59. $this->post('/theme', App\Controllers\UserController::class . ':updateTheme');
  60. $this->post('/mail', App\Controllers\UserController::class . ':updateMail');
  61. $this->post('/passwd_reset', App\Controllers\UserController::class . ':resetPasswd');
  62. $this->post('/method', App\Controllers\UserController::class . ':updateMethod');
  63. $this->get('/kill', App\Controllers\UserController::class . ':kill');
  64. $this->post('/kill', App\Controllers\UserController::class . ':handleKill');
  65. $this->get('/logout', App\Controllers\UserController::class . ':logout');
  66. $this->get('/backtoadmin', App\Controllers\UserController::class . ':backtoadmin');
  67. $this->get('/code', App\Controllers\UserController::class . ':code');
  68. $this->get('/code_check', App\Controllers\UserController::class . ':codeCheck');
  69. $this->post('/code', App\Controllers\UserController::class . ':codePost');
  70. $this->post('/ga_check', App\Controllers\UserController::class . ':checkGa');
  71. $this->post('/ga_set', App\Controllers\UserController::class . ':setGa');
  72. $this->get('/ga_reset', App\Controllers\UserController::class . ':resetGa');
  73. $this->post('/telegram_reset', App\Controllers\UserController::class . ':resetTelegram');
  74. $this->post('/unblock', App\Controllers\UserController::class . ':unblock');
  75. $this->get('/bought', App\Controllers\UserController::class . ':bought');
  76. $this->delete('/bought', App\Controllers\UserController::class . ':deleteBoughtGet');
  77. $this->post('/url_reset', App\Controllers\UserController::class . ':resetURL');
  78. $this->put('/invite', App\Controllers\UserController::class . ':resetInviteURL');
  79. //深色模式
  80. $this->post('/switch_theme_mode', App\Controllers\UserController::class . ':switchThemeMode');
  81. // 订阅记录
  82. $this->get('/subscribe_log', App\Controllers\UserController::class . ':subscribeLog');
  83. // getUserAllURL
  84. $this->get('/getUserAllURL', App\Controllers\UserController::class . ':getUserAllURL');
  85. // 支付
  86. $this->post('/payment/purchase/{type}', App\Services\Payment::class . ':purchase');
  87. $this->get('/payment/purchase/{type}', App\Services\Payment::class . ':purchase');
  88. $this->get('/payment/return/{type}', App\Services\Payment::class . ':returnHTML');
  89. })->add(new Auth());
  90. $app->group('/payment', function (): void {
  91. $this->get('/notify/{type}', App\Services\Payment::class . ':notify');
  92. $this->post('/notify/{type}', App\Services\Payment::class . ':notify');
  93. $this->post('/status/{type}', App\Services\Payment::class . ':getStatus');
  94. });
  95. // Auth
  96. $app->group('/auth', function (): void {
  97. $this->get('/login', App\Controllers\AuthController::class . ':login');
  98. $this->post('/qrcode_check', App\Controllers\AuthController::class . ':qrcodeCheck');
  99. $this->post('/login', App\Controllers\AuthController::class . ':loginHandle');
  100. $this->post('/qrcode_login', App\Controllers\AuthController::class . ':qrcodeLoginHandle');
  101. $this->get('/register', App\Controllers\AuthController::class . ':register');
  102. $this->post('/register', App\Controllers\AuthController::class . ':registerHandle');
  103. $this->post('/send', App\Controllers\AuthController::class . ':sendVerify');
  104. $this->get('/logout', App\Controllers\AuthController::class . ':logout');
  105. $this->get('/telegram_oauth', App\Controllers\AuthController::class . ':telegramOauth');
  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 . ':ajaxPayback');
  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->post('/node/{id}/password_reset', App\Controllers\Admin\NodeController::class . ':resetNodePassword');
  129. $this->post('/node/{id}/copy', App\Controllers\Admin\NodeController::class . ':copy');
  130. $this->put('/node/{id}', App\Controllers\Admin\NodeController::class . ':update');
  131. $this->delete('/node/{id}', App\Controllers\Admin\NodeController::class . ':delete');
  132. $this->post('/node/ajax', App\Controllers\Admin\NodeController::class . ':ajax');
  133. // Ticket Mange
  134. $this->get('/ticket', App\Controllers\Admin\TicketController::class . ':index');
  135. $this->post('/ticket', App\Controllers\Admin\TicketController::class . ':add');
  136. $this->get('/ticket/{id}/view', App\Controllers\Admin\TicketController::class . ':ticketView');
  137. $this->put('/ticket/{id}/close', App\Controllers\Admin\TicketController::class . ':close');
  138. $this->put('/ticket/{id}', App\Controllers\Admin\TicketController::class . ':update');
  139. $this->delete('/ticket/{id}', App\Controllers\Admin\TicketController::class . ':delete');
  140. $this->post('/ticket/ajax', App\Controllers\Admin\TicketController::class . ':ajax');
  141. // Shop Mange
  142. $this->get('/shop', App\Controllers\Admin\ShopController::class . ':index');
  143. $this->post('/shop/ajax', App\Controllers\Admin\ShopController::class . ':ajaxShop');
  144. $this->get('/shop/create', App\Controllers\Admin\ShopController::class . ':create');
  145. $this->post('/shop', App\Controllers\Admin\ShopController::class . ':add');
  146. $this->get('/shop/{id}/edit', App\Controllers\Admin\ShopController::class . ':edit');
  147. $this->put('/shop/{id}', App\Controllers\Admin\ShopController::class . ':update');
  148. $this->delete('/shop', App\Controllers\Admin\ShopController::class . ':deleteGet');
  149. // Bought Mange
  150. $this->get('/bought', App\Controllers\Admin\ShopController::class . ':bought');
  151. $this->delete('/bought', App\Controllers\Admin\ShopController::class . ':deleteBoughtGet');
  152. $this->post('/bought/ajax', App\Controllers\Admin\ShopController::class . ':ajaxBought');
  153. // Ann Mange
  154. $this->get('/announcement', App\Controllers\Admin\AnnController::class . ':index');
  155. $this->get('/announcement/create', App\Controllers\Admin\AnnController::class . ':create');
  156. $this->post('/announcement', App\Controllers\Admin\AnnController::class . ':add');
  157. $this->get('/announcement/{id}/edit', App\Controllers\Admin\AnnController::class . ':edit');
  158. $this->put('/announcement/{id}', App\Controllers\Admin\AnnController::class . ':update');
  159. $this->delete('/announcement/{id}', App\Controllers\Admin\AnnController::class . ':delete');
  160. $this->post('/announcement/ajax', App\Controllers\Admin\AnnController::class . ':ajax');
  161. // Detect Mange
  162. $this->get('/detect', App\Controllers\Admin\DetectController::class . ':index');
  163. $this->get('/detect/create', App\Controllers\Admin\DetectController::class . ':create');
  164. $this->post('/detect', App\Controllers\Admin\DetectController::class . ':add');
  165. $this->get('/detect/{id}/edit', App\Controllers\Admin\DetectController::class . ':edit');
  166. $this->put('/detect/{id}', App\Controllers\Admin\DetectController::class . ':update');
  167. $this->delete('/detect', App\Controllers\Admin\DetectController::class . ':delete');
  168. $this->get('/detect/log', App\Controllers\Admin\DetectController::class . ':log');
  169. $this->post('/detect/ajax', App\Controllers\Admin\DetectController::class . ':ajaxRule');
  170. $this->post('/detect/log/ajax', App\Controllers\Admin\DetectController::class . ':ajaxLog');
  171. // IP Mange
  172. $this->get('/login', App\Controllers\Admin\IpController::class . ':login');
  173. $this->get('/alive', App\Controllers\Admin\IpController::class . ':alive');
  174. $this->post('/login/ajax', App\Controllers\Admin\IpController::class . ':ajaxLogin');
  175. $this->post('/alive/ajax', App\Controllers\Admin\IpController::class . ':ajaxAlive');
  176. // Code Mange
  177. $this->get('/code', App\Controllers\Admin\CodeController::class . ':index');
  178. $this->get('/code/create', App\Controllers\Admin\CodeController::class . ':create');
  179. $this->post('/code', App\Controllers\Admin\CodeController::class . ':add');
  180. $this->post('/code/ajax', App\Controllers\Admin\CodeController::class . ':ajaxCode');
  181. // User Mange
  182. $this->get('/user', App\Controllers\Admin\UserController::class . ':index');
  183. $this->get('/user/{id}/edit', App\Controllers\Admin\UserController::class . ':edit');
  184. $this->put('/user/{id}', App\Controllers\Admin\UserController::class . ':update');
  185. $this->post('/user/changetouser', App\Controllers\Admin\UserController::class . ':changetouser');
  186. $this->post('/user/create', App\Controllers\Admin\UserController::class . ':createNewUser');
  187. $this->delete('/user/{id}', App\Controllers\Admin\UserController::class . ':delete');
  188. $this->post('/user/ajax', App\Controllers\Admin\UserController::class . ':ajax');
  189. // Coupon Mange
  190. $this->get('/coupon', App\Controllers\Admin\CouponController::class . ':index');
  191. $this->post('/coupon', App\Controllers\Admin\CouponController::class . ':add');
  192. $this->post('/coupon/ajax', App\Controllers\Admin\CouponController::class . ':ajax');
  193. $this->delete('/coupon/{id}', App\Controllers\Admin\CouponController::class . ':delete');
  194. // Subscribe Log Mange
  195. $this->get('/subscribe', App\Controllers\Admin\SubscribeLogController::class . ':index');
  196. $this->post('/subscribe/ajax', App\Controllers\Admin\SubscribeLogController::class . ':ajaxSubscribeLog');
  197. // Traffic Log Mange
  198. $this->get('/trafficlog', App\Controllers\Admin\TrafficLogController::class . ':index');
  199. $this->post('/trafficlog/ajax', App\Controllers\Admin\TrafficLogController::class . ':ajaxTrafficLog');
  200. // Detect Ban Mange
  201. $this->get('/detect/ban', App\Controllers\Admin\DetectBanLogController::class . ':index');
  202. $this->post('/detect/ban/ajax', App\Controllers\Admin\DetectBanLogController::class . ':ajaxLog');
  203. // 设置中心
  204. $this->get('/setting', App\Controllers\Admin\SettingController::class . ':index');
  205. $this->post('/setting', App\Controllers\Admin\SettingController::class . ':save');
  206. $this->post('/setting/email', App\Controllers\Admin\SettingController::class . ':test');
  207. $this->post('/setting/payment', App\Controllers\Admin\SettingController::class . ':payment');
  208. // 礼品卡
  209. $this->get('/giftcard', App\Controllers\Admin\GiftCardController::class . ':index');
  210. $this->post('/giftcard', App\Controllers\Admin\GiftCardController::class . ':add');
  211. $this->post('/giftcard/ajax', App\Controllers\Admin\GiftCardController::class . ':ajax');
  212. $this->delete('/giftcard/{id}', App\Controllers\Admin\GiftCardController::class . ':delete');
  213. // 商品
  214. $this->get('/product', App\Controllers\Admin\ProductController::class . ':index');
  215. $this->get('/product/create', App\Controllers\Admin\ProductController::class . ':create');
  216. $this->post('/product', App\Controllers\Admin\ProductController::class . ':add');
  217. $this->get('/product/{id}/edit', App\Controllers\Admin\ProductController::class . ':edit');
  218. $this->post('/product/{id}/copy', App\Controllers\Admin\ProductController::class . ':copy');
  219. $this->put('/product/{id}', App\Controllers\Admin\ProductController::class . ':update');
  220. $this->delete('/product/{id}', App\Controllers\Admin\ProductController::class . ':delete');
  221. $this->post('/product/ajax', App\Controllers\Admin\ProductController::class . ':ajax');
  222. // 订单
  223. $this->get('/order', App\Controllers\Admin\OrderController::class . ':index');
  224. $this->get('/order/{id}/view', App\Controllers\Admin\OrderController::class . ':detail');
  225. $this->post('/order/{id}/cancel', App\Controllers\Admin\OrderController::class . ':cancel');
  226. $this->delete('/order/{id}', App\Controllers\Admin\OrderController::class . ':delete');
  227. $this->post('/order/ajax', App\Controllers\Admin\OrderController::class . ':ajax');
  228. // 账单
  229. $this->get('/invoice', App\Controllers\Admin\InvoiceController::class . ':index');
  230. $this->get('/invoice/{id}/view', App\Controllers\Admin\InvoiceController::class . ':detail');
  231. $this->post('/invoice/{id}/mark_paid', App\Controllers\Admin\InvoiceController::class . ':markPaid');
  232. $this->post('/invoice/ajax', App\Controllers\Admin\InvoiceController::class . ':ajax');
  233. })->add(new Admin());
  234. //$app->group('/admin/api', function (): void {
  235. // $this->post('/{action}', App\Controllers\Api\AdminApiController::class . ':actionHandler');
  236. //})->add(new AdminApiToken());
  237. //$app->group('/user/api', function (): void {
  238. // $this->post('/{action}', App\Controllers\Api\UserApiController::class . ':actionHandler');
  239. //})->add(new UserApiToken());
  240. // WebAPI
  241. $app->group('/mod_mu', function (): void {
  242. // 流媒体检测
  243. $this->post('/media/save_report', App\Controllers\WebAPI\NodeController::class . ':saveReport');
  244. // 节点
  245. $this->get('/nodes/{id}/info', App\Controllers\WebAPI\NodeController::class . ':getInfo');
  246. // 用户
  247. $this->get('/users', App\Controllers\WebAPI\UserController::class . ':index');
  248. $this->post('/users/traffic', App\Controllers\WebAPI\UserController::class . ':addTraffic');
  249. $this->post('/users/aliveip', App\Controllers\WebAPI\UserController::class . ':addAliveIp');
  250. $this->post('/users/detectlog', App\Controllers\WebAPI\UserController::class . ':addDetectLog');
  251. // 审计 & 杂七杂八的功能
  252. $this->get('/func/detect_rules', App\Controllers\WebAPI\FuncController::class . ':getDetectLogs');
  253. $this->get('/func/ping', App\Controllers\WebAPI\FuncController::class . ':ping');
  254. // Dummy API for old version
  255. $this->get('/nodes', App\Controllers\WebAPI\NodeController::class . ':getAllInfo');
  256. $this->post('/func/block_ip', App\Controllers\WebAPI\FuncController::class . ':addBlockIp');
  257. $this->get('/func/block_ip', App\Controllers\WebAPI\FuncController::class . ':getBlockip');
  258. $this->get('/func/unblock_ip', App\Controllers\WebAPI\FuncController::class . ':getUnblockip');
  259. $this->post('/nodes/{id}/info', App\Controllers\WebAPI\NodeController::class . ':info');
  260. })->add(new NodeToken());
  261. // 传统订阅(SS/V2Ray/Trojan etc.)
  262. $app->group('/link', function (): void {
  263. $this->get('/{token}', App\Controllers\LinkController::class . ':getContent');
  264. });
  265. // 通用订阅(Json/Clash)
  266. $app->group('/sub', function (): void {
  267. $this->get('/{token}/{subtype}', App\Controllers\SubController::class . ':getContent');
  268. });
  269. };