server.js 5.2 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175
  1. let express = require('express');
  2. let config = require("./config/config.js");
  3. //config.setToLocalDb();
  4. config.setToQaDb();
  5. //config.setupCache();
  6. let cfgCacheUtil = require("./config/cacheCfg");
  7. cfgCacheUtil.setupDftCache();
  8. let path = require('path');
  9. let session = require('express-session');
  10. let DBStore = require('connect-mongo')(session);
  11. let URL = require('url')
  12. let app = express();
  13. let _rootDir = __dirname;
  14. app.use(express.static(_rootDir));
  15. app.set('views', path.join(__dirname, 'web'));
  16. app.engine('.html', require('ejs').__express);
  17. app.set('view engine', 'html');
  18. let bodyParser = require('body-parser');
  19. app.use(bodyParser.urlencoded({extended: false}));
  20. app.use(bodyParser.json());
  21. app.use(session({
  22. name: 'usersSession',
  23. secret: 'session users secret',
  24. cookie: {maxAge: 1000*60*30},
  25. resave: false,
  26. saveUninitialized: true
  27. //*
  28. ,store: new DBStore({
  29. url: 'mongodb://' + config.current.server + ':' + config.current.port + '/usersManages'
  30. })
  31. //*/
  32. }));
  33. // 登录状态全局判断
  34. app.use(function (req, res, next) {
  35. let url = req.originalUrl;
  36. // @todo 上一个页面跳转
  37. let referer = '';
  38. if (/^\/login/.test(url)) {
  39. // 如果是登录页面则忽略判断数据
  40. next();
  41. } else {
  42. try {
  43. // 判断session
  44. let sessionUser = req.session.sessionUser;
  45. if (!sessionUser) {
  46. throw 'session error';
  47. }
  48. res.locals.sessionUser = sessionUser;
  49. } catch (error) {
  50. return res.redirect('/login');
  51. }
  52. next();
  53. }
  54. });
  55. // 用户相关路由区域
  56. app.use('/', require("./modules/users/routes/login_route"));
  57. app.use('/boot', require("./modules/users/routes/boot_route"));
  58. app.use('/user', require("./modules/users/routes/user_route"));
  59. app.use('/feeRates', require('./modules/fee_rates/routes/fee_rates_route'));
  60. app.get('/template/bills', function (req, res) {
  61. let checkAdmin = function (userAccount) {
  62. return true;
  63. }
  64. if (checkAdmin(req.session.userAccount)) {
  65. res.render('maintain/templates/html/bills.html',
  66. {userAccount: req.session.userAccount,
  67. userID: req.session.userID});
  68. } else {
  69. res.redirect('/pm');
  70. }
  71. });
  72. app.use('/template/bills/api', function (req, res, next) {
  73. let checkAdmin = function (userAccount) {
  74. return true;
  75. }
  76. if (checkAdmin(req.session.sessionUser)) {
  77. next();
  78. } else {
  79. res.json({error: 1, message: '对不起,您无权限操作清单模板。', data: null});
  80. }
  81. });
  82. let billsTemplateRouter = require('./modules/templates/routes/bills_template_router');
  83. app.use('/template/bills/api', billsTemplateRouter);
  84. app.get('/pm', function(req, res){
  85. res.render('building_saas/pm/html/project-management.html',
  86. {userAccount: req.session.userAccount,
  87. userID: req.session.sessionUser.ssoId});
  88. });
  89. let pmRouter = require('./modules/pm/routes/pm_route');
  90. app.use('/pm/api', pmRouter);
  91. app.get('/main', function(req, res) {
  92. let pm = require('./modules/pm/controllers/pm_controller');
  93. console.log(req.session);
  94. pm.checkProjectRight(req.session.sessionUser.ssoId, req.query.project, function (hasRight) {
  95. if (hasRight) {
  96. res.render('building_saas/main/html/main.html',
  97. {
  98. userAccount: req.session.userAccount,
  99. userID: req.session.sessionUser.ssoId
  100. });
  101. } else {
  102. res.redirect('/pm');
  103. }
  104. });
  105. });
  106. let project_Router = require('./modules/main/routes/project_route');
  107. let bills_Router = require('./modules/main/routes/bills_route');
  108. let ration_Router = require('./modules/main/routes/ration_route');
  109. let GLJ_Router = require('./modules/main/routes/GLJ_route');
  110. app.use('/project', project_Router);
  111. app.use('/bills', bills_Router);
  112. app.use('/ration', ration_Router);
  113. app.use('/glj', GLJ_Router);
  114. //app.use(express.static(_rootDir+"/web"));
  115. //app.use(express.static(_rootDir+"/lib"));
  116. //let rations_Router = require("./modules/rationLibEditor/routes/rationLibEditor_route");
  117. //app.use("/rationLibEditor",rations_Router);
  118. app.get("/stdBillsmain", function(req, res){
  119. if(!req.session.sessionUser){
  120. res.redirect('/login');
  121. }
  122. else {
  123. res.render("maintain/bills_lib/html/main.html",
  124. {userAccount: req.session.userAccount,
  125. userID: req.session.sessionUser.ssoId});
  126. }
  127. });
  128. app.get("/stdBills", function(req, res){
  129. res.render("maintain/bills_lib/html/qingdan.html");
  130. });
  131. app.get('/stdJobs', function(req, res){
  132. res.render('maintain/bills_lib/html/neirong.html');
  133. });
  134. app.get('/stdItems', function(req, res){
  135. res.render('maintain/bills_lib/html/tezheng.html');
  136. });
  137. let billsLibRouter = require("./modules/bills_lib/routes/bills_lib_routes");
  138. app.use("/stdBillsEditor", billsLibRouter);
  139. let rationRouter = require("./modules/ration_repository/routes/ration_front_end_routes");
  140. app.use("/rationRepository/api", rationRouter);
  141. //-----------------
  142. app.use(function(req, res, next) {
  143. res.status(404).send('404 Error');
  144. });
  145. app.use(function(err, req, res, next) {
  146. console.error(err.stack);
  147. res.status(500).send('500 Error');
  148. });
  149. app.listen(6060, function(){
  150. console.log('server started!');
  151. });