|
|
|
'use strict';
|
|
|
|
/*jslint node:true*/
|
|
|
|
const path = require('path');
|
|
|
|
const os = require('os');
|
|
|
|
const moment = require('moment');
|
|
|
|
const args = require('args');
|
|
|
|
|
|
|
|
const dev = process.env.NODE_ENV == 'development';
|
|
|
|
|
|
|
|
// 启动参数
|
|
|
|
args.option(['p', 'port'], '启动端口');
|
|
|
|
args.option(['g', 'pg'], 'postgre 服务 URL');
|
|
|
|
|
|
|
|
// 七牛云存储参数
|
|
|
|
args.option('qnak', 'qiniuAccessKey');
|
|
|
|
args.option('qnsk', 'qiniuSecretKey');
|
|
|
|
args.option('qnbkt', 'qiniuBucket');
|
|
|
|
args.option('qndmn', 'qiniuDomain');
|
|
|
|
|
|
|
|
// 微信小程序参数
|
|
|
|
args.option('wxDomain', '微信API Domain');
|
|
|
|
args.option('wxAppId', '微信小程序appid');
|
|
|
|
args.option('wxAppSecret', '微信小程序AppSecret');
|
|
|
|
|
|
|
|
const flags = args.parse(process.argv);
|
|
|
|
|
|
|
|
const XUNJIAN_DB = process.env.XUNJIAN_DB || flags.pg;
|
|
|
|
|
|
|
|
// 七牛云存储参数
|
|
|
|
const QINIU_DOMAIN_QNDMN_RESOURCE = process.env.ANXINCLOUD_QINIU_DOMAIN_QNDMN_RESOURCE || flags.qndmn;
|
|
|
|
const QINIU_BUCKET_RESOURCE = process.env.ANXINCLOUD_QINIU_BUCKET_RESOURCE || flags.qnbkt;
|
|
|
|
const QINIU_AK = process.env.ANXINCLOUD_QINIU_ACCESSKEY || flags.qnak;
|
|
|
|
const QINIU_SK = process.env.ANXINCLOUD_QINIU_SECRETKEY || flags.qnsk;
|
|
|
|
|
|
|
|
// 微信小程序参数
|
|
|
|
const WX_DOMAIN = process.env.WX_DOMAIN || flags.wxDomain;
|
|
|
|
const WX_APP_ID = process.env.WX_APP_ID || flags.wxAppId;
|
|
|
|
const WX_APP_SECRET = process.env.WX_APP_SECRET || flags.wxAppSecret;
|
|
|
|
//报表
|
|
|
|
const API_REPOR_GENERATE_URL = process.env.API_REPOR_GENERATE_URL || 'http://10.8.30.95:31825'
|
|
|
|
|
|
|
|
if (!XUNJIAN_DB || !QINIU_DOMAIN_QNDMN_RESOURCE || !QINIU_BUCKET_RESOURCE || !QINIU_AK || !QINIU_SK || !WX_DOMAIN || !WX_APP_ID || !WX_APP_SECRET) {
|
|
|
|
console.log('缺少启动参数,异常退出');
|
|
|
|
args.showHelp();
|
|
|
|
process.exit(-1);
|
|
|
|
}
|
|
|
|
|
|
|
|
const product = {
|
|
|
|
port: flags.port || 8080,
|
|
|
|
staticDirs: ['static'],
|
|
|
|
mws: [
|
|
|
|
{
|
|
|
|
entry: require('@fs/attachment').entry,
|
|
|
|
opts: {
|
|
|
|
qiniu: {
|
|
|
|
domain: QINIU_DOMAIN_QNDMN_RESOURCE,
|
|
|
|
bucket: QINIU_BUCKET_RESOURCE,
|
|
|
|
accessKey: QINIU_AK,
|
|
|
|
secretKey: QINIU_SK
|
|
|
|
},
|
|
|
|
maxSize: 104857600, // 100M
|
|
|
|
}
|
|
|
|
}, {
|
|
|
|
entry: require('./app/lib/middlewares/attachment').entry,
|
|
|
|
opts: {
|
|
|
|
qiniu: {
|
|
|
|
accessKey: QINIU_AK,
|
|
|
|
secretKey: QINIU_SK,
|
|
|
|
bucket: QINIU_BUCKET_RESOURCE,
|
|
|
|
domain: QINIU_DOMAIN_QNDMN_RESOURCE
|
|
|
|
},
|
|
|
|
maxSize: 104857600, // 100M
|
|
|
|
// uploadPath: 'other'
|
|
|
|
}
|
|
|
|
}, {
|
|
|
|
entry: require('./app').entry,
|
|
|
|
opts: {
|
|
|
|
dev,
|
|
|
|
exclude: [
|
|
|
|
// "*"
|
|
|
|
], // 不做认证的路由,也可以使用 exclude: ["*"] 跳过所有路由
|
|
|
|
qiniu: {
|
|
|
|
domain: QINIU_DOMAIN_QNDMN_RESOURCE,
|
|
|
|
bucket: QINIU_BUCKET_RESOURCE,
|
|
|
|
accessKey: QINIU_AK,
|
|
|
|
secretKey: QINIU_SK
|
|
|
|
},
|
|
|
|
sms: {
|
|
|
|
///阿里云-安心云
|
|
|
|
accessKey: 'LTAI5tAFdjz7j38aNF2C9Qe8',
|
|
|
|
accessSecret: '1trYkmiqfBtvZL6BxkNH2uQcQQPs0S'
|
|
|
|
},
|
|
|
|
pssaRequest:[ { name: 'reportGenerate',
|
|
|
|
root: API_REPOR_GENERATE_URL,
|
|
|
|
dataWord: 'text'
|
|
|
|
|
|
|
|
}
|
|
|
|
],
|
|
|
|
|
|
|
|
email: {
|
|
|
|
enabled: true,
|
|
|
|
host: 'smtp.exmail.qq.com',
|
|
|
|
port: 465,
|
|
|
|
sender: {
|
|
|
|
name: '运维服务',
|
|
|
|
address: 'fsiot@free-sun.com.cn',
|
|
|
|
password: 'Fs2689'
|
|
|
|
}
|
|
|
|
},
|
|
|
|
wx: {
|
|
|
|
domain: WX_DOMAIN,
|
|
|
|
appId: WX_APP_ID,
|
|
|
|
appSecret: WX_APP_SECRET
|
|
|
|
}
|
|
|
|
}
|
|
|
|
}
|
|
|
|
],
|
|
|
|
dc: {
|
|
|
|
url: XUNJIAN_DB,
|
|
|
|
opts: {
|
|
|
|
pool: {
|
|
|
|
max: 80,
|
|
|
|
min: 10,
|
|
|
|
idle: 10000
|
|
|
|
},
|
|
|
|
define: {
|
|
|
|
freezeTableName: true, // 固定表名
|
|
|
|
timestamps: false // 不含列 "createAt"/"updateAt"/"DeleteAt"
|
|
|
|
},
|
|
|
|
timezone: '+08:00',
|
|
|
|
logging: false
|
|
|
|
},
|
|
|
|
models: [require('./app').models]
|
|
|
|
},
|
|
|
|
logger: {
|
|
|
|
level: 'info',
|
|
|
|
json: false,
|
|
|
|
filename: path.join(__dirname, 'log', 'runtime.log'),
|
|
|
|
colorize: false,
|
|
|
|
maxsize: 1024 * 1024 * 5,
|
|
|
|
rotationFormat: false,
|
|
|
|
zippedArchive: true,
|
|
|
|
maxFiles: 10,
|
|
|
|
prettyPrint: true,
|
|
|
|
label: '',
|
|
|
|
timestamp: () => moment().format('YYYY-MM-DD HH:mm:ss.SSS'),
|
|
|
|
eol: os.EOL,
|
|
|
|
tailable: true,
|
|
|
|
depth: null,
|
|
|
|
showLevel: true,
|
|
|
|
maxRetries: 1
|
|
|
|
}
|
|
|
|
};
|
|
|
|
|
|
|
|
const development = {
|
|
|
|
port: product.port,
|
|
|
|
staticDirs: product.staticDirs,
|
|
|
|
mws: product.mws,
|
|
|
|
dc: product.dc,
|
|
|
|
logger: product.logger
|
|
|
|
};
|
|
|
|
|
|
|
|
if (dev) {
|
|
|
|
// mws
|
|
|
|
for (let mw of development.mws) {
|
|
|
|
// if (mw.opts.exclude) mw.opts.exclude = ['*']; // 使用 ['*'] 跳过所有路由
|
|
|
|
}
|
|
|
|
// logger
|
|
|
|
development.logger.filename = path.join(__dirname, 'log', 'development.log');
|
|
|
|
development.logger.level = 'debug';
|
|
|
|
development.dc.opts.logging = console.log;
|
|
|
|
}
|
|
|
|
|
|
|
|
module.exports = dev ? development : product;
|