routes.php 23 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333
  1. <?php
  2. declare(strict_types=1);
  3. use App\Middleware\Admin;
  4. use App\Middleware\Guest;
  5. use App\Middleware\NodeToken;
  6. use App\Middleware\User;
  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. // Bot Callback
  18. $app->post('/callback/{type}', App\Controllers\CallbackController::class . ':index');
  19. // OAuth
  20. $app->post('/oauth/{type}', App\Controllers\OAuthController::class . ':index');
  21. $app->get('/oauth/{type}', App\Controllers\OAuthController::class . ':index');
  22. // 通用订阅
  23. $app->get('/sub/{token}/{subtype}', App\Controllers\SubController::class . ':index');
  24. // User
  25. $app->group('/user', static function (RouteCollectorProxy $group): void {
  26. $group->get('', App\Controllers\UserController::class . ':index');
  27. $group->get('/', App\Controllers\UserController::class . ':index');
  28. // 签到
  29. $group->post('/checkin', App\Controllers\UserController::class . ':checkin');
  30. // 公告
  31. $group->get('/announcement', App\Controllers\UserController::class . ':announcement');
  32. // 文档
  33. $group->get('/docs', App\Controllers\User\DocsController::class . ':index');
  34. $group->get('/docs/{id:[0-9]+}/view', App\Controllers\User\DocsController::class . ':detail');
  35. // 个人资料
  36. $group->get('/profile', App\Controllers\UserController::class . ':profile');
  37. $group->get('/invite', App\Controllers\UserController::class . ':invite');
  38. // 封禁
  39. $group->get('/banned', App\Controllers\UserController::class . ':banned');
  40. // 节点
  41. $group->get('/server', App\Controllers\User\ServerController::class . ':index');
  42. // 动态倍率
  43. $group->get('/rate', App\Controllers\User\RateController::class . ':index');
  44. $group->post('/rate', App\Controllers\User\RateController::class . ':ajax');
  45. // 审计规则
  46. $group->get('/detect', App\Controllers\User\DetectRuleController::class . ':index');
  47. // 审计记录
  48. $group->get('/detect/log', App\Controllers\User\DetectLogController::class . ':index');
  49. // 工单
  50. $group->get('/ticket', App\Controllers\User\TicketController::class . ':index');
  51. $group->get('/ticket/create', App\Controllers\User\TicketController::class . ':create');
  52. $group->post('/ticket', App\Controllers\User\TicketController::class . ':add');
  53. $group->get('/ticket/{id:[0-9]+}/view', App\Controllers\User\TicketController::class . ':detail');
  54. $group->put('/ticket/{id:[0-9]+}', App\Controllers\User\TicketController::class . ':update');
  55. // 资料编辑
  56. $group->get('/edit', App\Controllers\User\InfoController::class . ':index');
  57. $group->post('/email', App\Controllers\User\InfoController::class . ':updateEmail');
  58. $group->post('/username', App\Controllers\User\InfoController::class . ':updateUsername');
  59. $group->post('/unbind_im', App\Controllers\User\InfoController::class . ':unbindIM');
  60. $group->post('/password', App\Controllers\User\InfoController::class . ':updatePassword');
  61. $group->post('/passwd_reset', App\Controllers\User\InfoController::class . ':resetPasswd');
  62. $group->post('/apitoken_reset', App\Controllers\User\InfoController::class . ':resetApiToken');
  63. $group->post('/method', App\Controllers\User\InfoController::class . ':updateMethod');
  64. $group->post('/url_reset', App\Controllers\User\InfoController::class . ':resetURL');
  65. $group->post('/invite_reset', App\Controllers\User\InfoController::class . ':resetInviteURL');
  66. $group->post('/daily_mail', App\Controllers\User\InfoController::class . ':updateDailyMail');
  67. $group->post('/contact_method', App\Controllers\User\InfoController::class . ':updateContactMethod');
  68. $group->post('/theme', App\Controllers\User\InfoController::class . ':updateTheme');
  69. $group->post('/kill', App\Controllers\User\InfoController::class . ':sendToGulag');
  70. // 发送验证邮件
  71. $group->post('/send', App\Controllers\AuthController::class . ':sendVerify');
  72. // MFA
  73. $group->post('/ga_check', App\Controllers\User\MFAController::class . ':checkGa');
  74. $group->post('/ga_set', App\Controllers\User\MFAController::class . ':setGa');
  75. $group->post('/ga_reset', App\Controllers\User\MFAController::class . ':resetGa');
  76. // 深色模式切换
  77. $group->post('/switch_theme_mode', App\Controllers\UserController::class . ':switchThemeMode');
  78. // 订阅记录
  79. $group->get('/subscribe', App\Controllers\User\SubLogController::class . ':index');
  80. // 账户余额
  81. $group->get('/money', App\Controllers\User\MoneyController::class . ':index');
  82. $group->post('/giftcard', App\Controllers\User\MoneyController::class . ':applyGiftCard');
  83. // 产品页面
  84. $group->get('/product', App\Controllers\User\ProductController::class . ':index');
  85. // 订单页面
  86. $group->get('/order', App\Controllers\User\OrderController::class . ':index');
  87. $group->get('/order/create', App\Controllers\User\OrderController::class . ':create');
  88. $group->post('/order/create', App\Controllers\User\OrderController::class . ':process');
  89. $group->get('/order/{id:[0-9]+}/view', App\Controllers\User\OrderController::class . ':detail');
  90. $group->post('/order/ajax', App\Controllers\User\OrderController::class . ':ajax');
  91. // 账单页面
  92. $group->get('/invoice', App\Controllers\User\InvoiceController::class . ':index');
  93. $group->get('/invoice/{id:[0-9]+}/view', App\Controllers\User\InvoiceController::class . ':detail');
  94. $group->post('/invoice/pay_balance', App\Controllers\User\InvoiceController::class . ':payBalance');
  95. $group->post('/invoice/ajax', App\Controllers\User\InvoiceController::class . ':ajax');
  96. // 新优惠码系统
  97. $group->post('/coupon', App\Controllers\User\CouponController::class . ':check');
  98. // 支付
  99. $group->post('/payment/purchase/{type}', App\Services\Payment::class . ':purchase');
  100. $group->get('/payment/purchase/{type}', App\Services\Payment::class . ':purchase');
  101. $group->get('/payment/return/{type}', App\Services\Payment::class . ':returnHTML');
  102. // Get Clients
  103. $group->get('/clients/{name}', App\Controllers\User\ClientController::class . ':getClients');
  104. // 登出
  105. $group->get('/logout', App\Controllers\UserController::class . ':logout');
  106. })->add(new User());
  107. $app->group('/payment', static function (RouteCollectorProxy $group): void {
  108. $group->get('/notify/{type}', App\Services\Payment::class . ':notify');
  109. $group->post('/notify/{type}', App\Services\Payment::class . ':notify');
  110. $group->post('/status/{type}', App\Services\Payment::class . ':getStatus');
  111. });
  112. // Auth
  113. $app->group('/auth', static function (RouteCollectorProxy $group): void {
  114. $group->get('/login', App\Controllers\AuthController::class . ':login');
  115. $group->post('/login', App\Controllers\AuthController::class . ':loginHandle');
  116. $group->get('/register', App\Controllers\AuthController::class . ':register');
  117. $group->post('/register', App\Controllers\AuthController::class . ':registerHandle');
  118. $group->post('/send', App\Controllers\AuthController::class . ':sendVerify');
  119. $group->get('/logout', App\Controllers\AuthController::class . ':logout');
  120. })->add(new Guest());
  121. // Password
  122. $app->group('/password', static function (RouteCollectorProxy $group): void {
  123. $group->get('/reset', App\Controllers\PasswordController::class . ':reset');
  124. $group->post('/reset', App\Controllers\PasswordController::class . ':handleReset');
  125. $group->get('/token/{token}', App\Controllers\PasswordController::class . ':token');
  126. $group->post('/token/{token}', App\Controllers\PasswordController::class . ':handleToken');
  127. })->add(new Guest());
  128. // Admin
  129. $app->group('/admin', static function (RouteCollectorProxy $group): void {
  130. $group->get('', App\Controllers\AdminController::class . ':index');
  131. $group->get('/', App\Controllers\AdminController::class . ':index');
  132. // Node
  133. $group->get('/node', App\Controllers\Admin\NodeController::class . ':index');
  134. $group->get('/node/create', App\Controllers\Admin\NodeController::class . ':create');
  135. $group->post('/node', App\Controllers\Admin\NodeController::class . ':add');
  136. $group->get('/node/{id:[0-9]+}/edit', App\Controllers\Admin\NodeController::class . ':edit');
  137. $group->post(
  138. '/node/{id:[0-9]+}/reset_password',
  139. App\Controllers\Admin\NodeController::class . ':resetPassword'
  140. );
  141. $group->post(
  142. '/node/{id:[0-9]+}/reset_bandwidth',
  143. App\Controllers\Admin\NodeController::class . ':resetBandwidth'
  144. );
  145. $group->post('/node/{id:[0-9]+}/copy', App\Controllers\Admin\NodeController::class . ':copy');
  146. $group->put('/node/{id:[0-9]+}', App\Controllers\Admin\NodeController::class . ':update');
  147. $group->delete('/node/{id:[0-9]+}', App\Controllers\Admin\NodeController::class . ':delete');
  148. $group->post('/node/ajax', App\Controllers\Admin\NodeController::class . ':ajax');
  149. // Ticket
  150. $group->get('/ticket', App\Controllers\Admin\TicketController::class . ':index');
  151. $group->post('/ticket', App\Controllers\Admin\TicketController::class . ':add');
  152. $group->get('/ticket/{id:[0-9]+}/view', App\Controllers\Admin\TicketController::class . ':detail');
  153. $group->put('/ticket/{id:[0-9]+}/close', App\Controllers\Admin\TicketController::class . ':close');
  154. $group->put('/ticket/{id:[0-9]+}', App\Controllers\Admin\TicketController::class . ':update');
  155. $group->put('/ticket/{id:[0-9]+}/ai', App\Controllers\Admin\TicketController::class . ':updateAI');
  156. $group->delete('/ticket/{id:[0-9]+}', App\Controllers\Admin\TicketController::class . ':delete');
  157. $group->post('/ticket/ajax', App\Controllers\Admin\TicketController::class . ':ajax');
  158. // Ann
  159. $group->get('/announcement', App\Controllers\Admin\AnnController::class . ':index');
  160. $group->get('/announcement/create', App\Controllers\Admin\AnnController::class . ':create');
  161. $group->post('/announcement', App\Controllers\Admin\AnnController::class . ':add');
  162. $group->get('/announcement/{id:[0-9]+}/edit', App\Controllers\Admin\AnnController::class . ':edit');
  163. $group->put('/announcement/{id:[0-9]+}', App\Controllers\Admin\AnnController::class . ':update');
  164. $group->delete('/announcement/{id:[0-9]+}', App\Controllers\Admin\AnnController::class . ':delete');
  165. $group->post('/announcement/ajax', App\Controllers\Admin\AnnController::class . ':ajax');
  166. // Docs
  167. $group->get('/docs', App\Controllers\Admin\DocsController::class . ':index');
  168. $group->get('/docs/create', App\Controllers\Admin\DocsController::class . ':create');
  169. $group->post('/docs', App\Controllers\Admin\DocsController::class . ':add');
  170. $group->post('/docs/generate', App\Controllers\Admin\DocsController::class . ':generate');
  171. $group->get('/docs/{id:[0-9]+}/edit', App\Controllers\Admin\DocsController::class . ':edit');
  172. $group->put('/docs/{id:[0-9]+}', App\Controllers\Admin\DocsController::class . ':update');
  173. $group->delete('/docs/{id:[0-9]+}', App\Controllers\Admin\DocsController::class . ':delete');
  174. $group->post('/docs/ajax', App\Controllers\Admin\DocsController::class . ':ajax');
  175. // 审计
  176. $group->get('/detect', App\Controllers\Admin\DetectRuleController::class . ':index');
  177. $group->get('/detect/create', App\Controllers\Admin\DetectRuleController::class . ':create');
  178. $group->post('/detect/add', App\Controllers\Admin\DetectRuleController::class . ':add');
  179. $group->delete('/detect/{id:[0-9]+}', App\Controllers\Admin\DetectRuleController::class . ':delete');
  180. $group->post('/detect/ajax', App\Controllers\Admin\DetectRuleController::class . ':ajax');
  181. // 审计触发日志
  182. $group->get('/detect/log', App\Controllers\Admin\DetectLogController::class . ':index');
  183. $group->post('/detect/log/ajax', App\Controllers\Admin\DetectLogController::class . ':ajax');
  184. // 审计封禁日志
  185. $group->get('/detect/ban', App\Controllers\Admin\DetectBanController::class . ':index');
  186. $group->post('/detect/ban/ajax', App\Controllers\Admin\DetectBanController::class . ':ajax');
  187. // User
  188. $group->get('/user', App\Controllers\Admin\UserController::class . ':index');
  189. $group->get('/user/{id:[0-9]+}/edit', App\Controllers\Admin\UserController::class . ':edit');
  190. $group->put('/user/{id:[0-9]+}', App\Controllers\Admin\UserController::class . ':update');
  191. $group->post('/user/create', App\Controllers\Admin\UserController::class . ':create');
  192. $group->delete('/user/{id}', App\Controllers\Admin\UserController::class . ':delete');
  193. $group->post('/user/ajax', App\Controllers\Admin\UserController::class . ':ajax');
  194. // Coupon
  195. $group->get('/coupon', App\Controllers\Admin\CouponController::class . ':index');
  196. $group->post('/coupon', App\Controllers\Admin\CouponController::class . ':add');
  197. $group->post('/coupon/ajax', App\Controllers\Admin\CouponController::class . ':ajax');
  198. $group->delete('/coupon/{id:[0-9]+}', App\Controllers\Admin\CouponController::class . ':delete');
  199. $group->post('/coupon/{id:[0-9]+}/disable', App\Controllers\Admin\CouponController::class . ':disable');
  200. // 登录日志
  201. $group->get('/login', App\Controllers\Admin\LoginLogController::class . ':index');
  202. $group->post('/login/ajax', App\Controllers\Admin\LoginLogController::class . ':ajax');
  203. // 在线IP日志
  204. $group->get('/online', App\Controllers\Admin\OnlineLogController::class . ':index');
  205. $group->post('/online/ajax', App\Controllers\Admin\OnlineLogController::class . ':ajax');
  206. // 订阅日志
  207. $group->get('/subscribe', App\Controllers\Admin\SubLogController::class . ':index');
  208. $group->post('/subscribe/ajax', App\Controllers\Admin\SubLogController::class . ':ajax');
  209. // 邀请日志
  210. $group->get('/invite', App\Controllers\Admin\InviteController::class . ':index');
  211. $group->post('/invite/update_invite', App\Controllers\Admin\InviteController::class . ':update');
  212. $group->post('/invite/add_invite', App\Controllers\Admin\InviteController::class . ':add');
  213. $group->post('/invite/ajax', App\Controllers\Admin\InviteController::class . ':ajax');
  214. // 流量日志
  215. $group->get('/traffic', App\Controllers\Admin\TrafficLogController::class . ':index');
  216. $group->post('/traffic/ajax', App\Controllers\Admin\TrafficLogController::class . ':ajax');
  217. // 用户余额日志
  218. $group->get('/money', App\Controllers\Admin\MoneyLogController::class . ':index');
  219. $group->post('/money/ajax', App\Controllers\Admin\MoneyLogController::class . ':ajax');
  220. // 支付网关日志
  221. $group->get('/gateway', App\Controllers\Admin\PaylistController::class . ':index');
  222. $group->post('/gateway/ajax', App\Controllers\Admin\PaylistController::class . ':ajax');
  223. // 系统状态
  224. $group->get('/system', App\Controllers\Admin\SystemController::class . ':index');
  225. $group->post('/system/check_update', App\Controllers\Admin\SystemController::class . ':checkUpdate');
  226. // 设置中心
  227. $group->get('/setting/billing', App\Controllers\Admin\Setting\BillingController::class . ':index');
  228. $group->post('/setting/billing', App\Controllers\Admin\Setting\BillingController::class . ':save');
  229. $group->get('/setting/captcha', App\Controllers\Admin\Setting\CaptchaController::class . ':index');
  230. $group->post('/setting/captcha', App\Controllers\Admin\Setting\CaptchaController::class . ':save');
  231. $group->get('/setting/cron', App\Controllers\Admin\Setting\CronController::class . ':index');
  232. $group->post('/setting/cron', App\Controllers\Admin\Setting\CronController::class . ':save');
  233. $group->get('/setting/email', App\Controllers\Admin\Setting\EmailController::class . ':index');
  234. $group->post('/setting/email', App\Controllers\Admin\Setting\EmailController::class . ':save');
  235. $group->get('/setting/feature', App\Controllers\Admin\Setting\FeatureController::class . ':index');
  236. $group->post('/setting/feature', App\Controllers\Admin\Setting\FeatureController::class . ':save');
  237. $group->get('/setting/im', App\Controllers\Admin\Setting\ImController::class . ':index');
  238. $group->post('/setting/im', App\Controllers\Admin\Setting\ImController::class . ':save');
  239. $group->get('/setting/ref', App\Controllers\Admin\Setting\RefController::class . ':index');
  240. $group->post('/setting/ref', App\Controllers\Admin\Setting\RefController::class . ':save');
  241. $group->get('/setting/reg', App\Controllers\Admin\Setting\RegController::class . ':index');
  242. $group->post('/setting/reg', App\Controllers\Admin\Setting\RegController::class . ':save');
  243. $group->get('/setting/sub', App\Controllers\Admin\Setting\SubController::class . ':index');
  244. $group->post('/setting/sub', App\Controllers\Admin\Setting\SubController::class . ':save');
  245. $group->get('/setting/support', App\Controllers\Admin\Setting\SupportController::class . ':index');
  246. $group->post('/setting/support', App\Controllers\Admin\Setting\SupportController::class . ':save');
  247. // 设置测试
  248. $group->post(
  249. '/setting/test/email',
  250. App\Controllers\Admin\Setting\EmailController::class . ':testEmail'
  251. );
  252. $group->post(
  253. '/setting/test/telegram',
  254. App\Controllers\Admin\Setting\ImController::class . ':testTelegram'
  255. );
  256. $group->post(
  257. '/setting/test/discord',
  258. App\Controllers\Admin\Setting\ImController::class . ':testDiscord'
  259. );
  260. $group->post(
  261. '/setting/test/slack',
  262. App\Controllers\Admin\Setting\ImController::class . ':testSlack'
  263. );
  264. // 礼品卡
  265. $group->get('/giftcard', App\Controllers\Admin\GiftCardController::class . ':index');
  266. $group->post('/giftcard', App\Controllers\Admin\GiftCardController::class . ':add');
  267. $group->post('/giftcard/ajax', App\Controllers\Admin\GiftCardController::class . ':ajax');
  268. $group->delete('/giftcard/{id:[0-9]+}', App\Controllers\Admin\GiftCardController::class . ':delete');
  269. // 商品
  270. $group->get('/product', App\Controllers\Admin\ProductController::class . ':index');
  271. $group->get('/product/create', App\Controllers\Admin\ProductController::class . ':create');
  272. $group->post('/product', App\Controllers\Admin\ProductController::class . ':add');
  273. $group->get('/product/{id:[0-9]+}/edit', App\Controllers\Admin\ProductController::class . ':edit');
  274. $group->post('/product/{id:[0-9]+}/copy', App\Controllers\Admin\ProductController::class . ':copy');
  275. $group->put('/product/{id:[0-9]+}', App\Controllers\Admin\ProductController::class . ':update');
  276. $group->delete('/product/{id:[0-9]+}', App\Controllers\Admin\ProductController::class . ':delete');
  277. $group->post('/product/ajax', App\Controllers\Admin\ProductController::class . ':ajax');
  278. // 订单
  279. $group->get('/order', App\Controllers\Admin\OrderController::class . ':index');
  280. $group->get('/order/{id:[0-9]+}/view', App\Controllers\Admin\OrderController::class . ':detail');
  281. $group->post('/order/{id:[0-9]+}/cancel', App\Controllers\Admin\OrderController::class . ':cancel');
  282. $group->delete('/order/{id:[0-9]+}', App\Controllers\Admin\OrderController::class . ':delete');
  283. $group->post('/order/ajax', App\Controllers\Admin\OrderController::class . ':ajax');
  284. // 账单
  285. $group->get('/invoice', App\Controllers\Admin\InvoiceController::class . ':index');
  286. $group->get('/invoice/{id:[0-9]+}/view', App\Controllers\Admin\InvoiceController::class . ':detail');
  287. $group->post('/invoice/{id:[0-9]+}/mark_paid', App\Controllers\Admin\InvoiceController::class . ':markPaid');
  288. $group->post('/invoice/ajax', App\Controllers\Admin\InvoiceController::class . ':ajax');
  289. })->add(new Admin());
  290. // Admin REST API
  291. //$app->group('/admin/api/v1', function (RouteCollectorProxy $group): void {
  292. // $group->post('/{action}', App\Controllers\Api\AdminApiV1Controller::class . ':actionHandler');
  293. //})->add(new AdminApi());
  294. // User REST API
  295. //$app->group('/user/api/v1', function (RouteCollectorProxy $group): void {
  296. // $group->post('/{action}', App\Controllers\Api\UserApiV1Controller::class . ':actionHandler');
  297. //})->add(new UserApi());
  298. // WebAPI V2(Aka Node API V1)
  299. //$app->group('/node/api/v1', function (RouteCollectorProxy $group): void {
  300. // $group->get('/heartbeat', App\Controllers\Api\NodeApiV1Controller::class . ':getHeartbeat');
  301. // $group->get('/info', App\Controllers\Api\NodeApiV1Controller::class . ':getInfo');
  302. // $group->get('/user', App\Controllers\Api\NodeApiV1Controller::class . ':getUser');
  303. // $group->get('/detect_rule', App\Controllers\Api\NodeApiV1Controller::class . ':getDetectRule');
  304. // $group->post('/user/traffic', App\Controllers\Api\NodeApiV1Controller::class . ':addUserTraffic');
  305. // $group->post('/user/online_ip', App\Controllers\Api\NodeApiV1Controller::class . ':addUserOnlineIp');
  306. // $group->post('/user/detect_log', App\Controllers\Api\NodeApiV1Controller::class . ':addUserDetectLog');
  307. //})->add(new NodeApi());
  308. // WebAPI
  309. $app->group('/mod_mu', static function (RouteCollectorProxy $group): void {
  310. // 节点
  311. $group->get('/nodes/{id:[0-9]+}/info', App\Controllers\WebAPI\NodeController::class . ':getInfo');
  312. // 用户
  313. $group->get('/users', App\Controllers\WebAPI\UserController::class . ':index');
  314. $group->post('/users/traffic', App\Controllers\WebAPI\UserController::class . ':addTraffic');
  315. $group->post('/users/aliveip', App\Controllers\WebAPI\UserController::class . ':addAliveIp');
  316. $group->post('/users/detectlog', App\Controllers\WebAPI\UserController::class . ':addDetectLog');
  317. // 审计 & 杂七杂八的功能
  318. $group->get('/func/detect_rules', App\Controllers\WebAPI\FuncController::class . ':getDetectRules');
  319. $group->get('/func/ping', App\Controllers\WebAPI\FuncController::class . ':ping');
  320. })->add(new NodeToken());
  321. };