From 6443e55721e87fea23858cce8b3c18d641b9897d Mon Sep 17 00:00:00 2001 From: chenwenchang <479999519@qq.com> Date: Thu, 19 Sep 2024 10:21:42 +0800 Subject: [PATCH] =?UTF-8?q?feat(frontend):=20=E5=AF=86=E7=A0=81=E8=A7=84?= =?UTF-8?q?=E5=88=99=20#7031?= MIME-Version: 1.0 Content-Type: text/plain; charset=UTF-8 Content-Transfer-Encoding: 8bit --- .../frontend/src/common/const/clusterTypes.ts | 2 + .../frontend/src/common/const/ticketTypes.ts | 3 +- dbm-ui/frontend/src/locales/en.json | 1 - dbm-ui/frontend/src/locales/zh-cn.json | 8 +- .../mongodb/mongodb-permission-account.ts | 26 +- .../model/mysql/mysql-permission-account.ts | 24 +- .../sqlserver/sqlserver-permission-account.ts | 26 +- .../source/mongodbPermissionAccount.ts | 38 +- .../source/mongodbPermissionAuthorize.ts | 10 +- .../services/source/mysqlPermissionAccount.ts | 94 ++ .../source/mysqlPermissionAuthorize.ts | 41 + .../src/services/source/permission.ts | 133 +-- .../source/sqlserverPermissionAccount.ts | 46 +- .../source/sqlserverPermissionAuthorize.ts | 10 +- .../frontend/src/services/types/permission.ts | 36 +- .../add-permission-rule-dialog/Index.vue | 20 +- .../cluster-authorize/ClusterAuthorize.vue | 943 ------------------ .../common/cluster-authorize/Index.vue | 220 ++++ .../components/ErrorMessage.vue | 52 + .../components/RulesPreview.vue | 285 ++++++ .../components/SourceIps.vue | 66 ++ .../components/TargetInstances.vue | 289 ++++++ .../mysql-permission-rules/Index.vue | 79 ++ .../components/DbSelect.vue | 78 ++ .../components/RulesTable.vue | 56 ++ .../components/UserSelect.vue | 85 ++ .../components/permission-rules/Index.vue | 127 +++ .../accounter-rules-selector}/Index.vue | 22 +- .../components/AccountRulesTable.vue | 20 +- .../accout-rules-preview-table/Index.vue | 16 +- .../cluster-authorize/db-form/Mongo.vue | 97 ++ .../cluster-authorize/db-form/Mysql.vue | 117 +++ .../cluster-authorize/db-form/Sqlserver.vue | 97 ++ .../db-form/Tendbcluster.vue | 117 +++ .../db-manage/common/password-input/Index.vue | 370 +++++++ .../index.vue => common/permission/Index.vue} | 209 ++-- .../components/common/AccountCreate.vue | 220 ++++ .../components/common/AccountDetail.vue} | 23 +- .../components/mongo}/CreateRule.vue | 14 +- .../permission/components/mongo/config.ts | 17 + .../permission/components/mysql/config.ts | 33 + .../components/mysql/create-rule/Index.vue | 339 +++++++ .../create-rule/components/PreviewDiff.vue | 357 +++++++ .../create-rule/components/RuleSettings.vue | 390 ++++++++ .../components/sqlserver}/CreateRule.vue | 23 +- .../permission/components/sqlserver/config.ts | 4 + .../db-manage/mongodb/permission/Index.vue | 413 +------- .../mongodb/permission/common/consts.ts | 73 -- .../components/CreateAccountDialog.vue | 478 --------- .../permission/hooks/useDeleteAccount.ts | 60 -- .../components/list/Index.vue | 2 +- .../src/views/db-manage/mongodb/routes.ts | 8 +- .../components/list/Index.vue | 2 +- .../mysql/ha-cluster-list/components/List.vue | 2 +- .../components/template-detail/Index.vue | 12 +- .../components/PrivRuleDetail.vue | 10 +- .../mysql/openarea/template-create/Index.vue | 22 +- .../mysql/permission-rule/common/const.ts | 58 -- .../components/AccountDialog.vue | 511 ---------- .../db-manage/mysql/permission/Index.vue | 9 + .../pages/page1/Index.vue | 2 +- .../pages/page1/Index.vue | 2 +- .../src/views/db-manage/mysql/routes.ts | 4 +- .../single-cluster-list/components/List.vue | 2 +- .../views/db-manage/redis/apply-ha/Index.vue | 20 +- .../db-manage/redis/apply/ApplyRedis.vue | 33 +- .../redis/common/password-input/Index.vue | 299 ------ .../ha-cluster-list/components/List.vue | 2 +- .../db-manage/sqlserver/permission/Index.vue | 513 +--------- .../permission/components/AccountDialog.vue | 511 ---------- .../src/views/db-manage/sqlserver/routes.ts | 2 +- .../single-cluster/components/List.vue | 2 +- .../list/components/list/Index.vue | 2 +- .../components/template-detail/Index.vue | 12 +- .../components/PrivRuleDetail.vue | 10 +- .../openarea-template-create/Index.vue | 16 +- .../components/PermissionRule.vue | 10 +- .../tendb-cluster/permission-list/Index.vue | 202 ---- .../components/ExcelAuthorize.vue | 289 ------ .../tendb-cluster/permission/Index.vue | 489 +-------- .../tendb-cluster/permission/common/consts.ts | 36 - .../components/AccountInfoDialog.vue | 129 --- .../components/AddAccountDialog.vue | 472 --------- .../permission/components/CreateRule.vue | 575 ----------- .../permission/hooks/useDeleteAccount.ts | 64 -- .../pages/page1/Index.vue | 2 +- .../pages/page1/Index.vue | 2 +- .../views/db-manage/tendb-cluster/routes.ts | 10 +- .../views/password-manage/policy/Index.vue | 218 +--- .../policy/components/Content.vue | 325 ++++++ .../src/views/password-manage/routes.ts | 1 + .../index/Index.vue | 37 +- .../task-info/com-factory/Index.vue | 495 +++++++++ .../com-factory/mongodb/AuthorizeRules.vue | 260 +++++ .../mysql/authorize-rule/Index.vue | 250 +++++ .../openarea/components/PermissionRule.vue | 181 ++++ .../com-factory/spider/AuthorizeRules.vue | 204 ++++ .../components/demand-factory/Index.vue | 2 +- .../demand-factory/mongodb/AuthorizeRules.vue | 2 +- .../components/PreviewDiff.vue | 283 ++++++ .../mysql/authorize-rule/Index.vue | 5 +- .../openarea/components/PermissionRule.vue | 12 +- .../spider/AccountRuleChange.vue | 60 ++ .../demand-factory/spider/AuthorizeRules.vue | 4 +- 104 files changed, 6144 insertions(+), 6850 deletions(-) create mode 100644 dbm-ui/frontend/src/services/source/mysqlPermissionAccount.ts create mode 100644 dbm-ui/frontend/src/services/source/mysqlPermissionAuthorize.ts delete mode 100644 dbm-ui/frontend/src/views/db-manage/common/cluster-authorize/ClusterAuthorize.vue create mode 100644 dbm-ui/frontend/src/views/db-manage/common/cluster-authorize/Index.vue create mode 100644 dbm-ui/frontend/src/views/db-manage/common/cluster-authorize/components/ErrorMessage.vue create mode 100644 dbm-ui/frontend/src/views/db-manage/common/cluster-authorize/components/RulesPreview.vue create mode 100644 dbm-ui/frontend/src/views/db-manage/common/cluster-authorize/components/SourceIps.vue create mode 100644 dbm-ui/frontend/src/views/db-manage/common/cluster-authorize/components/TargetInstances.vue create mode 100644 dbm-ui/frontend/src/views/db-manage/common/cluster-authorize/components/mysql-permission-rules/Index.vue create mode 100644 dbm-ui/frontend/src/views/db-manage/common/cluster-authorize/components/mysql-permission-rules/components/DbSelect.vue create mode 100644 dbm-ui/frontend/src/views/db-manage/common/cluster-authorize/components/mysql-permission-rules/components/RulesTable.vue create mode 100644 dbm-ui/frontend/src/views/db-manage/common/cluster-authorize/components/mysql-permission-rules/components/UserSelect.vue create mode 100644 dbm-ui/frontend/src/views/db-manage/common/cluster-authorize/components/permission-rules/Index.vue rename dbm-ui/frontend/src/views/db-manage/common/cluster-authorize/{accouter-rules-selector => components/permission-rules/components/accounter-rules-selector}/Index.vue (89%) rename dbm-ui/frontend/src/views/db-manage/common/cluster-authorize/{accouter-rules-selector => components/permission-rules/components/accounter-rules-selector}/components/AccountRulesTable.vue (94%) rename dbm-ui/frontend/src/views/db-manage/common/cluster-authorize/{ => components/permission-rules/components}/accout-rules-preview-table/Index.vue (95%) create mode 100644 dbm-ui/frontend/src/views/db-manage/common/cluster-authorize/db-form/Mongo.vue create mode 100644 dbm-ui/frontend/src/views/db-manage/common/cluster-authorize/db-form/Mysql.vue create mode 100644 dbm-ui/frontend/src/views/db-manage/common/cluster-authorize/db-form/Sqlserver.vue create mode 100644 dbm-ui/frontend/src/views/db-manage/common/cluster-authorize/db-form/Tendbcluster.vue create mode 100644 dbm-ui/frontend/src/views/db-manage/common/password-input/Index.vue rename dbm-ui/frontend/src/views/db-manage/{mysql/permission-rule/index.vue => common/permission/Index.vue} (70%) create mode 100644 dbm-ui/frontend/src/views/db-manage/common/permission/components/common/AccountCreate.vue rename dbm-ui/frontend/src/views/db-manage/{mongodb/permission/components/AccountInfoDialog.vue => common/permission/components/common/AccountDetail.vue} (76%) rename dbm-ui/frontend/src/views/db-manage/{mongodb/permission/components => common/permission/components/mongo}/CreateRule.vue (96%) create mode 100644 dbm-ui/frontend/src/views/db-manage/common/permission/components/mongo/config.ts create mode 100644 dbm-ui/frontend/src/views/db-manage/common/permission/components/mysql/config.ts create mode 100644 dbm-ui/frontend/src/views/db-manage/common/permission/components/mysql/create-rule/Index.vue create mode 100644 dbm-ui/frontend/src/views/db-manage/common/permission/components/mysql/create-rule/components/PreviewDiff.vue create mode 100644 dbm-ui/frontend/src/views/db-manage/common/permission/components/mysql/create-rule/components/RuleSettings.vue rename dbm-ui/frontend/src/views/db-manage/{sqlserver/permission/components => common/permission/components/sqlserver}/CreateRule.vue (95%) create mode 100644 dbm-ui/frontend/src/views/db-manage/common/permission/components/sqlserver/config.ts delete mode 100644 dbm-ui/frontend/src/views/db-manage/mongodb/permission/common/consts.ts delete mode 100644 dbm-ui/frontend/src/views/db-manage/mongodb/permission/components/CreateAccountDialog.vue delete mode 100644 dbm-ui/frontend/src/views/db-manage/mongodb/permission/hooks/useDeleteAccount.ts delete mode 100644 dbm-ui/frontend/src/views/db-manage/mysql/permission-rule/common/const.ts delete mode 100644 dbm-ui/frontend/src/views/db-manage/mysql/permission-rule/components/AccountDialog.vue create mode 100644 dbm-ui/frontend/src/views/db-manage/mysql/permission/Index.vue delete mode 100644 dbm-ui/frontend/src/views/db-manage/redis/common/password-input/Index.vue delete mode 100644 dbm-ui/frontend/src/views/db-manage/sqlserver/permission/components/AccountDialog.vue delete mode 100644 dbm-ui/frontend/src/views/db-manage/tendb-cluster/permission-list/Index.vue delete mode 100644 dbm-ui/frontend/src/views/db-manage/tendb-cluster/permission-list/components/ExcelAuthorize.vue delete mode 100644 dbm-ui/frontend/src/views/db-manage/tendb-cluster/permission/common/consts.ts delete mode 100644 dbm-ui/frontend/src/views/db-manage/tendb-cluster/permission/components/AccountInfoDialog.vue delete mode 100644 dbm-ui/frontend/src/views/db-manage/tendb-cluster/permission/components/AddAccountDialog.vue delete mode 100644 dbm-ui/frontend/src/views/db-manage/tendb-cluster/permission/components/CreateRule.vue delete mode 100644 dbm-ui/frontend/src/views/db-manage/tendb-cluster/permission/hooks/useDeleteAccount.ts create mode 100644 dbm-ui/frontend/src/views/password-manage/policy/components/Content.vue create mode 100644 dbm-ui/frontend/src/views/ticket-center/common/ticket-detail/components/task-info/com-factory/Index.vue create mode 100644 dbm-ui/frontend/src/views/ticket-center/common/ticket-detail/components/task-info/com-factory/mongodb/AuthorizeRules.vue create mode 100644 dbm-ui/frontend/src/views/ticket-center/common/ticket-detail/components/task-info/com-factory/mysql/authorize-rule/Index.vue create mode 100644 dbm-ui/frontend/src/views/ticket-center/common/ticket-detail/components/task-info/com-factory/mysql/openarea/components/PermissionRule.vue create mode 100644 dbm-ui/frontend/src/views/ticket-center/common/ticket-detail/components/task-info/com-factory/spider/AuthorizeRules.vue create mode 100644 dbm-ui/frontend/src/views/tickets/common/components/demand-factory/mysql/account-rule-change/components/PreviewDiff.vue create mode 100644 dbm-ui/frontend/src/views/tickets/common/components/demand-factory/spider/AccountRuleChange.vue diff --git a/dbm-ui/frontend/src/common/const/clusterTypes.ts b/dbm-ui/frontend/src/common/const/clusterTypes.ts index b0377582fb..8f92077cfe 100644 --- a/dbm-ui/frontend/src/common/const/clusterTypes.ts +++ b/dbm-ui/frontend/src/common/const/clusterTypes.ts @@ -42,3 +42,5 @@ export enum ClusterTypes { SQLSERVER_SINGLE = 'sqlserver_single', // SQLServer单节点版 SQLSERVER_HA = 'sqlserver_ha', // SQLServer主从版 } + +export type ClusterTypeValues = keyof typeof ClusterTypes; diff --git a/dbm-ui/frontend/src/common/const/ticketTypes.ts b/dbm-ui/frontend/src/common/const/ticketTypes.ts index 76114084b2..8077b92cd9 100644 --- a/dbm-ui/frontend/src/common/const/ticketTypes.ts +++ b/dbm-ui/frontend/src/common/const/ticketTypes.ts @@ -40,7 +40,7 @@ export enum TicketTypes { MYSQL_PROXY_UPGRADE = 'MYSQL_PROXY_UPGRADE', // MySQL Proxy 升级 MYSQL_LOCAL_UPGRADE = 'MYSQL_LOCAL_UPGRADE', // MySQL 原地升级 MYSQL_MIGRATE_UPGRADE = 'MYSQL_MIGRATE_UPGRADE', // MySQL 迁移升级 - MYSQL_SLAVE_MIGRATE_UPGRADE = 'MYSQL_SLAVE_MIGRATE_UPGRADE' // MySQL 从库迁移升级 + MYSQL_SLAVE_MIGRATE_UPGRADE = 'MYSQL_SLAVE_MIGRATE_UPGRADE', // MySQL 从库迁移升级 } export enum TicketTypes { REDIS_CLUSTER_APPLY = 'REDIS_CLUSTER_APPLY', @@ -123,7 +123,6 @@ export enum TicketTypes { MONGODB_ENABLE = 'MONGODB_ENABLE', // MongoDB 集群启用 MONGODB_DESTROY = 'MONGODB_DESTROY', // MongoDB 集群删除 MONGODB_SCALE_UPDOWN = 'MONGODB_SCALE_UPDOWN', // MongoDB 分片式集群单个容量变更 - MONGODB_AUTHORIZE = 'MONGODB_AUTHORIZE', // MongoDB 集群授权 MONGODB_EXCEL_AUTHORIZE = 'MONGODB_EXCEL_AUTHORIZE', // MongoDB 导入授权 MONGODB_AUTHORIZE_RULES = 'MONGODB_AUTHORIZE_RULES', // MongoDB 集群授权 MONGODB_EXCEL_AUTHORIZE_RULES = 'MONGODB_EXCEL_AUTHORIZE_RULES', // MongoDB 导入授权 diff --git a/dbm-ui/frontend/src/locales/en.json b/dbm-ui/frontend/src/locales/en.json index 5aa731aa89..c44980d59c 100644 --- a/dbm-ui/frontend/src/locales/en.json +++ b/dbm-ui/frontend/src/locales/en.json @@ -1037,7 +1037,6 @@ "进行中": "In progress", "DB实例权限克隆": "DB instance privileges clone", "DB重命名": "DB Rename", - "MySQL_授权规则": "'MySQL' grant rules", "MySQL单节点_集群管理": "'MySQL standalone' Management", "MySQL单节点详情": "MySQL standalone details", "MySQL主从集群_实例视图": "'MySQL HA' instance view", diff --git a/dbm-ui/frontend/src/locales/zh-cn.json b/dbm-ui/frontend/src/locales/zh-cn.json index 305a6bceea..f0e27c8768 100644 --- a/dbm-ui/frontend/src/locales/zh-cn.json +++ b/dbm-ui/frontend/src/locales/zh-cn.json @@ -1046,11 +1046,10 @@ "清除表数据和结构_droptable": "清除表数据和结构(drop table)", "清除表数据_truncatetable": "清除表数据(truncate table)", "特殊符号序": "特殊符号序", - "包含特殊字符_除空格外": "包含特殊字符,除空格外", "包含数字": "包含数字", "包含大写字母": "包含大写字母", "包含小写字母": "包含小写字母", - "MySQL_授权规则": "【MySQL】授权规则", + "指定特殊字符(s)": "指定特殊字符({s})", "MySQL主从集群_实例详情": "【MySQL 主从集群】实例详情", "MySQL主从集群_实例视图": "【MySQL 主从集群】实例视图", "MySQL主从集群详情": "MySQL 主从集群详情", @@ -2569,7 +2568,6 @@ "复制域名": "复制域名", "克隆分区策略": "克隆分区策略", "注意_对从域名授权时仅会授予 select 权限": "注意:对从域名授权时仅会授予 select 权限", - "mongDB实例视图": "【MongDB】实例视图", "实例:name": "实例:{name}", "从域名": "从域名", "请输入关键字或选择条件搜索": "请输入关键字或选择条件搜索", @@ -2594,9 +2592,6 @@ "申请MongoDB副本集部署": "申请 MongoDB 副本集部署", "MongoDB分片集群部署": "MongoDB 分片集群部署", "MongoDB副本集部署": "MongoDB 副本集部署", - "【MongDB】分片集群管理": "【MongDB】分片集群管理", - "【MongDB】副本集集群管理": "【MongDB】副本集集群管理", - "【MongDB】授权规则": "【MongDB】授权规则", "MongoDB版本": "MongoDB 版本", "默认从n开始分配": "默认从 {0} 开始分配", "每台主机oplog容量占比": "每台主机oplog容量占比", @@ -3483,6 +3478,7 @@ "中的任意 n 种": "中的任意 {n} 种", "不允许超过 x 位连续字符": "不允许超过 {x} 位连续字符", "不允许的字符: s": "不允许的字符: {s}", + "包含特殊字符_除空格外": "包含特殊字符_除空格外", "请先添加实例": "请先添加实例", "【SQLServer】授权规则": "【SQLServer】授权规则", "【MySQL】授权规则": "【MySQL】授权规则", diff --git a/dbm-ui/frontend/src/services/model/mongodb/mongodb-permission-account.ts b/dbm-ui/frontend/src/services/model/mongodb/mongodb-permission-account.ts index 5ef9304469..8202375d3d 100644 --- a/dbm-ui/frontend/src/services/model/mongodb/mongodb-permission-account.ts +++ b/dbm-ui/frontend/src/services/model/mongodb/mongodb-permission-account.ts @@ -11,29 +11,21 @@ * the specific language governing permissions and limitations under the License. */ +import type { PermissionRule, PermissionRuleAccount, PermissionRuleInfo } from '@services/types'; + import { isRecentDays } from '@utils'; -export default class MongodbPermissonAccount { - account: { - account_id: number; - bk_biz_id: number; - create_time: string; - creator: string; - password: string; - user: string; +export default class MongodbPermissonAccount implements PermissionRule { + account: PermissionRuleAccount; + permission: { + mongodb_account_delete: boolean; + mongodb_add_account_rule: boolean; }; - rules: Array<{ - access_db: string; - account_id: number; - bk_biz_id: number; - create_time: string; - creator: string; - privilege: string; - rule_id: number; - }>; + rules: PermissionRuleInfo[]; constructor(payload = {} as MongodbPermissonAccount) { this.account = payload.account; + this.permission = payload.permission; this.rules = payload.rules; } diff --git a/dbm-ui/frontend/src/services/model/mysql/mysql-permission-account.ts b/dbm-ui/frontend/src/services/model/mysql/mysql-permission-account.ts index d3275896bc..4877023e9f 100644 --- a/dbm-ui/frontend/src/services/model/mysql/mysql-permission-account.ts +++ b/dbm-ui/frontend/src/services/model/mysql/mysql-permission-account.ts @@ -11,33 +11,21 @@ * the specific language governing permissions and limitations under the License. */ +import type { PermissionRule, PermissionRuleAccount, PermissionRuleInfo } from '@services/types'; + import { isRecentDays } from '@utils'; -export default class MysqlPermissonAccount { - account: { - account_id: number; - bk_biz_id: number; - create_time: string; - creator: string; - user: string; - }; +export default class MysqlPermissionAccount implements PermissionRule { + account: PermissionRuleAccount; permission: { mysql_account_delete: boolean; mysql_add_account_rule: boolean; tendbcluster_account_delete: boolean; tendbcluster_add_account_rule: boolean; }; - rules: Array<{ - access_db: string; - account_id: number; - bk_biz_id: number; - create_time: string; - creator: string; - privilege: string; - rule_id: number; - }>; + rules: PermissionRuleInfo[]; - constructor(payload = {} as MysqlPermissonAccount) { + constructor(payload = {} as MysqlPermissionAccount) { this.account = payload.account; this.permission = payload.permission; this.rules = payload.rules; diff --git a/dbm-ui/frontend/src/services/model/sqlserver/sqlserver-permission-account.ts b/dbm-ui/frontend/src/services/model/sqlserver/sqlserver-permission-account.ts index 2297b6206b..14f78b8f3d 100644 --- a/dbm-ui/frontend/src/services/model/sqlserver/sqlserver-permission-account.ts +++ b/dbm-ui/frontend/src/services/model/sqlserver/sqlserver-permission-account.ts @@ -13,29 +13,21 @@ import dayjs from 'dayjs'; +import type { PermissionRule, PermissionRuleAccount, PermissionRuleInfo } from '@services/types'; + import { utcDisplayTime } from '@utils'; -export default class SqlserverPermissionAccount { - account: { - account_id: number; - bk_biz_id: number; - create_time: string; - creator: string; - password: string; - user: string; +export default class SqlserverPermissionAccount implements PermissionRule { + account: PermissionRuleAccount; + permission: { + sqlserver_account_delete: boolean; + sqlserver_add_account_rule: boolean; }; - rules: { - access_db: string; - account_id: number; - bk_biz_id: number; - create_time: string; - creator: string; - privilege: string; - rule_id: number; - }[]; + rules: PermissionRuleInfo[]; constructor(payload: SqlserverPermissionAccount) { this.account = payload.account; + this.permission = payload.permission; this.rules = payload.rules; } diff --git a/dbm-ui/frontend/src/services/source/mongodbPermissionAccount.ts b/dbm-ui/frontend/src/services/source/mongodbPermissionAccount.ts index aa7218b68d..df1b258e69 100644 --- a/dbm-ui/frontend/src/services/source/mongodbPermissionAccount.ts +++ b/dbm-ui/frontend/src/services/source/mongodbPermissionAccount.ts @@ -14,20 +14,16 @@ import MongodbPermissonAccountModel from '@services/model/mongodb/mongodb-permission-account'; import type { ListBase } from '@services/types'; -import { useGlobalBizs } from '@stores'; - import type { AccountTypesValues } from '@common/const'; import http, { type IRequestPayload } from '../http'; -const { currentBizId } = useGlobalBizs(); - -const path = `/apis/mongodb/bizs/${currentBizId}/permission/account`; +const getRootPath = () => `/apis/mongodb/bizs/${window.PROJECT_CONFIG.BIZ_ID}/permission/account`; /** * 添加账号规则 */ -export function addMongodbAccountRule(params: { +export function addAccountRule(params: { access_db: string; privilege: { mongo_user: string[]; @@ -36,27 +32,27 @@ export function addMongodbAccountRule(params: { account_id: number | null; account_type: AccountTypesValues; }) { - return http.post(`${path}/add_account_rule/`, params); + return http.post(`${getRootPath()}/add_account_rule/`, params); } /** * 创建账号 */ -export function createMongodbAccount(params: { user: string; password: string; account_type?: AccountTypesValues }) { - return http.post(`${path}/create_account/`, params); +export function createAccount(params: { user: string; password: string; account_type?: AccountTypesValues }) { + return http.post(`${getRootPath()}/create_account/`, params); } /** * 删除账号 */ -export function deleteMongodbAccount(params: { bizId: number; account_id: number; account_type?: AccountTypesValues }) { - return http.delete(`${path}/delete_account/`, params); +export function deleteAccount(params: { bizId: number; account_id: number; account_type?: AccountTypesValues }) { + return http.delete(`${getRootPath()}/delete_account/`, params); } /** * 查询账号规则列表 */ -export function getMongodbPermissionRules( +export function getPermissionRules( params: { limit?: number; offset?: number; @@ -68,7 +64,7 @@ export function getMongodbPermissionRules( payload = {} as IRequestPayload, ) { return http - .get>(`${path}/list_account_rules/`, params, payload) + .get>(`${getRootPath()}/list_account_rules/`, params, payload) .then((res) => ({ ...res, results: res.results.map((item) => new MongodbPermissonAccountModel(item)), @@ -78,13 +74,11 @@ export function getMongodbPermissionRules( /** * 查询账号规则 */ -export function queryMongodbAccountRules(params: { - user: string; - access_dbs: string[]; - account_type?: AccountTypesValues; -}) { - return http.post>(`${path}/query_account_rules/`, params).then((res) => ({ - ...res, - results: res.results.map((item) => new MongodbPermissonAccountModel(item)), - })); +export function queryAccountRules(params: { user: string; access_dbs: string[]; account_type?: AccountTypesValues }) { + return http + .post>(`${getRootPath()}/query_account_rules/`, params) + .then((res) => ({ + ...res, + results: res.results.map((item) => new MongodbPermissonAccountModel(item)), + })); } diff --git a/dbm-ui/frontend/src/services/source/mongodbPermissionAuthorize.ts b/dbm-ui/frontend/src/services/source/mongodbPermissionAuthorize.ts index 5761087e00..0bcf5ff41f 100644 --- a/dbm-ui/frontend/src/services/source/mongodbPermissionAuthorize.ts +++ b/dbm-ui/frontend/src/services/source/mongodbPermissionAuthorize.ts @@ -11,18 +11,14 @@ * the specific language governing permissions and limitations under the License. */ -import { useGlobalBizs } from '@stores'; - import http from '../http'; -const { currentBizId } = useGlobalBizs(); - -const path = `/apis/mongodb/bizs/${currentBizId}/permission/authorize`; +const getRootPath = () => `/apis/mongodb/bizs/${window.PROJECT_CONFIG.BIZ_ID}/permission/authorize`; /** * MongoDB 授权规则前置检查 */ -export function preCheckMongodbAuthorizeRules(params: { +export function preCheckAuthorizeRules(params: { mongo_users: { user: string; access_dbs: string[]; @@ -45,5 +41,5 @@ export function preCheckMongodbAuthorizeRules(params: { authorize_uid: string; message: string; pre_check: boolean; - }>(`${path}/pre_check_rules/`, params); + }>(`${getRootPath()}/pre_check_rules/`, params); } diff --git a/dbm-ui/frontend/src/services/source/mysqlPermissionAccount.ts b/dbm-ui/frontend/src/services/source/mysqlPermissionAccount.ts new file mode 100644 index 0000000000..e711f9c73e --- /dev/null +++ b/dbm-ui/frontend/src/services/source/mysqlPermissionAccount.ts @@ -0,0 +1,94 @@ +/* + * TencentBlueKing is pleased to support the open source community by making 蓝鲸智云-DB管理系统(BlueKing-BK-DBM) available. + * + * Copyright (C) 2017-2023 THL A29 Limited, a Tencent company. All rights reserved. + * + * Licensed under the MIT License (the "License"); you may not use this file except in compliance with the License. + * You may obtain a copy of the License at https://opensource.org/licenses/MIT + * + * Unless required by applicable law or agreed to in writing, software distributed under the License is distributed + * on an "AS IS" BASIS, WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. See the License for + * the specific language governing permissions and limitations under the License. + */ +import MysqlPermissionAccountModel from '@services/model/mysql/mysql-permission-account'; +import type { ListBase } from '@services/types'; +import type { AccountRule, CreateAccountParams, PermissionRule } from '@services/types/permission'; + +import type { AccountTypesValues } from '@common/const'; + +import http, { type IRequestPayload } from '../http'; + +const getRootPath = () => `/apis/mysql/bizs/${window.PROJECT_CONFIG.BIZ_ID}/permission/account`; + +/** + * 查询账号规则列表 + */ +export const getPermissionRules = ( + params: { + limit?: number; + offset?: number; + bk_biz_id: number; + rule_ids?: string; + user?: string; + access_db?: string; + privilege?: string; + account_type?: AccountTypesValues; + }, + payload = {} as IRequestPayload, +) => + http + .get>(`${getRootPath()}/list_account_rules/`, params, payload) + .then((res) => ({ + ...res, + results: res.results.map((item) => new MysqlPermissionAccountModel(item)), + })); +/** + * 创建账户 + */ +export const createAccount = (params: CreateAccountParams) => http.post(`${getRootPath()}/create_account/`, params); + +/** + * 删除账号 + */ +export const deleteAccount = (params: { bizId: number; account_id: number; account_type?: AccountTypesValues }) => + http.delete(`${getRootPath()}/delete_account/`, params); + +/** + * 添加账号规则 + */ +export const createAccountRule = (params: AccountRule & { bk_biz_id: number }) => + http.post(`${getRootPath()}/add_account_rule/`, params); + +/** + * 修改账号规则 + */ +export const modifyAccountRule = ( + params: AccountRule & { + rule_id: number; + bk_biz_id: number; + }, +) => http.post(`${getRootPath()}/modify_account_rule/`, params); + +/** + * 查询账号规则 + */ +export const queryAccountRules = (params: { user: string; access_dbs: string[]; account_type: AccountTypesValues }) => + http.post>(`${getRootPath()}/query_account_rules/`, params); + +/** + * 添加账号规则前置检查 + */ +export const preCheckAddAccountRule = (params: { + account_id: number | null; + access_db: string; + privilege: { + dml: string[]; + ddl: string[]; + glob: string[]; + }; + account_type: AccountTypesValues; +}) => + http.post<{ + force_run: boolean; + warning: string | null; + }>(`${getRootPath()}/pre_check_add_account_rule/`, params); diff --git a/dbm-ui/frontend/src/services/source/mysqlPermissionAuthorize.ts b/dbm-ui/frontend/src/services/source/mysqlPermissionAuthorize.ts new file mode 100644 index 0000000000..56a17a305f --- /dev/null +++ b/dbm-ui/frontend/src/services/source/mysqlPermissionAuthorize.ts @@ -0,0 +1,41 @@ +/* + * TencentBlueKing is pleased to support the open source community by making 蓝鲸智云-DB管理系统(BlueKing-BK-DBM) available. + * + * Copyright (C) 2017-2023 THL A29 Limited, a Tencent company. All rights reserved. + * + * Licensed under the MIT License (the "License"); you may not use this file except in compliance with the License. + * You may obtain a copy of the License at https://opensource.org/licenses/MIT + * + * Unless required by applicable law or agreed to in writing, software distributed under the License is distributed + * on an "AS IS" BASIS, WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. See the License for + * the specific language governing permissions and limitations under the License. + */ +import type { AuthorizePreCheckData, AuthorizePreCheckResult } from '@services/types/permission'; + +import http from '../http'; + +/** + * 授权规则前置检查 + */ +export const preCheckAuthorizeRules = (params: AuthorizePreCheckData & { bizId: number }) => + http.post(`/apis/mysql/bizs/${params.bizId}/permission/authorize/pre_check_rules/`, params); + +/** + * 权限克隆前置检查 + */ +export const precheckPermissionClone = (params: { + bizId: number; + clone_type: 'instance' | 'client'; + clone_list: Array<{ source: string; target: string }>; + clone_cluster_type: 'mysql' | 'tendbcluster'; +}) => + http.post<{ + clone_data_list: Array<{ + message: string; + source: string; + target: Array | string; + }>; + clone_uid: string; + message: string; + pre_check: boolean; + }>(`/apis/mysql/bizs/${params.bizId}/permission/clone/pre_check_clone/`, params); diff --git a/dbm-ui/frontend/src/services/source/permission.ts b/dbm-ui/frontend/src/services/source/permission.ts index ca53dbdfc3..8420e5a08d 100644 --- a/dbm-ui/frontend/src/services/source/permission.ts +++ b/dbm-ui/frontend/src/services/source/permission.ts @@ -11,21 +11,12 @@ * the specific language governing permissions and limitations under the License. */ import AdminPasswordModel from '@services/model/admin-password/admin-password'; -import MysqlPermissonAccountModel from '@services/model/mysql/mysql-permission-account'; import type { ListBase } from '@services/types'; -import type { AccountTypesValues, ClusterTypes, DBTypes } from '@common/const'; +import type { ClusterTypes, DBTypes } from '@common/const'; import http, { type IRequestPayload } from '../http'; -import type { - AccountRule, - AuthorizePreCheckData, - AuthorizePreCheckResult, - CreateAccountParams, - PasswordPolicy, - PasswordStrength, - PermissionRule, -} from '../types/permission'; +import type { PasswordPolicy, PasswordStrength } from '../types/permission'; // 密码随机化周期 interface RamdomCycle { @@ -52,13 +43,13 @@ interface AdminPasswordResultItem { /** * 查询密码安全策略 */ -export const getPasswordPolicy = (params = {}, payload = {} as IRequestPayload) => - http.get('/apis/conf/password_policy/get_password_policy/', params, payload); +export const getPasswordPolicy = (params: { name: string }) => + http.get('/apis/conf/password_policy/get_password_policy/', params); /** * 更新密码安全策略 */ -export const updatePasswordPolicy = (params: PasswordPolicy) => +export const updatePasswordPolicy = (params: PasswordPolicy & { reset: boolean }) => http.post('/apis/conf/password_policy/update_password_policy/', params); /** @@ -76,7 +67,7 @@ export const modifyRandomCycle = (params: RamdomCycle) => /** * 获取符合密码强度的字符串 */ -export const getRandomPassword = (params?: { security_type: 'password' | 'redis_password' }) => +export const getRandomPassword = (params?: { security_type: string }) => http.get<{ password: string; }>('/apis/conf/password_policy/get_random_password/', params); @@ -131,115 +122,5 @@ export const getRSAPublicKeys = (params: { names: string[] }) => /** * 校验密码强度 */ -export const verifyPasswordStrength = (params: { password: string }) => +export const verifyPasswordStrength = (params: { security_type: string; password: string }) => http.post('/apis/conf/password_policy/verify_password_strength/', params); - -/** - * 查询账号规则列表 - */ -export const getPermissionRules = ( - params: { - limit?: number; - offset?: number; - bk_biz_id: number; - rule_ids?: string; - user?: string; - access_db?: string; - privilege?: string; - account_type?: AccountTypesValues; - }, - payload = {} as IRequestPayload, -) => - http - .get< - ListBase - >(`/apis/mysql/bizs/${params.bk_biz_id}/permission/account/list_account_rules/`, params, payload) - .then((res) => ({ - ...res, - results: res.results.map((item) => new MysqlPermissonAccountModel(item)), - })); -/** - * 创建账户 - */ -export const createAccount = (params: CreateAccountParams & { bk_biz_id: number }) => - http.post(`/apis/mysql/bizs/${params.bk_biz_id}/permission/account/create_account/`, params); - -/** - * 删除账号 - */ -export const deleteAccount = (params: { bizId: number; account_id: number; account_type?: AccountTypesValues }) => - http.delete(`/apis/mysql/bizs/${params.bizId}/permission/account/delete_account/`, params); - -/** - * 添加账号规则 - */ -export const createAccountRule = (params: AccountRule & { bk_biz_id: number }) => - http.post(`/apis/mysql/bizs/${params.bk_biz_id}/permission/account/add_account_rule/`, params); - -/** - * 修改账号规则 - */ -export const modifyAccountRule = ( - params: AccountRule & { - rule_id: number; - bk_biz_id: number; - }, -) => http.post(`/apis/mysql/bizs/${params.bk_biz_id}/permission/account/modify_account_rule/`, params); - -/** - * 授权规则前置检查 - */ -export const preCheckAuthorizeRules = (params: AuthorizePreCheckData & { bizId: number }) => - http.post(`/apis/mysql/bizs/${params.bizId}/permission/authorize/pre_check_rules/`, params); - -/** - * 查询账号规则 - */ -export const queryAccountRules = (params: { - bizId: number; - user: string; - access_dbs: string[]; - account_type: AccountTypesValues; -}) => - http.post>( - `/apis/mysql/bizs/${params.bizId}/permission/account/query_account_rules/`, - params, - ); - -/** - * 添加账号规则前置检查 - */ -export const preCheckAddAccountRule = (params: { - account_id: number | null; - access_db: string; - privilege: { - dml: string[]; - ddl: string[]; - glob: string[]; - }; - account_type: AccountTypesValues; -}) => - http.post<{ - force_run: boolean; - warning: string | null; - }>(`/apis/mysql/bizs/${window.PROJECT_CONFIG.BIZ_ID}/permission/account/pre_check_add_account_rule/`, params); - -/** - * 权限克隆前置检查 - */ -export const precheckPermissionClone = (params: { - bizId: number; - clone_type: 'instance' | 'client'; - clone_list: Array<{ source: string; target: string }>; - clone_cluster_type: 'mysql' | 'tendbcluster'; -}) => - http.post<{ - clone_data_list: Array<{ - message: string; - source: string; - target: Array | string; - }>; - clone_uid: string; - message: string; - pre_check: boolean; - }>(`/apis/mysql/bizs/${params.bizId}/permission/clone/pre_check_clone/`, params); diff --git a/dbm-ui/frontend/src/services/source/sqlserverPermissionAccount.ts b/dbm-ui/frontend/src/services/source/sqlserverPermissionAccount.ts index 45cbafb665..9f56d6c332 100644 --- a/dbm-ui/frontend/src/services/source/sqlserverPermissionAccount.ts +++ b/dbm-ui/frontend/src/services/source/sqlserverPermissionAccount.ts @@ -14,20 +14,16 @@ import SqlserverPermissionAccountModel from '@services/model/sqlserver/sqlserver-permission-account'; import type { ListBase } from '@services/types'; -import { useGlobalBizs } from '@stores'; - import type { AccountTypesValues } from '@common/const'; import http from '../http'; -const { currentBizId } = useGlobalBizs(); - -const path = `/apis/sqlserver/bizs/${currentBizId}/permission/account`; +const getRootPath = () => `/apis/sqlserver/bizs/${window.PROJECT_CONFIG.BIZ_ID}/permission/account`; /** * 添加账号规则 */ -export function addSqlserverAccountRule(params: { +export function addAccountRule(params: { account_id: number; access_db: string; privilege: { @@ -36,27 +32,27 @@ export function addSqlserverAccountRule(params: { }; account_type: AccountTypesValues; }) { - return http.post(`${path}/add_account_rule/`, params); + return http.post(`${getRootPath()}/add_account_rule/`, params); } /** * 创建账号 */ -export function createSqlserverAccount(params: { user: string; password: string; account_type?: AccountTypesValues }) { - return http.post(`${path}/create_account/`, params); +export function createAccount(params: { user: string; password: string; account_type?: AccountTypesValues }) { + return http.post(`${getRootPath()}/create_account/`, params); } /** * 删除账号 */ -export function deleteSqlserverAccount(params: { account_id: number; account_type?: AccountTypesValues }) { - return http.delete(`${path}/delete_account/`, params); +export function deleteAccount(params: { account_id: number; account_type?: AccountTypesValues }) { + return http.delete(`${getRootPath()}/delete_account/`, params); } /** * 查询账号规则列表 */ -export function getSqlserverPermissionRules(params: { +export function getPermissionRules(params: { limit?: number; offset?: number; user?: string; @@ -64,22 +60,22 @@ export function getSqlserverPermissionRules(params: { privilege?: string; account_type?: AccountTypesValues; }) { - return http.get>(`${path}/list_account_rules/`, params).then((res) => ({ - ...res, - results: res.results.map((item) => new SqlserverPermissionAccountModel(item)), - })); + return http + .get>(`${getRootPath()}/list_account_rules/`, params) + .then((res) => ({ + ...res, + results: res.results.map((item) => new SqlserverPermissionAccountModel(item)), + })); } /** * 查询账号规则 */ -export function querySqlserverAccountRules(params: { - user: string; - access_dbs: string[]; - account_type?: AccountTypesValues; -}) { - return http.post>(`${path}/query_account_rules/`, params).then((res) => ({ - ...res, - results: res.results.map((item) => new SqlserverPermissionAccountModel(item)), - })); +export function queryAccountRules(params: { user: string; access_dbs: string[]; account_type?: AccountTypesValues }) { + return http + .post>(`${getRootPath()}/query_account_rules/`, params) + .then((res) => ({ + ...res, + results: res.results.map((item) => new SqlserverPermissionAccountModel(item)), + })); } diff --git a/dbm-ui/frontend/src/services/source/sqlserverPermissionAuthorize.ts b/dbm-ui/frontend/src/services/source/sqlserverPermissionAuthorize.ts index 1f05c4b2ec..c626a5c732 100644 --- a/dbm-ui/frontend/src/services/source/sqlserverPermissionAuthorize.ts +++ b/dbm-ui/frontend/src/services/source/sqlserverPermissionAuthorize.ts @@ -11,18 +11,14 @@ * the specific language governing permissions and limitations under the License. */ -import { useGlobalBizs } from '@stores'; - import http from '../http'; -const { currentBizId } = useGlobalBizs(); - -const path = `/apis/sqlserver/bizs/${currentBizId}/permission/authorize`; +const getRootPath = () => `/apis/sqlserver/bizs/${window.PROJECT_CONFIG.BIZ_ID}/permission/authorize`; /** * Sqlserver 授权规则前置检查 */ -export function preCheckSqlserverAuthorizeRules(params: { +export function preCheckAuthorizeRules(params: { sqlserver_users: { user: string; access_dbs: string[]; @@ -48,5 +44,5 @@ export function preCheckSqlserverAuthorizeRules(params: { authorize_uid: string; message: string; pre_check: boolean; - }>(`${path}/pre_check_rules/`, params); + }>(`${getRootPath()}/pre_check_rules/`, params); } diff --git a/dbm-ui/frontend/src/services/types/permission.ts b/dbm-ui/frontend/src/services/types/permission.ts index 0b3d40278c..961b96c47d 100644 --- a/dbm-ui/frontend/src/services/types/permission.ts +++ b/dbm-ui/frontend/src/services/types/permission.ts @@ -36,6 +36,7 @@ export interface PermissionRuleAccount { account_id: number; bk_biz_id: number; user: string; + password: string; creator: string; create_time: string; } @@ -73,17 +74,16 @@ export interface PasswordStrength { * 密码强度校验项 */ export interface PasswordStrengthVerifyInfo { + number_of_types_valid: boolean; + allowed_valid: boolean; + out_of_range: string; + repeats_valid: boolean; follow_keyboards_valid: boolean; follow_letters_valid: boolean; follow_numbers_valid: boolean; follow_symbols_valid: boolean; - lowercase_valid: boolean; - max_length_valid: boolean; min_length_valid: boolean; - numbers_valid: boolean; - repeats_valid: boolean; - symbols_valid: boolean; - uppercase_valid: boolean; + max_length_valid: boolean; } // 密码策略 @@ -91,17 +91,13 @@ export interface PasswordPolicy { id: number; name: string; rule: { - include_rule: PasswordPolicyIncludeRule; - exclude_continuous_rule: { - limit: number; - letters: boolean; - numbers: boolean; - repeats: boolean; - symbols: boolean; - keyboards: boolean; - }; + repeats: number; max_length: number; min_length: number; + include_rule: PasswordPolicyIncludeRule; + weak_password: boolean; + number_of_types: number; + symbols_allowed: string; }; creator?: string; create_time?: string; @@ -117,14 +113,6 @@ export interface PasswordPolicyIncludeRule { uppercase: boolean; } -// 密码策略 include_rule -export interface PasswordPolicyIncludeRule { - numbers: boolean; - symbols: boolean; - lowercase: boolean; - uppercase: boolean; -} - /** * 新增账号规则 */ @@ -144,6 +132,8 @@ export interface AccountRulePrivilege { glob: string[]; } +export type AccountRulePrivilegeKey = keyof AccountRulePrivilege; + /** * 规则授权前置检查信息 */ diff --git a/dbm-ui/frontend/src/views/db-manage/common/add-permission-rule-dialog/Index.vue b/dbm-ui/frontend/src/views/db-manage/common/add-permission-rule-dialog/Index.vue index 41a1e112a5..fcd767efb8 100644 --- a/dbm-ui/frontend/src/views/db-manage/common/add-permission-rule-dialog/Index.vue +++ b/dbm-ui/frontend/src/views/db-manage/common/add-permission-rule-dialog/Index.vue @@ -71,8 +71,10 @@ import type { ISearchValue } from 'bkui-vue/lib/search-select/utils'; import { useI18n } from 'vue-i18n'; - import MysqlPermissonAccountModel from '@services/model/mysql/mysql-permission-account'; - import { getPermissionRules } from '@services/source/permission'; + import MysqlPermissionAccountModel from '@services/model/mysql/mysql-permission-account'; + import { getPermissionRules } from '@services/source/mysqlPermissionAccount'; + + import type { AccountTypes } from '@common/const'; import TextOverflowLayout from '@components/text-overflow-layout/Index.vue'; @@ -80,7 +82,7 @@ interface Props { clusterId: number, - dbType: 'mysql' | 'tendbcluster', + accountType: AccountTypes.MYSQL | AccountTypes.TENDBCLUSTER, } interface Emits { @@ -146,7 +148,7 @@ field: 'user', width: 220, showOverflowTooltip: false, - render: ({ data }: { data: MysqlPermissonAccountModel }) => ( + render: ({ data }: { data: MysqlPermissionAccountModel }) => (