base_controller.js 4.3 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149
  1. /**
  2. * 控制器基类
  3. *
  4. * @author CaiAoLin
  5. * @date 2017/6/29
  6. * @version
  7. */
  8. import crypto from "crypto";
  9. import Url from "url";
  10. import Moment from "moment";
  11. import menuData from "../../../config/menu";
  12. class BaseController {
  13. /**
  14. * 页面title
  15. *
  16. * @var string
  17. */
  18. title = '';
  19. /**
  20. * 构造函数
  21. *
  22. * @return {void}
  23. */
  24. constructor() {
  25. if (new.target === BaseController) {
  26. throw new Error('BaseController不能实例化,只能继承使用。');
  27. }
  28. }
  29. /**
  30. * 初始化函数
  31. *
  32. * @param {object} request
  33. * @param {object} response
  34. * @param {function} next
  35. * @return {void}
  36. */
  37. init(request, response, next) {
  38. // 获取当前控制器和动作名称
  39. let urlInfo = Url.parse(request.originalUrl, true);
  40. let url = urlInfo.pathname.substr(1);
  41. let actionInfo = url.split('/');
  42. let controller = 'index';
  43. let action = 'index';
  44. switch (actionInfo.length) {
  45. case 1:
  46. controller = actionInfo[0];
  47. break;
  48. case 2:
  49. controller = actionInfo[0];
  50. action = actionInfo[1];
  51. break;
  52. default:
  53. controller = actionInfo[0];
  54. break;
  55. }
  56. try {
  57. // 如果不适超级管理员则判断权限
  58. let sessionManager = request.session.managerData;
  59. if (sessionManager.superAdmin !== 1) {
  60. let currentPermission = sessionManager.permission;
  61. // 校验权限
  62. currentPermission = currentPermission.split(',');
  63. let withoutPermission = ['login', 'dashboard'];
  64. // 工具页面整合
  65. let toolPermission = ['rationRepository', 'stdBillsmain'];
  66. let hasToolPermission = false;
  67. if (controller === 'tool') {
  68. for (let tmpPermission of toolPermission) {
  69. if (currentPermission.indexOf(tmpPermission) >= 0) {
  70. hasToolPermission = true;
  71. break;
  72. }
  73. }
  74. }
  75. if (!hasToolPermission && withoutPermission.indexOf(controller) < 0 &&
  76. (currentPermission.length <= 0 || currentPermission.indexOf(controller)) < 0) {
  77. throw '没有权限';
  78. }
  79. }
  80. // 菜单数据
  81. response.locals.menu = menuData;
  82. // 二级菜单数据
  83. response.locals.secondMenu = menuData[controller] !== undefined && menuData[controller].children !== undefined ?
  84. menuData[controller].children : {};
  85. // url相关数据
  86. response.locals.urlQuery = JSON.stringify(urlInfo.query);
  87. response.locals.controller = controller;
  88. response.locals.action = action;
  89. // 用户session数据
  90. response.locals.manager = sessionManager;
  91. // moment工具
  92. response.locals.moment = Moment;
  93. } catch (error) {
  94. console.log(error);
  95. response.redirect('/dashboard');
  96. return;
  97. }
  98. next();
  99. }
  100. /**
  101. * 验证方法
  102. *
  103. * @param {object} request
  104. * @param {object} response
  105. * @param {function} next
  106. * @return {void}
  107. */
  108. auth(request, response, next) {
  109. // 判断session
  110. let mangerData = request.session.managerData;
  111. try {
  112. if (typeof mangerData !== 'object' || Object.keys(mangerData).length < 0) {
  113. throw 'err data';
  114. }
  115. if (mangerData.username === undefined || mangerData.loginTime === undefined) {
  116. throw 'username empty';
  117. }
  118. // 校验session
  119. let sessionToken = crypto.createHmac('sha1', mangerData.loginTime + '')
  120. .update(mangerData.username).digest().toString('base64');
  121. if (sessionToken !== mangerData.sessionToken) {
  122. throw 'session error';
  123. }
  124. } catch (error) {
  125. response.redirect('/login');
  126. return;
  127. }
  128. next();
  129. }
  130. }
  131. export default BaseController;