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.
154 lines
4.8 KiB
154 lines
4.8 KiB
'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('aliOssAccessKey', '阿里OSS AccessKey');
|
|
args.option('aliOssSecretKey', '阿里OSS SecretKey');
|
|
args.option('aliOssBucket', '阿里OSS Bucket');
|
|
args.option('aliOssRegion', '阿里OSS Region');
|
|
|
|
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;
|
|
|
|
//阿里OSS
|
|
const ALI_OSS_ACCESSKEY = process.env.ALI_OSS_ACCESSKEY || flags.aliOssAccessKey;
|
|
const ALI_OSS_SECRETKET = process.env.ALI_OSS_SECRETKET || flags.aliOssSecretKey;
|
|
const ALI_OSS_BUCKET = process.env.ALI_OSS_BUCKET || flags.aliOssBucket;
|
|
const ALI_OSS_REGION = process.env.ALI_OSS_REGION || flags.aliOssRegion;
|
|
|
|
if (!XUNJIAN_DB || !QINIU_DOMAIN_QNDMN_RESOURCE || !QINIU_BUCKET_RESOURCE || !QINIU_AK || !QINIU_SK) {
|
|
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').entry,
|
|
opts: {
|
|
dev,
|
|
exclude: [
|
|
// "*"
|
|
], // 不做认证的路由,也可以使用 exclude: ["*"] 跳过所有路由
|
|
qiniu: {
|
|
domain: QINIU_DOMAIN_QNDMN_RESOURCE,
|
|
bucket: QINIU_BUCKET_RESOURCE,
|
|
accessKey: QINIU_AK,
|
|
secretKey: QINIU_SK
|
|
},
|
|
aliOss: {
|
|
accessKey: ALI_OSS_ACCESSKEY,
|
|
secretKey: ALI_OSS_SECRETKET,
|
|
bucket: ALI_OSS_BUCKET,
|
|
region: ALI_OSS_REGION
|
|
},
|
|
sms: {
|
|
///阿里云-安心云
|
|
accessKey: 'LTAI5tAFdjz7j38aNF2C9Qe8',
|
|
accessSecret: '1trYkmiqfBtvZL6BxkNH2uQcQQPs0S'
|
|
},
|
|
email: {
|
|
enabled: true,
|
|
host: 'smtp.exmail.qq.com',
|
|
port: 465,
|
|
sender: {
|
|
name: '中鼎服务',
|
|
address: 'fsiot@free-sun.com.cn',
|
|
password: 'Fs2689'
|
|
}
|
|
},
|
|
}
|
|
}
|
|
],
|
|
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;
|
|
|