From 77be2b011f9025793e4c68fb6dfff05c30837371 Mon Sep 17 00:00:00 2001 From: wenlele Date: Thu, 29 Jun 2023 08:27:06 +0800 Subject: [PATCH] =?UTF-8?q?REST=E6=9C=8D=E5=8A=A1=E5=8F=91=E5=B8=83?= MIME-Version: 1.0 Content-Type: text/plain; charset=UTF-8 Content-Transfer-Encoding: 8bit --- api/.vscode/launch.json | 1 + .../lib/controllers/latestMetadata/index.js | 1534 +++++++++-------- api/app/lib/routes/latestMetadata/index.js | 3 + .../dataQuality/containers/ruleLibrary.js | 6 +- .../actions/businessMetadata.js | 258 +-- .../components/releaseModal.js | 237 +++ .../containers/databasesTable.js | 673 ++++---- web/client/src/utils/webapi.js | 1 + 8 files changed, 1509 insertions(+), 1204 deletions(-) create mode 100644 web/client/src/sections/metadataManagement/components/releaseModal.js diff --git a/api/.vscode/launch.json b/api/.vscode/launch.json index 2b979aa..21014f1 100644 --- a/api/.vscode/launch.json +++ b/api/.vscode/launch.json @@ -16,6 +16,7 @@ "-p 4400", // 研发 "-g postgres://FashionAdmin:123456@10.8.30.39:5432/GovernmentDataResourceCenter", + // "-g postgres://FashionAdmin:123456@10.8.30.156:5432/gdrcenter", "-b http://10.8.30.161:31420" ] }, diff --git a/api/app/lib/controllers/latestMetadata/index.js b/api/app/lib/controllers/latestMetadata/index.js index 90f88ed..d2e54e4 100644 --- a/api/app/lib/controllers/latestMetadata/index.js +++ b/api/app/lib/controllers/latestMetadata/index.js @@ -3,828 +3,852 @@ const moment = require("moment/moment"); //获取资源目录 -async function getResourceCatalog(ctx) { - try { - const models = ctx.fs.dc.models; - const rslt = await models.ResourceCatalog.findAll({ - order: [['id', 'asc']], - }); - ctx.status = 200; - ctx.body = rslt; - } catch (error) { - ctx.fs.logger.error(`path: ${ctx.path}, error: ${error}`); - ctx.status = 400; - ctx.body = { - "message": "获取资源目录失败" - } - } +async function getResourceCatalog (ctx) { + try { + const models = ctx.fs.dc.models; + const rslt = await models.ResourceCatalog.findAll({ + order: [['id', 'asc']], + }); + ctx.status = 200; + ctx.body = rslt; + } catch (error) { + ctx.fs.logger.error(`path: ${ctx.path}, error: ${error}`); + ctx.status = 400; + ctx.body = { + "message": "获取资源目录失败" + } + } } //新建资源目录 -async function postResourceCatalog(ctx) { - try { - const { name, code } = ctx.request.body; - const models = ctx.fs.dc.models; - const postOne = await models.ResourceCatalog.findOne({ - where: { $or: [{ name: name }, { code: code }] } - }); - if (postOne) { +async function postResourceCatalog (ctx) { + try { + const { name, code } = ctx.request.body; + const models = ctx.fs.dc.models; + const postOne = await models.ResourceCatalog.findOne({ + where: { $or: [{ name: name }, { code: code }] } + }); + if (postOne) { + ctx.status = 400; + ctx.body = { message: '该资源目录名称或代码已存在' } + } else { + if (!name || !code) { + ctx.body = { message: '参数不全,请重新配置' } ctx.status = 400; - ctx.body = { message: '该资源目录名称或代码已存在' } - } else { - if (!name || !code) { - ctx.body = { message: '参数不全,请重新配置' } - ctx.status = 400; - } else { - await models.ResourceCatalog.create(ctx.request.body); - ctx.body = { message: '新建资源目录成功' } - ctx.status = 200; - } - } - } catch (error) { - ctx.fs.logger.error(`path: ${ctx.path}, error: ${error}`); - ctx.status = 400; - ctx.body = { - "message": "新建资源目录失败" - } - } + } else { + await models.ResourceCatalog.create(ctx.request.body); + ctx.body = { message: '新建资源目录成功' } + ctx.status = 200; + } + } + } catch (error) { + ctx.fs.logger.error(`path: ${ctx.path}, error: ${error}`); + ctx.status = 400; + ctx.body = { + "message": "新建资源目录失败" + } + } } //修改资源目录 -async function putResourceCatalog(ctx) { - try { - const { id } = ctx.params; - const { name, code, description } = ctx.request.body; - const models = ctx.fs.dc.models; - let resourceCatalogInfo = await models.ResourceCatalog.findOne({ where: { id } }); - if (resourceCatalogInfo) { - const putOne = await models.ResourceCatalog.findOne({ where: { id: { $not: id }, $or: [{ name: name }, { code: code }] } }); - if (putOne) { - ctx.status = 400; - ctx.body = { message: '该资源目录名称或代码已存在' } - } else { - await models.ResourceCatalog.update(ctx.request.body, { where: { id: id } }); - ctx.status = 200; - ctx.body = { message: '修改资源目录成功' } - } - } else { +async function putResourceCatalog (ctx) { + try { + const { id } = ctx.params; + const { name, code, description } = ctx.request.body; + const models = ctx.fs.dc.models; + let resourceCatalogInfo = await models.ResourceCatalog.findOne({ where: { id } }); + if (resourceCatalogInfo) { + const putOne = await models.ResourceCatalog.findOne({ where: { id: { $not: id }, $or: [{ name: name }, { code: code }] } }); + if (putOne) { ctx.status = 400; - ctx.body = { message: '该资源目录不存在' } - } - } catch (error) { - ctx.fs.logger.error(`path: ${ctx.path}, error: ${error}`); - ctx.status = 400; - ctx.body = { - "message": "修改资源目录失败" - } - } + ctx.body = { message: '该资源目录名称或代码已存在' } + } else { + await models.ResourceCatalog.update(ctx.request.body, { where: { id: id } }); + ctx.status = 200; + ctx.body = { message: '修改资源目录成功' } + } + } else { + ctx.status = 400; + ctx.body = { message: '该资源目录不存在' } + } + } catch (error) { + ctx.fs.logger.error(`path: ${ctx.path}, error: ${error}`); + ctx.status = 400; + ctx.body = { + "message": "修改资源目录失败" + } + } } //删除资源目录 -async function delResourceCatalog(ctx) { - const transaction = await ctx.fs.dc.orm.transaction(); - try { - const models = ctx.fs.dc.models; - const { id } = ctx.params; - let resourceCatalogInfo = await models.ResourceCatalog.findOne({ where: { id } }); - if (resourceCatalogInfo) { - let deletable = true; - let childResourceCatalogInfo = await models.ResourceCatalog.findOne({ where: { parent: id } }); - let databaseInfo = await models.MetadataDatabase.findOne({ where: { catalog: id } }); - let fileInfo = await models.MetadataFile.findOne({ where: { catalog: id } }); - let restapiInfo = await models.MetadataRestapi.findOne({ where: { catalog: id } }); - let dataSourceInfo = await models.DataSource.findOne({ where: { mountPath: id } }); - if (childResourceCatalogInfo || databaseInfo || fileInfo || restapiInfo || dataSourceInfo) { - ctx.status = 400; - ctx.body = { message: '存在关联数据,请删除相关数据,再删除该资源目录' } - deletable = false; - } - if (deletable) { - await models.ResourceCatalog.destroy({ - where: { id: id }, - transaction - }) - await transaction.commit(); - ctx.status = 200; - ctx.body = { message: '删除资源目录成功' } - } - } else { +async function delResourceCatalog (ctx) { + const transaction = await ctx.fs.dc.orm.transaction(); + try { + const models = ctx.fs.dc.models; + const { id } = ctx.params; + let resourceCatalogInfo = await models.ResourceCatalog.findOne({ where: { id } }); + if (resourceCatalogInfo) { + let deletable = true; + let childResourceCatalogInfo = await models.ResourceCatalog.findOne({ where: { parent: id } }); + let databaseInfo = await models.MetadataDatabase.findOne({ where: { catalog: id } }); + let fileInfo = await models.MetadataFile.findOne({ where: { catalog: id } }); + let restapiInfo = await models.MetadataRestapi.findOne({ where: { catalog: id } }); + let dataSourceInfo = await models.DataSource.findOne({ where: { mountPath: id } }); + if (childResourceCatalogInfo || databaseInfo || fileInfo || restapiInfo || dataSourceInfo) { ctx.status = 400; - ctx.body = { message: '该资源目录不存在' } - } - } catch (error) { - await transaction.rollback(); - ctx.fs.logger.error(`path: ${ctx.path}, error: ${error}`); - ctx.status = 400; - ctx.body = { message: '删除资源目录失败' } - } + ctx.body = { message: '存在关联数据,请删除相关数据,再删除该资源目录' } + deletable = false; + } + if (deletable) { + await models.ResourceCatalog.destroy({ + where: { id: id }, + transaction + }) + await transaction.commit(); + ctx.status = 200; + ctx.body = { message: '删除资源目录成功' } + } + } else { + ctx.status = 400; + ctx.body = { message: '该资源目录不存在' } + } + } catch (error) { + await transaction.rollback(); + ctx.fs.logger.error(`path: ${ctx.path}, error: ${error}`); + ctx.status = 400; + ctx.body = { message: '删除资源目录失败' } + } } //获取库表元数据列表 -async function getMetadataDatabases(ctx) { - try { - const models = ctx.fs.dc.models; - const { catalog, limit, offset, keywords, orderBy = 'createAt', orderDirection = 'desc', id = null, resourceId } = ctx.query; - const where = {}; - if (catalog) { - where.catalog = catalog; - } - if (id) { - where.parent = id; - } - if (resourceId) { - where.id = resourceId; - } +async function getMetadataDatabases (ctx) { + try { + const models = ctx.fs.dc.models; + const { catalog, limit, offset, keywords, orderBy = 'createAt', orderDirection = 'desc', id = null, resourceId } = ctx.query; + const where = {}; + if (catalog) { + where.catalog = catalog; + } + if (id) { + where.parent = id; + } + if (resourceId) { + where.id = resourceId; + } - if (keywords) { - where['$or'] = [{ name: { $iLike: `%${keywords}%` } }, - { code: { $iLike: `%${keywords}%` } }, - { type: { $iLike: `%${keywords}%` } }] - } - const findObj = { - include: [ - { - model: models.User, - attributes: ['id', 'name', 'username'], - }, - { - model: models.TagDatabase, - include: [{ - model: models.Tag, - }] - }], - where: where, - order: [[orderBy, orderDirection]], - distinct: true - } - if (Number(limit) > 0 && Number(offset) >= 0) { - findObj.offset = Number(offset) * Number(limit); - findObj.limit = Number(limit); - } - const rslt = await models.MetadataDatabase.findAndCountAll(findObj); - ctx.status = 200; - ctx.body = rslt; - } catch (error) { - ctx.fs.logger.error(`path: ${ctx.path}, error: ${error}`); - ctx.status = 400; - ctx.body = { - "message": "获取库表元数据列表失败" - } - } + if (keywords) { + where['$or'] = [{ name: { $iLike: `%${keywords}%` } }, + { code: { $iLike: `%${keywords}%` } }, + { type: { $iLike: `%${keywords}%` } }] + } + const findObj = { + include: [ + { + model: models.User, + attributes: ['id', 'name', 'username'], + }, + { + model: models.TagDatabase, + include: [{ + model: models.Tag, + }] + }], + where: where, + order: [[orderBy, orderDirection]], + distinct: true + } + if (Number(limit) > 0 && Number(offset) >= 0) { + findObj.offset = Number(offset) * Number(limit); + findObj.limit = Number(limit); + } + const rslt = await models.MetadataDatabase.findAndCountAll(findObj); + ctx.status = 200; + ctx.body = rslt; + } catch (error) { + ctx.fs.logger.error(`path: ${ctx.path}, error: ${error}`); + ctx.status = 400; + ctx.body = { + "message": "获取库表元数据列表失败" + } + } } //获取文件元数据列表 -async function getMetadataFiles(ctx) { - try { - const models = ctx.fs.dc.models; - const { catalog, limit, offset, keywords, orderBy = 'updateAt', orderDirection = 'desc', resourceId } = ctx.query; - const where = { catalog: catalog }; - //文件类型关键字查询时需匹配fileName不能为空。 - //因存在编辑时将文件删除,但未重新上传直接点击取消的情况,此时文件已删除不可恢复,数据字段fileName更新为null - if (keywords) { - where['$or'] = [{ name: { $iLike: `%${keywords}%` } }, { type: { $iLike: `%${keywords}%` }, fileName: { $not: null } }] - } - if (resourceId) { - where.id = resourceId; - } - const findObj = { - include: [ - // { - // model: models.User, - // attributes: ['id', 'name', 'username'], - // }, - { - model: models.TagFile, - include: [{ - model: models.Tag, - }] - }], - where: where, - order: [[orderBy, orderDirection]], - distinct: true - }; - if (Number(limit) > 0 && Number(offset) >= 0) { - findObj.offset = Number(offset) * Number(limit); - findObj.limit = Number(limit); - } - const rslt = await models.MetadataFile.findAndCountAll(findObj); - ctx.status = 200; - ctx.body = rslt; - } catch (error) { - ctx.fs.logger.error(`path: ${ctx.path}, error: ${error}`); - ctx.status = 400; - ctx.body = { - "message": "获取文件元数据列表失败" - } - } +async function getMetadataFiles (ctx) { + try { + const models = ctx.fs.dc.models; + const { catalog, limit, offset, keywords, orderBy = 'updateAt', orderDirection = 'desc', resourceId } = ctx.query; + const where = { catalog: catalog }; + //文件类型关键字查询时需匹配fileName不能为空。 + //因存在编辑时将文件删除,但未重新上传直接点击取消的情况,此时文件已删除不可恢复,数据字段fileName更新为null + if (keywords) { + where['$or'] = [{ name: { $iLike: `%${keywords}%` } }, { type: { $iLike: `%${keywords}%` }, fileName: { $not: null } }] + } + if (resourceId) { + where.id = resourceId; + } + const findObj = { + include: [ + // { + // model: models.User, + // attributes: ['id', 'name', 'username'], + // }, + { + model: models.TagFile, + include: [{ + model: models.Tag, + }] + }], + where: where, + order: [[orderBy, orderDirection]], + distinct: true + }; + if (Number(limit) > 0 && Number(offset) >= 0) { + findObj.offset = Number(offset) * Number(limit); + findObj.limit = Number(limit); + } + const rslt = await models.MetadataFile.findAndCountAll(findObj); + ctx.status = 200; + ctx.body = rslt; + } catch (error) { + ctx.fs.logger.error(`path: ${ctx.path}, error: ${error}`); + ctx.status = 400; + ctx.body = { + "message": "获取文件元数据列表失败" + } + } } //获取接口元数据列表 -async function getMetadataRestapis(ctx) { - try { - const models = ctx.fs.dc.models; - const { catalog, limit, offset, keywords, orderBy = 'createAt', orderDirection = 'desc', resourceId } = ctx.query; - const where = { catalog: catalog }; - if (keywords) { - where.name = { $iLike: `%${keywords}%` }; - } - if (resourceId) { - where.id = resourceId; - } - const findObj = { - include: [ - { - model: models.User, - attributes: ['id', 'name', 'username'], - }, - { - model: models.TagRestapi, - include: [{ - model: models.Tag, - }] - }], - where: where, - order: [[orderBy, orderDirection]], - distinct: true - }; - if (Number(limit) > 0 && Number(offset) >= 0) { - findObj.offset = Number(offset) * Number(limit); - findObj.limit = Number(limit); - } - const rslt = await models.MetadataRestapi.findAndCountAll(findObj); - ctx.status = 200; - ctx.body = rslt; - } catch (error) { - ctx.fs.logger.error(`path: ${ctx.path}, error: ${error}`); - ctx.status = 400; - ctx.body = { - "message": "获取接口元数据列表失败" - } - } +async function getMetadataRestapis (ctx) { + try { + const models = ctx.fs.dc.models; + const { catalog, limit, offset, keywords, orderBy = 'createAt', orderDirection = 'desc', resourceId } = ctx.query; + const where = { catalog: catalog }; + if (keywords) { + where.name = { $iLike: `%${keywords}%` }; + } + if (resourceId) { + where.id = resourceId; + } + const findObj = { + include: [ + { + model: models.User, + attributes: ['id', 'name', 'username'], + }, + { + model: models.TagRestapi, + include: [{ + model: models.Tag, + }] + }], + where: where, + order: [[orderBy, orderDirection]], + distinct: true + }; + if (Number(limit) > 0 && Number(offset) >= 0) { + findObj.offset = Number(offset) * Number(limit); + findObj.limit = Number(limit); + } + const rslt = await models.MetadataRestapi.findAndCountAll(findObj); + ctx.status = 200; + ctx.body = rslt; + } catch (error) { + ctx.fs.logger.error(`path: ${ctx.path}, error: ${error}`); + ctx.status = 400; + ctx.body = { + "message": "获取接口元数据列表失败" + } + } } //获取元数据模型 -async function getMetadataModels(ctx) { - try { - const models = ctx.fs.dc.models; - const { modelTypes } = ctx.query; - let rslt = []; - if (modelTypes) { - rslt = await models.MetaModel.findAll({ - where: { - modelType: { $in: modelTypes.split(',') } - } - }); - } - ctx.status = 200; - ctx.body = rslt; - } catch (error) { - ctx.fs.logger.error(`path: ${ctx.path}, error: ${error}`); - ctx.status = 400; - ctx.body = { - "message": "获取元数据模型失败" - } - } +async function getMetadataModels (ctx) { + try { + const models = ctx.fs.dc.models; + const { modelTypes } = ctx.query; + let rslt = []; + if (modelTypes) { + rslt = await models.MetaModel.findAll({ + where: { + modelType: { $in: modelTypes.split(',') } + } + }); + } + ctx.status = 200; + ctx.body = rslt; + } catch (error) { + ctx.fs.logger.error(`path: ${ctx.path}, error: ${error}`); + ctx.status = 400; + ctx.body = { + "message": "获取元数据模型失败" + } + } } //新建库表元数据 -async function postMetadataDatabases(ctx) { - try { - const { name, code, catalog, parent } = ctx.request.body; - const models = ctx.fs.dc.models; - const where = { $or: [{ name: name }, { code: code }] }; - if (parent) { - where.parent = parent; - } else { - where.parent = null; - where.catalog = catalog; - } - const postOne = await models.MetadataDatabase.findOne({ - where: where - }); - if (postOne) { +async function postMetadataDatabases (ctx) { + try { + const { name, code, catalog, parent } = ctx.request.body; + const models = ctx.fs.dc.models; + const where = { $or: [{ name: name }, { code: code }] }; + if (parent) { + where.parent = parent; + } else { + where.parent = null; + where.catalog = catalog; + } + const postOne = await models.MetadataDatabase.findOne({ + where: where + }); + if (postOne) { + ctx.status = 400; + ctx.body = { message: '同一父节点下该元数据名称或代码已存在' } + } else { + if (!name || !code || !catalog) { + ctx.body = { message: '参数不全,请重新配置' } ctx.status = 400; - ctx.body = { message: '同一父节点下该元数据名称或代码已存在' } - } else { - if (!name || !code || !catalog) { - ctx.body = { message: '参数不全,请重新配置' } - ctx.status = 400; - } else { - await models.MetadataDatabase.create({ createAt: moment(), ...ctx.request.body }); - ctx.body = { message: '新建元数据成功' } - ctx.status = 200; - } - } - } catch (error) { - ctx.fs.logger.error(`path: ${ctx.path}, error: ${error}`); - ctx.status = 400; - ctx.body = { - "message": "新建元数据失败" - } - } + } else { + await models.MetadataDatabase.create({ createAt: moment(), ...ctx.request.body }); + ctx.body = { message: '新建元数据成功' } + ctx.status = 200; + } + } + } catch (error) { + ctx.fs.logger.error(`path: ${ctx.path}, error: ${error}`); + ctx.status = 400; + ctx.body = { + "message": "新建元数据失败" + } + } } //修改库表元数据 -async function putMetadataDatabases(ctx) { - try { - const { id } = ctx.params; - const { catalog, name, code } = ctx.request.body; - const models = ctx.fs.dc.models; - let metadataDatabaseInfo = await models.MetadataDatabase.findOne({ where: { id } }); - if (metadataDatabaseInfo) { - const where = { id: { $not: id }, $or: [{ name: name }, { code: code }] } - if (metadataDatabaseInfo.parent) { - where.parent = metadataDatabaseInfo.parent; - } else { - where.parent = null; - where.catalog = catalog; - } - const putOne = await models.MetadataDatabase.findOne({ where: where }); - if (putOne) { - ctx.status = 400; - ctx.body = { message: '同一父节点下该元数据名称或代码已存在' } - } else { - await models.MetadataDatabase.update({ updateAt: moment(), ...ctx.request.body }, { where: { id: id } }); - ctx.status = 200; - ctx.body = { message: '修改元数据成功' } - } - } else { +async function putMetadataDatabases (ctx) { + try { + const { id } = ctx.params; + const { catalog, name, code } = ctx.request.body; + const models = ctx.fs.dc.models; + let metadataDatabaseInfo = await models.MetadataDatabase.findOne({ where: { id } }); + if (metadataDatabaseInfo) { + const where = { id: { $not: id }, $or: [{ name: name }, { code: code }] } + if (metadataDatabaseInfo.parent) { + where.parent = metadataDatabaseInfo.parent; + } else { + where.parent = null; + where.catalog = catalog; + } + const putOne = await models.MetadataDatabase.findOne({ where: where }); + if (putOne) { ctx.status = 400; - ctx.body = { message: '该元数据不存在' } - } - } catch (error) { - ctx.fs.logger.error(`path: ${ctx.path}, error: ${error}`); - ctx.status = 400; - ctx.body = { - "message": "修改元数据失败" - } - } + ctx.body = { message: '同一父节点下该元数据名称或代码已存在' } + } else { + await models.MetadataDatabase.update({ updateAt: moment(), ...ctx.request.body }, { where: { id: id } }); + ctx.status = 200; + ctx.body = { message: '修改元数据成功' } + } + } else { + ctx.status = 400; + ctx.body = { message: '该元数据不存在' } + } + } catch (error) { + ctx.fs.logger.error(`path: ${ctx.path}, error: ${error}`); + ctx.status = 400; + ctx.body = { + "message": "修改元数据失败" + } + } } //删除库表元数据 -async function delMetadataDatabases(ctx) { - const transaction = await ctx.fs.dc.orm.transaction(); - try { - const models = ctx.fs.dc.models; - const { id } = ctx.params; - let metadataDatabaseInfo = await models.MetadataDatabase.findOne({ where: { id } }); - if (metadataDatabaseInfo) { - let deletable = true; - let childMetadataDatabaseInfo = await models.MetadataDatabase.findOne({ where: { parent: id } }); - if (childMetadataDatabaseInfo) { - ctx.status = 400; - ctx.body = { message: '存在关联子类元数据,请删除相关数据,再删除该元数据' } - deletable = false; +async function delMetadataDatabases (ctx) { + const transaction = await ctx.fs.dc.orm.transaction(); + try { + const models = ctx.fs.dc.models; + const { id } = ctx.params; + let metadataDatabaseInfo = await models.MetadataDatabase.findOne({ where: { id } }); + if (metadataDatabaseInfo) { + let deletable = true; + let childMetadataDatabaseInfo = await models.MetadataDatabase.findOne({ where: { parent: id } }); + if (childMetadataDatabaseInfo) { + ctx.status = 400; + ctx.body = { message: '存在关联子类元数据,请删除相关数据,再删除该元数据' } + deletable = false; + } else { + let tagDatabaseInfo = await models.TagDatabase.findOne({ where: { database: id } }); + if (tagDatabaseInfo) { + ctx.status = 400; + ctx.body = { message: '该元数据已被打标' } + deletable = false; } else { - let tagDatabaseInfo = await models.TagDatabase.findOne({ where: { database: id } }); - if (tagDatabaseInfo) { - ctx.status = 400; - ctx.body = { message: '该元数据已被打标' } - deletable = false; - } else { - let resourceConsumptionInfo = await models.ResourceConsumption.findOne({ - where: { - resourceId: id, - resourceName: metadataDatabaseInfo.name, - resourceType: '库表' - } - }); - if (resourceConsumptionInfo) { - ctx.status = 400; - ctx.body = { message: '该元数据存在资源申请' } - deletable = false; - } - } + let resourceConsumptionInfo = await models.ResourceConsumption.findOne({ + where: { + resourceId: id, + resourceName: metadataDatabaseInfo.name, + resourceType: '库表' + } + }); + if (resourceConsumptionInfo) { + ctx.status = 400; + ctx.body = { message: '该元数据存在资源申请' } + deletable = false; + } } - if (deletable) { - await models.MetadataDatabase.destroy({ - where: { id: id }, - transaction - }) - await transaction.commit(); - ctx.status = 200; - ctx.body = { message: '删除元数据成功' } - } - } else { - ctx.status = 400; - ctx.body = { message: '该元数据不存在' } - } - } catch (error) { - await transaction.rollback(); - ctx.fs.logger.error(`path: ${ctx.path}, error: ${error}`); - ctx.status = 400; - ctx.body = { message: '删除元数据失败' } - } + } + if (deletable) { + await models.MetadataDatabase.destroy({ + where: { id: id }, + transaction + }) + await transaction.commit(); + ctx.status = 200; + ctx.body = { message: '删除元数据成功' } + } + } else { + ctx.status = 400; + ctx.body = { message: '该元数据不存在' } + } + } catch (error) { + await transaction.rollback(); + ctx.fs.logger.error(`path: ${ctx.path}, error: ${error}`); + ctx.status = 400; + ctx.body = { message: '删除元数据失败' } + } } //获取库表元数据基本信息 -async function getMetadataDatabasesById(ctx) { - try { - const models = ctx.fs.dc.models; - const { id } = ctx.params; - const findObj = { - include: [ - { - model: models.User, - attributes: ['id', 'name', 'username'], - }, - { - model: models.TagDatabase, - include: [{ - model: models.Tag, - }] - }], - where: { id: id }, - } - const rslt = await models.MetadataDatabase.findOne(findObj); - ctx.status = 200; - ctx.body = rslt; - } catch (error) { - ctx.fs.logger.error(`path: ${ctx.path}, error: ${error}`); - ctx.status = 400; - ctx.body = { - "message": "获取元数据基本信息失败" - } - } +async function getMetadataDatabasesById (ctx) { + try { + const models = ctx.fs.dc.models; + const { id } = ctx.params; + const findObj = { + include: [ + { + model: models.User, + attributes: ['id', 'name', 'username'], + }, + { + model: models.TagDatabase, + include: [{ + model: models.Tag, + }] + }], + where: { id: id }, + } + const rslt = await models.MetadataDatabase.findOne(findObj); + ctx.status = 200; + ctx.body = rslt; + } catch (error) { + ctx.fs.logger.error(`path: ${ctx.path}, error: ${error}`); + ctx.status = 400; + ctx.body = { + "message": "获取元数据基本信息失败" + } + } } //打标元数据 -async function postTagMetadata(ctx) { - const transaction = await ctx.fs.dc.orm.transaction(); - try { - const { tags, database, file, restapi } = ctx.request.body; - const models = ctx.fs.dc.models; - if (tags.length && (database || file || restapi)) { - if (database) { - await models.TagDatabase.destroy({ where: { database: database }, transaction }); - const data = tags.map(tag => { return { tagId: tag, database: database } }); - if (data.length) - await models.TagDatabase.bulkCreate(data, { transaction }); - } - if (file) { - await models.TagFile.destroy({ where: { file: file }, transaction }); - const data = tags.map(tag => { return { tagId: tag, file: file } }); - if (data.length) - await models.TagFile.bulkCreate(data, { transaction }); - } - if (restapi) { - await models.TagRestapi.destroy({ where: { restapi: restapi }, transaction }); - const data = tags.map(tag => { return { tagId: tag, restapi: restapi } }); - if (data.length) - await models.TagRestapi.bulkCreate(data, { transaction }); - } - await transaction.commit(); - ctx.status = 204; - } else { - ctx.body = { message: '参数不全,请重新配置' } - ctx.status = 400; - } - } catch (error) { - await transaction.rollback(); - ctx.fs.logger.error(`path: ${ctx.path}, error: ${error}`); - ctx.status = 400; - ctx.body = { - "message": "打标元数据失败" - } - } +async function postTagMetadata (ctx) { + const transaction = await ctx.fs.dc.orm.transaction(); + try { + const { tags, database, file, restapi } = ctx.request.body; + const models = ctx.fs.dc.models; + if (tags.length && (database || file || restapi)) { + if (database) { + await models.TagDatabase.destroy({ where: { database: database }, transaction }); + const data = tags.map(tag => { return { tagId: tag, database: database } }); + if (data.length) + await models.TagDatabase.bulkCreate(data, { transaction }); + } + if (file) { + await models.TagFile.destroy({ where: { file: file }, transaction }); + const data = tags.map(tag => { return { tagId: tag, file: file } }); + if (data.length) + await models.TagFile.bulkCreate(data, { transaction }); + } + if (restapi) { + await models.TagRestapi.destroy({ where: { restapi: restapi }, transaction }); + const data = tags.map(tag => { return { tagId: tag, restapi: restapi } }); + if (data.length) + await models.TagRestapi.bulkCreate(data, { transaction }); + } + await transaction.commit(); + ctx.status = 204; + } else { + ctx.body = { message: '参数不全,请重新配置' } + ctx.status = 400; + } + } catch (error) { + await transaction.rollback(); + ctx.fs.logger.error(`path: ${ctx.path}, error: ${error}`); + ctx.status = 400; + ctx.body = { + "message": "打标元数据失败" + } + } } //获取元数据已打标数据 -async function getTagMetadata(ctx) { - try { - const models = ctx.fs.dc.models; - const { id } = ctx.params; - const { type } = ctx.query; - let rslt = []; - if (type === 'database') { - rslt = await models.Tag.findAll({ - where: { '$tagDatabases.database$': id }, - include: [{ - model: models.TagDatabase, - }], - order: [['id', 'asc']], - }); - } - if (type === 'file') { - rslt = await models.Tag.findAll({ - where: { '$tagFiles.file$': id }, - include: [{ - model: models.TagFile, - }], - order: [['id', 'asc']], - }); - } - if (type === 'restapi') { - rslt = await models.Tag.findAll({ - where: { '$tagRestapis.restapi$': id }, - include: [{ - model: models.TagRestapi, - }], - order: [['id', 'asc']], - }); - } - ctx.status = 200; - ctx.body = rslt; - } catch (error) { - ctx.fs.logger.error(`path: ${ctx.path}, error: ${error}`); - ctx.status = 400; - ctx.body = { - "message": "获取元数据已打标数据失败" - } - } +async function getTagMetadata (ctx) { + try { + const models = ctx.fs.dc.models; + const { id } = ctx.params; + const { type } = ctx.query; + let rslt = []; + if (type === 'database') { + rslt = await models.Tag.findAll({ + where: { '$tagDatabases.database$': id }, + include: [{ + model: models.TagDatabase, + }], + order: [['id', 'asc']], + }); + } + if (type === 'file') { + rslt = await models.Tag.findAll({ + where: { '$tagFiles.file$': id }, + include: [{ + model: models.TagFile, + }], + order: [['id', 'asc']], + }); + } + if (type === 'restapi') { + rslt = await models.Tag.findAll({ + where: { '$tagRestapis.restapi$': id }, + include: [{ + model: models.TagRestapi, + }], + order: [['id', 'asc']], + }); + } + ctx.status = 200; + ctx.body = rslt; + } catch (error) { + ctx.fs.logger.error(`path: ${ctx.path}, error: ${error}`); + ctx.status = 400; + ctx.body = { + "message": "获取元数据已打标数据失败" + } + } } //申请资源 -async function postMetadataResourceApplications(ctx) { - try { - const { resourceName, applyBy, resourceType, resourceId } = ctx.request.body; - if (!resourceName || !applyBy || !resourceType || !resourceId) { +async function postMetadataResourceApplications (ctx) { + try { + const { resourceName, applyBy, resourceType, resourceId } = ctx.request.body; + if (!resourceName || !applyBy || !resourceType || !resourceId) { + ctx.status = 400; + ctx.body = { message: '参数不全,请重新申请资源' } + } else { + const models = ctx.fs.dc.models; + const postOne = await models.ResourceConsumption.findOne({ + where: { applyBy: applyBy, resourceName: resourceName, resourceId, resourceType } + }); + if (postOne) { ctx.status = 400; - ctx.body = { message: '参数不全,请重新申请资源' } - } else { - const models = ctx.fs.dc.models; - const postOne = await models.ResourceConsumption.findOne({ - where: { applyBy: applyBy, resourceName: resourceName, resourceId, resourceType } - }); - if (postOne) { - ctx.status = 400; - ctx.body = { message: '该用户已申请过该元数据资源' } - } else { - await models.ResourceConsumption.create({ applyAt: moment(), approveState: '审批中', ...ctx.request.body }); - ctx.body = { message: '申请资源成功' } - ctx.status = 200; - } - } - } catch (error) { - ctx.fs.logger.error(`path: ${ctx.path}, error: ${error}`); - ctx.status = 400; - ctx.body = { - "message": "申请资源失败" - } - } + ctx.body = { message: '该用户已申请过该元数据资源' } + } else { + await models.ResourceConsumption.create({ applyAt: moment(), approveState: '审批中', ...ctx.request.body }); + ctx.body = { message: '申请资源成功' } + ctx.status = 200; + } + } + } catch (error) { + ctx.fs.logger.error(`path: ${ctx.path}, error: ${error}`); + ctx.status = 400; + ctx.body = { + "message": "申请资源失败" + } + } } //获取元数据资源申请记录 -async function getMetadataResourceApplications(ctx) { - try { - const models = ctx.fs.dc.models; - const { resourceNames, type } = ctx.query; - let rslt = []; - if (resourceNames && type) { - rslt = await models.ResourceConsumption.findAll({ - where: { resourceName: { $in: resourceNames.split(',') }, resourceType: type } - }); - } - ctx.status = 200; - ctx.body = rslt; - } catch (error) { - ctx.fs.logger.error(`path: ${ctx.path}, error: ${error}`); - ctx.status = 400; - ctx.body = { - "message": "获取元数据资源申请记录失败" - } - } +async function getMetadataResourceApplications (ctx) { + try { + const models = ctx.fs.dc.models; + const { resourceNames, type } = ctx.query; + let rslt = []; + if (resourceNames && type) { + rslt = await models.ResourceConsumption.findAll({ + where: { resourceName: { $in: resourceNames.split(',') }, resourceType: type } + }); + } + ctx.status = 200; + ctx.body = rslt; + } catch (error) { + ctx.fs.logger.error(`path: ${ctx.path}, error: ${error}`); + ctx.status = 400; + ctx.body = { + "message": "获取元数据资源申请记录失败" + } + } } //新建文件元数据 -async function postMetadataFiles(ctx) { - try { - const { name, catalog, type, fileName } = ctx.request.body; - const models = ctx.fs.dc.models; - const postOne = await models.MetadataFile.findOne({ - where: { name: name, catalog: catalog } - }); - if (postOne) { +async function postMetadataFiles (ctx) { + try { + const { name, catalog, type, fileName } = ctx.request.body; + const models = ctx.fs.dc.models; + const postOne = await models.MetadataFile.findOne({ + where: { name: name, catalog: catalog } + }); + if (postOne) { + ctx.status = 400; + ctx.body = { message: '该资源目录下元数据名称已存在' } + } else { + if (!name || !catalog || !type || !fileName) { + ctx.body = { message: '参数不全,请重新配置' } ctx.status = 400; - ctx.body = { message: '该资源目录下元数据名称已存在' } - } else { - if (!name || !catalog || !type || !fileName) { - ctx.body = { message: '参数不全,请重新配置' } - ctx.status = 400; - } else { - await models.MetadataFile.create({ createAt: moment(), ...ctx.request.body }); - ctx.body = { message: '新建元数据成功' } - ctx.status = 200; - } - } - } catch (error) { - ctx.fs.logger.error(`path: ${ctx.path}, error: ${error}`); - ctx.status = 400; - ctx.body = { - "message": "新建元数据失败" - } - } + } else { + await models.MetadataFile.create({ createAt: moment(), ...ctx.request.body }); + ctx.body = { message: '新建元数据成功' } + ctx.status = 200; + } + } + } catch (error) { + ctx.fs.logger.error(`path: ${ctx.path}, error: ${error}`); + ctx.status = 400; + ctx.body = { + "message": "新建元数据失败" + } + } } //修改文件元数据 -async function putMetadataFiles(ctx) { - try { - const { id } = ctx.params; - const { updateFileName } = ctx.query; - const { catalog, name, type } = ctx.request.body; - const models = ctx.fs.dc.models; - let metadataFileInfo = await models.MetadataFile.findOne({ where: { id } }); - if (metadataFileInfo) { - if (updateFileName) {//编辑时,将文件删除,后又取消,则更新文件名为null - await models.MetadataFile.update({ updateAt: moment(), fileName: null }, { where: { id: id } }); - ctx.status = 204; +async function putMetadataFiles (ctx) { + try { + const { id } = ctx.params; + const { updateFileName } = ctx.query; + const { catalog, name, type } = ctx.request.body; + const models = ctx.fs.dc.models; + let metadataFileInfo = await models.MetadataFile.findOne({ where: { id } }); + if (metadataFileInfo) { + if (updateFileName) {//编辑时,将文件删除,后又取消,则更新文件名为null + await models.MetadataFile.update({ updateAt: moment(), fileName: null }, { where: { id: id } }); + ctx.status = 204; + } else { + if (!name || !catalog || !type) { + ctx.body = { message: '参数不全,请重新配置' } + ctx.status = 400; } else { - if (!name || !catalog || !type) { - ctx.body = { message: '参数不全,请重新配置' } - ctx.status = 400; - } else { - const putOne = await models.MetadataFile.findOne({ where: { id: { $not: id }, catalog: catalog, name: name } }); - if (putOne) { - ctx.status = 400; - ctx.body = { message: '该元数据名称已存在' } - } else { - await models.MetadataFile.update({ updateAt: moment(), ...ctx.request.body }, { where: { id: id } }); - ctx.status = 200; - ctx.body = { message: '修改元数据成功' } - } - } + const putOne = await models.MetadataFile.findOne({ where: { id: { $not: id }, catalog: catalog, name: name } }); + if (putOne) { + ctx.status = 400; + ctx.body = { message: '该元数据名称已存在' } + } else { + await models.MetadataFile.update({ updateAt: moment(), ...ctx.request.body }, { where: { id: id } }); + ctx.status = 200; + ctx.body = { message: '修改元数据成功' } + } } - } else { - ctx.status = 400; - ctx.body = { message: '该元数据不存在' } - } - } catch (error) { - ctx.fs.logger.error(`path: ${ctx.path}, error: ${error}`); - ctx.status = 400; - ctx.body = { - "message": "修改元数据失败" - } - } + } + } else { + ctx.status = 400; + ctx.body = { message: '该元数据不存在' } + } + } catch (error) { + ctx.fs.logger.error(`path: ${ctx.path}, error: ${error}`); + ctx.status = 400; + ctx.body = { + "message": "修改元数据失败" + } + } } //删除文件元数据 -async function delMetadataFiles(ctx) { - const transaction = await ctx.fs.dc.orm.transaction(); - try { - const models = ctx.fs.dc.models; - const { id } = ctx.params; - let metadataFileInfo = await models.MetadataFile.findOne({ where: { id } }); - if (metadataFileInfo) { - let deletable = true; - let tagFileInfo = await models.TagFile.findOne({ where: { file: id } }); - if (tagFileInfo) { - ctx.status = 400; - ctx.body = { message: '该元数据已被打标' } - deletable = false; - } else { - let resourceConsumptionInfo = await models.ResourceConsumption.findOne({ - where: { - resourceName: metadataFileInfo.name, - resourceType: '文件' - } - }); - if (resourceConsumptionInfo) { - ctx.status = 400; - ctx.body = { message: '该元数据存在资源申请' } - deletable = false; - } - } - if (deletable) { - await models.MetadataFile.destroy({ - where: { id: id }, - transaction - }) - await transaction.commit(); - ctx.status = 200; - ctx.body = { message: '删除元数据成功' } - } - } else { +async function delMetadataFiles (ctx) { + const transaction = await ctx.fs.dc.orm.transaction(); + try { + const models = ctx.fs.dc.models; + const { id } = ctx.params; + let metadataFileInfo = await models.MetadataFile.findOne({ where: { id } }); + if (metadataFileInfo) { + let deletable = true; + let tagFileInfo = await models.TagFile.findOne({ where: { file: id } }); + if (tagFileInfo) { ctx.status = 400; - ctx.body = { message: '该元数据不存在' } - } - } catch (error) { - await transaction.rollback(); - ctx.fs.logger.error(`path: ${ctx.path}, error: ${error}`); - ctx.status = 400; - ctx.body = { message: '删除元数据失败' } - } + ctx.body = { message: '该元数据已被打标' } + deletable = false; + } else { + let resourceConsumptionInfo = await models.ResourceConsumption.findOne({ + where: { + resourceName: metadataFileInfo.name, + resourceType: '文件' + } + }); + if (resourceConsumptionInfo) { + ctx.status = 400; + ctx.body = { message: '该元数据存在资源申请' } + deletable = false; + } + } + if (deletable) { + await models.MetadataFile.destroy({ + where: { id: id }, + transaction + }) + await transaction.commit(); + ctx.status = 200; + ctx.body = { message: '删除元数据成功' } + } + } else { + ctx.status = 400; + ctx.body = { message: '该元数据不存在' } + } + } catch (error) { + await transaction.rollback(); + ctx.fs.logger.error(`path: ${ctx.path}, error: ${error}`); + ctx.status = 400; + ctx.body = { message: '删除元数据失败' } + } } //新建接口元数据 -async function postMetadataRestapis(ctx) { - try { - const { name, catalog, method, url } = ctx.request.body; - const models = ctx.fs.dc.models; - const postOne = await models.MetadataRestapi.findOne({ - where: { name: name, catalog: catalog } - }); - if (postOne) { +async function postMetadataRestapis (ctx) { + try { + const { name, catalog, method, url } = ctx.request.body; + const models = ctx.fs.dc.models; + const postOne = await models.MetadataRestapi.findOne({ + where: { name: name, catalog: catalog } + }); + if (postOne) { + ctx.status = 400; + ctx.body = { message: '该资源目录下元数据名称已存在' } + } else { + if (!name || !catalog || !method || !url) { + ctx.body = { message: '参数不全,请重新配置' } ctx.status = 400; - ctx.body = { message: '该资源目录下元数据名称已存在' } - } else { - if (!name || !catalog || !method || !url) { - ctx.body = { message: '参数不全,请重新配置' } - ctx.status = 400; - } else { - await models.MetadataRestapi.create({ createAt: moment(), ...ctx.request.body }); - ctx.body = { message: '新建元数据成功' } - ctx.status = 200; - } - } - } catch (error) { - ctx.fs.logger.error(`path: ${ctx.path}, error: ${error}`); - ctx.status = 400; - ctx.body = { - "message": "新建元数据失败" - } - } + } else { + await models.MetadataRestapi.create({ createAt: moment(), ...ctx.request.body }); + ctx.body = { message: '新建元数据成功' } + ctx.status = 200; + } + } + } catch (error) { + ctx.fs.logger.error(`path: ${ctx.path}, error: ${error}`); + ctx.status = 400; + ctx.body = { + "message": "新建元数据失败" + } + } } //修改接口元数据 -async function putMetadataRestapis(ctx) { - try { - const { id } = ctx.params; - const { catalog, name, method, url } = ctx.request.body; - const models = ctx.fs.dc.models; - let metadataRestapiInfo = await models.MetadataRestapi.findOne({ where: { id } }); - if (metadataRestapiInfo) { - if (!name || !catalog || !method || !url) { - ctx.body = { message: '参数不全,请重新修改' } - ctx.status = 400; +async function putMetadataRestapis (ctx) { + try { + const { id } = ctx.params; + const { catalog, name, method, url } = ctx.request.body; + const models = ctx.fs.dc.models; + let metadataRestapiInfo = await models.MetadataRestapi.findOne({ where: { id } }); + if (metadataRestapiInfo) { + if (!name || !catalog || !method || !url) { + ctx.body = { message: '参数不全,请重新修改' } + ctx.status = 400; + } else { + const putOne = await models.MetadataRestapi.findOne({ where: { id: { $not: id }, catalog: catalog, name: name } }); + if (putOne) { + ctx.status = 400; + ctx.body = { message: '该元数据名称已存在' } } else { - const putOne = await models.MetadataRestapi.findOne({ where: { id: { $not: id }, catalog: catalog, name: name } }); - if (putOne) { - ctx.status = 400; - ctx.body = { message: '该元数据名称已存在' } - } else { - await models.MetadataRestapi.update({ updateAt: moment(), ...ctx.request.body }, { where: { id: id } }); - ctx.status = 200; - ctx.body = { message: '修改元数据成功' } - } + await models.MetadataRestapi.update({ updateAt: moment(), ...ctx.request.body }, { where: { id: id } }); + ctx.status = 200; + ctx.body = { message: '修改元数据成功' } } - } else { - ctx.status = 400; - ctx.body = { message: '该元数据不存在' } - } - } catch (error) { - ctx.fs.logger.error(`path: ${ctx.path}, error: ${error}`); - ctx.status = 400; - ctx.body = { - "message": "修改元数据失败" - } - } + } + } else { + ctx.status = 400; + ctx.body = { message: '该元数据不存在' } + } + } catch (error) { + ctx.fs.logger.error(`path: ${ctx.path}, error: ${error}`); + ctx.status = 400; + ctx.body = { + "message": "修改元数据失败" + } + } } //删除接口元数据 -async function delMetadataRestapis(ctx) { - const transaction = await ctx.fs.dc.orm.transaction(); - try { - const models = ctx.fs.dc.models; - const { id } = ctx.params; - let metadataRestapiInfo = await models.MetadataRestapi.findOne({ where: { id } }); - if (metadataRestapiInfo) { - let deletable = true; - let tagRestapiInfo = await models.TagRestapi.findOne({ where: { restapi: id } }); - if (tagRestapiInfo) { - ctx.status = 400; - ctx.body = { message: '该元数据已被打标' } - deletable = false; - } else { - let resourceConsumptionInfo = await models.ResourceConsumption.findOne({ - where: { - resourceName: metadataRestapiInfo.name, - resourceType: '接口' - } - }); - if (resourceConsumptionInfo) { - ctx.status = 400; - ctx.body = { message: '该元数据存在资源申请' } - deletable = false; - } - } - if (deletable) { - await models.MetadataRestapi.destroy({ - where: { id: id }, - transaction - }) - await transaction.commit(); - ctx.status = 200; - ctx.body = { message: '删除元数据成功' } - } - } else { +async function delMetadataRestapis (ctx) { + const transaction = await ctx.fs.dc.orm.transaction(); + try { + const models = ctx.fs.dc.models; + const { id } = ctx.params; + let metadataRestapiInfo = await models.MetadataRestapi.findOne({ where: { id } }); + if (metadataRestapiInfo) { + let deletable = true; + let tagRestapiInfo = await models.TagRestapi.findOne({ where: { restapi: id } }); + if (tagRestapiInfo) { ctx.status = 400; - ctx.body = { message: '该元数据不存在' } - } - } catch (error) { - await transaction.rollback(); - ctx.fs.logger.error(`path: ${ctx.path}, error: ${error}`); - ctx.status = 400; - ctx.body = { message: '删除元数据失败' } - } + ctx.body = { message: '该元数据已被打标' } + deletable = false; + } else { + let resourceConsumptionInfo = await models.ResourceConsumption.findOne({ + where: { + resourceName: metadataRestapiInfo.name, + resourceType: '接口' + } + }); + if (resourceConsumptionInfo) { + ctx.status = 400; + ctx.body = { message: '该元数据存在资源申请' } + deletable = false; + } + } + if (deletable) { + await models.MetadataRestapi.destroy({ + where: { id: id }, + transaction + }) + await transaction.commit(); + ctx.status = 200; + ctx.body = { message: '删除元数据成功' } + } + } else { + ctx.status = 400; + ctx.body = { message: '该元数据不存在' } + } + } catch (error) { + await transaction.rollback(); + ctx.fs.logger.error(`path: ${ctx.path}, error: ${error}`); + ctx.status = 400; + ctx.body = { message: '删除元数据失败' } + } +} + +//获取对表的库与字段信息 +async function listStructuredData (ctx) { + try { + const models = ctx.fs.dc.models; + const { id, parent } = ctx.query; + + let field = await models.MetadataDatabase.findAll({ where: { parent: id } }) || [] + let database = await models.MetadataDatabase.findOne({ where: { id: parent } }) || {} + + ctx.status = 200; + ctx.body = { + field: field, + database: database + }; + } catch (error) { + ctx.fs.logger.error(`path: ${ctx.path}, error: ${error}`); + ctx.status = 400; + ctx.body = { + "message": "获取元数据资源申请记录失败" + } + } } module.exports = { - getResourceCatalog, - postResourceCatalog, - putResourceCatalog, - delResourceCatalog, - getMetadataDatabases, - getMetadataFiles, - getMetadataRestapis, - getMetadataModels, - postMetadataDatabases, - putMetadataDatabases, - delMetadataDatabases, - getMetadataDatabasesById, - postTagMetadata, - getTagMetadata, - postMetadataResourceApplications, - getMetadataResourceApplications, - postMetadataFiles, - putMetadataFiles, - delMetadataFiles, - postMetadataRestapis, - putMetadataRestapis, - delMetadataRestapis + getResourceCatalog, + postResourceCatalog, + putResourceCatalog, + delResourceCatalog, + getMetadataDatabases, + getMetadataFiles, + getMetadataRestapis, + getMetadataModels, + postMetadataDatabases, + putMetadataDatabases, + delMetadataDatabases, + getMetadataDatabasesById, + postTagMetadata, + getTagMetadata, + postMetadataResourceApplications, + getMetadataResourceApplications, + postMetadataFiles, + putMetadataFiles, + delMetadataFiles, + postMetadataRestapis, + putMetadataRestapis, + delMetadataRestapis, + listStructuredData } \ No newline at end of file diff --git a/api/app/lib/routes/latestMetadata/index.js b/api/app/lib/routes/latestMetadata/index.js index 01022e1..2f78a22 100644 --- a/api/app/lib/routes/latestMetadata/index.js +++ b/api/app/lib/routes/latestMetadata/index.js @@ -68,4 +68,7 @@ module.exports = function (app, router, opts) { app.fs.api.logAttr['DEL/metadata/restapis/:id'] = { content: '删除接口元数据', visible: true }; router.delete('/metadata/restapis/:id', latestMetadata.delMetadataRestapis); + + app.fs.api.logAttr['GET/listStructuredData'] = { content: '获取对表的库与字段信息', visible: true }; + router.get('/listStructuredData', latestMetadata.listStructuredData); }; \ No newline at end of file diff --git a/web/client/src/sections/dataQuality/containers/ruleLibrary.js b/web/client/src/sections/dataQuality/containers/ruleLibrary.js index d53c408..9525330 100644 --- a/web/client/src/sections/dataQuality/containers/ruleLibrary.js +++ b/web/client/src/sections/dataQuality/containers/ruleLibrary.js @@ -97,7 +97,7 @@ function RuleLibrary ({ loading, clientHeight, actions, dispatch, }) { return <> -
+
@@ -123,7 +123,7 @@ function RuleLibrary ({ loading, clientHeight, actions, dispatch, }) { { setRuleModal(false); setEditData({}) - } } + }} success={() => { resourceData({ limit: 10, page: 0, keyword }) } diff --git a/web/client/src/sections/metadataManagement/actions/businessMetadata.js b/web/client/src/sections/metadataManagement/actions/businessMetadata.js index e61ba1d..fe391f3 100644 --- a/web/client/src/sections/metadataManagement/actions/businessMetadata.js +++ b/web/client/src/sections/metadataManagement/actions/businessMetadata.js @@ -3,151 +3,163 @@ import { basicAction } from '@peace/utils' import { ApiTable } from '$utils' -export function getBusinessMetadataDatabases(params) { - return dispatch => basicAction({ - type: 'get', - dispatch: dispatch, - query: params, - actionType: 'GET_BUSINESS_METADATA_DATABASES_LIST', - url: ApiTable.getBusinessMetadataDatabases, - msg: { error: '获取业务元数据列表失败' }, - reducer: { name: 'businessMetadataDatabases' } - }); +export function getBusinessMetadataDatabases (params) { + return dispatch => basicAction({ + type: 'get', + dispatch: dispatch, + query: params, + actionType: 'GET_BUSINESS_METADATA_DATABASES_LIST', + url: ApiTable.getBusinessMetadataDatabases, + msg: { error: '获取业务元数据列表失败' }, + reducer: { name: 'businessMetadataDatabases' } + }); } -export function postBusinessMetadataDatabases(data) { - return dispatch => basicAction({ - type: 'post', - data: data, - dispatch: dispatch, - actionType: 'POST_BUSINESS_METADATA_DATABASES', - url: ApiTable.postBusinessMetadataDatabases, - msg: { option: '新建业务元数据' }, - reducer: {} - }); +export function postBusinessMetadataDatabases (data) { + return dispatch => basicAction({ + type: 'post', + data: data, + dispatch: dispatch, + actionType: 'POST_BUSINESS_METADATA_DATABASES', + url: ApiTable.postBusinessMetadataDatabases, + msg: { option: '新建业务元数据' }, + reducer: {} + }); } -export function putBusinessMetadataDatabases(id, data) { - return dispatch => basicAction({ - type: 'put', - data: data, - dispatch, - actionType: 'PUT_BUSINESS_METADATA_DATABASES', - url: ApiTable.putBusinessMetadataDatabases.replace('{id}', id), - msg: { - option: '修改业务元数据', - } - }); +export function putBusinessMetadataDatabases (id, data) { + return dispatch => basicAction({ + type: 'put', + data: data, + dispatch, + actionType: 'PUT_BUSINESS_METADATA_DATABASES', + url: ApiTable.putBusinessMetadataDatabases.replace('{id}', id), + msg: { + option: '修改业务元数据', + } + }); } -export function delBusinessMetadataDatabases(id) { - return dispatch => basicAction({ - type: 'del', - dispatch, - actionType: 'DELETE_BUSINESS_METADATA_DATABASES', - url: ApiTable.delBusinessMetadataDatabases.replace('{id}', id), - msg: { - option: '删除业务元数据', - } - }); +export function delBusinessMetadataDatabases (id) { + return dispatch => basicAction({ + type: 'del', + dispatch, + actionType: 'DELETE_BUSINESS_METADATA_DATABASES', + url: ApiTable.delBusinessMetadataDatabases.replace('{id}', id), + msg: { + option: '删除业务元数据', + } + }); } -export function getBusinessMetadataFiles(params) { - return dispatch => basicAction({ - type: 'get', - dispatch: dispatch, - query: params, - actionType: 'GET_BUSINESS_METADATA_FILES_LIST', - url: ApiTable.getBusinessMetadataFiles, - msg: { error: '获取业务元数据列表失败' }, - reducer: { name: 'businessMetadataFiles' } - }); +export function getBusinessMetadataFiles (params) { + return dispatch => basicAction({ + type: 'get', + dispatch: dispatch, + query: params, + actionType: 'GET_BUSINESS_METADATA_FILES_LIST', + url: ApiTable.getBusinessMetadataFiles, + msg: { error: '获取业务元数据列表失败' }, + reducer: { name: 'businessMetadataFiles' } + }); } -export function postBusinessMetadataFiles(data) { - return dispatch => basicAction({ - type: 'post', - data: data, - dispatch: dispatch, - actionType: 'POST_BUSINESS_METADATA_FILES', - url: ApiTable.postBusinessMetadataFiles, - msg: { option: '新建业务元数据' }, - reducer: {} - }); +export function postBusinessMetadataFiles (data) { + return dispatch => basicAction({ + type: 'post', + data: data, + dispatch: dispatch, + actionType: 'POST_BUSINESS_METADATA_FILES', + url: ApiTable.postBusinessMetadataFiles, + msg: { option: '新建业务元数据' }, + reducer: {} + }); } -export function putBusinessMetadataFiles(id, data) { - return dispatch => basicAction({ - type: 'put', - data: data, - dispatch, - actionType: 'PUT_BUSINESS_METADATA_FILES', - url: ApiTable.putBusinessMetadataFiles.replace('{id}', id), - msg: { - option: '修改业务元数据', - } - }); +export function putBusinessMetadataFiles (id, data) { + return dispatch => basicAction({ + type: 'put', + data: data, + dispatch, + actionType: 'PUT_BUSINESS_METADATA_FILES', + url: ApiTable.putBusinessMetadataFiles.replace('{id}', id), + msg: { + option: '修改业务元数据', + } + }); } -export function delBusinessMetadataFiles(id) { - return dispatch => basicAction({ - type: 'del', - dispatch, - actionType: 'DELETE_BUSINESS_METADATA_FILES', - url: ApiTable.delBusinessMetadataFiles.replace('{id}', id), - msg: { - option: '删除业务元数据', - } - }); +export function delBusinessMetadataFiles (id) { + return dispatch => basicAction({ + type: 'del', + dispatch, + actionType: 'DELETE_BUSINESS_METADATA_FILES', + url: ApiTable.delBusinessMetadataFiles.replace('{id}', id), + msg: { + option: '删除业务元数据', + } + }); } -export function getBusinessMetadataRestapis(params) { - return dispatch => basicAction({ - type: 'get', - dispatch: dispatch, - query: params, - actionType: 'GET_BUSINESS_METADATA_RESTAPIS_LIST', - url: ApiTable.getBusinessMetadataRestapis, - msg: { error: '获取业务元数据列表失败' }, - reducer: { name: 'businessMetadataRestapis' } - }); +export function getBusinessMetadataRestapis (params) { + return dispatch => basicAction({ + type: 'get', + dispatch: dispatch, + query: params, + actionType: 'GET_BUSINESS_METADATA_RESTAPIS_LIST', + url: ApiTable.getBusinessMetadataRestapis, + msg: { error: '获取业务元数据列表失败' }, + reducer: { name: 'businessMetadataRestapis' } + }); } -export function postBusinessMetadataRestapis(data) { - return dispatch => basicAction({ - type: 'post', - data: data, - dispatch: dispatch, - actionType: 'POST_BUSINESS_METADATA_RESTAPIS', - url: ApiTable.postBusinessMetadataRestapis, - msg: { option: '新建业务元数据' }, - reducer: {} - }); +export function postBusinessMetadataRestapis (data) { + return dispatch => basicAction({ + type: 'post', + data: data, + dispatch: dispatch, + actionType: 'POST_BUSINESS_METADATA_RESTAPIS', + url: ApiTable.postBusinessMetadataRestapis, + msg: { option: '新建业务元数据' }, + reducer: {} + }); } -export function putBusinessMetadataRestapis(id, data) { - return dispatch => basicAction({ - type: 'put', - data: data, - dispatch, - actionType: 'PUT_BUSINESS_METADATA_RESTAPIS', - url: ApiTable.putBusinessMetadataRestapis.replace('{id}', id), - msg: { - option: '修改业务元数据', - } - }); +export function putBusinessMetadataRestapis (id, data) { + return dispatch => basicAction({ + type: 'put', + data: data, + dispatch, + actionType: 'PUT_BUSINESS_METADATA_RESTAPIS', + url: ApiTable.putBusinessMetadataRestapis.replace('{id}', id), + msg: { + option: '修改业务元数据', + } + }); } -export function delBusinessMetadataRestapis(id) { - return dispatch => basicAction({ - type: 'del', - dispatch, - actionType: 'DELETE_BUSINESS_METADATA_RESTAPIS', - url: ApiTable.delBusinessMetadataRestapis.replace('{id}', id), - msg: { - option: '删除业务元数据', - } - }); +export function delBusinessMetadataRestapis (id) { + return dispatch => basicAction({ + type: 'del', + dispatch, + actionType: 'DELETE_BUSINESS_METADATA_RESTAPIS', + url: ApiTable.delBusinessMetadataRestapis.replace('{id}', id), + msg: { + option: '删除业务元数据', + } + }); +} + +export function listStructuredData (query = {}) { + return dispatch => basicAction({ + type: 'get', + query, + dispatch: dispatch, + actionType: 'GET_LIST_STRUCTURED_DATA', + url: ApiTable.listStructuredData, + msg: { error: '获取对表的库与字段信息失败' }, + reducer: {} + }); } diff --git a/web/client/src/sections/metadataManagement/components/releaseModal.js b/web/client/src/sections/metadataManagement/components/releaseModal.js new file mode 100644 index 0000000..92f60c9 --- /dev/null +++ b/web/client/src/sections/metadataManagement/components/releaseModal.js @@ -0,0 +1,237 @@ +import React, { useEffect, useState } from 'react'; +import { connect } from 'react-redux'; +import { Modal, Input, Form, Tabs, Avatar, Checkbox, Button, Select } from 'antd'; +import { PlusCircleOutlined, MinusCircleOutlined } from '@ant-design/icons'; +const { TabPane } = Tabs; +const { TextArea } = Input; +const CheckboxGroup = Checkbox.Group; +const ReleaseModal = ({ actions, dispatch, onConfirm, onCancel, editData = {} }) => { + + const { metadataManagement } = actions; + const [activeKey, setActiveKeyl] = useState("field") + const [fieldList, setFiedList] = useState([]) + const [fieldData, setFiedData] = useState([]) + const [database, setDatabase] = useState({}) + const [fieldValue, setFiedValue] = useState([]) + const [indeterminate, setIndeterminate] = useState(false) + const [fromData, setFromData] = useState([{ value1: '', value2: '', value3: '' }]) + const [sql, setSql] = useState() + const [form] = Form.useForm(); + useEffect(() => { + + dispatch(metadataManagement.listStructuredData({ id: editData?.id, parent: editData?.parent })).then(res => { + if (res.success) { + setFiedData(res.payload.data?.field || []) + setFiedList(res.payload.data?.field?.map(v => v.code) || []) + setDatabase(res.payload.data?.database || {}) + } + + }) + }, []); + + + + let operator = [{ value: '=', label: '=' }, + { value: '!=', label: '!=' }, + { value: '>', label: '>' }, + { value: '<', label: '<' }, + { value: '>=', label: '>=' }, + { value: '<=', label: '<=' }, + { value: 'BETWEEN', label: 'BETWEEN' }, + { value: 'LIKE', label: 'LIKE' }, + { value: 'IN', label: 'IN' }] + + return ( + handleOk(null)} + onCancel={onCancel} + footer={null} + > +
+ {[{ name: '选择字段', key: "field" }, + { name: '配置条件', key: "condition" }, + { name: '预览SQL', key: "SQL" }, + { name: '服务发布', key: "release" }].map((v, index) => { + let title = [] + if (index > 0) { + title.push(
) + } + title.push(
+ + {v.name} +
) + return title + })} +
+ { + setActiveKeyl(v) + }} > + + + +
选择字段
+ {/*
*/} + { + setFiedValue(e.target.checked ? fieldList : []); + setIndeterminate(e.target.checked); + }}> + 全选 + +
+
字段:
+ { + setFiedValue(v) + if (v?.length == fieldList?.length) { + setIndeterminate(true) + } else { + setIndeterminate(false) + } + }} /> +
+ + + + +
配置条件:
+ {fromData?.map((f, index) => { + return
+ { + fromData?.splice(index, 1, { value1: f.value1, value2: v, value3: f.value3 }) + setFromData([...fromData]) + }} + options={operator} + allowClear + /> + { + fromData?.splice(index, 1, { value1: f.value1, value2: f.value2, value3: v?.target?.value }) + setFromData([...fromData]) + }} + allowClear + /> + {index == 0 ? + { + fromData?.splice(index, 0, { value1: '', value2: '', value3: '' }) + setFromData([...fromData]) + }} /> + : { + fromData?.splice(index, 1) + setFromData([...fromData]) + }} /> + } +
+ })} +
+ + +
预览SQL:
+