routes.php 23 KB

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