routes.php 21 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294
  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\Routing\RouteCollectorProxy;
  8. return static function (Slim\App $app): void {
  9. // Home
  10. $app->get('/', App\Controllers\HomeController::class . ':index');
  11. $app->get('/tos', App\Controllers\HomeController::class . ':tos');
  12. $app->get('/staff', App\Controllers\HomeController::class . ':staff');
  13. // Error Page
  14. $app->get('/404', App\Controllers\HomeController::class . ':notFound');
  15. $app->get('/405', App\Controllers\HomeController::class . ':methodNotAllowed');
  16. $app->get('/500', App\Controllers\HomeController::class . ':internalServerError');
  17. // Telegram
  18. $app->post('/telegram_callback', App\Controllers\HomeController::class . ':telegram');
  19. // User Center
  20. $app->group('/user', static function (RouteCollectorProxy $group): void {
  21. $group->get('', App\Controllers\UserController::class . ':index');
  22. $group->get('/', App\Controllers\UserController::class . ':index');
  23. // 签到
  24. $group->post('/checkin', App\Controllers\UserController::class . ':doCheckin');
  25. // 公告
  26. $group->get('/announcement', App\Controllers\UserController::class . ':announcement');
  27. // 文档
  28. $group->get('/docs', App\Controllers\User\DocsController::class . ':index');
  29. $group->get('/docs/{id}/view', App\Controllers\User\DocsController::class . ':detail');
  30. // 个人资料
  31. $group->get('/profile', App\Controllers\UserController::class . ':profile');
  32. $group->get('/invite', App\Controllers\UserController::class . ':invite');
  33. // 封禁
  34. $group->get('/banned', App\Controllers\UserController::class . ':banned');
  35. // 节点
  36. $group->get('/server', App\Controllers\User\ServerController::class . ':server');
  37. // 审计
  38. $group->get('/detect', App\Controllers\User\DetectController::class . ':index');
  39. // 工单
  40. $group->get('/ticket', App\Controllers\User\TicketController::class . ':ticket');
  41. $group->get('/ticket/create', App\Controllers\User\TicketController::class . ':ticketCreate');
  42. $group->post('/ticket', App\Controllers\User\TicketController::class . ':ticketAdd');
  43. $group->get('/ticket/{id}/view', App\Controllers\User\TicketController::class . ':ticketView');
  44. $group->put('/ticket/{id}', App\Controllers\User\TicketController::class . ':ticketUpdate');
  45. // 资料编辑
  46. $group->get('/edit', App\Controllers\User\InfoController::class . ':index');
  47. $group->post('/email', App\Controllers\User\InfoController::class . ':updateEmail');
  48. $group->post('/username', App\Controllers\User\InfoController::class . ':updateUsername');
  49. $group->post('/password', App\Controllers\User\InfoController::class . ':updatePassword');
  50. $group->post('/contact_update', App\Controllers\User\InfoController::class . ':updateContact');
  51. $group->post('/theme', App\Controllers\User\InfoController::class . ':updateTheme');
  52. $group->post('/daily_mail', App\Controllers\User\InfoController::class . ':updateDailyMail');
  53. $group->post('/passwd_reset', App\Controllers\User\InfoController::class . ':resetPasswd');
  54. $group->post('/apitoken_reset', App\Controllers\User\InfoController::class . ':resetApiToken');
  55. $group->post('/method', App\Controllers\User\InfoController::class . ':updateMethod');
  56. $group->post('/url_reset', App\Controllers\User\InfoController::class . ':resetURL');
  57. $group->put('/invite', App\Controllers\User\InfoController::class . ':resetInviteURL');
  58. $group->post('/kill', App\Controllers\User\InfoController::class . ':sendToGulag');
  59. // 发送验证邮件
  60. $group->post('/send', App\Controllers\AuthController::class . ':sendVerify');
  61. // 登出
  62. $group->get('/logout', App\Controllers\UserController::class . ':logout');
  63. // MFA
  64. $group->post('/ga_check', App\Controllers\User\MFAController::class . ':checkGa');
  65. $group->post('/ga_set', App\Controllers\User\MFAController::class . ':setGa');
  66. $group->post('/ga_reset', App\Controllers\User\MFAController::class . ':resetGa');
  67. // Telegram
  68. $group->post('/telegram_reset', App\Controllers\UserController::class . ':resetTelegram');
  69. // 深色模式切换
  70. $group->post('/switch_theme_mode', App\Controllers\UserController::class . ':switchThemeMode');
  71. // 记录
  72. $group->get('/subscribe/log', App\Controllers\User\LogController::class . ':subscribe');
  73. $group->get('/detect/log', App\Controllers\User\LogController::class . ':detect');
  74. // 账户余额
  75. $group->get('/money', App\Controllers\User\MoneyController::class . ':money');
  76. // 礼品卡兑换
  77. $group->post('/giftcard', App\Controllers\User\MoneyController::class . ':applyGiftCard');
  78. // 产品页面
  79. $group->get('/product', App\Controllers\User\ProductController::class . ':product');
  80. // 订单页面
  81. $group->get('/order', App\Controllers\User\OrderController::class . ':order');
  82. $group->get('/order/create', App\Controllers\User\OrderController::class . ':create');
  83. $group->post('/order/create', App\Controllers\User\OrderController::class . ':process');
  84. $group->get('/order/{id}/view', App\Controllers\User\OrderController::class . ':detail');
  85. $group->post('/order/ajax', App\Controllers\User\OrderController::class . ':ajax');
  86. // 账单页面
  87. $group->get('/invoice', App\Controllers\User\InvoiceController::class . ':invoice');
  88. $group->get('/invoice/{id}/view', App\Controllers\User\InvoiceController::class . ':detail');
  89. $group->post('/invoice/pay_balance', App\Controllers\User\InvoiceController::class . ':payBalance');
  90. $group->post('/invoice/ajax', App\Controllers\User\InvoiceController::class . ':ajax');
  91. // 新优惠码系统
  92. $group->post('/coupon', App\Controllers\User\CouponController::class . ':check');
  93. // 支付
  94. $group->post('/payment/purchase/{type}', App\Services\Payment::class . ':purchase');
  95. $group->get('/payment/purchase/{type}', App\Services\Payment::class . ':purchase');
  96. $group->get('/payment/return/{type}', App\Services\Payment::class . ':returnHTML');
  97. // Get Clients
  98. $group->get('/clients/{name}', App\Controllers\User\ClientController::class . ':getClients');
  99. })->add(new Auth());
  100. $app->group('/payment', static function (RouteCollectorProxy $group): void {
  101. $group->get('/notify/{type}', App\Services\Payment::class . ':notify');
  102. $group->post('/notify/{type}', App\Services\Payment::class . ':notify');
  103. $group->post('/status/{type}', App\Services\Payment::class . ':getStatus');
  104. });
  105. // Auth
  106. $app->group('/auth', static function (RouteCollectorProxy $group): void {
  107. $group->get('/login', App\Controllers\AuthController::class . ':login');
  108. $group->post('/login', App\Controllers\AuthController::class . ':loginHandle');
  109. $group->get('/register', App\Controllers\AuthController::class . ':register');
  110. $group->post('/register', App\Controllers\AuthController::class . ':registerHandle');
  111. $group->post('/send', App\Controllers\AuthController::class . ':sendVerify');
  112. $group->get('/logout', App\Controllers\AuthController::class . ':logout');
  113. })->add(new Guest());
  114. // Password
  115. $app->group('/password', static function (RouteCollectorProxy $group): void {
  116. $group->get('/reset', App\Controllers\PasswordController::class . ':reset');
  117. $group->post('/reset', App\Controllers\PasswordController::class . ':handleReset');
  118. $group->get('/token/{token}', App\Controllers\PasswordController::class . ':token');
  119. $group->post('/token/{token}', App\Controllers\PasswordController::class . ':handleToken');
  120. })->add(new Guest());
  121. // Admin
  122. $app->group('/admin', static function (RouteCollectorProxy $group): void {
  123. $group->get('', App\Controllers\AdminController::class . ':index');
  124. $group->get('/', App\Controllers\AdminController::class . ':index');
  125. // Node
  126. $group->get('/node', App\Controllers\Admin\NodeController::class . ':index');
  127. $group->get('/node/create', App\Controllers\Admin\NodeController::class . ':create');
  128. $group->post('/node', App\Controllers\Admin\NodeController::class . ':add');
  129. $group->get('/node/{id}/edit', App\Controllers\Admin\NodeController::class . ':edit');
  130. $group->post('/node/{id}/password_reset', App\Controllers\Admin\NodeController::class . ':resetNodePassword');
  131. $group->post('/node/{id}/copy', App\Controllers\Admin\NodeController::class . ':copy');
  132. $group->put('/node/{id}', App\Controllers\Admin\NodeController::class . ':update');
  133. $group->delete('/node/{id}', App\Controllers\Admin\NodeController::class . ':delete');
  134. $group->post('/node/ajax', App\Controllers\Admin\NodeController::class . ':ajax');
  135. // Ticket
  136. $group->get('/ticket', App\Controllers\Admin\TicketController::class . ':index');
  137. $group->post('/ticket', App\Controllers\Admin\TicketController::class . ':add');
  138. $group->get('/ticket/{id}/view', App\Controllers\Admin\TicketController::class . ':ticketView');
  139. $group->put('/ticket/{id}/close', App\Controllers\Admin\TicketController::class . ':close');
  140. $group->put('/ticket/{id}', App\Controllers\Admin\TicketController::class . ':update');
  141. $group->put('/ticket/{id}/ai', App\Controllers\Admin\TicketController::class . ':updateAI');
  142. $group->delete('/ticket/{id}', App\Controllers\Admin\TicketController::class . ':delete');
  143. $group->post('/ticket/ajax', App\Controllers\Admin\TicketController::class . ':ajax');
  144. // Ann
  145. $group->get('/announcement', App\Controllers\Admin\AnnController::class . ':index');
  146. $group->get('/announcement/create', App\Controllers\Admin\AnnController::class . ':create');
  147. $group->post('/announcement', App\Controllers\Admin\AnnController::class . ':add');
  148. $group->get('/announcement/{id}/edit', App\Controllers\Admin\AnnController::class . ':edit');
  149. $group->put('/announcement/{id}', App\Controllers\Admin\AnnController::class . ':update');
  150. $group->delete('/announcement/{id}', App\Controllers\Admin\AnnController::class . ':delete');
  151. $group->post('/announcement/ajax', App\Controllers\Admin\AnnController::class . ':ajax');
  152. // Docs
  153. $group->get('/docs', App\Controllers\Admin\DocsController::class . ':index');
  154. $group->get('/docs/create', App\Controllers\Admin\DocsController::class . ':create');
  155. $group->post('/docs', App\Controllers\Admin\DocsController::class . ':add');
  156. $group->post('/docs/generate', App\Controllers\Admin\DocsController::class . ':generate');
  157. $group->get('/docs/{id}/edit', App\Controllers\Admin\DocsController::class . ':edit');
  158. $group->put('/docs/{id}', App\Controllers\Admin\DocsController::class . ':update');
  159. $group->delete('/docs/{id}', App\Controllers\Admin\DocsController::class . ':delete');
  160. $group->post('/docs/ajax', App\Controllers\Admin\DocsController::class . ':ajax');
  161. // 审计
  162. $group->get('/detect', App\Controllers\Admin\DetectController::class . ':detect');
  163. $group->get('/detect/create', App\Controllers\Admin\DetectController::class . ':create');
  164. $group->post('/detect/add', App\Controllers\Admin\DetectController::class . ':add');
  165. $group->delete('/detect/{id}', App\Controllers\Admin\DetectController::class . ':delete');
  166. $group->post('/detect/ajax', App\Controllers\Admin\DetectController::class . ':ajaxRule');
  167. $group->get('/detect/log', App\Controllers\Admin\DetectController::class . ':log');
  168. $group->post('/detect/log/ajax', App\Controllers\Admin\DetectController::class . ':ajaxLog');
  169. $group->get('/detect/ban', App\Controllers\Admin\DetectController::class . ':ban');
  170. $group->post('/detect/ban/ajax', App\Controllers\Admin\DetectController::class . ':ajaxBan');
  171. // User
  172. $group->get('/user', App\Controllers\Admin\UserController::class . ':index');
  173. $group->get('/user/{id}/edit', App\Controllers\Admin\UserController::class . ':edit');
  174. $group->put('/user/{id}', App\Controllers\Admin\UserController::class . ':update');
  175. $group->post('/user/create', App\Controllers\Admin\UserController::class . ':createNewUser');
  176. $group->delete('/user/{id}', App\Controllers\Admin\UserController::class . ':delete');
  177. $group->post('/user/ajax', App\Controllers\Admin\UserController::class . ':ajax');
  178. // Coupon
  179. $group->get('/coupon', App\Controllers\Admin\CouponController::class . ':index');
  180. $group->post('/coupon', App\Controllers\Admin\CouponController::class . ':add');
  181. $group->post('/coupon/ajax', App\Controllers\Admin\CouponController::class . ':ajax');
  182. $group->delete('/coupon/{id}', App\Controllers\Admin\CouponController::class . ':delete');
  183. $group->post('/coupon/{id}/disable', App\Controllers\Admin\CouponController::class . ':disable');
  184. // 登录日志
  185. $group->get('/login', App\Controllers\Admin\LoginLogController::class . ':index');
  186. $group->post('/login/ajax', App\Controllers\Admin\LoginLogController::class . ':ajax');
  187. // 在线IP
  188. $group->get('/online', App\Controllers\Admin\OnlineIpController::class . ':index');
  189. $group->post('/online/ajax', App\Controllers\Admin\OnlineIpController::class . ':ajax');
  190. // 订阅日志
  191. $group->get('/subscribe', App\Controllers\Admin\SubscribeLogController::class . ':index');
  192. $group->post('/subscribe/ajax', App\Controllers\Admin\SubscribeLogController::class . ':ajax');
  193. // 邀请日志
  194. $group->get('/invite', App\Controllers\Admin\InviteController::class . ':invite');
  195. $group->post('/invite/update_invite', App\Controllers\Admin\InviteController::class . ':update');
  196. $group->post('/invite/add_invite', App\Controllers\Admin\InviteController::class . ':add');
  197. $group->post('/invite/ajax', App\Controllers\Admin\InviteController::class . ':ajax');
  198. // 流量日志
  199. $group->get('/trafficlog', App\Controllers\Admin\TrafficLogController::class . ':index');
  200. $group->post('/trafficlog/ajax', App\Controllers\Admin\TrafficLogController::class . ':ajax');
  201. // 用户余额日志
  202. $group->get('/moneylog', App\Controllers\Admin\MoneyLogController::class . ':index');
  203. $group->post('/moneylog/ajax', App\Controllers\Admin\MoneyLogController::class . ':ajax');
  204. // 支付网关日志
  205. $group->get('/gateway', App\Controllers\Admin\PaylistController::class . ':index');
  206. $group->post('/gateway/ajax', App\Controllers\Admin\PaylistController::class . ':ajax');
  207. // 系统状态
  208. $group->get('/system', App\Controllers\Admin\SystemController::class . ':index');
  209. $group->post('/system/check_update', App\Controllers\Admin\SystemController::class . ':checkUpdate');
  210. // 设置中心
  211. $group->get('/setting/billing', App\Controllers\Admin\Setting\BillingController::class . ':billing');
  212. $group->post('/setting/billing', App\Controllers\Admin\Setting\BillingController::class . ':saveBilling');
  213. $group->get('/setting/captcha', App\Controllers\Admin\Setting\CaptchaController::class . ':captcha');
  214. $group->post('/setting/captcha', App\Controllers\Admin\Setting\CaptchaController::class . ':saveCaptcha');
  215. $group->get('/setting/cron', App\Controllers\Admin\Setting\CronController::class . ':cron');
  216. $group->post('/setting/cron', App\Controllers\Admin\Setting\CronController::class . ':saveCron');
  217. $group->get('/setting/email', App\Controllers\Admin\Setting\EmailController::class . ':email');
  218. $group->post('/setting/email', App\Controllers\Admin\Setting\EmailController::class . ':saveEmail');
  219. $group->get('/setting/feature', App\Controllers\Admin\Setting\FeatureController::class . ':feature');
  220. $group->post('/setting/feature', App\Controllers\Admin\Setting\FeatureController::class . ':saveFeature');
  221. $group->get('/setting/im', App\Controllers\Admin\Setting\ImController::class . ':im');
  222. $group->post('/setting/im', App\Controllers\Admin\Setting\ImController::class . ':saveIm');
  223. $group->get('/setting/ref', App\Controllers\Admin\Setting\RefController::class . ':ref');
  224. $group->post('/setting/ref', App\Controllers\Admin\Setting\RefController::class . ':saveRef');
  225. $group->get('/setting/reg', App\Controllers\Admin\Setting\RegController::class . ':reg');
  226. $group->post('/setting/reg', App\Controllers\Admin\Setting\RegController::class . ':saveReg');
  227. $group->get('/setting/sub', App\Controllers\Admin\Setting\SubscribeController::class . ':sub');
  228. $group->post('/setting/sub', App\Controllers\Admin\Setting\SubscribeController::class . ':saveSub');
  229. $group->get('/setting/support', App\Controllers\Admin\Setting\SupportController::class . ':support');
  230. $group->post('/setting/support', App\Controllers\Admin\Setting\SupportController::class . ':saveSupport');
  231. $group->post('/setting/test_email', App\Controllers\Admin\Setting\EmailController::class . ':testEmail');
  232. $group->post('/setting/test_discord', App\Controllers\Admin\Setting\ImController::class . ':testDiscord');
  233. // 礼品卡
  234. $group->get('/giftcard', App\Controllers\Admin\GiftCardController::class . ':index');
  235. $group->post('/giftcard', App\Controllers\Admin\GiftCardController::class . ':add');
  236. $group->post('/giftcard/ajax', App\Controllers\Admin\GiftCardController::class . ':ajax');
  237. $group->delete('/giftcard/{id}', App\Controllers\Admin\GiftCardController::class . ':delete');
  238. // 商品
  239. $group->get('/product', App\Controllers\Admin\ProductController::class . ':index');
  240. $group->get('/product/create', App\Controllers\Admin\ProductController::class . ':create');
  241. $group->post('/product', App\Controllers\Admin\ProductController::class . ':add');
  242. $group->get('/product/{id}/edit', App\Controllers\Admin\ProductController::class . ':edit');
  243. $group->post('/product/{id}/copy', App\Controllers\Admin\ProductController::class . ':copy');
  244. $group->put('/product/{id}', App\Controllers\Admin\ProductController::class . ':update');
  245. $group->delete('/product/{id}', App\Controllers\Admin\ProductController::class . ':delete');
  246. $group->post('/product/ajax', App\Controllers\Admin\ProductController::class . ':ajax');
  247. // 订单
  248. $group->get('/order', App\Controllers\Admin\OrderController::class . ':index');
  249. $group->get('/order/{id}/view', App\Controllers\Admin\OrderController::class . ':detail');
  250. $group->post('/order/{id}/cancel', App\Controllers\Admin\OrderController::class . ':cancel');
  251. $group->delete('/order/{id}', App\Controllers\Admin\OrderController::class . ':delete');
  252. $group->post('/order/ajax', App\Controllers\Admin\OrderController::class . ':ajax');
  253. // 账单
  254. $group->get('/invoice', App\Controllers\Admin\InvoiceController::class . ':index');
  255. $group->get('/invoice/{id}/view', App\Controllers\Admin\InvoiceController::class . ':detail');
  256. $group->post('/invoice/{id}/mark_paid', App\Controllers\Admin\InvoiceController::class . ':markPaid');
  257. $group->post('/invoice/ajax', App\Controllers\Admin\InvoiceController::class . ':ajax');
  258. })->add(new Admin());
  259. //$app->group('/admin/api', function (RouteCollectorProxy $group): void {
  260. // $group->post('/{action}', App\Controllers\Api\AdminApiController::class . ':actionHandler');
  261. //})->add(new AdminApiToken());
  262. //$app->group('/user/api', function (RouteCollectorProxy $group): void {
  263. // $group->post('/{action}', App\Controllers\Api\UserApiController::class . ':actionHandler');
  264. //})->add(new UserApiToken());
  265. // WebAPI
  266. $app->group('/mod_mu', static function (RouteCollectorProxy $group): void {
  267. // 节点
  268. $group->get('/nodes/{id}/info', App\Controllers\WebAPI\NodeController::class . ':getInfo');
  269. // 用户
  270. $group->get('/users', App\Controllers\WebAPI\UserController::class . ':index');
  271. $group->post('/users/traffic', App\Controllers\WebAPI\UserController::class . ':addTraffic');
  272. $group->post('/users/aliveip', App\Controllers\WebAPI\UserController::class . ':addAliveIp');
  273. $group->post('/users/detectlog', App\Controllers\WebAPI\UserController::class . ':addDetectLog');
  274. // 审计 & 杂七杂八的功能
  275. $group->get('/func/detect_rules', App\Controllers\WebAPI\FuncController::class . ':getDetectLogs');
  276. $group->get('/func/ping', App\Controllers\WebAPI\FuncController::class . ':ping');
  277. })->add(new NodeToken());
  278. // 传统订阅(SS/V2Ray/Trojan etc.)
  279. $app->get('/link/{token}', App\Controllers\LinkController::class . ':getContent');
  280. // 通用订阅(Json/Clash/SIP008)
  281. $app->get('/sub/{token}/{subtype}', App\Controllers\SubController::class . ':getContent');
  282. };