openapi_tables.sql 10 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176
  1. -- OpenAPI模块 - 开放API应用表
  2. -- 用于管理第三方应用的注册信息和配置
  3. CREATE TABLE `kku_openapi_apps` (
  4. `id` bigint(20) unsigned NOT NULL AUTO_INCREMENT COMMENT '主键ID',
  5. `app_id` varchar(64) NOT NULL DEFAULT '' COMMENT '应用ID',
  6. `app_secret` text NOT NULL COMMENT '应用密钥(加密存储)',
  7. `name` varchar(255) NOT NULL DEFAULT '' COMMENT '应用名称',
  8. `description` text COMMENT '应用描述',
  9. `website` varchar(500) NOT NULL DEFAULT '' COMMENT '应用网站',
  10. `logo` varchar(500) NOT NULL DEFAULT '' COMMENT '应用Logo',
  11. `callback_url` varchar(500) NOT NULL DEFAULT '' COMMENT '回调地址',
  12. `contact_email` varchar(255) NOT NULL DEFAULT '' COMMENT '联系邮箱',
  13. `status` varchar(20) NOT NULL DEFAULT 'PENDING' COMMENT '应用状态',
  14. `auth_type` varchar(20) NOT NULL DEFAULT 'API_KEY' COMMENT '认证类型',
  15. `scopes` json COMMENT '权限范围',
  16. `rate_limits` json COMMENT '限流配置',
  17. `ip_whitelist` json COMMENT 'IP白名单',
  18. `user_id` int(11) NOT NULL DEFAULT 0 COMMENT '创建用户ID',
  19. `user_name` varchar(100) NOT NULL DEFAULT '' COMMENT '创建用户名称',
  20. `approved_at` timestamp NULL DEFAULT NULL COMMENT '审核时间',
  21. `approved_by` int(11) DEFAULT NULL COMMENT '审核人ID',
  22. `approved_note` text COMMENT '审核备注',
  23. `expires_at` timestamp NULL DEFAULT NULL COMMENT '过期时间',
  24. `last_used_at` timestamp NULL DEFAULT NULL COMMENT '最后使用时间',
  25. `created_at` timestamp NULL DEFAULT CURRENT_TIMESTAMP COMMENT '创建时间',
  26. `updated_at` timestamp NULL DEFAULT CURRENT_TIMESTAMP ON UPDATE CURRENT_TIMESTAMP COMMENT '更新时间',
  27. PRIMARY KEY (`id`),
  28. UNIQUE KEY `uk_app_id` (`app_id`),
  29. KEY `idx_user_id` (`user_id`),
  30. KEY `idx_status` (`status`),
  31. KEY `idx_auth_type` (`auth_type`),
  32. KEY `idx_expires_at` (`expires_at`),
  33. KEY `idx_created_at` (`created_at`)
  34. ) ENGINE=InnoDB DEFAULT CHARSET=utf8mb4 COLLATE=utf8mb4_unicode_ci COMMENT='开放API应用表';
  35. -- OpenAPI模块 - API调用日志表
  36. -- 用于记录所有API调用的详细信息
  37. CREATE TABLE `kku_openapi_logs` (
  38. `id` bigint(20) unsigned NOT NULL AUTO_INCREMENT COMMENT '主键ID',
  39. `app_id` varchar(64) NOT NULL DEFAULT '' COMMENT '应用ID',
  40. `user_id` int(11) DEFAULT NULL COMMENT '用户ID',
  41. `method` varchar(10) NOT NULL DEFAULT '' COMMENT '请求方法',
  42. `uri` varchar(500) NOT NULL DEFAULT '' COMMENT '请求URI',
  43. `params` json COMMENT '请求参数',
  44. `headers` json COMMENT '请求头',
  45. `ip_address` varchar(45) NOT NULL DEFAULT '' COMMENT 'IP地址',
  46. `user_agent` text COMMENT '用户代理',
  47. `response_code` int(11) NOT NULL DEFAULT 0 COMMENT '响应状态码',
  48. `response_time` int(11) NOT NULL DEFAULT 0 COMMENT '响应时间(毫秒)',
  49. `response_size` int(11) NOT NULL DEFAULT 0 COMMENT '响应大小(字节)',
  50. `error_message` text COMMENT '错误信息',
  51. `scope` varchar(50) NOT NULL DEFAULT '' COMMENT '使用的权限范围',
  52. `rate_limit_hit` tinyint(1) NOT NULL DEFAULT 0 COMMENT '是否触发限流',
  53. `created_at` timestamp NULL DEFAULT CURRENT_TIMESTAMP COMMENT '创建时间',
  54. PRIMARY KEY (`id`),
  55. KEY `idx_app_id` (`app_id`),
  56. KEY `idx_user_id` (`user_id`),
  57. KEY `idx_method` (`method`),
  58. KEY `idx_response_code` (`response_code`),
  59. KEY `idx_scope` (`scope`),
  60. KEY `idx_created_at` (`created_at`),
  61. KEY `idx_ip_address` (`ip_address`)
  62. ) ENGINE=InnoDB DEFAULT CHARSET=utf8mb4 COLLATE=utf8mb4_unicode_ci COMMENT='API调用日志表';
  63. -- OpenAPI模块 - API权限范围表
  64. -- 用于定义和管理API权限范围
  65. CREATE TABLE `kku_openapi_scopes` (
  66. `id` bigint(20) unsigned NOT NULL AUTO_INCREMENT COMMENT '主键ID',
  67. `scope_name` varchar(50) NOT NULL DEFAULT '' COMMENT '权限范围名称',
  68. `scope_label` varchar(100) NOT NULL DEFAULT '' COMMENT '权限范围标签',
  69. `description` text COMMENT '权限描述',
  70. `category` varchar(50) NOT NULL DEFAULT '' COMMENT '权限分类',
  71. `risk_level` tinyint(4) NOT NULL DEFAULT 1 COMMENT '风险级别(1-5)',
  72. `is_default` tinyint(1) NOT NULL DEFAULT 0 COMMENT '是否默认权限',
  73. `is_enabled` tinyint(1) NOT NULL DEFAULT 1 COMMENT '是否启用',
  74. `dependencies` json COMMENT '依赖的权限',
  75. `created_at` timestamp NULL DEFAULT CURRENT_TIMESTAMP COMMENT '创建时间',
  76. `updated_at` timestamp NULL DEFAULT CURRENT_TIMESTAMP ON UPDATE CURRENT_TIMESTAMP COMMENT '更新时间',
  77. PRIMARY KEY (`id`),
  78. UNIQUE KEY `uk_scope_name` (`scope_name`),
  79. KEY `idx_category` (`category`),
  80. KEY `idx_risk_level` (`risk_level`),
  81. KEY `idx_is_enabled` (`is_enabled`)
  82. ) ENGINE=InnoDB DEFAULT CHARSET=utf8mb4 COLLATE=utf8mb4_unicode_ci COMMENT='API权限范围表';
  83. -- 插入默认权限范围数据
  84. INSERT INTO `kku_openapi_scopes` (`scope_name`, `scope_label`, `description`, `category`, `risk_level`, `is_default`) VALUES
  85. ('USER_READ', '读取用户信息', '允许读取用户基本信息、游戏数据等', '用户管理', 1, 1),
  86. ('USER_WRITE', '修改用户信息', '允许修改用户基本信息、游戏设置等', '用户管理', 3, 0),
  87. ('USER_DELETE', '删除用户信息', '允许删除用户账户(危险操作)', '用户管理', 5, 0),
  88. ('GAME_READ', '读取游戏数据', '允许读取游戏内数据,如等级、经验等', '游戏数据', 1, 1),
  89. ('GAME_WRITE', '修改游戏数据', '允许修改游戏内数据,如经验、等级等', '游戏数据', 3, 0),
  90. ('GAME_ADMIN', '游戏管理权限', '允许执行游戏管理操作,如重置数据等', '游戏数据', 5, 0),
  91. ('ITEM_READ', '读取物品信息', '允许读取用户物品信息和库存', '物品管理', 1, 0),
  92. ('ITEM_WRITE', '修改物品信息', '允许修改物品属性和数量', '物品管理', 3, 0),
  93. ('ITEM_TRANSFER', '转移物品', '允许在用户间转移物品', '物品管理', 4, 0),
  94. ('FUND_READ', '读取资金信息', '允许读取用户资金余额和记录', '资金管理', 2, 0),
  95. ('FUND_WRITE', '修改资金信息', '允许修改用户资金余额', '资金管理', 4, 0),
  96. ('FUND_TRANSFER', '转账权限', '允许执行转账操作', '资金管理', 5, 0),
  97. ('TRADE_READ', '读取交易信息', '允许读取交易记录和市场信息', '交易管理', 1, 0),
  98. ('TRADE_WRITE', '创建交易', '允许创建新的交易订单', '交易管理', 3, 0),
  99. ('TRADE_CANCEL', '取消交易', '允许取消交易订单', '交易管理', 3, 0),
  100. ('STATS_READ', '读取统计数据', '允许读取统计数据和报表', '统计分析', 1, 0),
  101. ('STATS_EXPORT', '导出统计数据', '允许导出统计数据', '统计分析', 2, 0),
  102. ('SYSTEM_READ', '读取系统信息', '允许读取系统状态和配置信息', '系统管理', 2, 0),
  103. ('SYSTEM_ADMIN', '系统管理权限', '允许执行系统管理操作', '系统管理', 5, 0);
  104. -- OpenAPI模块 - API统计表
  105. -- 用于存储API调用统计数据
  106. CREATE TABLE `kku_openapi_stats` (
  107. `id` bigint(20) unsigned NOT NULL AUTO_INCREMENT COMMENT '主键ID',
  108. `app_id` varchar(64) NOT NULL DEFAULT '' COMMENT '应用ID',
  109. `date` date NOT NULL COMMENT '统计日期',
  110. `hour` tinyint(4) DEFAULT NULL COMMENT '统计小时(0-23)',
  111. `total_requests` int(11) NOT NULL DEFAULT 0 COMMENT '总请求数',
  112. `successful_requests` int(11) NOT NULL DEFAULT 0 COMMENT '成功请求数',
  113. `failed_requests` int(11) NOT NULL DEFAULT 0 COMMENT '失败请求数',
  114. `rate_limited_requests` int(11) NOT NULL DEFAULT 0 COMMENT '被限流请求数',
  115. `average_response_time` int(11) NOT NULL DEFAULT 0 COMMENT '平均响应时间(毫秒)',
  116. `total_response_size` bigint(20) NOT NULL DEFAULT 0 COMMENT '总响应大小(字节)',
  117. `unique_ips` int(11) NOT NULL DEFAULT 0 COMMENT '唯一IP数量',
  118. `created_at` timestamp NULL DEFAULT CURRENT_TIMESTAMP COMMENT '创建时间',
  119. `updated_at` timestamp NULL DEFAULT CURRENT_TIMESTAMP ON UPDATE CURRENT_TIMESTAMP COMMENT '更新时间',
  120. PRIMARY KEY (`id`),
  121. UNIQUE KEY `uk_app_date_hour` (`app_id`, `date`, `hour`),
  122. KEY `idx_date` (`date`),
  123. KEY `idx_hour` (`hour`)
  124. ) ENGINE=InnoDB DEFAULT CHARSET=utf8mb4 COLLATE=utf8mb4_unicode_ci COMMENT='API统计表';
  125. -- OpenAPI模块 - Webhook配置表
  126. -- 用于管理应用的回调配置
  127. CREATE TABLE `kku_openapi_webhooks` (
  128. `id` bigint(20) unsigned NOT NULL AUTO_INCREMENT COMMENT '主键ID',
  129. `app_id` varchar(64) NOT NULL DEFAULT '' COMMENT '应用ID',
  130. `event_type` varchar(50) NOT NULL DEFAULT '' COMMENT '事件类型',
  131. `webhook_url` varchar(500) NOT NULL DEFAULT '' COMMENT '回调URL',
  132. `secret` varchar(255) NOT NULL DEFAULT '' COMMENT '签名密钥',
  133. `is_enabled` tinyint(1) NOT NULL DEFAULT 1 COMMENT '是否启用',
  134. `retry_times` tinyint(4) NOT NULL DEFAULT 3 COMMENT '重试次数',
  135. `timeout` int(11) NOT NULL DEFAULT 10 COMMENT '超时时间(秒)',
  136. `last_triggered_at` timestamp NULL DEFAULT NULL COMMENT '最后触发时间',
  137. `last_success_at` timestamp NULL DEFAULT NULL COMMENT '最后成功时间',
  138. `failure_count` int(11) NOT NULL DEFAULT 0 COMMENT '连续失败次数',
  139. `created_at` timestamp NULL DEFAULT CURRENT_TIMESTAMP COMMENT '创建时间',
  140. `updated_at` timestamp NULL DEFAULT CURRENT_TIMESTAMP ON UPDATE CURRENT_TIMESTAMP COMMENT '更新时间',
  141. PRIMARY KEY (`id`),
  142. KEY `idx_app_id` (`app_id`),
  143. KEY `idx_event_type` (`event_type`),
  144. KEY `idx_is_enabled` (`is_enabled`)
  145. ) ENGINE=InnoDB DEFAULT CHARSET=utf8mb4 COLLATE=utf8mb4_unicode_ci COMMENT='Webhook配置表';
  146. -- OpenAPI模块 - 限流记录表
  147. -- 用于记录限流状态和统计
  148. CREATE TABLE `kku_openapi_rate_limits` (
  149. `id` bigint(20) unsigned NOT NULL AUTO_INCREMENT COMMENT '主键ID',
  150. `app_id` varchar(64) NOT NULL DEFAULT '' COMMENT '应用ID',
  151. `scope` varchar(50) NOT NULL DEFAULT '' COMMENT '权限范围',
  152. `ip_address` varchar(45) NOT NULL DEFAULT '' COMMENT 'IP地址',
  153. `window_start` timestamp NOT NULL COMMENT '时间窗口开始',
  154. `window_end` timestamp NOT NULL COMMENT '时间窗口结束',
  155. `request_count` int(11) NOT NULL DEFAULT 0 COMMENT '请求次数',
  156. `limit_count` int(11) NOT NULL DEFAULT 0 COMMENT '限制次数',
  157. `is_blocked` tinyint(1) NOT NULL DEFAULT 0 COMMENT '是否被阻止',
  158. `created_at` timestamp NULL DEFAULT CURRENT_TIMESTAMP COMMENT '创建时间',
  159. `updated_at` timestamp NULL DEFAULT CURRENT_TIMESTAMP ON UPDATE CURRENT_TIMESTAMP COMMENT '更新时间',
  160. PRIMARY KEY (`id`),
  161. UNIQUE KEY `uk_app_scope_ip_window` (`app_id`, `scope`, `ip_address`, `window_start`),
  162. KEY `idx_window_end` (`window_end`),
  163. KEY `idx_is_blocked` (`is_blocked`)
  164. ) ENGINE=InnoDB DEFAULT CHARSET=utf8mb4 COLLATE=utf8mb4_unicode_ci COMMENT='限流记录表';