运维服务中台
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.

179 lines
8.3 KiB

/**
* 运维中台售后问题处理工单根据计划修复时间pa3aGiey3N发送企业微信通知因为不是必填项没有填写的不推送
*1.已完成的工单
* 根据表单数据中的是否已完成字段Solution_Status判断该单子是否推送通知
* 已完成的不推送未完成的推送通知
* 推送给处理人Processing_Personnel
* 2.未完成的工单
*
*/
const schedule = require('node-schedule')
const moment = require('moment')
const request = require('superagent')
let isDev = false
// isDev = true
const sendType = {
'mini': 'miniprogram_notice',
}
module.exports = function (app, opts) {
const workOrderNotice = app.fs.scheduleInit(
{
interval: '30 * * * *',//一小时执行一次
immediate: isDev,
proRun: !isDev,
},
async () => {
try {
//前一次执行时间
const phone = opts.phone//运维部门审批工单的负责人的电话号码
console.log('运维中台售后问题处理工单数据抽取开始', moment().format('YYYY-MM-DD HH:mm:ss'))
const { parseProcessData, getUserId, sendWechat } = app.fs.utils
const startTime = moment().format('YYYY-MM-DD HH:mm:ss')
const { models } = app.fs.dc
const { clickHouse } = app.fs
const { database: camWorkflow } = clickHouse.camWorkflow.opts.config
const formRes = await clickHouse.pepEmis.query(
`SELECT
story.id AS historyId,
story.procinst_id as procinstId,
story.apply_user AS pepUserId,
story.form_data AS formData,
story.submit_form_data AS submitFormData,
story.create_at as createTime,
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
AND fform.form_schema IS NOT NULL
INNER JOIN workflow_process AS fprocess
ON fprocess.id = fform.process_id
AND fprocess.name = '运维中台售后问题处理工单'
INNER JOIN workflow_group AS fgroup
ON fgroup.id = fprocess.group_id
INNER JOIN ${camWorkflow}.act_hi_procinst AS procin
ON procin.id_ = story.procinst_id
AND procin.state_ in ('COMPLETED','ACTIVE')
WHERE story.apply_user in ('731')`
).toPromise()
1 year ago
console.log('查询结果',formRes)
if (formRes && formRes.length > 0) {
for (let f of formRes) {
let user = {}
const parseData = f.formSchema && parseProcessData({
formSchema: JSON.parse(f.formSchema),
formData: JSON.parse(f.formData)
})
const rlst = await models.WorkOrderNotice.findOne({
where: {
procinstId: f.procinstId,
}
})
//没有计划完成时间,没有处理人,都不推送通知
if (parseData.processing_personnel.value && parseData.planTime.value) {
user = await clickHouse.pepEmis.query(`select * from user where id=${Number(parseData.processing_personnel.value)}`).toPromise()
if (!rlst) {
await models.WorkOrderNotice.create({
procinstId: f.procinstId,
planTime: parseData.planTime.value,
processingPersonnelId: parseData.processing_personnel.value,
processingPersonnelPhone: user && user.length && user[0].phone,
isSend: false,
haveDone: parseData.solution_status.value && parseData.solution_status.value === '否' ? false : true || false,
createTime: moment(f.createTime).format('YYYY-MM-DD'),
})
}
} else {
console.log('没有对应的处理人,没有计划完成时间', f.procinstId)
}
}
} else {
console.log('未查询到数据')
}
//数据全部插入完成之后(筛选数据进行发送企业微信通知)
// 获取当前时间
// 计算当前时间之后一天的日期
const lastDay = moment().subtract(1, 'days')
//需要发送提醒的数据
const sendRslt = await models.WorkOrderNotice.findAll({
where: {
isSend: false,//未发送
haveDone: false,//未完成
planTime: {
$gte: lastDay
}
}
})
console.log('sendRslt',sendRslt)
//发送企业微信通知
if (sendRslt && sendRslt.length) {
console.log('sendRslt发送通知的数据',sendRslt)
for (let { dataValues: c } of sendRslt) {
await new Promise(resolve => setTimeout(resolve, 5000)); // 这里的5000是等待时间,单位为毫秒,您可以根据需要调整
//根据电话号码查询企业微信对应的userId
//phone,兰邦夫的电话号码(2024-1-9)
const userId = await getUserId(opts, c.processingPersonnelPhone)
await new Promise(resolve => setTimeout(resolve, 5000)); // 这里的5000是等待时间,单位为毫秒,您可以根据需要调整
const manager = await getUserId(opts, phone)
//根据查询的userId发送通知
if (userId) {
const res = await sendWechat({
opts, msgtype: sendType["mini"],
data: { userId: userId, touser: [userId],content:`你有一个表单《运维中台售后工单问题处理工单 ${c.createTime}》,修复时间即将超期,请尽快处理` }
})
if (res.body.errmsg === 'ok') {
//将已发送的记录的isSend修改为true(已发送)
await models.WorkOrderNotice.update({ isSend: true }, { where: { id: c.id } })
} else {
console.log('发送消息失败', res.body.errmsg)
}
} else {
console.log('查询不到对应的userId', c.processingPersonnelPhone)
}
if (manager) {
const res = await sendWechat({
opts, msgtype: sendType["mini"],
data: { userId: manager, touser: [manager],content:`你有一个表单《运维中台售后工单问题处理工单 ${c.createTime}》,修复时间即将超期,请尽快处理` }
})
if (res.body.errmsg === 'ok') {
//将已发送的记录的isSend修改为true(已发送)
console.log('已发送给运维部门主管')
// await models.WorkOrderNotice.update({ isSend: true }, { where: { id: c.id } })
} else {
console.log('发送消息失败', res.body.errmsg)
}
} else {
console.log('查询不到对应的userId', phone)
}
}
}
} catch (error) {
console.error('失败原因', error)
}
}
);
return {
workOrderNotice,
}
}