From a78ece15105a04864e854919192df4b5b1b588ff Mon Sep 17 00:00:00 2001 From: "gao.zhiyuan" Date: Thu, 15 Sep 2022 09:27:34 +0800 Subject: [PATCH 01/10] =?UTF-8?q?=E4=BA=BA=E5=91=98=E4=BF=A1=E6=81=AF?= =?UTF-8?q?=E6=9F=A5=E8=AF=A2?= MIME-Version: 1.0 Content-Type: text/plain; charset=UTF-8 Content-Transfer-Encoding: 8bit --- api/app/lib/controllers/organization/index.js | 4 +++- 1 file changed, 3 insertions(+), 1 deletion(-) diff --git a/api/app/lib/controllers/organization/index.js b/api/app/lib/controllers/organization/index.js index c525290..c50985d 100644 --- a/api/app/lib/controllers/organization/index.js +++ b/api/app/lib/controllers/organization/index.js @@ -193,7 +193,9 @@ async function user (ctx) { for (let u of userRes.rows.concat(adminRes)) { userIds.add(u.pepUserId) } - let userPepRes = await clickHouse.pepEmis.query(`SELECT user.id AS id, "user"."name" AS name, department.name AS depName, department.id AS depId FROM department_user LEFT JOIN user ON department_user.user=user.id LEFT JOIN department ON department.id=department_user.department WHERE user.id IN (${[...userIds].join(',')}) AND department.delete=false`).toPromise() + let userPepRes = userIds.size ? + await clickHouse.pepEmis.query(`SELECT DISTINCT user.id AS id, "user"."name" AS name, department.name AS depName, department.id AS depId FROM department_user LEFT JOIN user ON department_user.user=user.id LEFT JOIN department ON department.id=department_user.department WHERE user.id IN (${[...userIds].join(',')}) AND department.delete=false`).toPromise() : + [] for (let u of userRes.rows.concat(adminRes)) { const corUsers = userPepRes.filter(up => up.id == u.pepUserId) From c4c392ea156c5b3a259c572e6aaf8210f69a91ec Mon Sep 17 00:00:00 2001 From: "gao.zhiyuan" Date: Thu, 15 Sep 2022 09:34:59 +0800 Subject: [PATCH 02/10] =?UTF-8?q?=E4=BA=BA=E5=91=98=E4=BF=A1=E6=81=AF?= =?UTF-8?q?=E6=9F=A5=E8=AF=A2?= MIME-Version: 1.0 Content-Type: text/plain; charset=UTF-8 Content-Transfer-Encoding: 8bit --- api/app/lib/controllers/organization/index.js | 4 ++-- 1 file changed, 2 insertions(+), 2 deletions(-) diff --git a/api/app/lib/controllers/organization/index.js b/api/app/lib/controllers/organization/index.js index c50985d..358843c 100644 --- a/api/app/lib/controllers/organization/index.js +++ b/api/app/lib/controllers/organization/index.js @@ -48,11 +48,11 @@ async function editUser (ctx) { // 存在且传递id 或者 不传id也存在 // 修改 update storageData.deleted = false - storageData.role = [...new Set([...existUserRes.role, ...role])] + storageData.role = role if ( storageData.role.includes('admin') ) { - storageData.disabled = false + storageData.disabled = true } await models.User.update(storageData, { where: { From ee0f5fde2dd1d3ef0314c63cc0839fea6e3d7bdd Mon Sep 17 00:00:00 2001 From: "gao.zhiyuan" Date: Thu, 15 Sep 2022 09:52:00 +0800 Subject: [PATCH 03/10] =?UTF-8?q?=E4=BA=BA=E5=91=98=E4=BF=A1=E6=81=AF?= =?UTF-8?q?=E6=9F=A5=E8=AF=A2?= MIME-Version: 1.0 Content-Type: text/plain; charset=UTF-8 Content-Transfer-Encoding: 8bit --- api/app/lib/controllers/alarm/app.js | 3 ++- api/app/lib/controllers/organization/index.js | 10 +++++++--- api/app/lib/models/app_alarm.js | 15 ++++++++++++++- api/sequelize-automate.config.js | 2 +- script/0.0.3/1.alert_app_alarm.sql | 2 ++ 5 files changed, 26 insertions(+), 6 deletions(-) create mode 100644 script/0.0.3/1.alert_app_alarm.sql diff --git a/api/app/lib/controllers/alarm/app.js b/api/app/lib/controllers/alarm/app.js index e970300..7d3f599 100644 --- a/api/app/lib/controllers/alarm/app.js +++ b/api/app/lib/controllers/alarm/app.js @@ -58,7 +58,7 @@ async function notedInspection (ctx) { async function apiError (ctx) { try { const models = ctx.fs.dc.models; - const { projectAppId, alarmContent, router, statusCode } = ctx.request.body + const { projectAppId, alarmContent, router, statusCode, screenshot = '' } = ctx.request.body const now = moment().format() let storageData = { @@ -86,6 +86,7 @@ async function apiError (ctx) { }) storageData.serialNumber = 'WEB' + (existCount < 9 ? '0' + (existCount + 1) : existCount) storageData.createTime = now + storageData.screenshot = screenshot await models.AppAlarm.create(storageData) } diff --git a/api/app/lib/controllers/organization/index.js b/api/app/lib/controllers/organization/index.js index 358843c..67c4b87 100644 --- a/api/app/lib/controllers/organization/index.js +++ b/api/app/lib/controllers/organization/index.js @@ -48,11 +48,15 @@ async function editUser (ctx) { // 存在且传递id 或者 不传id也存在 // 修改 update storageData.deleted = false - storageData.role = role if ( - storageData.role.includes('admin') + role.includes('admin') ) { + // 正在修改为管理员 storageData.disabled = true + storageData.role = [...[existUserRes.role], ...role] + } else if (existUserRes.role.includes('admin')) { + // 正在修改成员 但是此时还是管理员 + storageData.role = [...role, 'admin'] } await models.User.update(storageData, { where: { @@ -64,7 +68,7 @@ async function editUser (ctx) { await models.User.create(storageData) } - ctx.status = 200 + ctx.status = 204 } catch (error) { ctx.fs.logger.error(`path: ${ctx.path}, error: ${error}`); ctx.status = 400; diff --git a/api/app/lib/models/app_alarm.js b/api/app/lib/models/app_alarm.js index 6d6bdbb..fb958c7 100644 --- a/api/app/lib/models/app_alarm.js +++ b/api/app/lib/models/app_alarm.js @@ -31,7 +31,11 @@ module.exports = dc => { comment: "对应的项目id", primaryKey: false, field: "project_app_id", - autoIncrement: false + autoIncrement: false, + references: { + key: "id", + model: "projectApp" + } }, appDomain: { type: DataTypes.STRING, @@ -95,6 +99,15 @@ module.exports = dc => { primaryKey: false, field: "status_code", autoIncrement: false + }, + screenshot: { + type: DataTypes.STRING, + allowNull: true, + defaultValue: null, + comment: null, + primaryKey: false, + field: "screenshot", + autoIncrement: false } }, { tableName: "app_alarm", diff --git a/api/sequelize-automate.config.js b/api/sequelize-automate.config.js index ae7d5c4..e34d53b 100644 --- a/api/sequelize-automate.config.js +++ b/api/sequelize-automate.config.js @@ -26,7 +26,7 @@ module.exports = { dir: './app/lib/models', // 指定输出 models 文件的目录 typesDir: 'models', // 指定输出 TypeScript 类型定义的文件目录,只有 TypeScript / Midway 等会有类型定义 emptyDir: false, // !!! 谨慎操作 生成 models 之前是否清空 `dir` 以及 `typesDir` - tables: ['app_inspection'], // 指定生成哪些表的 models,如 ['user', 'user_post'];如果为 null,则忽略改属性 + tables: ['app_alarm'], // 指定生成哪些表的 models,如 ['user', 'user_post'];如果为 null,则忽略改属性 skipTables: [], // 指定跳过哪些表的 models,如 ['user'];如果为 null,则忽略改属性 tsNoCheck: false, // 是否添加 `@ts-nocheck` 注释到 models 文件中 ignorePrefix: [], // 生成的模型名称忽略的前缀,因为 项目中有以下表名是以 t_ 开头的,在实际模型中不需要, 可以添加多个 [ 't_data_', 't_',] ,长度较长的 前缀放前面 diff --git a/script/0.0.3/1.alert_app_alarm.sql b/script/0.0.3/1.alert_app_alarm.sql new file mode 100644 index 0000000..0bee93d --- /dev/null +++ b/script/0.0.3/1.alert_app_alarm.sql @@ -0,0 +1,2 @@ +alter table app_alarm + add screenshot varchar(1024); \ No newline at end of file From 9fc64e231dd3c04a9fa77afc5d012af730f0e8b2 Mon Sep 17 00:00:00 2001 From: "gao.zhiyuan" Date: Thu, 15 Sep 2022 09:58:54 +0800 Subject: [PATCH 04/10] =?UTF-8?q?=E4=BA=BA=E5=91=98=E4=BF=A1=E6=81=AF?= =?UTF-8?q?=E6=9F=A5=E8=AF=A2?= MIME-Version: 1.0 Content-Type: text/plain; charset=UTF-8 Content-Transfer-Encoding: 8bit --- api/app/lib/controllers/organization/index.js | 2 +- 1 file changed, 1 insertion(+), 1 deletion(-) diff --git a/api/app/lib/controllers/organization/index.js b/api/app/lib/controllers/organization/index.js index 67c4b87..8f5e3d4 100644 --- a/api/app/lib/controllers/organization/index.js +++ b/api/app/lib/controllers/organization/index.js @@ -53,7 +53,7 @@ async function editUser (ctx) { ) { // 正在修改为管理员 storageData.disabled = true - storageData.role = [...[existUserRes.role], ...role] + storageData.role = [...new Set([...existUserRes.role, ...role])] } else if (existUserRes.role.includes('admin')) { // 正在修改成员 但是此时还是管理员 storageData.role = [...role, 'admin'] From 452b2af3f18dbfa36088fcd5ae28cb64847d58cc Mon Sep 17 00:00:00 2001 From: deartibers <947466799@qq.com> Date: Thu, 15 Sep 2022 10:09:25 +0800 Subject: [PATCH 05/10] =?UTF-8?q?=E4=BA=BA=E5=91=98=E5=8F=8A=E8=A7=92?= =?UTF-8?q?=E8=89=B2?= MIME-Version: 1.0 Content-Type: text/plain; charset=UTF-8 Content-Transfer-Encoding: 8bit --- .../install/components/adminModal.jsx | 47 +++++++++++-------- .../install/components/memberModal.jsx | 28 +++++++---- 2 files changed, 47 insertions(+), 28 deletions(-) diff --git a/web/client/src/sections/install/components/adminModal.jsx b/web/client/src/sections/install/components/adminModal.jsx index cb1219a..98a7b8c 100644 --- a/web/client/src/sections/install/components/adminModal.jsx +++ b/web/client/src/sections/install/components/adminModal.jsx @@ -31,7 +31,7 @@ function adminModal (props) { } setPeopleList(departmentList) setDepartmentId(editObj.departments[0].id) - setPeopleId(editObj.id) + setPeopleId(editObj.pepUserId) setDisablePeople(false) } }, []); @@ -42,13 +42,19 @@ function adminModal (props) { .validate() .then((values) => { if (adminEdit) { - dispatch(install.postOrganizationUser({ role: ['admin'], pepUserId: values.pepUserId })).then((res) => {//获取项企(PEP)全部部门及其下用户 - close(); - }) + dispatch(install.deteleOrganizationAdmin(editObj.id)).then( + dispatch(install.postOrganizationUser({ role: ['admin'], pepUserId: values.pepUserId })).then((res) => {//获取项企(PEP)全部部门及其下用户 + if(res.success){ + close(); + } + }) + ) } else { dispatch(install.postOrganizationUser({ role: ['admin'], pepUserId: values.pepUserId })).then((res) => {//获取项企(PEP)全部部门及其下用户 - close(); + if(res.success){ + close(); + } }) } }) @@ -79,22 +85,25 @@ function adminModal (props) { labelAlign="right" labelWidth="90px" onValueChange={(values, field) => { - if (values.department >= 0) { - let departmentList = [] - for (let i = 0; i < pepList.length; i++) { - if (pepList[i].id == values.department) { - departmentList = pepList[i].users + for (var key in field) { + if (key == 'department') { + if (values.department >= 0) { + let departmentList = [] + for (let i = 0; i < pepList.length; i++) { + if (pepList[i].id == values.department) { + departmentList = pepList[i].users + } + } + setPeopleList(departmentList) + setDisablePeople(false) + form.current.setValue('pepUserId', undefined); + } + else { + setPeopleList([]) + setDisablePeople(true) + form.current.setValue('pepUserId', undefined); } } - setPeopleList(departmentList) - setDisablePeople(false) - // if(disablePeople){ - // form.current.setValue(pepUserId, undefined); - // } - } - else { - setPeopleList([]) - setDisablePeople(true) } }} getFormApi={(formApi) => (form.current = formApi)} diff --git a/web/client/src/sections/install/components/memberModal.jsx b/web/client/src/sections/install/components/memberModal.jsx index 6e04ab7..dc4c55e 100644 --- a/web/client/src/sections/install/components/memberModal.jsx +++ b/web/client/src/sections/install/components/memberModal.jsx @@ -40,7 +40,7 @@ function memberModal (props) { ]); //权限配置 //初始化 useEffect(() => { - if(editObj.id){ + if (editObj.id) { let departmentList = [] for (let i = 0; i < pepList.length; i++) { if (pepList[i].id == editObj.departments[0].id) { @@ -58,7 +58,9 @@ function memberModal (props) { .validate() .then((values) => { dispatch(install.postOrganizationUser({ role: values.role, pepUserId: values.pepUserId })).then((res) => {//获取项企(PEP)全部部门及其下用户 - close(); + if(res.success){ + close(); + } }) }) } @@ -88,19 +90,27 @@ function memberModal (props) { labelAlign="right" labelWidth="90px" onValueChange={(values, field) => { - for(var key in field){ - if(key=='department'){ + for (var key in field) { + if (key == 'department') { if (values.department >= 0) { + let departmentList = [] + for (let i = 0; i < pepList.length; i++) { + if (pepList[i].id == values.department) { + departmentList = pepList[i].users + } + } + setPeopleList(departmentList) setDisablePeople(false) - setPeopleList(pepList[values.department].users) + form.current.setValue('pepUserId', undefined); } else { setPeopleList([]) setDisablePeople(true) + form.current.setValue('pepUserId', undefined); } } } - + }} getFormApi={(formApi) => (form.current = formApi)} > @@ -118,7 +128,7 @@ function memberModal (props) { { pepList.map((item, index) => { return ( - + {item.name} ) @@ -134,7 +144,7 @@ function memberModal (props) { style={{ width: 417 }} rules={[{ required: true, message: "请选择人员" }]} showClear - initValue={editObj.id || ""} + initValue={editObj.pepUserId || ""} disabled={disablePeople} > { @@ -153,7 +163,7 @@ function memberModal (props) { field="role" label='权限配置:' showClear - initValue={editObj.role||[]} + initValue={editObj.role || []} > { jurisdiction.map((item, index) => { From 7901b7ba39d614bf317fb5ba9d482400fef2002e Mon Sep 17 00:00:00 2001 From: deartibers <947466799@qq.com> Date: Thu, 15 Sep 2022 10:28:27 +0800 Subject: [PATCH 06/10] =?UTF-8?q?=E5=BC=B9=E6=A1=86=E4=BF=AE=E6=94=B9?= MIME-Version: 1.0 Content-Type: text/plain; charset=UTF-8 Content-Transfer-Encoding: 8bit --- web/client/src/sections/install/components/memberModal.jsx | 6 +++++- 1 file changed, 5 insertions(+), 1 deletion(-) diff --git a/web/client/src/sections/install/components/memberModal.jsx b/web/client/src/sections/install/components/memberModal.jsx index dc4c55e..7302c5d 100644 --- a/web/client/src/sections/install/components/memberModal.jsx +++ b/web/client/src/sections/install/components/memberModal.jsx @@ -57,7 +57,11 @@ function memberModal (props) { form.current .validate() .then((values) => { - dispatch(install.postOrganizationUser({ role: values.role, pepUserId: values.pepUserId })).then((res) => {//获取项企(PEP)全部部门及其下用户 + let roleArr=JSON.parse(JSON.stringify(values.role)) + if (roleArr.indexOf('admin') != -1) { + roleArr.splice(roleArr.indexOf('admin'),1) + } + dispatch(install.postOrganizationUser({ role: roleArr, pepUserId: values.pepUserId })).then((res) => {//获取项企(PEP)全部部门及其下用户 if(res.success){ close(); } From 8921f03e2e39d59bf61ff2f84959a08e69bd8ecc Mon Sep 17 00:00:00 2001 From: deartibers <947466799@qq.com> Date: Thu, 15 Sep 2022 16:57:57 +0800 Subject: [PATCH 07/10] =?UTF-8?q?=E6=98=BE=E7=A4=BA=E9=97=AE=E9=A2=98?= =?UTF-8?q?=E4=BF=AE=E6=94=B9?= MIME-Version: 1.0 Content-Type: text/plain; charset=UTF-8 Content-Transfer-Encoding: 8bit --- .../src/sections/install/containers/roles.jsx | 18 ++++++++++++++++-- 1 file changed, 16 insertions(+), 2 deletions(-) diff --git a/web/client/src/sections/install/containers/roles.jsx b/web/client/src/sections/install/containers/roles.jsx index 5bb5a4b..2360319 100644 --- a/web/client/src/sections/install/containers/roles.jsx +++ b/web/client/src/sections/install/containers/roles.jsx @@ -322,19 +322,33 @@ const Roles = (props) => { borderRadius: 2, background: "url(/assets/images/install/cardBackground0" + (index + 1) + '.png)', backgroundSize: "100% 100%", marginRight: 20, marginBottom: 20, }}> - { item.id ? (
{ item.departments?.map((itm, idx) => { + let mydepartmentsArr=[] + for (let index = 0; index < item.departments.length; index++) { + mydepartmentsArr.push(item.departments[index].name) + } return (
- {itm.name} + { + idx > 2 ? ( + +
+ ... +
+
+ + ) : ( + itm.name + ) + }
) }) From 3b35ec6cf96f8c6dfed9e752dc41aa0ac25aacd2 Mon Sep 17 00:00:00 2001 From: "gao.zhiyuan" Date: Thu, 15 Sep 2022 17:06:38 +0800 Subject: [PATCH 08/10] =?UTF-8?q?=E7=AE=A1=E7=90=86=E5=91=98=E5=88=A4?= =?UTF-8?q?=E9=87=8D?= MIME-Version: 1.0 Content-Type: text/plain; charset=UTF-8 Content-Transfer-Encoding: 8bit --- api/app/lib/controllers/project/index.js | 37 ++++++++++++++++++++++++ 1 file changed, 37 insertions(+) diff --git a/api/app/lib/controllers/project/index.js b/api/app/lib/controllers/project/index.js index df0008f..70af536 100644 --- a/api/app/lib/controllers/project/index.js +++ b/api/app/lib/controllers/project/index.js @@ -20,7 +20,44 @@ async function appList (ctx) { } } +async function projectAnxincloud (ctx) { + try { + const models = ctx.fs.dc.models; + const { clickHouse } = ctx.app.fs + + const projectRes = await clickHouse.anxinyun.query(`SELECT * FROM t_project WHERE project_state = 4 ORDER BY id DESC`).toPromise() + + ctx.status = 200; + ctx.body = projectRes + } catch (error) { + ctx.fs.logger.error(`path: ${ctx.path}, error: error`); + ctx.status = 400; + ctx.body = { + message: typeof error == 'string' ? error : undefined + } + } +} + +async function projectPManage (ctx) { + try { + const models = ctx.fs.dc.models; + const { clickHouse } = ctx.app.fs + + const projectRes = await clickHouse.projectManage.query(`SELECT * FROM t_project WHERE project_state = 4 ORDER BY id DESC`).toPromise() + + ctx.status = 200; + ctx.body = projectRes + } catch (error) { + ctx.fs.logger.error(`path: ${ctx.path}, error: error`); + ctx.status = 400; + ctx.body = { + message: typeof error == 'string' ? error : undefined + } + } +} module.exports = { appList, + projectAnxincloud, + projectPManage, }; \ No newline at end of file From d43fc31276fb9fc48859fd84f1e4181c418ec991 Mon Sep 17 00:00:00 2001 From: "gao.zhiyuan" Date: Thu, 15 Sep 2022 17:06:42 +0800 Subject: [PATCH 09/10] =?UTF-8?q?=E7=AE=A1=E7=90=86=E5=91=98=E5=88=A4?= =?UTF-8?q?=E9=87=8D?= MIME-Version: 1.0 Content-Type: text/plain; charset=UTF-8 Content-Transfer-Encoding: 8bit --- api/app/lib/controllers/alarm/app.js | 86 +++++++++++++++++++ api/app/lib/controllers/organization/index.js | 4 + api/app/lib/index.js | 7 +- api/app/lib/routes/alarm/index.js | 10 ++- api/app/lib/routes/project/index.js | 5 ++ 5 files changed, 109 insertions(+), 3 deletions(-) diff --git a/api/app/lib/controllers/alarm/app.js b/api/app/lib/controllers/alarm/app.js index 7d3f599..58fe6e8 100644 --- a/api/app/lib/controllers/alarm/app.js +++ b/api/app/lib/controllers/alarm/app.js @@ -30,6 +30,73 @@ async function inspection (ctx) { } } +async function inspectionList (ctx) { + try { + const models = ctx.fs.dc.models; + const { clickHouse } = ctx.app.fs + const { timeStart, timeEnd, projectId, appId, noted } = ctx.query + + let findOption = { + where: { + + }, + order: [['id', 'DESC']], + include: [{ + model: models.ProjectApp, + required: Boolean(appId || projectId), + where: appId ? { + id: appId + } : undefined, + include: { + model: models.ProjectCorrelation, + required: Boolean(projectId), + where: projectId ? { + id: projectId + } : undefined, + attributes: { + exclude: ['anxinProjectId', 'createTime', 'createUser'] + } + } + }] + } + if (timeStart && timeEnd) { + findOption.where.createTime = { $between: [moment(timeStart).format(), moment(timeEnd).format()] } + } + if (noted) { + if (noted == 'noted') { + findOption.where.notedTime = { $ne: null } + } else if (noted == 'unnote') { + findOption.where.notedTime = null + } + } + + const inspectionRes = await models.AppInspection.findAll(findOption) + let notedUserIds = new Set() + for (let ins of inspectionRes) { + if (ins.notedPepUserId) { + notedUserIds.add(ins.notedPepUserId) + } + } + let userPepRes = notedUserIds.size ? + await clickHouse.pepEmis.query(`SELECT DISTINCT user.id AS id, "user"."name" AS name FROM user WHERE user.id IN (${[...notedUserIds].join(',')})`).toPromise() : + [] + for (let ins of inspectionRes) { + if (ins.notedPepUserId) { + const corUser = userPepRes.find(up => up.id == ins.notedPepUserId) + ins.dataValues.notedPepUser = corUser ? corUser.name : '' + } + } + ctx.status = 200; + ctx.body = inspectionRes + } catch (error) { + ctx.fs.logger.error(`path: ${ctx.path}, error: error`); + ctx.status = 400; + ctx.body = { + message: typeof error == 'string' ? error : undefined + } + } +} + async function notedInspection (ctx) { try { const models = ctx.fs.dc.models; @@ -100,6 +167,23 @@ async function apiError (ctx) { } } +async function apiErrorList (ctx) { + try { + const models = ctx.fs.dc.models; + const { clickHouse } = ctx.app.fs + const { } = ctx.query + + ctx.status = 200; + ctx.body = [] + } catch (error) { + ctx.fs.logger.error(`path: ${ctx.path}, error: error`); + ctx.status = 400; + ctx.body = { + message: typeof error == 'string' ? error : undefined + } + } +} + async function confirmApiError (ctx) { try { const models = ctx.fs.dc.models; @@ -125,7 +209,9 @@ async function confirmApiError (ctx) { module.exports = { inspection, + inspectionList, notedInspection, apiError, + apiErrorList, confirmApiError, }; \ No newline at end of file diff --git a/api/app/lib/controllers/organization/index.js b/api/app/lib/controllers/organization/index.js index 8f5e3d4..ea37a47 100644 --- a/api/app/lib/controllers/organization/index.js +++ b/api/app/lib/controllers/organization/index.js @@ -51,6 +51,10 @@ async function editUser (ctx) { if ( role.includes('admin') ) { + if (existUserRes.role.includes('admin')) { + // 已是管理员 + throw '当前人员已是管理员' + } // 正在修改为管理员 storageData.disabled = true storageData.role = [...new Set([...existUserRes.role, ...role])] diff --git a/api/app/lib/index.js b/api/app/lib/index.js index 2862fce..323a254 100644 --- a/api/app/lib/index.js +++ b/api/app/lib/index.js @@ -55,7 +55,12 @@ module.exports.models = function (dc) { // dc = { orm: Sequelize对象, ORM: Seq }); const { - + AppInspection, ProjectApp, ProjectCorrelation } = dc.models; + AppInspection.belongsTo(ProjectApp, { foreignKey: 'projectAppId', targetKey: 'id' }); + ProjectApp.hasMany(AppInspection, { foreignKey: 'projectAppId', sourceKey: 'id' }); + + ProjectApp.belongsTo(ProjectCorrelation, { foreignKey: 'projectId', targetKey: 'id' }); + ProjectCorrelation.hasMany(ProjectApp, { foreignKey: 'projectId', sourceKey: 'id' }); }; diff --git a/api/app/lib/routes/alarm/index.js b/api/app/lib/routes/alarm/index.js index 50dc0cb..7872086 100644 --- a/api/app/lib/routes/alarm/index.js +++ b/api/app/lib/routes/alarm/index.js @@ -9,12 +9,18 @@ module.exports = function (app, router, opts) { app.fs.api.logAttr['POST/alarm/application/inspection'] = { content: '保存应用巡检信息', visible: true }; router.post('/alarm/application/inspection', application.inspection); + app.fs.api.logAttr['GET/alarm/application/inspection'] = { content: '查询应用巡检信息', visible: true }; + router.get('/alarm/application/inspection', application.inspectionList); + app.fs.api.logAttr['PUT/alarm/application/noted'] = { content: '保存检验状态', visible: true }; router.put('/alarm/application/noted', application.notedInspection); - app.fs.api.logAttr['POST/alarm/application/api'] = { content: '保存应用接口错误信息', visible: true }; + app.fs.api.logAttr['POST/alarm/application/api'] = { content: '保存应用接口/元素错误信息', visible: true }; router.post('/alarm/application/api', application.apiError); - app.fs.api.logAttr['POST/alarm/application/api_confirm'] = { content: '确认应用接口错误信息', visible: true }; + app.fs.api.logAttr['GET/alarm/application/api'] = { content: '查询应用接口/元素错误信息', visible: true }; + router.get('/alarm/application/api', application.apiErrorList); + + app.fs.api.logAttr['POST/alarm/application/api_confirm'] = { content: '确认应用接口/元素错误信息', visible: true }; router.post('/alarm/application/api_confirm', application.confirmApiError); }; diff --git a/api/app/lib/routes/project/index.js b/api/app/lib/routes/project/index.js index 8f980de..8c41c72 100644 --- a/api/app/lib/routes/project/index.js +++ b/api/app/lib/routes/project/index.js @@ -10,4 +10,9 @@ module.exports = function (app, router, opts) { app.fs.api.logAttr['POST/project/bind'] = { content: '绑定安心云、项目管理项目', visible: true }; router.post('/project/bind', projectBind.bindAnxin2pep); + app.fs.api.logAttr['GET/project/anxincloud'] = { content: '获取安心云项目', visible: true }; + router.get('/project/anxincloud', project.projectAnxincloud); + + app.fs.api.logAttr['GET/project/pmanage'] = { content: '获取PEP项目管理项目', visible: true }; + router.get('/project/pmanage', project.projectPManage); }; \ No newline at end of file From 585d9d05f095c72905e5f38f3d9963751c690930 Mon Sep 17 00:00:00 2001 From: "gao.zhiyuan" Date: Thu, 15 Sep 2022 17:09:09 +0800 Subject: [PATCH 10/10] =?UTF-8?q?=20=E8=A7=92=E8=89=B2=E9=85=8D=E7=BD=AE-?= =?UTF-8?q?=E5=90=AF=E7=94=A8=E6=88=90=E5=91=98=E7=AE=A1=E7=90=86=E6=A0=8F?= =?UTF-8?q?=E7=82=B9=E5=87=BB=E7=A6=81=E7=94=A8=E6=8C=89=E9=92=AE=E6=8F=90?= =?UTF-8?q?=E7=A4=BA=E9=94=99=E8=AF=AF?= MIME-Version: 1.0 Content-Type: text/plain; charset=UTF-8 Content-Transfer-Encoding: 8bit --- api/app/lib/controllers/organization/index.js | 2 +- 1 file changed, 1 insertion(+), 1 deletion(-) diff --git a/api/app/lib/controllers/organization/index.js b/api/app/lib/controllers/organization/index.js index ea37a47..f8c4ba7 100644 --- a/api/app/lib/controllers/organization/index.js +++ b/api/app/lib/controllers/organization/index.js @@ -93,7 +93,7 @@ async function putUser (ctx) { } }) - if (existUserRes && existUserRes.role.includes('admin') && disabled) { + if (existUserRes && existUserRes.role.includes('admin') && !disabled) { throw '成员不能既是管理员又是普通成员' }