|
|
|
try {
|
|
|
|
const { Pool, Client } = require('pg')
|
|
|
|
const Hex = require('crypto-js/enc-hex');
|
|
|
|
const MD5 = require('crypto-js/md5');
|
|
|
|
const request = require('superagent');
|
|
|
|
const fs = require("fs");
|
|
|
|
const args = require('args');
|
|
|
|
const moment = require('moment');
|
|
|
|
|
|
|
|
const { ENV_SY_POOL, ENV_CS_POOL, PRO_POOL } = require('./config.js')
|
|
|
|
|
|
|
|
args.option(['e', 'env'], '商用环境');
|
|
|
|
args.option(['t', 'test'], '测试环境');
|
|
|
|
args.option(['p', 'product'], '生产环境');
|
|
|
|
const flags = args.parse(process.argv);
|
|
|
|
|
|
|
|
console.log("process.env.FS_ENV:", process.env.FS_ENV);
|
|
|
|
console.log("process.env.FS_ENV_TEST:", process.env.FS_ENV_TEST);
|
|
|
|
console.log(" flags.env:", flags.env);
|
|
|
|
console.log("flags.test:", flags.test);
|
|
|
|
|
|
|
|
const FS_ENV = process.env.FS_ENV || flags.env || false;
|
|
|
|
const FS_ENV_TEST = process.env.FS_ENV_TEST || flags.test || false;
|
|
|
|
|
|
|
|
|
|
|
|
let poolSetting = PRO_POOL;
|
|
|
|
let readAnswer = true;
|
|
|
|
|
|
|
|
if (FS_ENV && 'true' == FS_ENV) {//商用
|
|
|
|
poolSetting = ENV_SY_POOL;
|
|
|
|
console.log("poolSetting:FS_ENV");
|
|
|
|
} else if (FS_ENV_TEST && 'true' == FS_ENV_TEST) {//测试
|
|
|
|
poolSetting = ENV_CS_POOL;
|
|
|
|
console.log("poolSetting:FS_ENV_TEST");
|
|
|
|
} else {//研发
|
|
|
|
poolSetting = PRO_POOL;
|
|
|
|
//对权限初始变动时,readAnswer需设为false,其他数据库执行更新时设为true
|
|
|
|
// readAnswer = false;
|
|
|
|
console.log("poolSetting:PRO_POOL");
|
|
|
|
}
|
|
|
|
const pool = new Pool(poolSetting);
|
|
|
|
const baiduInfo = {
|
|
|
|
appid: '20200917000567738',
|
|
|
|
key: 'xXm4jsuuD38JIkkhEcK6'
|
|
|
|
}
|
|
|
|
// 功能名称 alias翻译别名,show展示的名字,btn操作按钮,child子类,order排序
|
|
|
|
let resource = [
|
|
|
|
{
|
|
|
|
show: '人员档案',
|
|
|
|
alias: '人员档案管理',
|
|
|
|
order: 1,
|
|
|
|
child: [{
|
|
|
|
show: '人员档案',
|
|
|
|
child: [{
|
|
|
|
btn: '新增档案',
|
|
|
|
alias: '新增档案'
|
|
|
|
}, {
|
|
|
|
btn: '导入员工信息'
|
|
|
|
}, {
|
|
|
|
btn: '导出',
|
|
|
|
alias: '导出员工档案'
|
|
|
|
}, {
|
|
|
|
btn: '编辑档案'
|
|
|
|
}, {
|
|
|
|
btn: '删除档案'
|
|
|
|
}]
|
|
|
|
}, {
|
|
|
|
show: '员工信息',
|
|
|
|
child: [{
|
|
|
|
btn: '导出',
|
|
|
|
alias: '导出员工信息'
|
|
|
|
}]
|
|
|
|
}, {
|
|
|
|
show: '岗位评级',
|
|
|
|
child: [{
|
|
|
|
btn: '导入',
|
|
|
|
alias: '导入岗位评级'
|
|
|
|
}]
|
|
|
|
}]
|
|
|
|
}, {
|
|
|
|
show: '部门档案',
|
|
|
|
alias: '部门档案管理',
|
|
|
|
order: 2,
|
|
|
|
child: [{
|
|
|
|
show: '部门档案'
|
|
|
|
}]
|
|
|
|
}, {
|
|
|
|
show: '假勤管理',
|
|
|
|
order: 3,
|
|
|
|
child: [{
|
|
|
|
show: '出勤统计',
|
|
|
|
}, {
|
|
|
|
show: '请假统计',
|
|
|
|
child: [{
|
|
|
|
btn: '导出',
|
|
|
|
alias: '导出请假统计'
|
|
|
|
}]
|
|
|
|
}, {
|
|
|
|
show: '加班统计',
|
|
|
|
child: [{
|
|
|
|
btn: '导出',
|
|
|
|
alias: '导出加班统计'
|
|
|
|
}]
|
|
|
|
}]
|
|
|
|
}, {
|
|
|
|
show: '员工沟通',
|
|
|
|
order: 4,
|
|
|
|
child: [{
|
|
|
|
show: '员工沟通统计',
|
|
|
|
child: [{
|
|
|
|
btn: '导出',
|
|
|
|
alias: '导出员工沟通统计'
|
|
|
|
}]
|
|
|
|
}]
|
|
|
|
}, {
|
|
|
|
show: '招聘记录',
|
|
|
|
order: 5,
|
|
|
|
child: [{
|
|
|
|
show: '任用记录'
|
|
|
|
}]
|
|
|
|
}, {
|
|
|
|
show: '销售统计',
|
|
|
|
order: 6,
|
|
|
|
child: [{
|
|
|
|
show: '销售人员分布',
|
|
|
|
child: [{
|
|
|
|
btn: '新增',
|
|
|
|
alias: '新增销售人员'
|
|
|
|
}, {
|
|
|
|
btn: '导入',
|
|
|
|
alias: '导入销售人员分布'
|
|
|
|
}]
|
|
|
|
}]
|
|
|
|
}, {
|
|
|
|
show: '培训档案',
|
|
|
|
order: 7,
|
|
|
|
child: [{
|
|
|
|
show: '培训资源储存库',
|
|
|
|
child: [{
|
|
|
|
btn: '文件夹管理'
|
|
|
|
}, {
|
|
|
|
btn: '上传文件',
|
|
|
|
alias: '上传培训资料'
|
|
|
|
}, {
|
|
|
|
btn: '下载',
|
|
|
|
alias: '下载培训资料'
|
|
|
|
}, {
|
|
|
|
btn: '删除',
|
|
|
|
alias: '删除培训资料'
|
|
|
|
}]
|
|
|
|
}]
|
|
|
|
}, {
|
|
|
|
show: '培训管理',
|
|
|
|
order: 8,
|
|
|
|
child: [{
|
|
|
|
show: '个人培训记录',
|
|
|
|
child: [{
|
|
|
|
btn: '导入',
|
|
|
|
alias: '导入个人培训记录'
|
|
|
|
}]
|
|
|
|
}, {
|
|
|
|
show: '部门培训记录',
|
|
|
|
child: [{
|
|
|
|
btn: '导入',
|
|
|
|
alias: '导入部门培训记录'
|
|
|
|
}]
|
|
|
|
}]
|
|
|
|
}, {
|
|
|
|
show: '基本动作管理',
|
|
|
|
order: 9,
|
|
|
|
child: [{
|
|
|
|
show: '周报管理',
|
|
|
|
child: [{
|
|
|
|
btn: '导出',
|
|
|
|
alias: '导出周报'
|
|
|
|
}]
|
|
|
|
}, {
|
|
|
|
show: '销售日志',
|
|
|
|
child: [{
|
|
|
|
btn: '导出',
|
|
|
|
alias: '导出销售日志'
|
|
|
|
}]
|
|
|
|
}, {
|
|
|
|
show: '工程日志',
|
|
|
|
child: [{
|
|
|
|
btn: '导出',
|
|
|
|
alias: '导出工程日志'
|
|
|
|
}]
|
|
|
|
}]
|
|
|
|
}, {
|
|
|
|
show: '员工考核',
|
|
|
|
order: 10,
|
|
|
|
child: [{
|
|
|
|
show: '试用期员工考核'
|
|
|
|
}, {
|
|
|
|
show: '正式员工考核',
|
|
|
|
child: [{
|
|
|
|
btn: '下载',
|
|
|
|
alias: '下载正式员工考核'
|
|
|
|
}]
|
|
|
|
}]
|
|
|
|
}, {
|
|
|
|
show: '中层考核',
|
|
|
|
order: 11,
|
|
|
|
child: [{
|
|
|
|
show: '月度过程考核',
|
|
|
|
alias: '中层月度过程考核',
|
|
|
|
child: [{
|
|
|
|
btn: '下载',
|
|
|
|
alias: '下载中层月度过程考核'
|
|
|
|
}]
|
|
|
|
}, {
|
|
|
|
show: '季度考核',
|
|
|
|
alias: '中层季度考核',
|
|
|
|
child: [{
|
|
|
|
btn: '下载',
|
|
|
|
alias: '下载中层季度考核'
|
|
|
|
}]
|
|
|
|
}]
|
|
|
|
}, {
|
|
|
|
show: '高层考核',
|
|
|
|
order: 12,
|
|
|
|
child: [{
|
|
|
|
show: '月度过程考核',
|
|
|
|
alias: '高层月度过程考核',
|
|
|
|
child: [{
|
|
|
|
btn: '下载',
|
|
|
|
alias: '下载高层月度过程考核'
|
|
|
|
}]
|
|
|
|
}, {
|
|
|
|
show: '季度考核',
|
|
|
|
alias: '高层季度考核',
|
|
|
|
child: [{
|
|
|
|
btn: '下载',
|
|
|
|
alias: '下载高层季度考核'
|
|
|
|
}]
|
|
|
|
}]
|
|
|
|
}, {
|
|
|
|
show: '奖惩信息',
|
|
|
|
alias: '奖惩管理',
|
|
|
|
order: 13,
|
|
|
|
child: [{
|
|
|
|
show: '奖惩信息'
|
|
|
|
}]
|
|
|
|
}];
|
|
|
|
|
|
|
|
let transResult = '';
|
|
|
|
let answerObj = {};
|
|
|
|
|
|
|
|
const getAnswer = async (query) => {
|
|
|
|
let start = (new Date()).getTime();
|
|
|
|
let salt = start;
|
|
|
|
let str1 = baiduInfo.appid + query + salt + baiduInfo.key;
|
|
|
|
let sign = Hex.stringify(MD5(str1));
|
|
|
|
let answer = await request.get('http://api.fanyi.baidu.com/api/trans/vip/translate').timeout(1000 * 30).query({
|
|
|
|
q: query,
|
|
|
|
appid: baiduInfo.appid,
|
|
|
|
salt: salt,
|
|
|
|
from: 'zh',
|
|
|
|
to: 'en',
|
|
|
|
sign: sign
|
|
|
|
});
|
|
|
|
if (answer.body.error_code) {
|
|
|
|
console.warn(answer.body);
|
|
|
|
throw '百度不给力,快快debug'
|
|
|
|
}
|
|
|
|
let rslt = answer.body.trans_result;
|
|
|
|
// let upperCaseRslt = rslt[0].dst.toLowerCase().replace(/( |^)[a-z]/g, (L) => L.toUpperCase()).replace(/ /g, '');
|
|
|
|
let upperCaseRslt = rslt[0].dst.toUpperCase().replace(/ /g, '');
|
|
|
|
while (((new Date()).getTime() - start) < (1000 / 5)) {//每s只能调用10次
|
|
|
|
continue;
|
|
|
|
}
|
|
|
|
return upperCaseRslt
|
|
|
|
}
|
|
|
|
|
|
|
|
(async () => {
|
|
|
|
const client = await pool.connect()
|
|
|
|
try {
|
|
|
|
let oldAnswer = {};
|
|
|
|
let answers;
|
|
|
|
if (readAnswer) {
|
|
|
|
answers = fs.readFileSync('Answer.txt', 'utf-8')
|
|
|
|
answers = JSON.parse(answers);
|
|
|
|
|
|
|
|
fs.exists('./AnswerOld.txt', (exists) => {
|
|
|
|
if (exists) {
|
|
|
|
oldAnswer = fs.readFileSync('AnswerOld.txt', 'utf-8')
|
|
|
|
if (oldAnswer != '') {
|
|
|
|
oldAnswer = JSON.parse(oldAnswer)
|
|
|
|
} else {
|
|
|
|
oldAnswer = {}
|
|
|
|
}
|
|
|
|
} else {//文件不存在
|
|
|
|
oldAnswer = {}
|
|
|
|
}
|
|
|
|
});
|
|
|
|
|
|
|
|
} else {
|
|
|
|
oldAnswer = fs.readFileSync('Answer.txt', 'utf-8')
|
|
|
|
if ('' != oldAnswer)
|
|
|
|
oldAnswer = JSON.parse(oldAnswer)
|
|
|
|
else oldAnswer = {}
|
|
|
|
}
|
|
|
|
|
|
|
|
await client.query('BEGIN')
|
|
|
|
|
|
|
|
let answerArr = [];
|
|
|
|
|
|
|
|
const dealResource = async (resource, flag, parentId, childNum) => {
|
|
|
|
let index = 1;
|
|
|
|
for (let r of resource) {
|
|
|
|
let query = r.alias || r.show || r.btn
|
|
|
|
console.log(query);
|
|
|
|
let name = r.show || r.btn;
|
|
|
|
let answer = readAnswer ? answers[query] : await getAnswer(query)
|
|
|
|
if (answerArr.some(a => a == answer)) {
|
|
|
|
console.error(r);
|
|
|
|
console.error(`${query}译名重复了!`)
|
|
|
|
throw 'xxx'
|
|
|
|
} else {
|
|
|
|
answerArr.push(answer)
|
|
|
|
}
|
|
|
|
let res = {}
|
|
|
|
/**对比原来的code */
|
|
|
|
if (oldAnswer[query]) { //resource
|
|
|
|
res = await client.query(`SELECT * FROM resource where code = $1`, [oldAnswer[query]])
|
|
|
|
if (!res.rows.length) {
|
|
|
|
console.log(query, 'code码未找到对应值 :', oldAnswer[query])
|
|
|
|
throw `code码未找到对应值 : ${oldAnswer[query]}`;
|
|
|
|
}
|
|
|
|
if (res.rows[0].name != name || (r.order && res.rows[0].order != r.order) || res.rows[0].order != index) {
|
|
|
|
await client.query(`UPDATE resource SET name = $1 ,"order" = $2 WHERE id = $3`, [name, r.order || index, res.rows[0].id])
|
|
|
|
}
|
|
|
|
if (r.old && oldAnswer[r.old]) {//r如果原来存在
|
|
|
|
//name code互换
|
|
|
|
const { id } = res.rows[0];
|
|
|
|
res = await client.query(`SELECT * FROM resource where code = $1`, [oldAnswer[r.old]]);
|
|
|
|
await client.query(`UPDATE resource SET code = $1 , name = $2 WHERE id = $3`, [oldAnswer[r.old], r.old, id]);
|
|
|
|
if (res.rows)
|
|
|
|
await client.query(`UPDATE resource SET code = $1 , name = $2 WHERE id = $3`, [oldAnswer[query], name, res.rows[0].id])
|
|
|
|
}
|
|
|
|
if (oldAnswer[query] != answer) {//原code码和新翻译不一样
|
|
|
|
// await client.query(`UPDATE system_functions SET code = $1 WHERE code = $2`, [answer, oldAnswer[query]])
|
|
|
|
answer = oldAnswer[query]; //采用原翻译
|
|
|
|
}
|
|
|
|
|
|
|
|
if (parentId && parentId != res.rows[0].parentId) {//和库里的parent_id不一致
|
|
|
|
await client.query(`UPDATE resource SET parent_id = $1 WHERE id = $2`, [parentId, res.rows[0].id]);
|
|
|
|
}
|
|
|
|
|
|
|
|
console.log(oldAnswer[query]);
|
|
|
|
delete oldAnswer[query];
|
|
|
|
} else {
|
|
|
|
res = await client.query(`SELECT * FROM resource where code = $1`, [answer])
|
|
|
|
if (res && !res.rows.length) {
|
|
|
|
const queryText = `INSERT INTO resource(name, code, "order", create_time, parent_id)
|
|
|
|
VALUES( $1, $2, $3, $4, $5) RETURNING id`;
|
|
|
|
res = await client.query(queryText, [name, answer, r.order || index, moment(), parentId ? parentId : null]);
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
answerObj[query] = answer;
|
|
|
|
if (childNum) {
|
|
|
|
for (let i = 0; i < childNum; i++)
|
|
|
|
transResult += ' ';
|
|
|
|
}
|
|
|
|
transResult += `${query} : ${r.btn ? '按钮' : '功能'} : ${answer} [${r.order || index}]`
|
|
|
|
if (r.child) {
|
|
|
|
transResult += '\n';
|
|
|
|
let num = childNum || 0;
|
|
|
|
await dealResource(r.child, null, res.rows[0].id, ++num)
|
|
|
|
} else {
|
|
|
|
if (!flag)
|
|
|
|
transResult += ';\n'
|
|
|
|
}
|
|
|
|
index++;
|
|
|
|
}
|
|
|
|
}
|
|
|
|
await dealResource(resource, true, null, null)
|
|
|
|
console.log("oldAnswer", oldAnswer);
|
|
|
|
/**删除多余code */
|
|
|
|
for (let item in oldAnswer) {
|
|
|
|
if (oldAnswer[item]) {
|
|
|
|
const functionData = await client.query(`SELECT * FROM resource where code = $1`, [oldAnswer[item]]);
|
|
|
|
if (functionData.rows[0]) {
|
|
|
|
const dealChild = async (id) => {
|
|
|
|
/**判断当前的code是否是其它code的父值parent_id */
|
|
|
|
const childFunction = await client.query(`SELECT * FROM resource where parent_id = $1`, [id]);
|
|
|
|
if (childFunction.rows.length) {
|
|
|
|
const childIds = childFunction.rows.reduce((p, c) => p = p.concat(c.id), []);
|
|
|
|
for (let child of childIds) {
|
|
|
|
await dealChild(child);
|
|
|
|
await client.query(`DELETE FROM resource where id = $1`, [child]);
|
|
|
|
}
|
|
|
|
}
|
|
|
|
}
|
|
|
|
await dealChild(functionData.rows[0].id);
|
|
|
|
await client.query(`DELETE FROM resource where id = $1`, [functionData.rows[0].id]);
|
|
|
|
}
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
await client.query('COMMIT')
|
|
|
|
if (!readAnswer) {
|
|
|
|
const old = fs.readFileSync('Answer.txt', 'utf-8')
|
|
|
|
fs.writeFileSync('AnswerOld.txt', old, 'utf-8');
|
|
|
|
|
|
|
|
fs.writeFileSync('AuthCode.txt', transResult, 'utf-8');
|
|
|
|
fs.writeFileSync('Answer.txt', JSON.stringify(answerObj), 'utf-8');
|
|
|
|
console.log('文件生成完毕!')
|
|
|
|
}
|
|
|
|
console.log('执行完毕~')
|
|
|
|
} catch (e) {
|
|
|
|
await client.query('ROLLBACK')
|
|
|
|
console.log('执行错误~')
|
|
|
|
throw e
|
|
|
|
} finally {
|
|
|
|
client.release()
|
|
|
|
}
|
|
|
|
})().catch(e => console.error(e.stack))
|
|
|
|
|
|
|
|
|
|
|
|
} catch (error) {
|
|
|
|
console.error(error)
|
|
|
|
}
|