Some checks failed
continuous-integration/drone/push Build is failing
- 后端:钉钉 OAuth 认证服务 - 后端:系统设置 API(钉钉配置) - 前端:登录页钉钉扫码入口 - 前端:系统设置页面 - 数据库迁移脚本
42 lines
2.0 KiB
SQL
42 lines
2.0 KiB
SQL
-- =====================================================
|
||
-- 钉钉免密登录功能 - 数据库迁移脚本
|
||
-- 创建时间: 2026-01-28
|
||
-- 说明: 为考培练系统添加钉钉免密登录支持
|
||
-- =====================================================
|
||
|
||
-- 1. 用户表添加 dingtalk_id 字段
|
||
-- -----------------------------------------------------
|
||
ALTER TABLE users ADD COLUMN dingtalk_id VARCHAR(64) UNIQUE COMMENT '钉钉用户ID';
|
||
CREATE INDEX idx_users_dingtalk_id ON users(dingtalk_id);
|
||
|
||
|
||
-- 2. 配置模板表添加钉钉配置项
|
||
-- -----------------------------------------------------
|
||
INSERT INTO config_templates (config_group, config_key, display_name, description, value_type, is_required, is_secret, sort_order) VALUES
|
||
('dingtalk', 'DINGTALK_APP_KEY', 'AppKey', '钉钉应用的AppKey(从钉钉开放平台获取)', 'string', 1, 0, 1),
|
||
('dingtalk', 'DINGTALK_APP_SECRET', 'AppSecret', '钉钉应用的AppSecret(敏感信息)', 'string', 1, 1, 2),
|
||
('dingtalk', 'DINGTALK_AGENT_ID', 'AgentId', '钉钉应用的AgentId', 'string', 1, 0, 3),
|
||
('dingtalk', 'DINGTALK_CORP_ID', 'CorpId', '钉钉企业的CorpId', 'string', 1, 0, 4);
|
||
|
||
|
||
-- 3. 功能开关表添加钉钉免密登录开关(默认禁用)
|
||
-- -----------------------------------------------------
|
||
INSERT INTO feature_switches (tenant_id, feature_code, feature_name, feature_group, is_enabled, description) VALUES
|
||
(NULL, 'dingtalk_login', '钉钉免密登录', 'auth', 0, '启用后,用户可通过钉钉免密登录系统');
|
||
|
||
|
||
-- =====================================================
|
||
-- 回滚脚本(如需回滚,执行以下SQL)
|
||
-- =====================================================
|
||
/*
|
||
-- 回滚步骤1: 删除功能开关
|
||
DELETE FROM feature_switches WHERE feature_code = 'dingtalk_login';
|
||
|
||
-- 回滚步骤2: 删除配置模板
|
||
DELETE FROM config_templates WHERE config_group = 'dingtalk';
|
||
|
||
-- 回滚步骤3: 删除用户表字段
|
||
ALTER TABLE users DROP INDEX idx_users_dingtalk_id;
|
||
ALTER TABLE users DROP COLUMN dingtalk_id;
|
||
*/
|