2023020100-init.php 25 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360361362363364365366367368369370371372373374375376377378379380381382383384385386387388389390391392393
  1. <?php
  2. declare(strict_types=1);
  3. use App\Interfaces\MigrationInterface;
  4. use App\Services\DB;
  5. return new class() implements MigrationInterface {
  6. public function up(): int
  7. {
  8. DB::getPdo()->exec(
  9. "CREATE TABLE `announcement` (
  10. `id` int(11) NOT NULL AUTO_INCREMENT COMMENT '公告ID',
  11. `date` datetime NOT NULL DEFAULT '1989-06-04 00:05:00' COMMENT '公告日期',
  12. `content` text NOT NULL DEFAULT '' COMMENT '公告内容',
  13. PRIMARY KEY (`id`)
  14. ) ENGINE=InnoDB DEFAULT CHARSET=utf8mb4 COLLATE=utf8mb4_unicode_ci;
  15. CREATE TABLE `config` (
  16. `id` int(11) NOT NULL AUTO_INCREMENT COMMENT '主键',
  17. `item` varchar(255) DEFAULT NULL COMMENT '配置项',
  18. `value` varchar(2048) DEFAULT NULL COMMENT '配置值',
  19. `class` varchar(255) DEFAULT 'default' COMMENT '配置类别',
  20. `is_public` int(11) DEFAULT 0 COMMENT '是否为公共参数',
  21. `type` varchar(255) DEFAULT NULL COMMENT '配置值类型',
  22. `default` varchar(255) DEFAULT NULL COMMENT '默认值',
  23. `mark` varchar(255) DEFAULT NULL COMMENT '备注',
  24. PRIMARY KEY (`id`),
  25. KEY `item` (`item`),
  26. KEY `class` (`class`),
  27. KEY `is_public` (`is_public`)
  28. ) ENGINE=InnoDB DEFAULT CHARSET=utf8mb4 COLLATE=utf8mb4_unicode_ci;
  29. CREATE TABLE `detect_ban_log` (
  30. `id` int(11) unsigned NOT NULL AUTO_INCREMENT COMMENT '封禁记录ID',
  31. `user_id` bigint(20) unsigned NOT NULL DEFAULT 0 COMMENT '用户ID',
  32. `detect_number` int(11) unsigned NOT NULL DEFAULT 0 COMMENT '本次违规次数',
  33. `ban_time` int(11) unsigned NOT NULL DEFAULT 0 COMMENT '封禁时长',
  34. `start_time` int(11) unsigned NOT NULL DEFAULT 0 COMMENT '封禁开始时间',
  35. `end_time` int(11) unsigned NOT NULL DEFAULT 0 COMMENT '封禁结束时间',
  36. `all_detect_number` int(11) unsigned NOT NULL DEFAULT 0 COMMENT '累计违规次数',
  37. PRIMARY KEY (`id`),
  38. KEY `user_id` (`user_id`)
  39. ) ENGINE=InnoDB DEFAULT CHARSET=utf8mb4 COLLATE=utf8mb4_unicode_ci;
  40. CREATE TABLE `detect_list` (
  41. `id` bigint(20) unsigned NOT NULL AUTO_INCREMENT COMMENT '审计规则ID',
  42. `name` varchar(255) NOT NULL DEFAULT '' COMMENT '规则名称',
  43. `text` varchar(255) NOT NULL DEFAULT '' COMMENT '规则介绍',
  44. `regex` varchar(255) NOT NULL DEFAULT '' COMMENT '正则表达式',
  45. `type` tinyint(1) unsigned NOT NULL DEFAULT 0 COMMENT '规则类型',
  46. PRIMARY KEY (`id`)
  47. ) ENGINE=InnoDB DEFAULT CHARSET=utf8mb4 COLLATE=utf8mb4_unicode_ci;
  48. CREATE TABLE `detect_log` (
  49. `id` bigint(20) unsigned NOT NULL AUTO_INCREMENT COMMENT '审计记录ID',
  50. `user_id` bigint(20) unsigned NOT NULL DEFAULT 0 COMMENT '用户ID',
  51. `list_id` bigint(20) unsigned NOT NULL DEFAULT 0 COMMENT '规则ID',
  52. `datetime` int(11) unsigned NOT NULL DEFAULT 0 COMMENT '触发时间',
  53. `node_id` bigint(20) unsigned NOT NULL DEFAULT 0 COMMENT '节点ID',
  54. `status` tinyint(1) unsigned NOT NULL DEFAULT 0 COMMENT '状态',
  55. PRIMARY KEY (`id`),
  56. KEY `user_id` (`user_id`),
  57. KEY `node_id` (`node_id`),
  58. KEY `list_id` (`list_id`)
  59. ) ENGINE=InnoDB DEFAULT CHARSET=utf8mb4 COLLATE=utf8mb4_unicode_ci;
  60. CREATE TABLE `docs` (
  61. `id` bigint(20) unsigned NOT NULL AUTO_INCREMENT COMMENT '文档ID',
  62. `date` datetime NOT NULL DEFAULT '1989-06-04 00:05:00' COMMENT '文档日期',
  63. `title` varchar(255) NOT NULL DEFAULT '' COMMENT '文档标题',
  64. `content` longtext NOT NULL DEFAULT '' COMMENT '文档内容',
  65. PRIMARY KEY (`id`)
  66. ) ENGINE=InnoDB DEFAULT CHARSET=utf8mb4 COLLATE=utf8mb4_unicode_ci;
  67. CREATE TABLE `email_queue` (
  68. `id` bigint(20) unsigned NOT NULL AUTO_INCREMENT COMMENT '记录ID',
  69. `to_email` varchar(255) NOT NULL DEFAULT '' COMMENT '收件人邮箱',
  70. `subject` varchar(255) NOT NULL DEFAULT '' COMMENT '邮件主题',
  71. `template` varchar(255) NOT NULL DEFAULT '' COMMENT '邮件模板',
  72. `array` longtext NOT NULL DEFAULT '{}' COMMENT '模板参数' CHECK (json_valid(`array`)),
  73. `time` int(11) unsigned NOT NULL DEFAULT 0 COMMENT '添加时间',
  74. PRIMARY KEY (`id`)
  75. ) ENGINE=InnoDB DEFAULT CHARSET=utf8mb4 COLLATE=utf8mb4_unicode_ci;
  76. CREATE TABLE `gift_card` (
  77. `id` bigint(20) unsigned NOT NULL AUTO_INCREMENT COMMENT '礼品卡ID',
  78. `card` text NOT NULL DEFAULT '' COMMENT '卡号',
  79. `balance` int(11) unsigned NOT NULL DEFAULT 0 COMMENT '余额',
  80. `create_time` int(11) unsigned NOT NULL DEFAULT 0 COMMENT '创建时间',
  81. `status` tinyint(1) unsigned NOT NULL DEFAULT 0 COMMENT '使用状态',
  82. `use_time` int(11) unsigned NOT NULL DEFAULT 0 COMMENT '使用时间',
  83. `use_user` bigint(20) unsigned NOT NULL DEFAULT 0 COMMENT '使用用户',
  84. PRIMARY KEY (`id`),
  85. KEY `id` (`id`),
  86. KEY `status` (`status`)
  87. ) ENGINE=InnoDB DEFAULT CHARSET=utf8mb4 COLLATE=utf8mb4_unicode_ci;
  88. CREATE TABLE `hourly_usage` (
  89. `id` bigint(20) unsigned NOT NULL AUTO_INCREMENT COMMENT '记录ID',
  90. `user_id` bigint(20) unsigned NOT NULL DEFAULT 0 COMMENT '用户ID',
  91. `date` date NOT NULL DEFAULT 0 COMMENT '记录日期',
  92. `usage` longtext NOT NULL DEFAULT '{}' COMMENT '流量用量' CHECK (json_valid(`usage`)),
  93. PRIMARY KEY (`id`),
  94. KEY `user_id` (`user_id`),
  95. KEY `date` (`date`)
  96. ) ENGINE=InnoDB DEFAULT CHARSET=utf8mb4 COLLATE=utf8mb4_unicode_ci;
  97. CREATE TABLE `invoice` (
  98. `id` bigint(20) NOT NULL AUTO_INCREMENT COMMENT '账单ID',
  99. `user_id` bigint(20) unsigned DEFAULT 0 COMMENT '归属用户ID',
  100. `order_id` bigint(20) unsigned DEFAULT 0 COMMENT '订单ID',
  101. `content` longtext DEFAULT '{}' COMMENT '账单内容' CHECK (json_valid(`content`)),
  102. `price` double unsigned DEFAULT 0 COMMENT '账单金额',
  103. `status` varchar(255) DEFAULT '' COMMENT '账单状态',
  104. `create_time` int(11) unsigned DEFAULT 0 COMMENT '创建时间',
  105. `update_time` int(11) unsigned DEFAULT 0 COMMENT '更新时间',
  106. `pay_time` int(11) unsigned DEFAULT 0 COMMENT '支付时间',
  107. PRIMARY KEY (`id`),
  108. KEY `id` (`id`),
  109. KEY `user_id` (`user_id`),
  110. KEY `order_id` (`order_id`),
  111. KEY `status` (`status`)
  112. ) ENGINE=InnoDB DEFAULT CHARSET=utf8mb4 COLLATE=utf8mb4_unicode_ci;
  113. CREATE TABLE `link` (
  114. `id` bigint(20) NOT NULL AUTO_INCREMENT COMMENT '记录ID',
  115. `token` varchar(255) NOT NULL DEFAULT '' COMMENT '订阅token',
  116. `userid` bigint(20) unsigned NOT NULL DEFAULT 0 COMMENT '用户ID',
  117. PRIMARY KEY (`id`),
  118. UNIQUE KEY `token` (`token`),
  119. UNIQUE KEY `userid` (`userid`)
  120. ) ENGINE=InnoDB DEFAULT CHARSET=utf8mb4 COLLATE=utf8mb4_unicode_ci;
  121. CREATE TABLE `login_ip` (
  122. `id` bigint(20) unsigned NOT NULL AUTO_INCREMENT COMMENT '记录ID',
  123. `userid` bigint(20) unsigned NOT NULL DEFAULT 0 COMMENT '用户ID',
  124. `ip` varchar(255) NOT NULL DEFAULT '' COMMENT '登录IP',
  125. `datetime` int(11) unsigned NOT NULL DEFAULT 0 COMMENT '登录时间',
  126. `type` tinyint(1) unsigned NOT NULL DEFAULT 1 COMMENT '登录类型',
  127. PRIMARY KEY (`id`),
  128. KEY `userid` (`userid`),
  129. KEY `type` (`type`)
  130. ) ENGINE=InnoDB DEFAULT CHARSET=utf8mb4 COLLATE=utf8mb4_unicode_ci;
  131. CREATE TABLE `node` (
  132. `id` bigint(20) unsigned NOT NULL AUTO_INCREMENT COMMENT '节点ID',
  133. `name` varchar(255) NOT NULL DEFAULT '' COMMENT '节点名称',
  134. `type` tinyint(1) unsigned NOT NULL DEFAULT 1 COMMENT '节点启用',
  135. `server` varchar(255) NOT NULL DEFAULT '' COMMENT '节点地址',
  136. `custom_config` longtext NOT NULL DEFAULT '{}' COMMENT '自定义配置' CHECK (json_valid(`custom_config`)),
  137. `sort` tinyint(2) unsigned NOT NULL DEFAULT 14 COMMENT '节点类型',
  138. `traffic_rate` float unsigned NOT NULL DEFAULT 1 COMMENT '流量倍率',
  139. `is_dynamic_rate` tinyint(1) unsigned NOT NULL DEFAULT 0 COMMENT '是否启用动态流量倍率',
  140. `dynamic_rate_type` tinyint(1) unsigned NOT NULL DEFAULT 0 COMMENT '动态流量倍率计算方式',
  141. `dynamic_rate_config` longtext NOT NULL DEFAULT '{}' COMMENT '动态流量倍率配置' CHECK (json_valid(`custom_config`)),
  142. `node_class` smallint(5) unsigned NOT NULL DEFAULT 0 COMMENT '节点等级',
  143. `node_speedlimit` double unsigned NOT NULL DEFAULT 0 COMMENT '节点限速',
  144. `node_bandwidth` bigint(20) unsigned NOT NULL DEFAULT 0 COMMENT '节点流量',
  145. `node_bandwidth_limit` bigint(20) unsigned NOT NULL DEFAULT 0 COMMENT '节点流量限制',
  146. `bandwidthlimit_resetday` tinyint(2) unsigned NOT NULL DEFAULT 0 COMMENT '流量重置日',
  147. `node_heartbeat` int(11) unsigned NOT NULL DEFAULT 0 COMMENT '节点心跳',
  148. `online_user` int(11) unsigned NOT NULL DEFAULT 0 COMMENT '节点在线用户',
  149. `ipv4` INET4 NOT NULL DEFAULT '127.0.0.1' COMMENT 'IPv4地址',
  150. `ipv6` INET6 NOT NULL DEFAULT '::1' COMMENT 'IPv6地址',
  151. `node_group` smallint(5) unsigned NOT NULL DEFAULT 0 COMMENT '节点群组',
  152. `online` tinyint(1) NOT NULL DEFAULT 1 COMMENT '在线状态',
  153. `gfw_block` tinyint(1) unsigned NOT NULL DEFAULT 0 COMMENT '是否被GFW封锁',
  154. `password` varchar(255) NOT NULL DEFAULT '' COMMENT '后端连接密码',
  155. PRIMARY KEY (`id`),
  156. UNIQUE KEY `password` (`password`),
  157. KEY `type` (`type`),
  158. KEY `sort` (`sort`),
  159. KEY `is_dynamic_rate` (`is_dynamic_rate`),
  160. KEY `node_class` (`node_class`),
  161. KEY `bandwidthlimit_resetday` (`bandwidthlimit_resetday`),
  162. KEY `node_group` (`node_group`),
  163. KEY `online` (`online`)
  164. ) ENGINE=InnoDB DEFAULT CHARSET=utf8mb4 COLLATE=utf8mb4_unicode_ci;
  165. CREATE TABLE `online_log` (
  166. `id` bigint(20) unsigned NOT NULL AUTO_INCREMENT COMMENT '记录ID',
  167. `user_id` bigint(20) unsigned NOT NULL COMMENT '用户ID',
  168. `ip` inet6 NOT NULL COMMENT 'IP地址',
  169. `node_id` int(11) unsigned NOT NULL COMMENT '节点ID',
  170. `first_time` int(11) unsigned NOT NULL COMMENT '首次在线时间',
  171. `last_time` int(11) unsigned NOT NULL COMMENT '最后在线时间',
  172. PRIMARY KEY (`id`),
  173. UNIQUE KEY (`user_id`, `ip`),
  174. KEY `node_id` (`node_id`),
  175. KEY `last_time` (`last_time`)
  176. ) ENGINE=InnoDB DEFAULT CHARSET=utf8mb4 COLLATE=utf8mb4_unicode_ci;
  177. CREATE TABLE `order` (
  178. `id` bigint(20) unsigned NOT NULL AUTO_INCREMENT COMMENT '订单ID',
  179. `user_id` bigint(20) unsigned NOT NULL DEFAULT 0 COMMENT '提交用户ID',
  180. `product_id` bigint(20) unsigned NOT NULL DEFAULT 0 COMMENT '商品ID',
  181. `product_type` varchar(255) NOT NULL DEFAULT '' COMMENT '商品类型',
  182. `product_name` varchar(255) NOT NULL DEFAULT '' COMMENT '商品名称',
  183. `product_content` longtext NOT NULL DEFAULT '{}' COMMENT '商品内容' CHECK (json_valid(`product_content`)),
  184. `coupon` varchar(255) NOT NULL DEFAULT '' COMMENT '订单优惠码',
  185. `price` double unsigned NOT NULL DEFAULT 0 COMMENT '订单金额',
  186. `status` varchar(255) NOT NULL DEFAULT '' COMMENT '订单状态',
  187. `create_time` int(11) unsigned NOT NULL DEFAULT 0 COMMENT '创建时间',
  188. `update_time` int(11) unsigned NOT NULL DEFAULT 0 COMMENT '更新时间',
  189. PRIMARY KEY (`id`),
  190. KEY `id` (`id`),
  191. KEY `user_id` (`user_id`),
  192. KEY `product_id` (`product_id`),
  193. KEY `status` (`status`)
  194. ) ENGINE=InnoDB DEFAULT CHARSET=utf8mb4 COLLATE=utf8mb4_unicode_ci;
  195. CREATE TABLE `payback` (
  196. `id` bigint(20) unsigned NOT NULL AUTO_INCREMENT COMMENT '记录ID',
  197. `total` decimal(12,2) unsigned NOT NULL DEFAULT 0 COMMENT '总金额',
  198. `userid` bigint(20) unsigned NOT NULL DEFAULT 0 COMMENT '用户ID',
  199. `ref_by` bigint(20) unsigned NOT NULL DEFAULT 0 COMMENT '推荐人ID',
  200. `ref_get` decimal(12,2) unsigned NOT NULL DEFAULT 0 COMMENT '推荐人获得金额',
  201. `invoice_id` bigint(20) unsigned NOT NULL DEFAULT 0 COMMENT '账单ID',
  202. `datetime` int(11) unsigned NOT NULL DEFAULT 0 COMMENT '创建时间',
  203. PRIMARY KEY (`id`),
  204. KEY `userid` (`userid`),
  205. KEY `ref_by` (`ref_by`),
  206. KEY `invoice_id` (`invoice_id`)
  207. ) ENGINE=InnoDB DEFAULT CHARSET=utf8mb4 COLLATE=utf8mb4_unicode_ci;
  208. CREATE TABLE `paylist` (
  209. `id` bigint(20) unsigned NOT NULL AUTO_INCREMENT COMMENT '记录ID',
  210. `userid` bigint(20) unsigned NOT NULL DEFAULT 0 COMMENT '用户ID',
  211. `total` decimal(12,2) NOT NULL DEFAULT 0 COMMENT '总金额',
  212. `status` tinyint(1) unsigned NOT NULL DEFAULT 0 COMMENT '状态',
  213. `invoice_id` bigint(20) unsigned NOT NULL DEFAULT 0 COMMENT '账单ID',
  214. `tradeno` varchar(255) NOT NULL DEFAULT '' COMMENT '网关单号',
  215. `gateway` varchar(255) NOT NULL DEFAULT '' COMMENT '支付网关',
  216. `datetime` int(11) unsigned NOT NULL DEFAULT 0 COMMENT '创建时间',
  217. PRIMARY KEY (`id`),
  218. UNIQUE KEY `tradeno` (`tradeno`),
  219. KEY `userid` (`userid`),
  220. KEY `status` (`status`),
  221. KEY `invoice_id` (`invoice_id`)
  222. ) ENGINE=InnoDB DEFAULT CHARSET=utf8mb4 COLLATE=utf8mb4_unicode_ci;
  223. CREATE TABLE `product` (
  224. `id` bigint(20) unsigned NOT NULL AUTO_INCREMENT COMMENT '商品ID',
  225. `type` varchar(255) NOT NULL DEFAULT 'tabp' COMMENT '类型',
  226. `name` varchar(255) NOT NULL DEFAULT '' COMMENT '名称',
  227. `price` double unsigned NOT NULL DEFAULT 0 COMMENT '售价',
  228. `content` longtext NOT NULL DEFAULT '{}' COMMENT '内容' CHECK (json_valid(`content`)),
  229. `limit` longtext NOT NULL DEFAULT '{}' COMMENT '购买限制' CHECK (json_valid(`limit`)),
  230. `status` tinyint(1) unsigned NOT NULL DEFAULT 1 COMMENT '销售状态',
  231. `create_time` int(11) unsigned NOT NULL DEFAULT 0 COMMENT '创建时间',
  232. `update_time` int(11) unsigned NOT NULL DEFAULT 0 COMMENT '更新时间',
  233. `sale_count` int(11) unsigned NOT NULL DEFAULT 0 COMMENT '累计销量',
  234. `stock` int(11) NOT NULL DEFAULT -1 COMMENT '库存',
  235. PRIMARY KEY (`id`),
  236. KEY `id` (`id`),
  237. KEY `type` (`type`),
  238. KEY `status` (`status`)
  239. ) ENGINE=InnoDB DEFAULT CHARSET=utf8mb4 COLLATE=utf8mb4_unicode_ci;
  240. CREATE TABLE `subscribe_log` (
  241. `id` bigint(20) unsigned NOT NULL AUTO_INCREMENT COMMENT '记录ID',
  242. `user_id` bigint(20) unsigned NOT NULL DEFAULT 0 COMMENT '用户ID',
  243. `type` varchar(255) NOT NULL DEFAULT '' COMMENT '获取的订阅类型',
  244. `request_ip` varchar(255) NOT NULL DEFAULT '' COMMENT '请求IP',
  245. `request_time` int(11) unsigned NOT NULL DEFAULT 0 COMMENT '请求时间',
  246. `request_user_agent` varchar(255) NOT NULL DEFAULT '' COMMENT '请求UA',
  247. PRIMARY KEY (`id`),
  248. KEY `user_id` (`user_id`),
  249. KEY `type` (`type`)
  250. ) ENGINE=InnoDB DEFAULT CHARSET=utf8mb4 COLLATE=utf8mb4_unicode_ci;
  251. CREATE TABLE `ticket` (
  252. `id` bigint(20) unsigned NOT NULL AUTO_INCREMENT COMMENT '工单ID',
  253. `title` varchar(255) NOT NULL DEFAULT '' COMMENT '工单标题',
  254. `content` longtext NOT NULL DEFAULT '{}' COMMENT '工单内容' CHECK (json_valid(`content`)),
  255. `userid` bigint(20) unsigned NOT NULL DEFAULT 0 COMMENT '用户ID',
  256. `status` varchar(255) NOT NULL DEFAULT '' COMMENT '工单状态',
  257. `type` varchar(255) NOT NULL DEFAULT '' COMMENT '工单类型',
  258. `datetime` int(11) unsigned NOT NULL DEFAULT 0 COMMENT '创建时间',
  259. PRIMARY KEY (`id`),
  260. KEY `userid` (`userid`),
  261. KEY `status` (`status`),
  262. KEY `type` (`type`)
  263. ) ENGINE=InnoDB DEFAULT CHARSET=utf8mb4 COLLATE=utf8mb4_unicode_ci;
  264. CREATE TABLE `user` (
  265. `id` bigint(20) unsigned NOT NULL AUTO_INCREMENT COMMENT '用户ID',
  266. `user_name` varchar(255) NOT NULL DEFAULT '' COMMENT '用户名',
  267. `email` varchar(255) NOT NULL COMMENT 'E-Mail',
  268. `pass` varchar(255) NOT NULL COMMENT '登录密码',
  269. `passwd` varchar(255) NOT NULL COMMENT '节点密码',
  270. `uuid` char(36) NOT NULL COMMENT 'UUID',
  271. `u` bigint(20) unsigned NOT NULL DEFAULT 0 COMMENT '账户当前上传流量',
  272. `d` bigint(20) unsigned NOT NULL DEFAULT 0 COMMENT '账户当前下载流量',
  273. `transfer_today` bigint(20) unsigned NOT NULL DEFAULT 0 COMMENT '账户今日所用流量',
  274. `transfer_total` bigint(20) unsigned NOT NULL DEFAULT 0 COMMENT '账户累计使用流量',
  275. `transfer_enable` bigint(20) unsigned NOT NULL DEFAULT 0 COMMENT '账户当前可用流量',
  276. `port` smallint(6) unsigned NOT NULL COMMENT '端口',
  277. `last_detect_ban_time` datetime NOT NULL DEFAULT '1989-06-04 00:05:00' COMMENT '最后一次被封禁的时间',
  278. `all_detect_number` int(11) unsigned NOT NULL DEFAULT 0 COMMENT '累计违规次数',
  279. `last_use_time` int(11) unsigned NOT NULL DEFAULT 0 COMMENT '最后使用时间',
  280. `last_check_in_time` int(11) unsigned DEFAULT 0 COMMENT '最后签到时间',
  281. `last_login_time` int(11) unsigned DEFAULT 0 COMMENT '最后登录时间',
  282. `reg_date` datetime NOT NULL DEFAULT '1989-06-04 00:05:00' COMMENT '注册时间',
  283. `money` decimal(10,2) NOT NULL DEFAULT 0.00 COMMENT '账户余额',
  284. `ref_by` bigint(20) unsigned NOT NULL DEFAULT 0 COMMENT '邀请人ID',
  285. `method` varchar(255) NOT NULL DEFAULT 'aes-128-gcm' COMMENT 'Shadowsocks加密方式',
  286. `reg_ip` varchar(255) NOT NULL DEFAULT '127.0.0.1' COMMENT '注册IP',
  287. `node_speedlimit` double NOT NULL DEFAULT 0 COMMENT '用户限速',
  288. `node_iplimit` smallint(6) unsigned NOT NULL DEFAULT 0 COMMENT '同时可连接IP数',
  289. `is_admin` tinyint(1) unsigned NOT NULL DEFAULT 0 COMMENT '是否管理员',
  290. `im_type` smallint(6) unsigned NOT NULL DEFAULT 0 COMMENT '联系方式类型',
  291. `im_value` varchar(255) NOT NULL DEFAULT '' COMMENT '联系方式',
  292. `contact_method` smallint(6) NOT NULL DEFAULT 1 COMMENT '偏好的联系方式',
  293. `daily_mail_enable` tinyint(1) NOT NULL DEFAULT 0 COMMENT '每日报告开关',
  294. `class` smallint(5) unsigned NOT NULL DEFAULT 0 COMMENT '等级',
  295. `class_expire` datetime NOT NULL DEFAULT '1989-06-04 00:05:00' COMMENT '等级过期时间',
  296. `theme` varchar(255) NOT NULL DEFAULT 'tabler' COMMENT '网站主题',
  297. `ga_token` varchar(255) NOT NULL DEFAULT '' COMMENT 'GA密钥',
  298. `ga_enable` tinyint(1) unsigned NOT NULL DEFAULT 0 COMMENT 'GA开关',
  299. `remark` text NOT NULL DEFAULT '' COMMENT '备注',
  300. `node_group` smallint(6) unsigned NOT NULL DEFAULT 0 COMMENT '节点分组',
  301. `is_banned` tinyint(1) unsigned NOT NULL DEFAULT 0 COMMENT '是否封禁',
  302. `banned_reason` varchar(255) NOT NULL DEFAULT '' COMMENT '封禁理由',
  303. `is_shadow_banned` tinyint(1) unsigned NOT NULL DEFAULT 0 COMMENT '是否处于账户异常状态',
  304. `expire_notified` tinyint(1) unsigned NOT NULL DEFAULT 0 COMMENT '过期提醒',
  305. `traffic_notified` tinyint(1) unsigned NOT NULL DEFAULT 0 COMMENT '流量提醒',
  306. `forbidden_ip` varchar(255) NOT NULL DEFAULT '' COMMENT '禁止访问IP',
  307. `forbidden_port` varchar(255) NOT NULL DEFAULT '' COMMENT '禁止访问端口',
  308. `auto_reset_day` smallint(6) unsigned NOT NULL DEFAULT 0 COMMENT '自动重置流量日',
  309. `auto_reset_bandwidth` decimal(12,2) unsigned NOT NULL DEFAULT 0 COMMENT '自动重置流量',
  310. `api_token` char(36) NOT NULL DEFAULT '' COMMENT 'API 密钥',
  311. `is_dark_mode` tinyint(1) unsigned NOT NULL DEFAULT 0 COMMENT '是否启用暗黑模式',
  312. `is_inactive` tinyint(1) unsigned NOT NULL DEFAULT 0 COMMENT '是否处于闲置状态',
  313. `locale` varchar(16) NOT NULL DEFAULT 'zh-TW' COMMENT '显示语言',
  314. PRIMARY KEY (`id`),
  315. UNIQUE KEY `email` (`email`),
  316. UNIQUE KEY `uuid` (`uuid`),
  317. UNIQUE KEY `ga_token` (`ga_token`),
  318. UNIQUE KEY `api_token` (`api_token`),
  319. KEY `is_admin` (`is_admin`),
  320. KEY `is_banned` (`is_banned`),
  321. KEY `is_shadow_banned` (`is_shadow_banned`),
  322. KEY `is_inactive` (`is_inactive`)
  323. ) ENGINE=InnoDB DEFAULT CHARSET=utf8mb4 COLLATE=utf8mb4_unicode_ci;
  324. CREATE TABLE `user_coupon` (
  325. `id` int(11) unsigned NOT NULL AUTO_INCREMENT COMMENT '优惠码ID',
  326. `code` varchar(255) NOT NULL DEFAULT '' COMMENT '优惠码',
  327. `content` longtext NOT NULL DEFAULT '{}' COMMENT '优惠码内容' CHECK (json_valid(`content`)),
  328. `limit` longtext NOT NULL DEFAULT '{}' COMMENT '优惠码限制' CHECK (json_valid(`limit`)),
  329. `use_count` int(11) unsigned NOT NULL DEFAULT 0 COMMENT '累计使用次数',
  330. `create_time` int(11) unsigned NOT NULL DEFAULT 0 COMMENT '创建时间',
  331. `expire_time` int(11) unsigned NOT NULL DEFAULT 0 COMMENT '过期时间',
  332. PRIMARY KEY (`id`),
  333. KEY `id` (`id`),
  334. KEY `code` (`code`),
  335. KEY `expire_time` (`expire_time`)
  336. ) ENGINE=InnoDB DEFAULT CHARSET=utf8mb4 COLLATE=utf8mb4_unicode_ci;
  337. CREATE TABLE `user_invite_code` (
  338. `id` bigint(20) unsigned NOT NULL AUTO_INCREMENT COMMENT '记录ID',
  339. `code` varchar(255) NOT NULL DEFAULT '' COMMENT '邀请码',
  340. `user_id` bigint(20) unsigned NOT NULL DEFAULT 0 COMMENT '用户ID',
  341. PRIMARY KEY (`id`),
  342. UNIQUE KEY `code` (`code`),
  343. UNIQUE KEY `user_id` (`user_id`)
  344. ) ENGINE=InnoDB DEFAULT CHARSET=utf8mb4 COLLATE=utf8mb4_unicode_ci;
  345. CREATE TABLE `user_money_log` (
  346. `id` bigint(20) unsigned NOT NULL AUTO_INCREMENT COMMENT '记录ID',
  347. `user_id` bigint(20) unsigned NOT NULL DEFAULT 0 COMMENT '用户ID',
  348. `before` decimal(10,2) NOT NULL DEFAULT 0 COMMENT '用户变动前账户余额',
  349. `after` decimal(10,2) NOT NULL DEFAULT 0 COMMENT '用户变动后账户余额',
  350. `amount` decimal(10,2) NOT NULL DEFAULT 0 COMMENT '变动总额',
  351. `remark` text NOT NULL DEFAULT '' COMMENT '备注',
  352. `create_time` int(11) unsigned NOT NULL DEFAULT 0 COMMENT '创建时间',
  353. PRIMARY KEY (`id`),
  354. KEY `user_id` (`user_id`)
  355. ) ENGINE=InnoDB DEFAULT CHARSET=utf8mb4 COLLATE=utf8mb4_unicode_ci;"
  356. );
  357. return 2023020100;
  358. }
  359. public function down(): int
  360. {
  361. echo 'No reverse operation for initial migration' . PHP_EOL . PHP_EOL;
  362. return 2023020100;
  363. }
  364. };