midway-fatcms 0.0.1-beta.1 → 0.0.1-beta.10

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
Files changed (91) hide show
  1. package/dist/config/config.default.js +52 -15
  2. package/dist/controller/base/BaseApiController.js +9 -6
  3. package/dist/controller/gateway/CrudMtdGatewayController.js +3 -0
  4. package/dist/controller/gateway/DocGatewayController.js +13 -8
  5. package/dist/controller/gateway/StaticController.d.ts +3 -0
  6. package/dist/controller/gateway/StaticController.js +41 -21
  7. package/dist/controller/home.controller.js +2 -2
  8. package/dist/controller/manage/CrudStandardDesignApi.js +83 -68
  9. package/dist/controller/manage/DeployManageApi.js +6 -4
  10. package/dist/controller/manage/SuperAdminManageApi.js +12 -8
  11. package/dist/controller/manage/SysConfigMangeApi.js +3 -1
  12. package/dist/controller/manage/UserAccountManageApi.d.ts +1 -1
  13. package/dist/controller/manage/UserAccountManageApi.js +5 -0
  14. package/dist/controller/myinfo/AuthController.d.ts +0 -4
  15. package/dist/controller/myinfo/AuthController.js +0 -53
  16. package/dist/controller/render/AppRenderController.js +4 -2
  17. package/dist/index.d.ts +28 -4
  18. package/dist/index.js +28 -4
  19. package/dist/libs/global-config/global-config.d.ts +39 -0
  20. package/dist/libs/global-config/global-config.js +32 -0
  21. package/dist/models/SystemTables.d.ts +0 -3
  22. package/dist/models/SystemTables.js +1 -4
  23. package/dist/service/AuthService.js +8 -5
  24. package/dist/service/EnumInfoService.js +7 -4
  25. package/dist/service/FileCenterService.js +13 -9
  26. package/dist/service/SysConfigService.js +4 -2
  27. package/dist/service/UserAccountService.js +10 -6
  28. package/dist/service/VisitStatService.js +4 -2
  29. package/dist/service/WorkbenchService.js +4 -2
  30. package/dist/service/anyapi/AnyApiService.js +4 -2
  31. package/dist/service/crudstd/CrudStdService.js +6 -2
  32. package/dist/service/curd/CurdMixByAccountService.js +12 -6
  33. package/dist/service/curd/CurdMixByDictService.js +4 -2
  34. package/dist/service/curd/CurdMixBySysConfigService.js +4 -2
  35. package/dist/service/curd/CurdMixByWorkbenchService.js +4 -2
  36. package/dist/service/curd/CurdMixUtils.d.ts +7 -0
  37. package/dist/service/curd/CurdMixUtils.js +31 -1
  38. package/dist/service/proxyapi/ProxyApiLoadService.js +7 -4
  39. package/dist/views/404_app.html +31 -0
  40. package/dist/views/404_workbench.html +34 -0
  41. package/dist/views/static/favicon.ico +0 -0
  42. package/package.json +5 -1
  43. package/src/config/config.default.ts +58 -27
  44. package/src/controller/base/BaseApiController.ts +13 -13
  45. package/src/controller/gateway/CrudMtdGatewayController.ts +5 -1
  46. package/src/controller/gateway/DocGatewayController.ts +9 -1
  47. package/src/controller/gateway/StaticController.ts +50 -25
  48. package/src/controller/home.controller.ts +8 -10
  49. package/src/controller/manage/CrudStandardDesignApi.ts +139 -94
  50. package/src/controller/manage/DeployManageApi.ts +4 -1
  51. package/src/controller/manage/SuperAdminManageApi.ts +11 -2
  52. package/src/controller/manage/SysConfigMangeApi.ts +4 -1
  53. package/src/controller/manage/UserAccountManageApi.ts +6 -0
  54. package/src/controller/myinfo/AuthController.ts +4 -66
  55. package/src/controller/render/AppRenderController.ts +17 -14
  56. package/src/index.ts +33 -4
  57. package/src/libs/global-config/global-config.ts +72 -0
  58. package/src/models/SystemTables.ts +0 -4
  59. package/src/service/AuthService.ts +11 -6
  60. package/src/service/EnumInfoService.ts +6 -1
  61. package/src/service/FileCenterService.ts +8 -2
  62. package/src/service/SysConfigService.ts +9 -5
  63. package/src/service/UserAccountService.ts +11 -1
  64. package/src/service/VisitStatService.ts +5 -1
  65. package/src/service/WorkbenchService.ts +6 -1
  66. package/src/service/anyapi/AnyApiService.ts +4 -1
  67. package/src/service/crudstd/CrudStdService.ts +11 -1
  68. package/src/service/curd/CurdMixByAccountService.ts +13 -5
  69. package/src/service/curd/CurdMixByDictService.ts +7 -1
  70. package/src/service/curd/CurdMixBySysConfigService.ts +6 -1
  71. package/src/service/curd/CurdMixByWorkbenchService.ts +5 -1
  72. package/src/service/curd/CurdMixUtils.ts +42 -12
  73. package/src/service/proxyapi/ProxyApiLoadService.ts +9 -1
  74. package/src/views/404_app.html +31 -0
  75. package/src/views/404_workbench.html +34 -0
  76. package/src/views/static/favicon.ico +0 -0
  77. package/dist/controller/medstatistic/MedAdminController.d.ts +0 -35
  78. package/dist/controller/medstatistic/MedAdminController.js +0 -205
  79. package/dist/controller/medstatistic/MedClientController.d.ts +0 -28
  80. package/dist/controller/medstatistic/MedClientController.js +0 -188
  81. package/dist/controller/medstatistic/MedMessageService.d.ts +0 -19
  82. package/dist/controller/medstatistic/MedMessageService.js +0 -95
  83. package/dist/controller/medstatistic/MedScoreService.d.ts +0 -21
  84. package/dist/controller/medstatistic/MedScoreService.js +0 -107
  85. package/dist/controller/medstatistic/constants.d.ts +0 -32
  86. package/dist/controller/medstatistic/constants.js +0 -43
  87. package/src/controller/medstatistic/MedAdminController.ts +0 -221
  88. package/src/controller/medstatistic/MedClientController.ts +0 -188
  89. package/src/controller/medstatistic/MedMessageService.ts +0 -89
  90. package/src/controller/medstatistic/MedScoreService.ts +0 -108
  91. package/src/controller/medstatistic/constants.ts +0 -63
@@ -13,7 +13,13 @@ exports.default = (appInfo) => {
13
13
  * 内置超级管理员用户
14
14
  * 可以使用这个工具生成:http://127.0.0.1:7002/ns/api/helpers/generateDatabasePassword?loginName=xxxx&pw0=xxxx
15
15
  */
16
- superAdminList: [{ pwd_salt: 'c837f8c6de7261de228ec58b1b3ca9fa1htbvgm88', pwd_md5: 'e334410fca1fd49972f63bf91f3be1be', login_name: 'superadmin' }],
16
+ superAdminList: [
17
+ {
18
+ pwd_salt: 'c837f8c6de7261de228ec58b1b3ca9fa1htbvgm88',
19
+ pwd_md5: 'e334410fca1fd49972f63bf91f3be1be',
20
+ login_name: 'superadmin',
21
+ },
22
+ ],
17
23
  // use for cookie sign key, should change to your own and keep security
18
24
  keys: '1715169944707_323',
19
25
  koa: {
@@ -29,7 +35,11 @@ exports.default = (appInfo) => {
29
35
  jsonLimit: '1mb',
30
36
  textLimit: '1mb',
31
37
  xmlLimit: '1mb',
32
- ignore: ['/ns/gw/proxy/*', '/ns/gw/file/uploadFile', '/ns/api/manage/deploy/uploadAssets'], // 忽略代理路径的 body 解析
38
+ ignore: [
39
+ '/ns/gw/proxy/*',
40
+ '/ns/gw/file/uploadFile',
41
+ '/ns/api/manage/deploy/uploadAssets',
42
+ ], // 忽略代理路径的 body 解析
33
43
  },
34
44
  mysql2: {
35
45
  fatcms: {
@@ -45,7 +55,7 @@ exports.default = (appInfo) => {
45
55
  },
46
56
  },
47
57
  postgres2: {
48
- postgres_test1: {
58
+ postgres_test_fatcms_inner_demo_config: {
49
59
  user: 'postgres',
50
60
  host: '127.0.0.1',
51
61
  database: 'postgres',
@@ -54,10 +64,10 @@ exports.default = (appInfo) => {
54
64
  max: 20,
55
65
  idleTimeoutMillis: 30000,
56
66
  connectionTimeoutMillis: 2000, // 连接超时时间(毫秒)
57
- }
67
+ },
58
68
  },
59
69
  sqlserver2: {
60
- sqlserver_master: {
70
+ sqlserver_master_fatcms_inner_demo_config: {
61
71
  user: 'sa',
62
72
  password: '123456',
63
73
  server: '127.0.0.1',
@@ -65,19 +75,19 @@ exports.default = (appInfo) => {
65
75
  database: 'master',
66
76
  options: {
67
77
  encrypt: false,
68
- trustServerCertificate: true // 信任自签名证书
78
+ trustServerCertificate: true, // 信任自签名证书
69
79
  },
70
80
  pool: {
71
81
  max: 30,
72
82
  min: 1,
73
- idleTimeoutMillis: 30000 // 连接空闲超时时间(毫秒)
74
- }
75
- }
83
+ idleTimeoutMillis: 30000, // 连接空闲超时时间(毫秒)
84
+ },
85
+ },
76
86
  },
77
87
  redis: {
78
88
  client: {
79
89
  port: 6379,
80
- host: "127.0.0.1", // Redis host
90
+ host: '127.0.0.1', // Redis host
81
91
  },
82
92
  },
83
93
  oss: {
@@ -105,7 +115,34 @@ exports.default = (appInfo) => {
105
115
  fileSize: '20mb',
106
116
  limit: '20mb',
107
117
  // whitelist: string[],文件扩展名白名单
108
- whitelist: ['.jpg', '.jpeg', '.png', '.gif', '.pdf', '.zip', '.xlsx', '.docx', '.pptx', '.txt', '.md', '.json', '.js', '.cjs', '.ejs', '.jsx', '.css', '.java', '.ts', '.tsx', '.less', '.scss', '.html', '.ttf', '.map', '.svg'],
118
+ whitelist: [
119
+ '.jpg',
120
+ '.jpeg',
121
+ '.png',
122
+ '.gif',
123
+ '.pdf',
124
+ '.zip',
125
+ '.xlsx',
126
+ '.docx',
127
+ '.pptx',
128
+ '.txt',
129
+ '.md',
130
+ '.json',
131
+ '.js',
132
+ '.cjs',
133
+ '.ejs',
134
+ '.jsx',
135
+ '.css',
136
+ '.java',
137
+ '.ts',
138
+ '.tsx',
139
+ '.less',
140
+ '.scss',
141
+ '.html',
142
+ '.ttf',
143
+ '.map',
144
+ '.svg',
145
+ ],
109
146
  // tmpdir: string,上传的文件临时存储路径
110
147
  tmpdir: (0, path_1.join)((0, os_1.tmpdir)(), 'fatcms-upload-files'),
111
148
  // cleanTimeout: number,上传的文件在临时目录中多久之后自动删除,默认为 5 分钟
@@ -134,13 +171,13 @@ exports.default = (appInfo) => {
134
171
  // 使用浏览器插件配置header信息:插件名:ModHeader - Modify HTTP headers
135
172
  // 默认值:配置key:fatcmsdebug, 配置value: headerSecret的值
136
173
  fatcmsDebug: {
137
- headerKey: 'euhvfvv5sDt19dNoerVFamhNYlLJ8ZDDYcRZhMJWNRxALxtrxLPqJSks9sRZEpKY',
138
- headerSecret: 'IlddQO1fO8X7KSwnF3KazNaNHK05Y0kYaD+1z3yGlfZpz0+aAF5hDzf7KQk2dyx0',
174
+ headerKey: 'fatcmsDebug',
175
+ headerSecret: '111',
139
176
  },
140
177
  // 是否开启SA账号。只有账号密码没有用,必须通过ModHeader插件设置如下字段
141
178
  fatcmsSAEnable: {
142
- headerKey: 'WyuX2jf8hehgXAjV5Bf22hvbK/KTEiHCM8eiQeI0FETm/UFXkcLnn3GSTUfwVrrE',
143
- headerSecret: 'lzt19Ef6HxSqg2rp6Q1M3YT+uMrTecmAm3cX1mwFZGqoXknwWdj5fTJil1Vr9AeHDIUFuOOxrU1kSSVa6h/Ppw==',
179
+ headerKey: 'fatcmsSAEnable',
180
+ headerSecret: '222',
144
181
  },
145
182
  // 是否启用内置的定时任务
146
183
  fatcmsScheduleService: true,
@@ -13,7 +13,7 @@ exports.BaseApiController = void 0;
13
13
  const core_1 = require("@midwayjs/core");
14
14
  const CurdMixService_1 = require("../../service/curd/CurdMixService");
15
15
  const keys_1 = require("../../libs/crud-pro/models/keys");
16
- const SystemTables_1 = require("../../models/SystemTables");
16
+ const global_config_1 = require("../../libs/global-config/global-config");
17
17
  const UserAccountService_1 = require("../../service/UserAccountService");
18
18
  const CurdMixUtils_1 = require("../../service/curd/CurdMixUtils");
19
19
  const BaseService_1 = require("../../service/base/BaseService");
@@ -25,11 +25,12 @@ let BaseApiController = class BaseApiController extends BaseService_1.BaseServic
25
25
  return this.ctx.userSession.getSessionInfo();
26
26
  }
27
27
  async executeSysSQL(executeSql, executeSqlArgs) {
28
+ const { SystemDbName, SystemDbType } = global_config_1.GLOBAL_STATIC_CONFIG.getConfig();
28
29
  return await this.curdMixService.executeSQL({
29
30
  executeSql: executeSql,
30
31
  executeSqlArgs: executeSqlArgs,
31
- sqlDatabase: SystemTables_1.SystemDbName,
32
- sqlDdType: SystemTables_1.SystemDbType,
32
+ sqlDatabase: SystemDbName,
33
+ sqlDdType: SystemDbType,
33
34
  crudType: keys_1.KeyOfCrudTypes.SYS_QUERY,
34
35
  });
35
36
  }
@@ -41,14 +42,15 @@ let BaseApiController = class BaseApiController extends BaseService_1.BaseServic
41
42
  * @protected
42
43
  */
43
44
  async executeSysSimpleSQL(sqlTable, sqlSimpleName, params) {
45
+ const { SystemDbName, SystemDbType } = global_config_1.GLOBAL_STATIC_CONFIG.getConfig();
44
46
  const body = this.ctx.request.body;
45
47
  const req = this.ctx.req;
46
48
  const cfgModel = {
47
49
  method: `${req.method}:${req.url}`,
48
50
  sqlTable,
49
51
  sqlSimpleName,
50
- sqlDatabase: SystemTables_1.SystemDbName,
51
- sqlDdType: SystemTables_1.SystemDbType,
52
+ sqlDatabase: SystemDbName,
53
+ sqlDdType: SystemDbType,
52
54
  updateCfg: {},
53
55
  };
54
56
  if (params && typeof params === 'object') {
@@ -61,7 +63,8 @@ let BaseApiController = class BaseApiController extends BaseService_1.BaseServic
61
63
  return await this.curdMixService.executeCrudByCfg(body, cfgModel);
62
64
  }
63
65
  get sysDBUtil() {
64
- return this.curdMixService.getBbUtil(SystemTables_1.SystemDbName, SystemTables_1.SystemDbType);
66
+ const { SystemDbName, SystemDbType } = global_config_1.GLOBAL_STATIC_CONFIG.getConfig();
67
+ return this.curdMixService.getBbUtil(SystemDbName, SystemDbType);
65
68
  }
66
69
  addAccountBasicInfoCfgModel(cfgModel) {
67
70
  let columnsRelation = cfgModel.columnsRelation;
@@ -22,6 +22,7 @@ const ApiBaseService_1 = require("../../service/base/ApiBaseService");
22
22
  const CurdProService_1 = require("../../service/curd/CurdProService");
23
23
  const CurdMixService_1 = require("../../service/curd/CurdMixService");
24
24
  const DatabaseName_1 = require("../../libs/crud-pro/utils/DatabaseName");
25
+ const global_config_1 = require("../../libs/global-config/global-config");
25
26
  const QUERY_AS_LIST = ['condition', 'data'];
26
27
  function pickAsQuery(query_as_pick, query) {
27
28
  if (query_as_pick && typeof query_as_pick === 'string') {
@@ -84,6 +85,8 @@ let CrudMtdGatewayController = class CrudMtdGatewayController extends ApiBaseSer
84
85
  const { dbType, dbName } = (0, DatabaseName_1.parseDatabaseName)(cfgModel.sqlDatabase);
85
86
  cfgModel.sqlDatabase = dbName;
86
87
  cfgModel.sqlDdType = dbType;
88
+ // 业务系统自定义的修改cfgModel
89
+ await global_config_1.GLOBAL_STATIC_CONFIG.getConfig().bizUpdateCfgModelForCrudMtd(reqJson, cfgModel, methodInfo, this.ctx);
87
90
  return this.curdMixService.executeCrudByCfg(reqJson, cfgModel);
88
91
  }
89
92
  };
@@ -16,6 +16,7 @@ exports.DocGatewayController = void 0;
16
16
  const core_1 = require("@midwayjs/core");
17
17
  const BaseApiController_1 = require("../base/BaseApiController");
18
18
  const SystemTables_1 = require("../../models/SystemTables");
19
+ const global_config_1 = require("../../libs/global-config/global-config");
19
20
  const keys_1 = require("../../libs/crud-pro/models/keys");
20
21
  const WorkbenchService_1 = require("../../service/WorkbenchService");
21
22
  const common_dto_1 = require("../../libs/utils/common-dto");
@@ -40,6 +41,7 @@ let DocGatewayController = class DocGatewayController extends BaseApiController_
40
41
  if (nxRes !== 'OK') {
41
42
  return;
42
43
  }
44
+ const { SystemDbName, SystemDbType } = global_config_1.GLOBAL_STATIC_CONFIG.getConfig();
43
45
  await this.curdMixService.executeCrudByCfg({
44
46
  data: {
45
47
  pv: pv + 1
@@ -51,8 +53,8 @@ let DocGatewayController = class DocGatewayController extends BaseApiController_
51
53
  }, {
52
54
  sqlTable: SystemTables_1.SystemTables.sys_doc,
53
55
  sqlSimpleName: keys_1.KeysOfSimpleSQL.SIMPLE_UPDATE,
54
- sqlDatabase: SystemTables_1.SystemDbName,
55
- sqlDdType: SystemTables_1.SystemDbType,
56
+ sqlDatabase: SystemDbName,
57
+ sqlDdType: SystemDbType,
56
58
  });
57
59
  }
58
60
  /**
@@ -66,6 +68,7 @@ let DocGatewayController = class DocGatewayController extends BaseApiController_
66
68
  if (!docLibInfoRes.success) {
67
69
  return docLibInfoRes;
68
70
  }
71
+ const { SystemDbName, SystemDbType } = global_config_1.GLOBAL_STATIC_CONFIG.getConfig();
69
72
  const res = await this.curdMixService.executeCrudByCfg({
70
73
  condition: {
71
74
  id: parseInt(docId),
@@ -74,8 +77,8 @@ let DocGatewayController = class DocGatewayController extends BaseApiController_
74
77
  }, {
75
78
  sqlTable: SystemTables_1.SystemTables.sys_doc,
76
79
  sqlSimpleName: keys_1.KeysOfSimpleSQL.SIMPLE_QUERY_ONE,
77
- sqlDatabase: SystemTables_1.SystemDbName,
78
- sqlDdType: SystemTables_1.SystemDbType,
80
+ sqlDatabase: SystemDbName,
81
+ sqlDdType: SystemDbType,
79
82
  });
80
83
  // 更新PV数据
81
84
  const docObj = res.getOneObj();
@@ -94,6 +97,7 @@ let DocGatewayController = class DocGatewayController extends BaseApiController_
94
97
  if (!docLibInfoRes.success) {
95
98
  return docLibInfoRes;
96
99
  }
100
+ const { SystemDbName, SystemDbType } = global_config_1.GLOBAL_STATIC_CONFIG.getConfig();
97
101
  return this.curdMixService.executeCrudByCfg({
98
102
  columns: 'id,title,doc_category_code,sort_index',
99
103
  orderBy: 'sort_index+,id-',
@@ -106,8 +110,8 @@ let DocGatewayController = class DocGatewayController extends BaseApiController_
106
110
  }, {
107
111
  sqlTable: SystemTables_1.SystemTables.sys_doc,
108
112
  sqlSimpleName: keys_1.KeysOfSimpleSQL.SIMPLE_QUERY,
109
- sqlDatabase: SystemTables_1.SystemDbName,
110
- sqlDdType: SystemTables_1.SystemDbType,
113
+ sqlDatabase: SystemDbName,
114
+ sqlDdType: SystemDbType,
111
115
  });
112
116
  }
113
117
  /**
@@ -116,6 +120,7 @@ let DocGatewayController = class DocGatewayController extends BaseApiController_
116
120
  */
117
121
  async getDocLibInfo(docLibId) {
118
122
  checkIsNumber(docLibId, 'docLibId');
123
+ const { SystemDbName, SystemDbType } = global_config_1.GLOBAL_STATIC_CONFIG.getConfig();
119
124
  const s = await this.curdMixService.executeCrudByCfg({
120
125
  condition: {
121
126
  id: parseInt(docLibId),
@@ -123,8 +128,8 @@ let DocGatewayController = class DocGatewayController extends BaseApiController_
123
128
  }, {
124
129
  sqlTable: SystemTables_1.SystemTables.sys_doc_lib,
125
130
  sqlSimpleName: keys_1.KeysOfSimpleSQL.SIMPLE_QUERY_ONE,
126
- sqlDatabase: SystemTables_1.SystemDbName,
127
- sqlDdType: SystemTables_1.SystemDbType,
131
+ sqlDatabase: SystemDbName,
132
+ sqlDdType: SystemDbType,
128
133
  });
129
134
  const docLibInfo = s.getOneObj();
130
135
  if (!docLibInfo) {
@@ -11,6 +11,9 @@ interface HttpGetRes {
11
11
  */
12
12
  export declare class StaticController extends BaseApiController {
13
13
  protected ctx: Context;
14
+ constructor();
15
+ private getLocalPaths;
16
+ private initNotFoundList;
14
17
  private responseLocalFile;
15
18
  proxyStaticFile(ossName: string, relativePath: string): Promise<string>;
16
19
  saveNotFoundList(): Promise<void>;
@@ -20,17 +20,17 @@ const fs2 = require("fs");
20
20
  const path = require("path");
21
21
  const https = require("https");
22
22
  const functions_1 = require("../../libs/utils/functions");
23
- const localDir = path.join(__dirname, '../../../public/static'); // 本地文件存储目录
24
- const notFoundListFile = path.join(localDir, '__404__list.json'); // 404列表文件
25
23
  function getPathConfig(ossName) {
26
24
  const remoteBaseUrlMap = {
27
25
  "cdnjsx": 'https://cdnjsx.oss-cn-shanghai.aliyuncs.com',
28
26
  "i.alicdn.com": "https://i.alicdn.com",
29
27
  "img.alicdn.com": "https://img.alicdn.com",
28
+ "at.alicdn.com": "https://at.alicdn.com",
30
29
  };
31
- const remoteBaseUrl = remoteBaseUrlMap[ossName];
30
+ let remoteBaseUrl = remoteBaseUrlMap[ossName];
32
31
  if (!remoteBaseUrl) {
33
- throw new Error(`ossName: ${ossName} 未配置`);
32
+ console.error(`getPathConfig ossName: ${ossName} 未配置`);
33
+ remoteBaseUrl = `https://${ossName}`;
34
34
  }
35
35
  return {
36
36
  remoteBaseUrl,
@@ -38,26 +38,43 @@ function getPathConfig(ossName) {
38
38
  }
39
39
  // 404列表缓存
40
40
  let notFoundList = new Set();
41
- // 初始化:加载404列表
42
- async function init() {
43
- try {
44
- // 确保本地存储目录存在
45
- await fs.mkdir(localDir, { recursive: true });
46
- const data = await fs.readFile(notFoundListFile, 'utf8');
47
- notFoundList = new Set(JSON.parse(data));
48
- console.log(`已加载${notFoundList.size}个404记录`);
49
- }
50
- catch (error) {
51
- if (error.code !== 'ENOENT') {
52
- console.error('读取404列表失败:', error);
53
- }
54
- }
55
- }
56
- init();
41
+ let notFoundListIsInit = false;
57
42
  /**
58
43
  * 静态文件代理功能
59
44
  */
60
45
  let StaticController = class StaticController extends BaseApiController_1.BaseApiController {
46
+ constructor() {
47
+ super();
48
+ this.initNotFoundList();
49
+ }
50
+ getLocalPaths() {
51
+ const appDir = this.app.getAppDir();
52
+ const localDir = path.join(appDir, './public/static'); // 本地文件存储目录
53
+ const notFoundListFile = path.join(localDir, '__404__list.json'); // 404列表文件
54
+ return {
55
+ localDir,
56
+ notFoundListFile
57
+ };
58
+ }
59
+ async initNotFoundList() {
60
+ if (notFoundListIsInit) {
61
+ return;
62
+ }
63
+ notFoundListIsInit = true;
64
+ const { localDir, notFoundListFile } = this.getLocalPaths();
65
+ try {
66
+ // 确保本地存储目录存在
67
+ await fs.mkdir(localDir, { recursive: true });
68
+ const data = await fs.readFile(notFoundListFile, 'utf8');
69
+ notFoundList = new Set(JSON.parse(data));
70
+ console.log(`已加载${notFoundList.size}个404记录`);
71
+ }
72
+ catch (error) {
73
+ if (error.code !== 'ENOENT') {
74
+ console.error('读取404列表失败:', error);
75
+ }
76
+ }
77
+ }
61
78
  async responseLocalFile(localFilePath, localHeaderPath, relativePath) {
62
79
  const headers = {
63
80
  "Cache-Control": 'public, max-age=31536000',
@@ -107,6 +124,7 @@ let StaticController = class StaticController extends BaseApiController_1.BaseAp
107
124
  return false;
108
125
  }
109
126
  async proxyStaticFile(ossName, relativePath) {
127
+ const { localDir } = this.getLocalPaths();
110
128
  const PATH_CONFIG = getPathConfig(ossName);
111
129
  // 构建本地路径和远程路径
112
130
  const localFilePath = path.join(localDir, ossName, "files", relativePath);
@@ -161,6 +179,7 @@ let StaticController = class StaticController extends BaseApiController_1.BaseAp
161
179
  }
162
180
  // 保存404列表
163
181
  async saveNotFoundList() {
182
+ const { notFoundListFile } = this.getLocalPaths();
164
183
  try {
165
184
  // 确保存储404列表的目录存在
166
185
  const dir = path.dirname(notFoundListFile);
@@ -260,6 +279,7 @@ __decorate([
260
279
  __metadata("design:returntype", Promise)
261
280
  ], StaticController.prototype, "proxyStaticFile", null);
262
281
  StaticController = __decorate([
263
- (0, core_1.Controller)('/ns/static')
282
+ (0, core_1.Controller)('/ns/static'),
283
+ __metadata("design:paramtypes", [])
264
284
  ], StaticController);
265
285
  exports.StaticController = StaticController;
@@ -31,13 +31,13 @@ let HomeController = class HomeController extends BaseApiController_1.BaseApiCon
31
31
  }
32
32
  const html_content = workbenchInfo.html_content || '未配置HTML模版';
33
33
  const userInfo = this.getUserSessionInfo();
34
- const fatcmscsrftoken = await crypto_utils_1.privateAES.time_encrypt_utf8_base64("" + Date.now());
34
+ const fatcmscsrftoken = await crypto_utils_1.privateAES.time_encrypt_utf8_base64('' + Date.now());
35
35
  const utils = (0, render_utils_1.createRenderUtils)({
36
36
  ctx: this.ctx,
37
37
  userInfo,
38
38
  workbenchInfo,
39
39
  package_assets: workbenchInfo.package_assets,
40
- fatcmscsrftoken
40
+ fatcmscsrftoken,
41
41
  });
42
42
  return this.ctx.renderString(html_content, { workbenchInfo, userInfo, utils }, { viewEngine: 'ejs' });
43
43
  }
@@ -26,8 +26,7 @@ let CrudStandardDesignApi = class CrudStandardDesignApi extends BaseApiControlle
26
26
  const postgresList = Object.keys(this.postgres2Config || {});
27
27
  const sqlServerList = Object.keys(this.sqlserver2Config || {});
28
28
  const toSelectList = (dbCfgNameList, dbType) => {
29
- return dbCfgNameList.map(item => {
30
- const dbName = item;
29
+ return dbCfgNameList.map(dbName => {
31
30
  const value = (0, DatabaseName_1.toDatabaseNameStr)(dbType, dbName);
32
31
  return { value, label: value, dbName, dbType };
33
32
  });
@@ -35,7 +34,14 @@ let CrudStandardDesignApi = class CrudStandardDesignApi extends BaseApiControlle
35
34
  const mysqlObjList = toSelectList(mysqlList, keys_1.SqlDbType.mysql);
36
35
  const postgresObjList = toSelectList(postgresList, keys_1.SqlDbType.postgres);
37
36
  const sqlserverObjList = toSelectList(sqlServerList, keys_1.SqlDbType.sqlserver);
38
- const databaseList = [...mysqlObjList, ...postgresObjList, ...sqlserverObjList];
37
+ const databaseList = [
38
+ ...mysqlObjList,
39
+ ...postgresObjList,
40
+ ...sqlserverObjList,
41
+ ].filter((obj) => {
42
+ const value = '' + obj.value;
43
+ return !value.endsWith('_fatcms_inner_demo_config');
44
+ });
39
45
  return {
40
46
  success: true,
41
47
  data: databaseList,
@@ -131,13 +137,10 @@ let CrudStandardDesignApi = class CrudStandardDesignApi extends BaseApiControlle
131
137
  async getTableListOfSqlserver(dbName) {
132
138
  const dbConfig = this.sqlserver2Config[dbName];
133
139
  if (!dbConfig) {
134
- throw new exceptions_1.CommonException("DB_NOT_FOUND", "数据库配置没有找到:" + dbName);
140
+ throw new exceptions_1.CommonException('DB_NOT_FOUND', '数据库配置没有找到:' + dbName);
135
141
  }
136
142
  const dbType = keys_1.SqlDbType.sqlserver;
137
- const sql = "" +
138
- "SELECT name as tablename \n" +
139
- "FROM sys.tables" +
140
- "";
143
+ const sql = 'SELECT name as tablename FROM sys.tables';
141
144
  const arr = await this.curdMixService.executeSQL({
142
145
  executeSql: sql,
143
146
  sqlDatabase: dbName,
@@ -150,8 +153,9 @@ let CrudStandardDesignApi = class CrudStandardDesignApi extends BaseApiControlle
150
153
  return {
151
154
  value: tableName,
152
155
  label: tableName,
153
- dbName, dbType,
154
- tableName
156
+ dbName,
157
+ dbType,
158
+ tableName,
155
159
  };
156
160
  });
157
161
  return common_dto_1.CommonResult.successRes(tableNames);
@@ -159,65 +163,76 @@ let CrudStandardDesignApi = class CrudStandardDesignApi extends BaseApiControlle
159
163
  async getTableListOfPostgreSQL(dbName) {
160
164
  const dbConfig = this.postgres2Config[dbName];
161
165
  if (!dbConfig) {
162
- throw new exceptions_1.CommonException("DB_NOT_FOUND", "数据库配置没有找到:" + dbName);
166
+ throw new exceptions_1.CommonException('DB_NOT_FOUND', '数据库配置没有找到:' + dbName);
163
167
  }
164
- const schemaname = "public";
165
- const sql = "" +
166
- "SELECT tablename\n" +
167
- "FROM pg_tables\n" +
168
- `WHERE schemaname = '${schemaname}' \n` +
169
- "ORDER BY tablename;";
170
168
  const dbType = keys_1.SqlDbType.postgres;
171
- const arr = await this.curdMixService.executeSQL({
172
- executeSql: sql,
173
- sqlDatabase: dbName,
174
- sqlDdType: dbType,
175
- crudType: keys_1.KeyOfCrudTypes.SYS_QUERY,
176
- executeSqlArgs: [],
177
- });
178
- const tableNames = arr.map(v => {
179
- const tableName = v.tablename;
180
- return {
181
- value: tableName,
182
- label: tableName,
183
- dbName, dbType,
184
- tableName
185
- };
186
- });
187
- return common_dto_1.CommonResult.successRes(tableNames);
169
+ const schemaname = 'public';
170
+ const tableListSql = '' +
171
+ 'SELECT tablename\n' +
172
+ 'FROM pg_tables\n' +
173
+ `WHERE schemaname = '${schemaname}' \n` +
174
+ 'ORDER BY tablename;';
175
+ const viewListSql = '' +
176
+ 'SELECT viewname as tablename\n' +
177
+ 'FROM pg_views\n' +
178
+ `WHERE schemaname = '${schemaname}' \n` +
179
+ 'ORDER BY viewname;';
180
+ const toSelectOptions = async (executeSql, tableType) => {
181
+ const arr = await this.curdMixService.executeSQL({
182
+ executeSql: executeSql,
183
+ sqlDatabase: dbName,
184
+ sqlDdType: dbType,
185
+ crudType: keys_1.KeyOfCrudTypes.SYS_QUERY,
186
+ executeSqlArgs: [],
187
+ });
188
+ return arr.map(v => {
189
+ const tableName = v.tablename;
190
+ return {
191
+ value: tableName,
192
+ label: tableName,
193
+ dbName,
194
+ dbType,
195
+ tableName,
196
+ tableType,
197
+ };
198
+ });
199
+ };
200
+ const tableNames = await toSelectOptions(tableListSql, 'table');
201
+ const viewNames = await toSelectOptions(viewListSql, 'view');
202
+ const tableNameMerge = [...tableNames, ...viewNames];
203
+ return common_dto_1.CommonResult.successRes(tableNameMerge);
188
204
  }
189
205
  async getTableFieldsOfSqlServer(dbName, tableName) {
190
206
  const dbConfig = this.sqlserver2Config[dbName];
191
207
  if (!dbConfig) {
192
- throw new exceptions_1.CommonException("DB_NOT_FOUND", "数据库配置没有找到:" + dbName);
208
+ throw new exceptions_1.CommonException('DB_NOT_FOUND', '数据库配置没有找到:' + dbName);
193
209
  }
194
- const columnArraySql = "" +
195
- "\n" +
196
- "SELECT\n" +
197
- " c.name AS column_name,\n" +
198
- " t.name AS data_type,\n" +
199
- " c.max_length AS max_length,\n" +
200
- " c.precision,\n" +
201
- " c.scale,\n" +
202
- " c.is_nullable,\n" +
203
- " c.is_identity,\n" +
204
- " dc.definition AS column_default, \n" +
205
- " ep.value AS column_description \n" +
206
- "FROM\n" +
207
- " sys.columns c\n" +
208
- " JOIN\n" +
209
- " sys.types t ON c.user_type_id = t.user_type_id\n" +
210
- " LEFT JOIN\n" +
211
- " sys.default_constraints dc\n" +
212
- " ON c.default_object_id = dc.object_id \n" +
213
- " LEFT JOIN\n" +
214
- " sys.extended_properties ep\n" +
215
- " ON c.object_id = ep.major_id\n" +
216
- " AND c.column_id = ep.minor_id\n" +
217
- "WHERE\n" +
210
+ const columnArraySql = '' +
211
+ 'SELECT\n' +
212
+ ' c.name AS column_name,\n' +
213
+ ' t.name AS data_type,\n' +
214
+ ' c.max_length AS max_length,\n' +
215
+ ' c.precision,\n' +
216
+ ' c.scale,\n' +
217
+ ' c.is_nullable,\n' +
218
+ ' c.is_identity,\n' +
219
+ ' dc.definition AS column_default, \n' +
220
+ ' ep.value AS column_description \n' +
221
+ 'FROM\n' +
222
+ ' sys.columns c\n' +
223
+ ' JOIN\n' +
224
+ ' sys.types t ON c.user_type_id = t.user_type_id\n' +
225
+ ' LEFT JOIN\n' +
226
+ ' sys.default_constraints dc\n' +
227
+ ' ON c.default_object_id = dc.object_id \n' +
228
+ ' LEFT JOIN\n' +
229
+ ' sys.extended_properties ep\n' +
230
+ ' ON c.object_id = ep.major_id\n' +
231
+ ' AND c.column_id = ep.minor_id\n' +
232
+ 'WHERE\n' +
218
233
  ` c.object_id = OBJECT_ID('${tableName}') \n` +
219
- " ORDER BY\n" +
220
- " c.column_id;";
234
+ ' ORDER BY\n' +
235
+ ' c.column_id;';
221
236
  const dbType = keys_1.SqlDbType.sqlserver;
222
237
  const columnArray = await this.curdMixService.executeSQL({
223
238
  executeSql: columnArraySql,
@@ -232,11 +247,11 @@ let CrudStandardDesignApi = class CrudStandardDesignApi extends BaseApiControlle
232
247
  fieldIndex: column_name || '',
233
248
  fieldTitle: column_description || column_name || '',
234
249
  isNullable: is_nullable,
235
- defaultValue: column_default || "",
250
+ defaultValue: column_default || '',
236
251
  extra: others,
237
252
  // key: column_name, // 索引
238
253
  type: data_type,
239
- is_identity: is_identity
254
+ is_identity: is_identity,
240
255
  };
241
256
  });
242
257
  return common_dto_1.CommonResult.successRes({
@@ -248,9 +263,9 @@ let CrudStandardDesignApi = class CrudStandardDesignApi extends BaseApiControlle
248
263
  async getTableFieldsOfPostgreSQL(dbName, tableName) {
249
264
  const dbConfig = this.postgres2Config[dbName];
250
265
  if (!dbConfig) {
251
- throw new exceptions_1.CommonException("DB_NOT_FOUND", "数据库配置没有找到:" + dbName);
266
+ throw new exceptions_1.CommonException('DB_NOT_FOUND', '数据库配置没有找到:' + dbName);
252
267
  }
253
- const schemaname = "public";
268
+ const schemaname = 'public';
254
269
  const columnArraySql = `
255
270
 
256
271
  SELECT
@@ -259,7 +274,7 @@ let CrudStandardDesignApi = class CrudStandardDesignApi extends BaseApiControlle
259
274
  WHERE table_schema = $1 and table_name = $2
260
275
  ORDER BY ordinal_position;
261
276
 
262
- `.trim();
277
+ `.trim();
263
278
  const dbType = keys_1.SqlDbType.postgres;
264
279
  const columnArray = await this.curdMixService.executeSQL({
265
280
  executeSql: columnArraySql,
@@ -274,11 +289,11 @@ let CrudStandardDesignApi = class CrudStandardDesignApi extends BaseApiControlle
274
289
  fieldIndex: column_name || '',
275
290
  fieldTitle: column_name || '',
276
291
  isNullable: is_nullable,
277
- defaultValue: column_default || "",
292
+ defaultValue: column_default || '',
278
293
  extra: others,
279
294
  // key: column_name, // 索引
280
295
  type: data_type,
281
- is_identity: is_identity
296
+ is_identity: is_identity,
282
297
  };
283
298
  });
284
299
  return {