Browse Source

项目绑定信息与应用信息绑定

dev
巴林闲侠 2 years ago
parent
commit
1e1cd4cd20
  1. 93
      api/app/lib/controllers/project/bind.js

93
api/app/lib/controllers/project/bind.js

@ -7,7 +7,7 @@ async function bindAnxin2pep (ctx) {
const models = ctx.fs.dc.models; const models = ctx.fs.dc.models;
const { clickHouse } = ctx.app.fs const { clickHouse } = ctx.app.fs
const { userId, pepUserId } = ctx.fs.api const { userId, pepUserId } = ctx.fs.api
const { bindId, name, pepProjectId, anxinProjectId = [], app = [] } = ctx.request.body const { bindId, name, pepProjectId, anxinProjectId = [], appId = [] } = ctx.request.body
let bindId_ = bindId let bindId_ = bindId
const now = moment() const now = moment()
@ -24,16 +24,8 @@ async function bindAnxin2pep (ctx) {
name, pepProjectId, anxinProjectId, name, pepProjectId, anxinProjectId,
del: false, del: false,
} }
// 已经创建过的 app
let existApp = []
// 新增的
let createAppData = []
// url 相同需要更新的 解除 lock 状态
let updateAppData = []
// 没有出现但存在的 叠加 lock 状态
let lockAppData = []
if (bindId_) { if (bindId) {
// 修改 // 修改
if (!existRes) { if (!existRes) {
throw '尚无已绑定的项企项目' throw '尚无已绑定的项企项目'
@ -47,7 +39,6 @@ async function bindAnxin2pep (ctx) {
}, },
transaction transaction
}) })
existApp = existRes.projectApps
} else { } else {
// 新增 // 新增
if (existRes) { if (existRes) {
@ -60,7 +51,6 @@ async function bindAnxin2pep (ctx) {
}, },
transaction transaction
}) })
existApp = existRes.projectApps
} else { } else {
// 没有删除 重复添加 // 没有删除 重复添加
throw '当前项企项目已绑定' throw '当前项企项目已绑定'
@ -75,80 +65,23 @@ async function bindAnxin2pep (ctx) {
} }
} }
app.forEach((a, i, arr) => { if (bindId) {
if (!a.name && !a.url) { await models.ProjectApp.destroy({
return where: {
} projectId: bindId
if (!a.name || !a.url) { },
throw `${a.name} ${a.url} 缺少必要参数` transaction
}
let curUrlArr = a.url.split('://')
if (curUrlArr.length < 2) {
throw `${a.name} ${a.url} url 地址错误`
}
curUrlArr.shift()
let curUrl = curUrlArr.join('://')
// 先判断传过来的数据有没有重复
for (let ii = i + 1; ii < arr.length; ii++) {
let curForUrlArr = arr[ii].url.split('://')
curForUrlArr.shift()
if (curUrl == curForUrlArr.join('://')) {
throw `${a.name} ${a.url}${arr[ii].name} ${arr[ii].url} 地址重复`
}
}
// 再判断和已有的有没有重复
let existSameApp = existApp.find(ea => {
let curForUrlArr = ea.url.split('://')
curForUrlArr.shift()
return curUrl == curForUrlArr.join('://')
})
if (existSameApp) {
// 有重复的将已有信息解除锁定并更新
updateAppData.push({
id: existSameApp.id,
name: a.name,
url: a.url,
projectId: bindId_,
lock: false,
})
existSameApp.addAgain = true
} else {
// 没有就创建
createAppData.push({
name: a.name,
url: a.url,
projectId: bindId_,
lock: false,
}) })
} }
// 筛选剩余的已有信息并将之锁定 await models.ProjectApp.bulkCreate(appId.map(aid => {
lockAppData = existApp.filter(esa => !esa.addAgain).map(esa => {
return { return {
id: esa.id, projectId: bindId_,
// name: esa.name, appId: aid
// url: esa.url,
// projectId: bindId_,
lock: true,
} }
}) }), {
})
createAppData.length ?
await models.ProjectApp.bulkCreate(createAppData, {
transaction
}) : null
updateAppData.length || lockAppData.length ?
await Promise.all(updateAppData.concat(lockAppData).map(ud => {
return models.ProjectApp.update(ud, {
where: {
id: ud.id
},
transaction transaction
}) })
}))
: null
await transaction.commit(); await transaction.commit();
ctx.status = 204; ctx.status = 204;

Loading…
Cancel
Save