app.js 3.5 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107
  1. 'use strict';
  2. /**
  3. * 自定义启动文件
  4. *
  5. * @author CaiAoLin
  6. * @date 2017/8/29
  7. * @version
  8. */
  9. const Uglyfy = require('uglify-es');
  10. const fs = require('fs');
  11. const moment = require('moment');
  12. const uuid = require('node-uuid');
  13. const _ = require('lodash');
  14. const crypto = require('crypto');
  15. //const calc = require('number-precision');
  16. const BaseService = require('./app/base/base_service');
  17. const BaseController = require('./app/base/base_controller');
  18. const menu = require('./config/menu');
  19. const JsFiles = require('./config/web');
  20. module.exports = app => {
  21. app.uuid = uuid;
  22. app.moment = moment;
  23. app._ = _;
  24. //app.calc = calc;
  25. app.menu = menu;
  26. // 数据模型基类
  27. app.BaseService = BaseService;
  28. // 控制器基类
  29. app.BaseController = BaseController;
  30. // 检查日志路径
  31. if (!fs.existsSync(app.baseDir + '/logs')) {
  32. fs.mkdirSync(app.baseDir + '/logs');
  33. }
  34. // 自定义手机校验规则
  35. app.validator.addRule('mobile', (rule, value) => {
  36. try {
  37. const regPhone = /^1([34578]\d)\d{8}$/;
  38. const allowEmpty = rule.allowEmpty === true;
  39. if (allowEmpty && value === '') {
  40. return true;
  41. }
  42. if (!(value.length === 11 && regPhone.test(value))) {
  43. throw 'please enter the correct phone number';
  44. }
  45. } catch (error) {
  46. return error;
  47. }
  48. });
  49. // 自定义手机IP规则
  50. app.validator.addRule('ip', (rule, value) => {
  51. try {
  52. const allowEmpty = rule.allowEmpty === true;
  53. if (allowEmpty && value === '') {
  54. return true;
  55. }
  56. const regIP = /^(\d{2,})\.(\d+)\.(\d+)\.(\d+)$/;
  57. if (!regIP.test(value)) {
  58. throw 'please enter the correct ip address';
  59. }
  60. } catch (error) {
  61. return error;
  62. }
  63. });
  64. //压缩前端js
  65. app.jsFiles = { common: JsFiles.commonFiles };
  66. if (!fs.existsSync(app.baseDir + '/app' + JsFiles.webPath)) {
  67. fs.mkdirSync(app.baseDir + '/app' + JsFiles.webPath);
  68. }
  69. for (const c in JsFiles.controller) {
  70. const controller = JsFiles.controller[c];
  71. app.jsFiles[c] = {};
  72. for (const a in controller) {
  73. const action = controller[a];
  74. if (app.config.min && action.mergeFiles && action.mergeFile.length > 0) {
  75. const minFileName = JsFiles.webPath + action.mergeFile + '.' + app.config.version + '.min.js';
  76. let code = '';
  77. for (const f of action.mergeFiles) {
  78. code = code + fs.readFileSync(app.baseDir + '/app' + f, 'utf8');
  79. }
  80. fs.writeFileSync(app.baseDir + '/app' + minFileName, Uglyfy.minify(code, {mangle: true}).code);
  81. app.jsFiles[c][a] = action.files.concat([minFileName]);
  82. } else {
  83. app.jsFiles[c][a] = action.files.concat(action.mergeFiles || []);
  84. }
  85. }
  86. }
  87. if (app.config.min) {
  88. app.minify = (file) => {
  89. const files = file instanceof Array ? file : [file];
  90. for (const f of files) {
  91. const fileName = app.baseDir + '/app/public/js/' + f;
  92. const code = fs.readFileSync(fileName, 'utf8');
  93. fs.writeFileSync(fileName.replace('.js', '.min.js'), Uglyfy.minify(code, { mangle: true }).code);
  94. }
  95. };
  96. app.minify(['spreadjs_rela/spreadjs_zh.js', 'path_tree.js']);
  97. }
  98. };