You can not select more than 25 topics
Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.
119 lines
4.4 KiB
119 lines
4.4 KiB
const moment = require('moment')
|
|
|
|
let isDev = false
|
|
// let isDev = true
|
|
|
|
module.exports = function (app, opts) {
|
|
const workorderStatistics = app.fs.scheduleInit(
|
|
{
|
|
interval: '24 0 */1 * * *', // 与 sql 相关 谨慎改动
|
|
immediate: isDev,
|
|
proRun: !isDev,
|
|
disabled: true
|
|
},
|
|
|
|
async () => {
|
|
try {
|
|
const { models, ORM: sequelize } = app.fs.dc
|
|
const { clickHouse } = app.fs
|
|
const { database: camWorkflow } = clickHouse.camWorkflow.opts.config
|
|
const { parseProcessData } = app.fs.utils
|
|
|
|
const existWorkorderCount = await models.Workorder.count()
|
|
|
|
const formRes = await clickHouse.pepEmis.query(
|
|
`
|
|
SELECT
|
|
story.id AS historyId,
|
|
story.apply_user AS pepUserId,
|
|
story.form_data AS formData,
|
|
story.submit_form_data AS submitFormData,
|
|
story.create_at AS createAt,
|
|
fform.form_schema AS formSchema,
|
|
fprocess.name AS processName,
|
|
procin.state_ AS state,
|
|
procin.end_time_ AS endTime,
|
|
fform.id AS formId,
|
|
fversion.id AS versionId,
|
|
fgroup.name AS groupName
|
|
FROM
|
|
workflow_process_history AS story
|
|
INNER JOIN workflow_process_version AS fversion
|
|
ON fversion.id = story.version_id
|
|
INNER JOIN workflow_process_form AS fform
|
|
ON fform.id = fversion.form_id
|
|
INNER JOIN workflow_process AS fprocess
|
|
ON fprocess.id = fform.process_id
|
|
INNER JOIN workflow_group AS fgroup
|
|
ON fgroup.id = fprocess.group_id
|
|
AND fgroup.name = '运维中台表单'
|
|
INNER JOIN ${camWorkflow}.act_hi_procinst AS procin
|
|
ON procin.id_ = story.procinst_id
|
|
${existWorkorderCount ?
|
|
// 25小时之内完成的 或 3个月内未完成的
|
|
`
|
|
WHERE
|
|
(
|
|
procin.end_time_ IS NOT NULL
|
|
AND
|
|
procin.end_time_ > '${moment().subtract(25, 'hours').format('YYYY-MM-DD HH:mm:ss')}'
|
|
)
|
|
OR
|
|
(
|
|
procin.end_time_ IS NULL
|
|
AND
|
|
story.create_at > '${moment().subtract(3, 'months').format('YYYY-MM-DD HH:mm:ss')}'
|
|
)
|
|
`
|
|
:
|
|
''
|
|
}
|
|
`
|
|
|
|
).toPromise()
|
|
|
|
for (let f of formRes) {
|
|
const parseData = parseProcessData({
|
|
formSchema: JSON.parse(f.formSchema),
|
|
formData: JSON.parse(f.formData)
|
|
})
|
|
const existRes = await models.Workorder.findOne({
|
|
where: {
|
|
storyId: f.historyId,
|
|
}
|
|
})
|
|
if (existRes) {
|
|
await models.Workorder.update({
|
|
completeTime: f.endTime || null,
|
|
state: f.state,
|
|
problemType: parseData.problemType.value,
|
|
solution: parseData.solution.value
|
|
}, {
|
|
where: {
|
|
storyId: f.historyId,
|
|
}
|
|
})
|
|
} else {
|
|
const newRes = await models.Workorder.create({
|
|
storyId: f.historyId,
|
|
pomsProjectId: parseData.pomsProjectId.value || null,
|
|
expectTime: parseData.expectTime.value || null,
|
|
createTime: f.createAt || null,
|
|
completeTime: f.endTime || null,
|
|
state: f.state,
|
|
problemType: parseData.problemType.value || null,
|
|
solution: parseData.solution.value || null
|
|
})
|
|
}
|
|
}
|
|
|
|
} catch (error) {
|
|
console.error(error);
|
|
}
|
|
}
|
|
)
|
|
|
|
return {
|
|
workorderStatistics,
|
|
}
|
|
}
|