operation.js 3.9 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142
  1. let express = require('express');
  2. // import schedule from 'node-schedule';
  3. let schedule = require("node-schedule");
  4. let config = require("./config/config.js");
  5. config.setupDb(process.env.NODE_ENV);
  6. let dbm = require("./config/db/db_manager");
  7. let path = require('path');
  8. let session = require('express-session');
  9. let DBStore = require('connect-mongo')(session);
  10. let fileUtils = require("./modules/common/fileUtils");
  11. let partials = require("express-partials");
  12. let log = require("./logs/log_helper");
  13. let URL = require('url');
  14. let fs = require('fs');
  15. let app = express();
  16. let _rootDir = __dirname;
  17. app.locals.rootDir = _rootDir;
  18. dbm.connect(process.env.NODE_ENV);
  19. //引入报表模块
  20. fileUtils.getGlobbedFiles('./modules/all_models/*.js').forEach(function(modelPath) {
  21. require(path.resolve(modelPath));
  22. });
  23. //config.setupCache();
  24. let cfgCacheUtil = require("./config/cacheCfg");
  25. cfgCacheUtil.setupDftCache();
  26. log.use(app);
  27. app.use(express.static(_rootDir));
  28. app.disable('view cache');
  29. app.set('views', path.join(__dirname, 'web'));
  30. app.engine('.html', require('ejs').__express);
  31. app.set('view engine', 'html');
  32. app.set('view options', {
  33. // defaultLayout: 'users/views/layout/layout'
  34. defaultLayout: false
  35. });
  36. app.use(partials());
  37. let bodyParser = require('body-parser');
  38. app.use(bodyParser.urlencoded({limit: '3mb', extended: true}));
  39. app.use(bodyParser.json({limit: '3mb'}));
  40. let dbname = 'yanghu';
  41. if(config[process.env.NODE_ENV].dbname) dbname = config[process.env.NODE_ENV].dbname;
  42. app.use(session({
  43. name: dbname+'Session',
  44. secret: 'session users secret',
  45. cookie: {maxAge: 3600 * 6 * 1000},
  46. resave: false,
  47. rolling: true,
  48. saveUninitialized: true
  49. //*
  50. ,store: new DBStore({
  51. url: config.getSessionURL(process.env.NODE_ENV)
  52. })
  53. //*/
  54. }));
  55. app.use(function (req, res, next) {
  56. let referer = '';
  57. if (!(/^\/cld\/(?!getCategoryStaff)/.test(req.originalUrl) || /^\/login/.test(req.originalUrl)) && !req.session.managerData) {
  58. if (req.headers["x-requested-with"] != null
  59. && req.headers["x-requested-with"] == "XMLHttpRequest"
  60. && req.url != "/login") {
  61. return res.json({ret_code: 99, ret_msg: '登录信息失效,请您重新登录'});
  62. } else{
  63. return res.redirect('/login');
  64. }
  65. }
  66. next();
  67. });
  68. //加载路由文件
  69. fileUtils.getGlobbedFiles('./modules/**/routes/*.js').forEach(function(modelPath) {
  70. require(path.resolve(modelPath))(app);
  71. });
  72. app.use(function(req, res, next) {
  73. res.status(404).send('404 Error');
  74. });
  75. app.use(function(err, req, res, next) {
  76. console.error(err.stack);
  77. res.status(500).send('500 Error');
  78. });
  79. //设置Date Format函数
  80. //备注: 经过测试nodejs 8.9.3版本不支持eval的方式修改prototype,为兼容考虑,把方法调整到stringUtil文件里
  81. require('./public/stringUtil').setupDateFormat();
  82. //定时任务
  83. let sysSchedule = require('./modules/sys_tools/models/sys_model');
  84. schedule.scheduleJob({hour: 3, minute: 30, dayOfWeek: 7}, function(){
  85. sysSchedule.clearJunkData(function (err) {
  86. if(err){
  87. console.log('清除失败');
  88. }
  89. else{
  90. console.log('清除成功');
  91. }
  92. })
  93. });
  94. schedule.scheduleJob({hour: 0, minute: 1}, function(){
  95. sysSchedule.checkUserCompilationStatus(function (err) {
  96. if(err){
  97. console.log('更新失败');
  98. }
  99. else{
  100. console.log('更新成功');
  101. }
  102. })
  103. });
  104. // schedule.scheduleJob({hour: 10, minute: 0}, function(){
  105. // sysSchedule.sendCompilationStatusSms(function (err) {
  106. // if(err){
  107. // console.log('短信发送失败');
  108. // }
  109. // else{
  110. // console.log('短信发送成功');
  111. // }
  112. // })
  113. // });
  114. let startPort = 2080;
  115. if(config[process.env.NODE_ENV].startPort) startPort = config[process.env.NODE_ENV].startPort;
  116. app.listen(startPort, function(){
  117. console.log("server started!");
  118. });