server.js 5.9 KB

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