server.js 5.9 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198
  1. var express = require('express');
  2. var config = require("./config/config.js");
  3. //config.setToLocalDb();
  4. config.setToQaDb();
  5. //config.setupCache();
  6. var cfgCacheUtil = require("./config/cacheCfg");
  7. cfgCacheUtil.setupDftCache();
  8. var path = require('path');
  9. var session = require('express-session');
  10. var DBStore = require('connect-mongo')(session);
  11. var URL = require('url')
  12. var app = express();
  13. var _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. var 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. app.use(function (req, res, next) {
  34. var url = req.originalUrl, referer;
  35. if (!/^\/login/.test(req.originalUrl) && !req.session.userAccount) {
  36. if (/\/api/.test(req.originalUrl)) {
  37. referer = URL.parse(req.headers.referer);
  38. return res.redirect('/login' + '?referer=' + referer.path);
  39. } else {
  40. return res.redirect("/login" + '?referer=' + req.originalUrl);
  41. }
  42. }
  43. next();
  44. });
  45. app.use('/', require('./modules/users/routes/users_route'));
  46. app.use('/feeRates', require('./modules/fee_rates/routes/fee_rates_route'));
  47. app.get('/template/bills', function (req, res) {
  48. var checkAdmin = function (userAccount) {
  49. return true;
  50. }
  51. if (checkAdmin(req.session.userAccount)) {
  52. res.render('templates/html/bills.html',
  53. {userAccount: req.session.userAccount,
  54. userID: req.session.userID});
  55. } else {
  56. res.redirect('/pm');
  57. }
  58. });
  59. app.use('/template/bills/api', function (req, res, next) {
  60. var checkAdmin = function (userAccount) {
  61. return true;
  62. }
  63. if (checkAdmin(req.session.userAccount)) {
  64. next();
  65. } else {
  66. res.json({error: 1, message: '对不起,您无权限操作清单模板。', data: null});
  67. }
  68. });
  69. var billsTemplateRouter = require('./modules/templates/routes/bills_template_router');
  70. app.use('/template/bills/api', billsTemplateRouter);
  71. app.get('/pm', function(req, res){
  72. res.render('pm/html/project-management.html',
  73. {userAccount: req.session.userAccount,
  74. userID: req.session.userID});
  75. });
  76. var pmRouter = require('./modules/pm/routes/pm_route');
  77. app.use('/pm/api', pmRouter);
  78. app.get('/main', function(req, res) {
  79. var checkProjectRight = function (userID, projectID) {
  80. return true;
  81. }
  82. if (checkProjectRight(req.session.userID, req.query.project)) {
  83. res.render('main/html/main.html',
  84. {
  85. userAccount: req.session.userAccount,
  86. userID: req.session.userID
  87. });
  88. } else {
  89. res.redirect('/pm');
  90. }
  91. });
  92. var project_Router = require('./modules/main/routes/project_route');
  93. var bills_Router = require('./modules/main/routes/bills_route');
  94. var ration_Router = require('./modules/main/routes/ration_route');
  95. var GLJ_Router = require('./modules/main/routes/GLJ_route');
  96. app.use('/project', project_Router);
  97. app.use('/bills', bills_Router);
  98. app.use('/ration', ration_Router);
  99. app.use('/glj', GLJ_Router);
  100. var rpt_Router = require("./modules/reports/routes/report_router");
  101. app.get('/report', function(req, res) {
  102. if (!req.session.userAccount) {
  103. res.redirect('/login');
  104. }
  105. else {
  106. res.render('report/html/RptHome.html',
  107. {userAccount: req.session.userAccount,
  108. userID: req.session.userID});
  109. }
  110. });
  111. app.use("/report_api", rpt_Router);
  112. //app.use(express.static(_rootDir+"/web"));
  113. //app.use(express.static(_rootDir+"/lib"));
  114. //var rations_Router = require("./modules/rationLibEditor/routes/rationLibEditor_route");
  115. //app.use("/rationLibEditor",rations_Router);
  116. var rationRepository_Router = require("./modules/rationRepository/routes/rationRepRoutes");
  117. app.get('/rationRepository/main', function(req, res) {
  118. res.render('rationRepository/main.html',
  119. {
  120. userAccount: req.session.userAccount,
  121. userID: req.session.userID
  122. });
  123. });
  124. app.get('/rationRepository/ration', function(req, res) {
  125. res.render('rationRepository/dinge.html',
  126. {
  127. userAccount: req.session.userAccount,
  128. userID: req.session.userID
  129. });
  130. });
  131. app.get('/rationRepository/lmm', function(req, res) {
  132. res.render('rationRepository/gongliao.html',
  133. {
  134. userAccount: req.session.userAccount,
  135. userID: req.session.userID
  136. });
  137. });
  138. app.get('/rationRepository/coeList', function(req, res) {
  139. res.render('rationRepository/fuzhu.html',
  140. {
  141. userAccount: req.session.userAccount,
  142. userID: req.session.userID
  143. });
  144. });
  145. app.use("/rationRepository/api",rationRepository_Router);
  146. app.get("/stdBillsmain", function(req, res){
  147. if(!req.session.userAccount){
  148. res.redirect('/login');
  149. }
  150. else {
  151. res.render("billsLib/html/main.html",
  152. {userAccount: req.session.userAccount,
  153. userID: req.session.userID});
  154. }
  155. });
  156. app.get("/stdBills", function(req, res){
  157. res.render("billsLib/html/qingdan.html");
  158. });
  159. app.get('/stdJobs', function(req, res){
  160. res.render('billsLib/html/neirong.html');
  161. });
  162. app.get('/stdItems', function(req, res){
  163. res.render('billsLib/html/tezheng.html');
  164. });
  165. var billsLibRouter = require("./modules/billsLib/billsLibRoutes/billsLibRoutes");
  166. app.use("/stdBillsEditor", billsLibRouter);
  167. //-----------------
  168. app.use(function(req, res, next) {
  169. res.status(404).send('404 Error');
  170. });
  171. app.use(function(err, req, res, next) {
  172. console.error(err.stack);
  173. res.status(500).send('500 Error');
  174. });
  175. app.listen(6060);