|
|
|
'use strict';
|
|
|
|
|
|
|
|
// 新增数据源
|
|
|
|
function addDataSource(opts) {
|
|
|
|
return async function (ctx, next) {
|
|
|
|
|
|
|
|
const models = ctx.fs.dc.models;
|
|
|
|
try {
|
|
|
|
const { name } = ctx.request.body
|
|
|
|
const checkName = await models.DataSource.findOne({ where: { name, name } });
|
|
|
|
if (checkName) {
|
|
|
|
ctx.status = 400;
|
|
|
|
ctx.body = { message: '该数据源名称已存在' }
|
|
|
|
} else {
|
|
|
|
let rslt = ctx.request.body;
|
|
|
|
await models.DataSource.create(Object.assign({}, rslt))
|
|
|
|
let datasource = await models.DataSource.findOne({ where: { name } })
|
|
|
|
ctx.status = 200;
|
|
|
|
ctx.body = { message: '新建数据源成功', id: datasource.id }
|
|
|
|
}
|
|
|
|
} catch (error) {
|
|
|
|
ctx.fs.logger.error(`path: ${ctx.path}, error: ${error}`);
|
|
|
|
ctx.status = 400;
|
|
|
|
ctx.body = { message: '新建数据源失败' }
|
|
|
|
}
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
function getDataSource(opts) {
|
|
|
|
return async function (ctx, next) {
|
|
|
|
|
|
|
|
const models = ctx.fs.dc.models;
|
|
|
|
const { page, limit, name } = ctx.query;
|
|
|
|
let errMsg = { message: '获取数据源失败' }
|
|
|
|
const Op = ctx.fs.dc.ORM.Op;
|
|
|
|
try {
|
|
|
|
let searchWhere = {}
|
|
|
|
let option = {
|
|
|
|
where: searchWhere,
|
|
|
|
order: [["id", "desc"]],
|
|
|
|
include: [{ model: models.Adapter }]
|
|
|
|
}
|
|
|
|
|
|
|
|
if (name) {
|
|
|
|
searchWhere.name = {
|
|
|
|
// 模糊查询
|
|
|
|
[Op.like]: '%' + name + '%',
|
|
|
|
};
|
|
|
|
}
|
|
|
|
|
|
|
|
option.where = searchWhere
|
|
|
|
|
|
|
|
let limit_ = limit || 10;
|
|
|
|
let page_ = page || 1;
|
|
|
|
let offset = (page_ - 1) * limit_;
|
|
|
|
if (limit && page) {
|
|
|
|
option.limit = limit_
|
|
|
|
option.offset = offset
|
|
|
|
}
|
|
|
|
|
|
|
|
const res = await models.DataSource.findAndCount(option);
|
|
|
|
ctx.status = 200;
|
|
|
|
ctx.body = res;
|
|
|
|
} catch (error) {
|
|
|
|
ctx.fs.logger.error(`path: ${ctx.path}, error: ${error}`);
|
|
|
|
ctx.status = 400;
|
|
|
|
ctx.body = errMsg
|
|
|
|
}
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
// 修改数据源
|
|
|
|
function editDataSource(opts) {
|
|
|
|
return async function (ctx, next) {
|
|
|
|
|
|
|
|
try {
|
|
|
|
const models = ctx.fs.dc.models;
|
|
|
|
const { id } = ctx.params;
|
|
|
|
const body = ctx.request.body;
|
|
|
|
const { name } = ctx.request.body
|
|
|
|
const checkName = await models.DataSource.findOne({ where: { id: { $not: id }, name, name } });
|
|
|
|
if (checkName) {
|
|
|
|
ctx.status = 400;
|
|
|
|
ctx.body = { message: '该数据源名称已存在' }
|
|
|
|
} else {
|
|
|
|
await models.DataSource.update(
|
|
|
|
body,
|
|
|
|
{ where: { id: id, } }
|
|
|
|
)
|
|
|
|
ctx.status = 204;
|
|
|
|
ctx.body = { message: '修改数据源成功' }
|
|
|
|
}
|
|
|
|
} catch (error) {
|
|
|
|
ctx.fs.logger.error(`path: ${ctx.path}, error: ${error}`);
|
|
|
|
ctx.status = 400;
|
|
|
|
ctx.body = { message: '修改数据源失败' }
|
|
|
|
}
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
// 删除数据源
|
|
|
|
function deleteDataSource(opts) {
|
|
|
|
return async function (ctx, next) {
|
|
|
|
|
|
|
|
try {
|
|
|
|
const models = ctx.fs.dc.models;
|
|
|
|
const { id } = ctx.params;
|
|
|
|
const task = await models.AcquisitionTask.findOne({
|
|
|
|
where: {
|
|
|
|
dataSourceId: id
|
|
|
|
}
|
|
|
|
})
|
|
|
|
|
|
|
|
if (task) {
|
|
|
|
ctx.status = 400;
|
|
|
|
ctx.body = { message: '数据源下存在采集任务,请删除任务后再删除数据源!' }
|
|
|
|
} else {
|
|
|
|
await models.DataSource.destroy({
|
|
|
|
where: {
|
|
|
|
id: id
|
|
|
|
}
|
|
|
|
})
|
|
|
|
ctx.status = 204;
|
|
|
|
ctx.body = { message: '删除数据源成功' }
|
|
|
|
}
|
|
|
|
} catch (error) {
|
|
|
|
ctx.fs.logger.error(`path: ${ctx.path}, error: ${error}`);
|
|
|
|
ctx.status = 400;
|
|
|
|
ctx.body = { message: '删除数据源失败' }
|
|
|
|
}
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
module.exports = {
|
|
|
|
addDataSource,
|
|
|
|
getDataSource,
|
|
|
|
editDataSource,
|
|
|
|
deleteDataSource
|
|
|
|
}
|