'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(['f', 'fileHost'], '文件中心本地化存储: WebApi 服务器地址(必填), 该服务器提供文件上传Web服务'); args.option('redisHost', 'redisHost'); args.option('redisPort', 'redisPort'); args.option('redisPswd', 'redisPassword'); args.option('axyApiUrl', '安心云 api'); args.option('iotAuthApi', 'IOT 鉴权 api'); args.option('godUrl', '高德地图API请求地址'); args.option('godKey', '高德地图API key'); args.option('iotVideoServerUrl', '视频后端服务地址'); args.option('mqttVideoServer', '视频后台 mqtt 服务 URL'); args.option('cameraPlayWsHost', '视频播放地址 ws://xxx:xxx'); args.option('cameraPlayHttpFlvHost', '视频播放地址 httpFlv'); args.option('cameraPlayHlsHost', '视频播放地址 hls'); args.option('cameraPlayRtmpHost', '视频播放地址 rtmp'); args.option('cameraPlayRtspHost', '视频播放地址 rtsp'); const flags = args.parse(process.argv); const IOT_VIDEO_ACCESS_DB = process.env.IOT_VIDEO_ACCESS_DB || flags.pg; const IOT_VIDEO_ACCESS_LOCAL_SVR_ORIGIN = process.env.IOT_VIDEO_ACCESS_LOCAL_SVR_ORIGIN || flags.fileHost; // Redis 参数 const IOTA_REDIS_SERVER_HOST = process.env.IOTA_REDIS_SERVER_HOST || flags.redisHost || "localhost";//redis IP const IOTA_REDIS_SERVER_PORT = process.env.IOTA_REDIS_SERVER_PORT || flags.redisPort || "6379";//redis 端口 const IOTA_REDIS_SERVER_PWD = process.env.IOTA_REDIS_SERVER_PWD || flags.redisPswd || "";//redis 密码 // 鉴权 api const IOT_AUTH_API = process.env.IOT_AUTH_API || flags.iotAuthApi; // 安心云api const AXY_API_URL = process.env.AXY_API_URL || flags.axyApiUrl; // 高德地图的参数 const GOD_URL = process.env.GOD_URL || flags.godUrl || 'https://restapi.amap.com/v3'; const GOD_KEY = process.env.GOD_KEY || flags.godKey; // 萤石服务的地址 const YINGSHI_URL = process.env.YINGSHI_URL || flags.yingshiUrl || 'https://open.ys7.com/api'; // 视频后台服务的地址 const IOT_VIDEO_SERVER_URL = process.env.IOT_VIDEO_SERVER_URL || flags.iotVideoServerUrl // 视频后台 mqtt 信息推送地址 const MQTT_VIDEO_SERVER = process.env.MQTT_VIDEO_SERVER || flags.mqttVideoServer; // 几种国标摄像头播放地址前缀 const CAMERA_PLAY_WS_HOST = process.env.CAMERA_PLAY_WS_HOST || flags.cameraPlayWsHost; const CAMERA_PLAY_HTTP_FLV_HOST = process.env.CAMERA_PLAY_HTTP_FLV_HOST || flags.cameraPlayHttpFlvHost; const CAMERA_PLAY_HLS_HOST = process.env.CAMERA_PLAY_HLS_HOST || flags.cameraPlayHlsHost; const CAMERA_PLAY_RTMP_HOST = process.env.CAMERA_PLAY_RTMP_HOST || flags.cameraPlayRtmpHost; const CAMERA_PLAY_RTSP_HOST = process.env.CAMERA_PLAY_RTSP_HOST || flags.cameraPlayRtspHost; if (!IOT_VIDEO_ACCESS_DB || !IOTA_REDIS_SERVER_HOST || !IOTA_REDIS_SERVER_PORT || !GOD_KEY || !MQTT_VIDEO_SERVER || !AXY_API_URL || !IOT_VIDEO_SERVER_URL || !IOT_AUTH_API || !CAMERA_PLAY_WS_HOST || !CAMERA_PLAY_HTTP_FLV_HOST || !CAMERA_PLAY_HLS_HOST || !CAMERA_PLAY_RTMP_HOST || !CAMERA_PLAY_RTSP_HOST ) { console.log('缺少启动参数,异常退出'); args.showHelp(); process.exit(-1); } const product = { port: flags.port || 8080, staticDirs: ['static'], mws: [ { entry: require('@fs/attachment').entry, opts: { local: { origin: IOT_VIDEO_ACCESS_LOCAL_SVR_ORIGIN || `http://localhost:${flags.port || 8080}`, rootPath: 'static', childPath: 'upload', }, maxSize: 104857600, // 100M } }, { entry: require('./app').entry, opts: { dev, exclude: [ { p: '/camera', o: 'GET' }, // 暂时滴 { p: '/application/check', o: 'GET' }, // 暂时滴 ], // 不做认证的路由,也可以使用 exclude: ["*"] 跳过所有路由 redis: { host: IOTA_REDIS_SERVER_HOST, port: IOTA_REDIS_SERVER_PORT, pwd: IOTA_REDIS_SERVER_PWD }, mqtt: { mqttVideoServer: MQTT_VIDEO_SERVER, }, cameraPlayHost: { ws: CAMERA_PLAY_WS_HOST, httpFlv: CAMERA_PLAY_HTTP_FLV_HOST, hls: CAMERA_PLAY_HLS_HOST, rtmp: CAMERA_PLAY_RTMP_HOST, rtsp: CAMERA_PLAY_RTSP_HOST, }, 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' } }, pssaRequest: [ {// name 会作为一个 request 出现在 ctx.app.fs name: 'authRequest', root: IOT_AUTH_API }, { name: 'axyRequest', root: AXY_API_URL }, { name: 'godRequest', root: GOD_URL, params: { query: { key: GOD_KEY } } }, { name: 'yingshiRequest', root: YINGSHI_URL, params: { query: { key: GOD_KEY } } }, { name: 'videoServerRequest', root: IOT_VIDEO_SERVER_URL + '/api', dataWord: 'text' }, ] } } ], dc: { url: IOT_VIDEO_ACCESS_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;