@eggjs/tegg-config 4.0.0-beta.3 → 4.0.0-beta.5
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.
- package/README.md +12 -0
- package/dist/agent.d.ts +2 -0
- package/dist/agent.js +7 -0
- package/dist/app.d.ts +19 -0
- package/dist/app.js +41 -0
- package/dist/config/config.default.d.ts +17 -0
- package/dist/config/config.default.js +13 -0
- package/dist/index.d.ts +1 -0
- package/dist/index.js +3 -0
- package/dist/lib/ModuleScanner.d.ts +15 -0
- package/dist/lib/ModuleScanner.js +38 -0
- package/dist/types.d.ts +1 -0
- package/dist/types.js +4 -0
- package/package.json +29 -30
- package/agent.d.ts +0 -2
- package/agent.js +0 -3
- package/app.d.ts +0 -7
- package/app.js +0 -33
- package/index.d.ts +0 -17
- package/index.js +0 -2
- package/lib/ModuleScanner.d.ts +0 -11
- package/lib/ModuleScanner.js +0 -44
- package/typings/index.d.ts +0 -1
package/README.md
CHANGED
|
@@ -1,5 +1,17 @@
|
|
|
1
1
|
# `@eggjs/tegg-config`
|
|
2
2
|
|
|
3
|
+
[![NPM version][npm-image]][npm-url]
|
|
4
|
+
[![Known Vulnerabilities][snyk-image]][snyk-url]
|
|
5
|
+
[![npm download][download-image]][download-url]
|
|
6
|
+
[](https://nodejs.org/en/download/)
|
|
7
|
+
|
|
8
|
+
[npm-image]: https://img.shields.io/npm/v/@eggjs/tegg-config.svg?style=flat-square
|
|
9
|
+
[npm-url]: https://npmjs.org/package/@eggjs/tegg-config
|
|
10
|
+
[snyk-image]: https://snyk.io/test/npm/@eggjs/tegg-config/badge.svg?style=flat-square
|
|
11
|
+
[snyk-url]: https://snyk.io/test/npm/@eggjs/tegg-config
|
|
12
|
+
[download-image]: https://img.shields.io/npm/dm/@eggjs/tegg-config.svg?style=flat-square
|
|
13
|
+
[download-url]: https://npmjs.org/package/@eggjs/tegg-config
|
|
14
|
+
|
|
3
15
|
Egg plugin to load module config(module.yml/module.json)
|
|
4
16
|
|
|
5
17
|
# Usage
|
package/dist/agent.d.ts
ADDED
package/dist/agent.js
ADDED
package/dist/app.d.ts
ADDED
|
@@ -0,0 +1,19 @@
|
|
|
1
|
+
import { ModuleConfigHolder, ModuleReference } from "@eggjs/tegg-common-util";
|
|
2
|
+
import { Application, ILifecycleBoot } from "egg";
|
|
3
|
+
|
|
4
|
+
//#region src/app.d.ts
|
|
5
|
+
declare class App implements ILifecycleBoot {
|
|
6
|
+
private readonly app;
|
|
7
|
+
constructor(app: Application);
|
|
8
|
+
configWillLoad(): void;
|
|
9
|
+
beforeClose(): Promise<void>;
|
|
10
|
+
}
|
|
11
|
+
declare module 'egg' {
|
|
12
|
+
interface ModuleConfig {}
|
|
13
|
+
interface EggApplicationCore {
|
|
14
|
+
moduleReferences: readonly ModuleReference[];
|
|
15
|
+
moduleConfigs: Record<string, ModuleConfigHolder>;
|
|
16
|
+
}
|
|
17
|
+
}
|
|
18
|
+
//#endregion
|
|
19
|
+
export { App as default };
|
package/dist/app.js
ADDED
|
@@ -0,0 +1,41 @@
|
|
|
1
|
+
import { ModuleScanner } from "./lib/ModuleScanner.js";
|
|
2
|
+
import { debuglog } from "node:util";
|
|
3
|
+
import { ModuleConfigUtil } from "@eggjs/tegg-common-util";
|
|
4
|
+
|
|
5
|
+
//#region src/app.ts
|
|
6
|
+
const debug = debuglog("tegg/plugin/config/app");
|
|
7
|
+
var App = class {
|
|
8
|
+
app;
|
|
9
|
+
constructor(app) {
|
|
10
|
+
this.app = app;
|
|
11
|
+
const configNames = this.app.loader.getTypeFiles("module");
|
|
12
|
+
ModuleConfigUtil.setConfigNames(configNames);
|
|
13
|
+
}
|
|
14
|
+
configWillLoad() {
|
|
15
|
+
const { readModuleOptions } = this.app.config.tegg;
|
|
16
|
+
const moduleScanner = new ModuleScanner(this.app.baseDir, readModuleOptions);
|
|
17
|
+
this.app.moduleReferences = moduleScanner.loadModuleReferences();
|
|
18
|
+
debug("load moduleReferences: %o", this.app.moduleReferences);
|
|
19
|
+
this.app.moduleConfigs = {};
|
|
20
|
+
for (const reference of this.app.moduleReferences) {
|
|
21
|
+
const absoluteRef = {
|
|
22
|
+
path: ModuleConfigUtil.resolveModuleDir(reference.path, this.app.baseDir),
|
|
23
|
+
name: reference.name,
|
|
24
|
+
optional: reference.optional
|
|
25
|
+
};
|
|
26
|
+
const moduleName = ModuleConfigUtil.readModuleNameSync(absoluteRef.path);
|
|
27
|
+
this.app.moduleConfigs[moduleName] = {
|
|
28
|
+
name: moduleName,
|
|
29
|
+
reference: absoluteRef,
|
|
30
|
+
config: ModuleConfigUtil.loadModuleConfigSync(absoluteRef.path)
|
|
31
|
+
};
|
|
32
|
+
}
|
|
33
|
+
debug("load moduleConfigs: %o", this.app.moduleConfigs);
|
|
34
|
+
}
|
|
35
|
+
async beforeClose() {
|
|
36
|
+
ModuleConfigUtil.setConfigNames(void 0);
|
|
37
|
+
}
|
|
38
|
+
};
|
|
39
|
+
|
|
40
|
+
//#endregion
|
|
41
|
+
export { App as default };
|
|
@@ -0,0 +1,17 @@
|
|
|
1
|
+
import { ReadModuleReferenceOptions } from "@eggjs/tegg-common-util";
|
|
2
|
+
import * as egg0 from "egg";
|
|
3
|
+
|
|
4
|
+
//#region src/config/config.default.d.ts
|
|
5
|
+
declare const _default: egg0.EggConfigFactory;
|
|
6
|
+
declare module 'egg' {
|
|
7
|
+
interface EggAppConfig {
|
|
8
|
+
/**
|
|
9
|
+
* tegg config
|
|
10
|
+
*/
|
|
11
|
+
tegg: {
|
|
12
|
+
readModuleOptions: ReadModuleReferenceOptions;
|
|
13
|
+
};
|
|
14
|
+
}
|
|
15
|
+
}
|
|
16
|
+
//#endregion
|
|
17
|
+
export { _default as default };
|
|
@@ -0,0 +1,13 @@
|
|
|
1
|
+
import "@eggjs/tegg-common-util";
|
|
2
|
+
import { defineConfigFactory } from "egg";
|
|
3
|
+
|
|
4
|
+
//#region src/config/config.default.ts
|
|
5
|
+
var config_default_default = defineConfigFactory((appInfo) => {
|
|
6
|
+
return { tegg: { readModuleOptions: {
|
|
7
|
+
deep: 10,
|
|
8
|
+
cwd: appInfo.baseDir
|
|
9
|
+
} } };
|
|
10
|
+
});
|
|
11
|
+
|
|
12
|
+
//#endregion
|
|
13
|
+
export { config_default_default as default };
|
package/dist/index.d.ts
ADDED
|
@@ -0,0 +1 @@
|
|
|
1
|
+
export { };
|
package/dist/index.js
ADDED
|
@@ -0,0 +1,15 @@
|
|
|
1
|
+
import { ModuleReference, ReadModuleReferenceOptions } from "@eggjs/tegg-common-util";
|
|
2
|
+
|
|
3
|
+
//#region src/lib/ModuleScanner.d.ts
|
|
4
|
+
declare class ModuleScanner {
|
|
5
|
+
private readonly baseDir;
|
|
6
|
+
private readonly readModuleOptions;
|
|
7
|
+
constructor(baseDir: string, readModuleOptions: ReadModuleReferenceOptions);
|
|
8
|
+
/**
|
|
9
|
+
* - load module references from config or scan from baseDir
|
|
10
|
+
* - load framework module as optional module reference
|
|
11
|
+
*/
|
|
12
|
+
loadModuleReferences(): readonly ModuleReference[];
|
|
13
|
+
}
|
|
14
|
+
//#endregion
|
|
15
|
+
export { ModuleScanner };
|
|
@@ -0,0 +1,38 @@
|
|
|
1
|
+
import { debuglog } from "node:util";
|
|
2
|
+
import { ModuleConfigUtil } from "@eggjs/tegg-common-util";
|
|
3
|
+
import path from "node:path";
|
|
4
|
+
import { readFileSync } from "node:fs";
|
|
5
|
+
import { importResolve } from "@eggjs/utils";
|
|
6
|
+
|
|
7
|
+
//#region src/lib/ModuleScanner.ts
|
|
8
|
+
const debug = debuglog("tegg/plugin/config/ModuleScanner");
|
|
9
|
+
var ModuleScanner = class {
|
|
10
|
+
baseDir;
|
|
11
|
+
readModuleOptions;
|
|
12
|
+
constructor(baseDir, readModuleOptions) {
|
|
13
|
+
this.baseDir = baseDir;
|
|
14
|
+
this.readModuleOptions = readModuleOptions;
|
|
15
|
+
}
|
|
16
|
+
/**
|
|
17
|
+
* - load module references from config or scan from baseDir
|
|
18
|
+
* - load framework module as optional module reference
|
|
19
|
+
*/
|
|
20
|
+
loadModuleReferences() {
|
|
21
|
+
const moduleReferences = ModuleConfigUtil.readModuleReference(this.baseDir, this.readModuleOptions || {});
|
|
22
|
+
const framework = JSON.parse(readFileSync(path.join(this.baseDir, "package.json"), "utf-8")).egg?.framework;
|
|
23
|
+
if (!framework) return moduleReferences;
|
|
24
|
+
const frameworkPkg = importResolve(`${framework}/package.json`, { paths: [this.baseDir] });
|
|
25
|
+
const frameworkDir = path.dirname(frameworkPkg);
|
|
26
|
+
debug("loadModuleReferences from framework:%o, frameworkDir:%o", framework, frameworkDir);
|
|
27
|
+
const optionalModuleReferences = ModuleConfigUtil.readModuleReference(frameworkDir, this.readModuleOptions || {});
|
|
28
|
+
const result = [...moduleReferences];
|
|
29
|
+
for (const optionalModuleReference of optionalModuleReferences) if (!result.some((t) => t.path === optionalModuleReference.path)) result.push({
|
|
30
|
+
...optionalModuleReference,
|
|
31
|
+
optional: true
|
|
32
|
+
});
|
|
33
|
+
return result;
|
|
34
|
+
}
|
|
35
|
+
};
|
|
36
|
+
|
|
37
|
+
//#endregion
|
|
38
|
+
export { ModuleScanner };
|
package/dist/types.d.ts
ADDED
|
@@ -0,0 +1 @@
|
|
|
1
|
+
export { };
|
package/dist/types.js
ADDED
package/package.json
CHANGED
|
@@ -3,7 +3,7 @@
|
|
|
3
3
|
"eggPlugin": {
|
|
4
4
|
"name": "teggConfig"
|
|
5
5
|
},
|
|
6
|
-
"version": "4.0.0-beta.
|
|
6
|
+
"version": "4.0.0-beta.5",
|
|
7
7
|
"description": "module config plugin for egg",
|
|
8
8
|
"keywords": [
|
|
9
9
|
"egg",
|
|
@@ -14,30 +14,18 @@
|
|
|
14
14
|
"tegg"
|
|
15
15
|
],
|
|
16
16
|
"files": [
|
|
17
|
-
"
|
|
18
|
-
"app.d.ts",
|
|
19
|
-
"typings/index.d.ts",
|
|
20
|
-
"lib/**/*.js",
|
|
21
|
-
"lib/**/*.d.ts",
|
|
22
|
-
"agent.js",
|
|
23
|
-
"agent.d.ts",
|
|
24
|
-
"index.js",
|
|
25
|
-
"index.d.ts"
|
|
17
|
+
"dist"
|
|
26
18
|
],
|
|
27
19
|
"type": "module",
|
|
28
20
|
"exports": {
|
|
29
|
-
".":
|
|
30
|
-
|
|
31
|
-
|
|
32
|
-
|
|
21
|
+
".": "./dist/index.js",
|
|
22
|
+
"./agent": "./dist/agent.js",
|
|
23
|
+
"./app": "./dist/app.js",
|
|
24
|
+
"./config/config.default": "./dist/config/config.default.js",
|
|
25
|
+
"./lib/ModuleScanner": "./dist/lib/ModuleScanner.js",
|
|
26
|
+
"./types": "./dist/types.js",
|
|
33
27
|
"./package.json": "./package.json"
|
|
34
28
|
},
|
|
35
|
-
"scripts": {
|
|
36
|
-
"clean": "tsc -b --clean",
|
|
37
|
-
"tsc": "npm run clean && tsc -p ./tsconfig.json",
|
|
38
|
-
"tsc:pub": "npm run tsc",
|
|
39
|
-
"prepublishOnly": "npm run tsc"
|
|
40
|
-
},
|
|
41
29
|
"homepage": "https://github.com/eggjs/tegg",
|
|
42
30
|
"bugs": {
|
|
43
31
|
"url": "https://github.com/eggjs/tegg/issues"
|
|
@@ -48,21 +36,32 @@
|
|
|
48
36
|
"directory": "plugin/config"
|
|
49
37
|
},
|
|
50
38
|
"engines": {
|
|
51
|
-
"node": ">=
|
|
39
|
+
"node": ">=22.18.0"
|
|
52
40
|
},
|
|
53
41
|
"dependencies": {
|
|
54
|
-
"@eggjs/
|
|
55
|
-
"@eggjs/
|
|
42
|
+
"@eggjs/utils": "beta",
|
|
43
|
+
"@eggjs/tegg-common-util": "4.0.0-beta.5"
|
|
44
|
+
},
|
|
45
|
+
"peerDependencies": {
|
|
46
|
+
"egg": "beta"
|
|
56
47
|
},
|
|
57
48
|
"devDependencies": {
|
|
58
|
-
"@eggjs/mock": "
|
|
59
|
-
"@types/node": "22",
|
|
60
|
-
"egg": "
|
|
61
|
-
"
|
|
62
|
-
"
|
|
49
|
+
"@eggjs/mock": "beta",
|
|
50
|
+
"@types/node": "^22.10.5",
|
|
51
|
+
"egg": "beta",
|
|
52
|
+
"typescript": "^5.9.3",
|
|
53
|
+
"tsdown": "^0.15.6",
|
|
54
|
+
"unplugin-unused": "^0.5.3"
|
|
63
55
|
},
|
|
64
56
|
"publishConfig": {
|
|
65
57
|
"access": "public"
|
|
66
58
|
},
|
|
67
|
-
"
|
|
68
|
-
|
|
59
|
+
"main": "./dist/index.js",
|
|
60
|
+
"module": "./dist/index.js",
|
|
61
|
+
"types": "./dist/index.d.ts",
|
|
62
|
+
"scripts": {
|
|
63
|
+
"clean": "rimraf dist",
|
|
64
|
+
"build": "tsdown",
|
|
65
|
+
"typecheck": "tsc --noEmit"
|
|
66
|
+
}
|
|
67
|
+
}
|
package/agent.d.ts
DELETED
package/agent.js
DELETED
|
@@ -1,3 +0,0 @@
|
|
|
1
|
-
import TeggConfigAppHook from './app.js';
|
|
2
|
-
export default TeggConfigAppHook;
|
|
3
|
-
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiYWdlbnQuanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyJhZ2VudC50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFBQSxPQUFPLGlCQUFpQixNQUFNLFVBQVUsQ0FBQztBQUV6QyxlQUFlLGlCQUFpQixDQUFDIn0=
|
package/app.d.ts
DELETED
package/app.js
DELETED
|
@@ -1,33 +0,0 @@
|
|
|
1
|
-
import { ModuleConfigUtil } from '@eggjs/tegg-common-util';
|
|
2
|
-
import { ModuleScanner } from './lib/ModuleScanner.js';
|
|
3
|
-
export default class App {
|
|
4
|
-
app;
|
|
5
|
-
constructor(app) {
|
|
6
|
-
this.app = app;
|
|
7
|
-
const configNames = this.app.loader.getTypeFiles('module');
|
|
8
|
-
ModuleConfigUtil.setConfigNames(configNames);
|
|
9
|
-
}
|
|
10
|
-
configWillLoad() {
|
|
11
|
-
const { readModuleOptions } = this.app.config.tegg || {};
|
|
12
|
-
const moduleScanner = new ModuleScanner(this.app.baseDir, readModuleOptions);
|
|
13
|
-
this.app.moduleReferences = moduleScanner.loadModuleReferences();
|
|
14
|
-
this.app.moduleConfigs = {};
|
|
15
|
-
for (const reference of this.app.moduleReferences) {
|
|
16
|
-
const absoluteRef = {
|
|
17
|
-
path: ModuleConfigUtil.resolveModuleDir(reference.path, this.app.baseDir),
|
|
18
|
-
name: reference.name,
|
|
19
|
-
optional: reference.optional,
|
|
20
|
-
};
|
|
21
|
-
const moduleName = ModuleConfigUtil.readModuleNameSync(absoluteRef.path);
|
|
22
|
-
this.app.moduleConfigs[moduleName] = {
|
|
23
|
-
name: moduleName,
|
|
24
|
-
reference: absoluteRef,
|
|
25
|
-
config: ModuleConfigUtil.loadModuleConfigSync(absoluteRef.path),
|
|
26
|
-
};
|
|
27
|
-
}
|
|
28
|
-
}
|
|
29
|
-
async beforeClose() {
|
|
30
|
-
ModuleConfigUtil.setConfigNames(undefined);
|
|
31
|
-
}
|
|
32
|
-
}
|
|
33
|
-
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiYXBwLmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiYXBwLnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQUNBLE9BQU8sRUFBRSxnQkFBZ0IsRUFBRSxNQUFNLHlCQUF5QixDQUFDO0FBRTNELE9BQU8sRUFBRSxhQUFhLEVBQUUsTUFBTSx3QkFBd0IsQ0FBQztBQUV2RCxNQUFNLENBQUMsT0FBTyxPQUFPLEdBQUc7SUFDTCxHQUFHLENBQWM7SUFFbEMsWUFBWSxHQUFnQjtRQUMxQixJQUFJLENBQUMsR0FBRyxHQUFHLEdBQUcsQ0FBQztRQUNmLE1BQU0sV0FBVyxHQUFHLElBQUksQ0FBQyxHQUFHLENBQUMsTUFBTSxDQUFDLFlBQVksQ0FBQyxRQUFRLENBQUMsQ0FBQztRQUMzRCxnQkFBZ0IsQ0FBQyxjQUFjLENBQUMsV0FBVyxDQUFDLENBQUM7SUFDL0MsQ0FBQztJQUVELGNBQWM7UUFDWixNQUFNLEVBQUUsaUJBQWlCLEVBQUUsR0FBRyxJQUFJLENBQUMsR0FBRyxDQUFDLE1BQU0sQ0FBQyxJQUFJLElBQUksRUFBRSxDQUFDO1FBQ3pELE1BQU0sYUFBYSxHQUFHLElBQUksYUFBYSxDQUFDLElBQUksQ0FBQyxHQUFHLENBQUMsT0FBTyxFQUFFLGlCQUFpQixDQUFDLENBQUM7UUFDN0UsSUFBSSxDQUFDLEdBQUcsQ0FBQyxnQkFBZ0IsR0FBRyxhQUFhLENBQUMsb0JBQW9CLEVBQUUsQ0FBQztRQUVqRSxJQUFJLENBQUMsR0FBRyxDQUFDLGFBQWEsR0FBRyxFQUFFLENBQUM7UUFFNUIsS0FBSyxNQUFNLFNBQVMsSUFBSSxJQUFJLENBQUMsR0FBRyxDQUFDLGdCQUFnQixFQUFFLENBQUM7WUFDbEQsTUFBTSxXQUFXLEdBQW9CO2dCQUNuQyxJQUFJLEVBQUUsZ0JBQWdCLENBQUMsZ0JBQWdCLENBQUMsU0FBUyxDQUFDLElBQUksRUFBRSxJQUFJLENBQUMsR0FBRyxDQUFDLE9BQU8sQ0FBQztnQkFDekUsSUFBSSxFQUFFLFNBQVMsQ0FBQyxJQUFJO2dCQUNwQixRQUFRLEVBQUUsU0FBUyxDQUFDLFFBQVE7YUFDN0IsQ0FBQztZQUVGLE1BQU0sVUFBVSxHQUFHLGdCQUFnQixDQUFDLGtCQUFrQixDQUFDLFdBQVcsQ0FBQyxJQUFJLENBQUMsQ0FBQztZQUN6RSxJQUFJLENBQUMsR0FBRyxDQUFDLGFBQWEsQ0FBQyxVQUFVLENBQUMsR0FBRztnQkFDbkMsSUFBSSxFQUFFLFVBQVU7Z0JBQ2hCLFNBQVMsRUFBRSxXQUFXO2dCQUN0QixNQUFNLEVBQUUsZ0JBQWdCLENBQUMsb0JBQW9CLENBQUMsV0FBVyxDQUFDLElBQUksQ0FBQzthQUNoRSxDQUFDO1FBQ0osQ0FBQztJQUNILENBQUM7SUFFRCxLQUFLLENBQUMsV0FBVztRQUNmLGdCQUFnQixDQUFDLGNBQWMsQ0FBQyxTQUFTLENBQUMsQ0FBQztJQUM3QyxDQUFDO0NBQ0YifQ==
|
package/index.d.ts
DELETED
|
@@ -1,17 +0,0 @@
|
|
|
1
|
-
import { ModuleReference as ModuleReferenceAlias } from '@eggjs/tegg-common-util';
|
|
2
|
-
declare module '@eggjs/core' {
|
|
3
|
-
type ModuleReference = ModuleReferenceAlias;
|
|
4
|
-
interface ModuleConfig {
|
|
5
|
-
}
|
|
6
|
-
interface ModuleConfigHolder {
|
|
7
|
-
name: string;
|
|
8
|
-
config: ModuleConfig;
|
|
9
|
-
reference: ModuleReference;
|
|
10
|
-
}
|
|
11
|
-
interface ModuleConfigApplication {
|
|
12
|
-
moduleReferences: readonly ModuleReference[];
|
|
13
|
-
moduleConfigs: Record<string, ModuleConfigHolder>;
|
|
14
|
-
}
|
|
15
|
-
interface EggCore extends ModuleConfigApplication {
|
|
16
|
-
}
|
|
17
|
-
}
|
package/index.js
DELETED
package/lib/ModuleScanner.d.ts
DELETED
|
@@ -1,11 +0,0 @@
|
|
|
1
|
-
import { ModuleReference, ReadModuleReferenceOptions } from '@eggjs/tegg-common-util';
|
|
2
|
-
export declare class ModuleScanner {
|
|
3
|
-
private readonly baseDir;
|
|
4
|
-
private readonly readModuleOptions;
|
|
5
|
-
constructor(baseDir: string, readModuleOptions: ReadModuleReferenceOptions);
|
|
6
|
-
/**
|
|
7
|
-
* - load module references from config or scan from baseDir
|
|
8
|
-
* - load framework module as optional module reference
|
|
9
|
-
*/
|
|
10
|
-
loadModuleReferences(): readonly ModuleReference[];
|
|
11
|
-
}
|
package/lib/ModuleScanner.js
DELETED
|
@@ -1,44 +0,0 @@
|
|
|
1
|
-
import path from 'node:path';
|
|
2
|
-
import { readFileSync } from 'node:fs';
|
|
3
|
-
import { ModuleConfigUtil } from '@eggjs/tegg-common-util';
|
|
4
|
-
import { importResolve } from '@eggjs/utils';
|
|
5
|
-
export class ModuleScanner {
|
|
6
|
-
baseDir;
|
|
7
|
-
readModuleOptions;
|
|
8
|
-
constructor(baseDir, readModuleOptions) {
|
|
9
|
-
this.baseDir = baseDir;
|
|
10
|
-
this.readModuleOptions = readModuleOptions;
|
|
11
|
-
}
|
|
12
|
-
/**
|
|
13
|
-
* - load module references from config or scan from baseDir
|
|
14
|
-
* - load framework module as optional module reference
|
|
15
|
-
*/
|
|
16
|
-
loadModuleReferences() {
|
|
17
|
-
const moduleReferences = ModuleConfigUtil.readModuleReference(this.baseDir, this.readModuleOptions || {});
|
|
18
|
-
// eslint-disable-next-line @typescript-eslint/no-var-requires
|
|
19
|
-
const appPkg = JSON.parse(readFileSync(path.join(this.baseDir, 'package.json'), 'utf-8'));
|
|
20
|
-
const framework = appPkg.egg?.framework;
|
|
21
|
-
if (!framework) {
|
|
22
|
-
return moduleReferences;
|
|
23
|
-
}
|
|
24
|
-
// eslint-disable-next-line @typescript-eslint/no-var-requires
|
|
25
|
-
const frameworkPkg = importResolve(`${framework}/package.json`, {
|
|
26
|
-
paths: [this.baseDir],
|
|
27
|
-
});
|
|
28
|
-
const frameworkDir = path.dirname(frameworkPkg);
|
|
29
|
-
const optionalModuleReferences = ModuleConfigUtil.readModuleReference(frameworkDir, this.readModuleOptions || {});
|
|
30
|
-
const result = [
|
|
31
|
-
...moduleReferences,
|
|
32
|
-
];
|
|
33
|
-
for (const optionalModuleReference of optionalModuleReferences) {
|
|
34
|
-
if (!result.some(t => t.path === optionalModuleReference.path)) {
|
|
35
|
-
result.push({
|
|
36
|
-
...optionalModuleReference,
|
|
37
|
-
optional: true,
|
|
38
|
-
});
|
|
39
|
-
}
|
|
40
|
-
}
|
|
41
|
-
return result;
|
|
42
|
-
}
|
|
43
|
-
}
|
|
44
|
-
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiTW9kdWxlU2Nhbm5lci5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIk1vZHVsZVNjYW5uZXIudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBQUEsT0FBTyxJQUFJLE1BQU0sV0FBVyxDQUFDO0FBQzdCLE9BQU8sRUFBRSxZQUFZLEVBQUUsTUFBTSxTQUFTLENBQUM7QUFDdkMsT0FBTyxFQUFFLGdCQUFnQixFQUErQyxNQUFNLHlCQUF5QixDQUFDO0FBQ3hHLE9BQU8sRUFBRSxhQUFhLEVBQUUsTUFBTSxjQUFjLENBQUM7QUFFN0MsTUFBTSxPQUFPLGFBQWE7SUFDUCxPQUFPLENBQVM7SUFDaEIsaUJBQWlCLENBQTZCO0lBRS9ELFlBQVksT0FBZSxFQUFFLGlCQUE2QztRQUN4RSxJQUFJLENBQUMsT0FBTyxHQUFHLE9BQU8sQ0FBQztRQUN2QixJQUFJLENBQUMsaUJBQWlCLEdBQUcsaUJBQWlCLENBQUM7SUFDN0MsQ0FBQztJQUVEOzs7T0FHRztJQUNILG9CQUFvQjtRQUNsQixNQUFNLGdCQUFnQixHQUFHLGdCQUFnQixDQUFDLG1CQUFtQixDQUFDLElBQUksQ0FBQyxPQUFPLEVBQUUsSUFBSSxDQUFDLGlCQUFpQixJQUFJLEVBQUUsQ0FBQyxDQUFDO1FBQzFHLDhEQUE4RDtRQUM5RCxNQUFNLE1BQU0sR0FBRyxJQUFJLENBQUMsS0FBSyxDQUFDLFlBQVksQ0FBQyxJQUFJLENBQUMsSUFBSSxDQUFDLElBQUksQ0FBQyxPQUFPLEVBQUUsY0FBYyxDQUFDLEVBQUUsT0FBTyxDQUFDLENBQUMsQ0FBQztRQUMxRixNQUFNLFNBQVMsR0FBRyxNQUFNLENBQUMsR0FBRyxFQUFFLFNBQVMsQ0FBQztRQUN4QyxJQUFJLENBQUMsU0FBUyxFQUFFLENBQUM7WUFDZixPQUFPLGdCQUFnQixDQUFDO1FBQzFCLENBQUM7UUFDRCw4REFBOEQ7UUFDOUQsTUFBTSxZQUFZLEdBQUcsYUFBYSxDQUFDLEdBQUcsU0FBUyxlQUFlLEVBQUU7WUFDOUQsS0FBSyxFQUFFLENBQUUsSUFBSSxDQUFDLE9BQU8sQ0FBRTtTQUN4QixDQUFDLENBQUM7UUFDSCxNQUFNLFlBQVksR0FBRyxJQUFJLENBQUMsT0FBTyxDQUFDLFlBQVksQ0FBQyxDQUFDO1FBQ2hELE1BQU0sd0JBQXdCLEdBQUcsZ0JBQWdCLENBQUMsbUJBQW1CLENBQUMsWUFBWSxFQUFFLElBQUksQ0FBQyxpQkFBaUIsSUFBSSxFQUFFLENBQUMsQ0FBQztRQUNsSCxNQUFNLE1BQU0sR0FBRztZQUNiLEdBQUcsZ0JBQWdCO1NBQ3BCLENBQUM7UUFDRixLQUFLLE1BQU0sdUJBQXVCLElBQUksd0JBQXdCLEVBQUUsQ0FBQztZQUMvRCxJQUFJLENBQUMsTUFBTSxDQUFDLElBQUksQ0FBQyxDQUFDLENBQUMsRUFBRSxDQUFDLENBQUMsQ0FBQyxJQUFJLEtBQUssdUJBQXVCLENBQUMsSUFBSSxDQUFDLEVBQUUsQ0FBQztnQkFDL0QsTUFBTSxDQUFDLElBQUksQ0FBQztvQkFDVixHQUFHLHVCQUF1QjtvQkFDMUIsUUFBUSxFQUFFLElBQUk7aUJBQ2YsQ0FBQyxDQUFDO1lBQ0wsQ0FBQztRQUNILENBQUM7UUFDRCxPQUFPLE1BQU0sQ0FBQztJQUNoQixDQUFDO0NBQ0YifQ==
|
package/typings/index.d.ts
DELETED
|
@@ -1 +0,0 @@
|
|
|
1
|
-
import 'egg';
|