app.js 3.2 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899
  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. app.validator.addRule('mobile', (rule, value) => {
  32. try {
  33. const regPhone = /^1([34578]\d)\d{8}$/;
  34. const allowEmpty = rule.allowEmpty === true;
  35. if (allowEmpty && value === '') {
  36. return true;
  37. }
  38. if (!(value.length === 11 && regPhone.test(value))) {
  39. throw 'please enter the correct phone number';
  40. }
  41. } catch (error) {
  42. return error;
  43. }
  44. });
  45. // 自定义手机IP规则
  46. app.validator.addRule('ip', (rule, value) => {
  47. try {
  48. const allowEmpty = rule.allowEmpty === true;
  49. if (allowEmpty && value === '') {
  50. return true;
  51. }
  52. const regIP = /^(\d{2,})\.(\d+)\.(\d+)\.(\d+)$/;
  53. if (!regIP.test(value)) {
  54. throw 'please enter the correct ip address';
  55. }
  56. } catch (error) {
  57. return error;
  58. }
  59. });
  60. //压缩前端js
  61. app.jsFiles = { common: JsFiles.commonFiles };
  62. for (const c in JsFiles.controller) {
  63. const controller = JsFiles.controller[c];
  64. app.jsFiles[c] = {};
  65. for (const a in controller) {
  66. const action = controller[a];
  67. if (app.config.min && action.mergeFiles && action.mergeFile.length > 0) {
  68. const minFileName = JsFiles.webPath + action.mergeFile + '.' + app.config.version + '.min.js';
  69. let code = '';
  70. for (const f of action.mergeFiles) {
  71. code = code + fs.readFileSync(app.baseDir + '/app' + f, 'utf8');
  72. }
  73. fs.writeFileSync(app.baseDir + '/app' + minFileName, Uglyfy.minify(code, {mangle: true}).code);
  74. app.jsFiles[c][a] = action.files.concat([minFileName]);
  75. } else {
  76. app.jsFiles[c][a] = action.files.concat(action.mergeFiles || []);
  77. }
  78. }
  79. }
  80. if (app.config.min) {
  81. app.minify = (file) => {
  82. const files = file instanceof Array ? file : [file];
  83. for (const f of files) {
  84. const fileName = app.baseDir + '/app/public/js/' + f;
  85. const code = fs.readFileSync(fileName, 'utf8');
  86. fs.writeFileSync(fileName.replace('.js', '.min.js'), Uglyfy.minify(code, { mangle: true }).code);
  87. }
  88. };
  89. app.minify(['spreadjs_rela/spreadjs_zh.js', 'path_tree.js']);
  90. }
  91. };