core.js 2.3 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172
  1. 'use strict';
  2. global.Core = {};
  3. //Global Path
  4. global.Core.Path = {
  5. System : ROOTPATH + '/system',
  6. CoreLib : ROOTPATH + '/system/lib/core',
  7. ExtraLib : ROOTPATH + '/system/lib/extra',
  8. Helper : ROOTPATH + '/system/lib/helper',
  9. Work : ROOTPATH + '/app',
  10. Module : ROOTPATH + '/app/modules',
  11. Handler : ROOTPATH + '/app/handlers',
  12. View : ROOTPATH + '/app/view',
  13. Temp : ROOTPATH + '/temp',
  14. Session : ROOTPATH + '/temp/session',
  15. Log : ROOTPATH + '/log',
  16. Asset : ROOTPATH + '/' + Config.asset_path
  17. };
  18. //Global Extension Require
  19. global.Commander = require('commander');
  20. global.URL = require('url');
  21. global.FILE = require('fs-extra');
  22. global.EJS = require('ejs');
  23. global.ASYNC = require('async');
  24. global.Base64 = require('js-base64');
  25. global.MD5 = require('md5');
  26. global.DateFormat = require('date-format');
  27. global.Formidable = require('formidable');
  28. global.Tracer = require('tracer').dailyfile({root:Core.Path.Log,format : "{{timestamp}} <{{title}}> {{file}}:{{line}} {{message}}", dateformat : "HH:MM:ss.L"});
  29. //System Library load
  30. let CoreLibFiles = FILE.readdirSync(Core.Path.CoreLib);
  31. CoreLibFiles.forEach(function(filename){
  32. let nameWithOutMimeType = (filename.split('.')[0]).toUpperCase();
  33. try {
  34. global[nameWithOutMimeType] = require(Core.Path.CoreLib + '/' + filename);
  35. }catch(e){
  36. console.log('[Core] Core library file ['+filename+'] load error!');
  37. Tracer.error('[Core] Core library file ['+filename+'] load error!');
  38. }
  39. });
  40. //System Library load end
  41. //Core Setting,just change it if necessary!
  42. global.Core.Setting = {
  43. //Mysql connect pool setting
  44. mysql_pool:{
  45. name: 'NMVCPOOL',
  46. maxconn: 5
  47. }
  48. };
  49. //If Mysql on,load Mysql Extension
  50. if(Config && Config.mysql_on && Config.mysql_cfg){
  51. let mysqlConfig = {
  52. pool:Core.Setting.mysql_pool,
  53. db:Config.mysql_cfg
  54. };
  55. global.MysqlPool = require(Core.Path.ExtraLib + '/mysql-pool.js').instance(mysqlConfig);
  56. global.MysqlDB = require(Core.Path.Helper + '/mysqldb.js');
  57. }
  58. //Check File Paths
  59. for(let path in global.Core.Path){
  60. try{
  61. FILE.statSync(global.Core.Path[path]);
  62. }catch(e){
  63. FILE.mkdirsSync(global.Core.Path[path]);
  64. }
  65. }