egg 3.29.0 → 4.0.0-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.
- package/README.md +2 -1
- package/README.zh-CN.md +7 -5
- package/dist/commonjs/agent.d.ts +4 -0
- package/dist/commonjs/agent.js +10 -0
- package/dist/commonjs/app/extend/context.d.ts +154 -0
- package/dist/commonjs/app/extend/context.js +261 -0
- package/dist/commonjs/app/extend/context.types.d.ts +16 -0
- package/dist/commonjs/app/extend/context.types.js +3 -0
- package/dist/commonjs/app/extend/helper.d.ts +37 -0
- package/dist/commonjs/app/extend/helper.js +49 -0
- package/dist/commonjs/app/extend/request.d.ts +128 -0
- package/dist/commonjs/app/extend/request.js +270 -0
- package/dist/commonjs/app/extend/response.d.ts +25 -0
- package/dist/commonjs/app/extend/response.js +37 -0
- package/dist/commonjs/app/middleware/body_parser.d.ts +2 -0
- package/dist/commonjs/app/middleware/body_parser.js +8 -0
- package/dist/commonjs/app/middleware/meta.d.ts +10 -0
- package/dist/commonjs/app/middleware/meta.js +22 -0
- package/dist/commonjs/app/middleware/notfound.d.ts +7 -0
- package/dist/commonjs/app/middleware/notfound.js +31 -0
- package/dist/commonjs/app/middleware/override_method.d.ts +2 -0
- package/dist/commonjs/app/middleware/override_method.js +8 -0
- package/dist/commonjs/app/middleware/site_file.d.ts +9 -0
- package/dist/commonjs/app/middleware/site_file.js +58 -0
- package/dist/commonjs/config/config.default.d.ts +9 -0
- package/dist/commonjs/config/config.default.js +379 -0
- package/dist/commonjs/config/config.local.d.ts +8 -0
- package/dist/commonjs/config/config.local.js +12 -0
- package/dist/commonjs/config/config.unittest.d.ts +7 -0
- package/dist/commonjs/config/config.unittest.js +11 -0
- package/dist/commonjs/config/plugin.d.ts +122 -0
- package/dist/commonjs/config/plugin.js +125 -0
- package/dist/commonjs/index.d.ts +63 -0
- package/dist/commonjs/index.js +91 -0
- package/dist/commonjs/lib/agent.d.ts +19 -0
- package/dist/commonjs/lib/agent.js +58 -0
- package/dist/commonjs/lib/application.d.ts +59 -0
- package/dist/commonjs/lib/application.js +270 -0
- package/dist/commonjs/lib/core/base_context_class.d.ts +14 -0
- package/dist/commonjs/lib/core/base_context_class.js +22 -0
- package/dist/commonjs/lib/core/base_context_logger.d.ts +36 -0
- package/dist/commonjs/lib/core/base_context_logger.js +64 -0
- package/dist/commonjs/lib/core/base_hook_class.d.ts +11 -0
- package/dist/commonjs/lib/core/base_hook_class.js +30 -0
- package/dist/commonjs/lib/core/context_httpclient.d.ts +16 -0
- package/dist/commonjs/lib/core/context_httpclient.js +30 -0
- package/dist/commonjs/lib/core/httpclient.d.ts +13 -0
- package/dist/commonjs/lib/core/httpclient.js +37 -0
- package/dist/commonjs/lib/core/logger.d.ts +3 -0
- package/dist/commonjs/lib/core/logger.js +40 -0
- package/dist/commonjs/lib/core/messenger/IMessenger.d.ts +50 -0
- package/dist/commonjs/lib/core/messenger/IMessenger.js +3 -0
- package/dist/commonjs/lib/core/messenger/index.d.ts +7 -0
- package/dist/commonjs/lib/core/messenger/index.js +14 -0
- package/dist/commonjs/lib/core/messenger/ipc.d.ts +59 -0
- package/dist/commonjs/lib/core/messenger/ipc.js +137 -0
- package/dist/commonjs/lib/core/messenger/local.d.ts +61 -0
- package/dist/commonjs/lib/core/messenger/local.js +137 -0
- package/dist/commonjs/lib/core/singleton.d.ts +23 -0
- package/dist/commonjs/lib/core/singleton.js +120 -0
- package/dist/commonjs/lib/core/utils.d.ts +2 -0
- package/dist/commonjs/lib/core/utils.js +77 -0
- package/dist/commonjs/lib/egg.d.ts +276 -0
- package/dist/commonjs/lib/egg.js +617 -0
- package/dist/commonjs/lib/egg.types.d.ts +6 -0
- package/dist/commonjs/lib/egg.types.js +3 -0
- package/dist/commonjs/lib/loader/AgentWorkerLoader.d.ts +12 -0
- package/dist/commonjs/lib/loader/AgentWorkerLoader.js +24 -0
- package/dist/commonjs/lib/loader/AppWorkerLoader.d.ts +17 -0
- package/dist/commonjs/lib/loader/AppWorkerLoader.js +43 -0
- package/dist/commonjs/lib/loader/EggApplicationLoader.d.ts +4 -0
- package/dist/commonjs/lib/loader/EggApplicationLoader.js +8 -0
- package/dist/commonjs/lib/loader/index.d.ts +3 -0
- package/dist/commonjs/lib/loader/index.js +22 -0
- package/dist/commonjs/lib/start.d.ts +15 -0
- package/dist/commonjs/lib/start.js +49 -0
- package/dist/commonjs/lib/type.d.ts +293 -0
- package/dist/commonjs/lib/type.js +3 -0
- package/dist/commonjs/lib/utils.d.ts +2 -0
- package/dist/commonjs/lib/utils.js +21 -0
- package/dist/commonjs/package.json +3 -0
- package/dist/esm/agent.d.ts +4 -0
- package/dist/esm/agent.js +7 -0
- package/dist/esm/app/extend/context.d.ts +154 -0
- package/dist/esm/app/extend/context.js +255 -0
- package/dist/esm/app/extend/context.types.d.ts +16 -0
- package/dist/esm/app/extend/context.types.js +2 -0
- package/dist/esm/app/extend/helper.d.ts +37 -0
- package/dist/esm/app/extend/helper.js +43 -0
- package/dist/esm/app/extend/request.d.ts +128 -0
- package/dist/esm/app/extend/request.js +264 -0
- package/dist/esm/app/extend/response.d.ts +25 -0
- package/dist/esm/app/extend/response.js +34 -0
- package/dist/esm/app/middleware/body_parser.d.ts +2 -0
- package/dist/esm/app/middleware/body_parser.js +3 -0
- package/dist/esm/app/middleware/meta.d.ts +10 -0
- package/dist/esm/app/middleware/meta.js +20 -0
- package/dist/esm/app/middleware/notfound.d.ts +7 -0
- package/dist/esm/app/middleware/notfound.js +29 -0
- package/dist/esm/app/middleware/override_method.d.ts +2 -0
- package/dist/esm/app/middleware/override_method.js +3 -0
- package/dist/esm/app/middleware/site_file.d.ts +9 -0
- package/dist/esm/app/middleware/site_file.js +53 -0
- package/dist/esm/config/config.default.d.ts +9 -0
- package/dist/esm/config/config.default.js +374 -0
- package/dist/esm/config/config.local.d.ts +8 -0
- package/dist/esm/config/config.local.js +10 -0
- package/dist/esm/config/config.unittest.d.ts +7 -0
- package/dist/esm/config/config.unittest.js +9 -0
- package/dist/esm/config/favicon.png +0 -0
- package/dist/esm/config/plugin.d.ts +122 -0
- package/dist/esm/config/plugin.js +123 -0
- package/dist/esm/index.d.ts +63 -0
- package/dist/esm/index.js +66 -0
- package/dist/esm/lib/agent.d.ts +19 -0
- package/dist/esm/lib/agent.js +54 -0
- package/dist/esm/lib/application.d.ts +59 -0
- package/dist/esm/lib/application.js +263 -0
- package/dist/esm/lib/core/base_context_class.d.ts +14 -0
- package/dist/esm/lib/core/base_context_class.js +18 -0
- package/dist/esm/lib/core/base_context_logger.d.ts +36 -0
- package/dist/esm/lib/core/base_context_logger.js +60 -0
- package/dist/esm/lib/core/base_hook_class.d.ts +11 -0
- package/dist/esm/lib/core/base_hook_class.js +23 -0
- package/dist/esm/lib/core/context_httpclient.d.ts +16 -0
- package/dist/esm/lib/core/context_httpclient.js +26 -0
- package/dist/esm/lib/core/httpclient.d.ts +13 -0
- package/dist/esm/lib/core/httpclient.js +33 -0
- package/dist/esm/lib/core/logger.d.ts +3 -0
- package/dist/esm/lib/core/logger.js +37 -0
- package/dist/esm/lib/core/messenger/IMessenger.d.ts +50 -0
- package/dist/esm/lib/core/messenger/IMessenger.js +2 -0
- package/dist/esm/lib/core/messenger/index.d.ts +7 -0
- package/dist/esm/lib/core/messenger/index.js +11 -0
- package/dist/esm/lib/core/messenger/ipc.d.ts +59 -0
- package/dist/esm/lib/core/messenger/ipc.js +130 -0
- package/dist/esm/lib/core/messenger/local.d.ts +61 -0
- package/dist/esm/lib/core/messenger/local.js +130 -0
- package/dist/esm/lib/core/singleton.d.ts +23 -0
- package/dist/esm/lib/core/singleton.js +113 -0
- package/dist/esm/lib/core/utils.d.ts +2 -0
- package/dist/esm/lib/core/utils.js +70 -0
- package/dist/esm/lib/egg.d.ts +276 -0
- package/dist/esm/lib/egg.js +574 -0
- package/dist/esm/lib/egg.types.d.ts +6 -0
- package/dist/esm/lib/egg.types.js +2 -0
- package/dist/esm/lib/loader/AgentWorkerLoader.d.ts +12 -0
- package/dist/esm/lib/loader/AgentWorkerLoader.js +20 -0
- package/dist/esm/lib/loader/AppWorkerLoader.d.ts +17 -0
- package/dist/esm/lib/loader/AppWorkerLoader.js +39 -0
- package/dist/esm/lib/loader/EggApplicationLoader.d.ts +4 -0
- package/dist/esm/lib/loader/EggApplicationLoader.js +4 -0
- package/dist/esm/lib/loader/index.d.ts +3 -0
- package/dist/esm/lib/loader/index.js +4 -0
- package/dist/esm/lib/start.d.ts +15 -0
- package/dist/esm/lib/start.js +43 -0
- package/dist/esm/lib/type.d.ts +293 -0
- package/dist/esm/lib/type.js +2 -0
- package/dist/esm/lib/utils.d.ts +2 -0
- package/dist/esm/lib/utils.js +14 -0
- package/dist/esm/package.json +3 -0
- package/dist/package.json +4 -0
- package/package.json +97 -79
- package/src/agent.ts +7 -0
- package/src/app/extend/context.ts +303 -0
- package/src/app/extend/context.types.ts +24 -0
- package/{app/extend/helper.js → src/app/extend/helper.ts} +14 -13
- package/{app/extend/request.js → src/app/extend/request.ts} +81 -79
- package/src/app/extend/response.ts +36 -0
- package/src/app/middleware/body_parser.ts +3 -0
- package/{app/middleware/meta.js → src/app/middleware/meta.ts} +11 -4
- package/{app/middleware/notfound.js → src/app/middleware/notfound.ts} +8 -3
- package/src/app/middleware/override_method.ts +3 -0
- package/src/app/middleware/site_file.ts +68 -0
- package/{config/config.default.js → src/config/config.default.ts} +25 -45
- package/src/config/config.local.ts +11 -0
- package/src/config/config.unittest.ts +10 -0
- package/src/config/favicon.png +0 -0
- package/{config/plugin.js → src/config/plugin.ts} +3 -5
- package/src/index.ts +80 -0
- package/src/lib/agent.ts +66 -0
- package/{lib/application.js → src/lib/application.ts} +76 -124
- package/src/lib/core/base_context_class.ts +21 -0
- package/src/lib/core/base_context_logger.ts +67 -0
- package/src/lib/core/base_hook_class.ts +30 -0
- package/src/lib/core/context_httpclient.ts +33 -0
- package/src/lib/core/httpclient.ts +51 -0
- package/src/lib/core/logger.ts +42 -0
- package/src/lib/core/messenger/IMessenger.ts +58 -0
- package/src/lib/core/messenger/index.ts +15 -0
- package/src/lib/core/messenger/ipc.ts +148 -0
- package/{lib/core/messenger/local.js → src/lib/core/messenger/local.ts} +36 -28
- package/{lib/core/singleton.js → src/lib/core/singleton.ts} +56 -33
- package/src/lib/core/utils.ts +77 -0
- package/{lib/egg.js → src/lib/egg.ts} +287 -221
- package/src/lib/egg.types.ts +6 -0
- package/src/lib/loader/AgentWorkerLoader.ts +21 -0
- package/src/lib/loader/AppWorkerLoader.ts +42 -0
- package/src/lib/loader/EggApplicationLoader.ts +5 -0
- package/src/lib/loader/index.ts +3 -0
- package/src/lib/start.ts +56 -0
- package/src/lib/type.ts +329 -0
- package/src/lib/utils.ts +16 -0
- package/CHANGELOG.md +0 -2395
- package/History.md +0 -52
- package/agent.js +0 -11
- package/app/extend/context.js +0 -285
- package/app/extend/response.js +0 -101
- package/app/middleware/body_parser.js +0 -3
- package/app/middleware/override_method.js +0 -3
- package/app/middleware/site_file.js +0 -31
- package/config/config.local.js +0 -7
- package/config/config.unittest.js +0 -8
- package/index.d.ts +0 -1288
- package/index.js +0 -68
- package/lib/agent.js +0 -95
- package/lib/core/base_context_class.js +0 -20
- package/lib/core/base_context_logger.js +0 -64
- package/lib/core/base_hook_class.js +0 -31
- package/lib/core/context_httpclient.js +0 -26
- package/lib/core/dnscache_httpclient.js +0 -93
- package/lib/core/httpclient.js +0 -119
- package/lib/core/httpclient_next.js +0 -80
- package/lib/core/logger.js +0 -35
- package/lib/core/messenger/index.js +0 -14
- package/lib/core/messenger/ipc.js +0 -141
- package/lib/core/utils.js +0 -73
- package/lib/loader/agent_worker_loader.js +0 -27
- package/lib/loader/app_worker_loader.js +0 -48
- package/lib/loader/index.js +0 -5
- package/lib/start.js +0 -39
- /package/{config → dist/commonjs/config}/favicon.png +0 -0
|
@@ -0,0 +1,21 @@
|
|
|
1
|
+
import { EggApplicationLoader } from './EggApplicationLoader.js';
|
|
2
|
+
|
|
3
|
+
/**
|
|
4
|
+
* Agent worker process loader
|
|
5
|
+
* @see https://github.com/eggjs/egg-core/blob/master/src/loader/egg_loader.ts
|
|
6
|
+
*/
|
|
7
|
+
export class AgentWorkerLoader extends EggApplicationLoader {
|
|
8
|
+
/**
|
|
9
|
+
* loadPlugin first, then loadConfig
|
|
10
|
+
*/
|
|
11
|
+
async loadConfig() {
|
|
12
|
+
await this.loadPlugin();
|
|
13
|
+
await super.loadConfig();
|
|
14
|
+
}
|
|
15
|
+
|
|
16
|
+
async load() {
|
|
17
|
+
await this.loadAgentExtend();
|
|
18
|
+
await this.loadContextExtend();
|
|
19
|
+
await this.loadCustomAgent();
|
|
20
|
+
}
|
|
21
|
+
}
|
|
@@ -0,0 +1,42 @@
|
|
|
1
|
+
import { EggApplicationLoader } from './EggApplicationLoader.js';
|
|
2
|
+
|
|
3
|
+
/**
|
|
4
|
+
* App worker process Loader, will load plugins
|
|
5
|
+
* @see https://github.com/eggjs/egg-core/blob/master/src/loader/egg_loader.ts
|
|
6
|
+
*/
|
|
7
|
+
export class AppWorkerLoader extends EggApplicationLoader {
|
|
8
|
+
/**
|
|
9
|
+
* loadPlugin first, then loadConfig
|
|
10
|
+
* @since 1.0.0
|
|
11
|
+
*/
|
|
12
|
+
async loadConfig() {
|
|
13
|
+
await this.loadPlugin();
|
|
14
|
+
await super.loadConfig();
|
|
15
|
+
}
|
|
16
|
+
|
|
17
|
+
/**
|
|
18
|
+
* Load all directories in convention
|
|
19
|
+
* @since 1.0.0
|
|
20
|
+
*/
|
|
21
|
+
async load() {
|
|
22
|
+
// app > plugin > core
|
|
23
|
+
await this.loadApplicationExtend();
|
|
24
|
+
await this.loadRequestExtend();
|
|
25
|
+
await this.loadResponseExtend();
|
|
26
|
+
await this.loadContextExtend();
|
|
27
|
+
await this.loadHelperExtend();
|
|
28
|
+
|
|
29
|
+
await this.loadCustomLoader();
|
|
30
|
+
|
|
31
|
+
// app > plugin
|
|
32
|
+
await this.loadCustomApp();
|
|
33
|
+
// app > plugin
|
|
34
|
+
await this.loadService();
|
|
35
|
+
// app > plugin > core
|
|
36
|
+
await this.loadMiddleware();
|
|
37
|
+
// app
|
|
38
|
+
await this.loadController();
|
|
39
|
+
// app
|
|
40
|
+
await this.loadRouter(); // Depend on controllers
|
|
41
|
+
}
|
|
42
|
+
}
|
package/src/lib/start.ts
ADDED
|
@@ -0,0 +1,56 @@
|
|
|
1
|
+
import path from 'node:path';
|
|
2
|
+
import { readJSON } from 'utility';
|
|
3
|
+
import { importModule } from '@eggjs/utils';
|
|
4
|
+
import { Agent } from './agent.js';
|
|
5
|
+
import { Application } from './application.js';
|
|
6
|
+
|
|
7
|
+
export interface StartEggOptions {
|
|
8
|
+
/** specify framework that can be absolute path or npm package */
|
|
9
|
+
framework?: string;
|
|
10
|
+
/** directory of application, default to `process.cwd()` */
|
|
11
|
+
baseDir?: string;
|
|
12
|
+
/** ignore single process mode warning */
|
|
13
|
+
ignoreWarning?: boolean;
|
|
14
|
+
mode?: 'single';
|
|
15
|
+
env?: string;
|
|
16
|
+
}
|
|
17
|
+
|
|
18
|
+
/**
|
|
19
|
+
* Start egg with single process
|
|
20
|
+
*/
|
|
21
|
+
export async function startEgg(options: StartEggOptions = {}) {
|
|
22
|
+
options.baseDir = options.baseDir ?? process.cwd();
|
|
23
|
+
options.mode = 'single';
|
|
24
|
+
|
|
25
|
+
// get agent from options.framework and package.egg.framework
|
|
26
|
+
if (!options.framework) {
|
|
27
|
+
try {
|
|
28
|
+
const pkg = await readJSON(path.join(options.baseDir, 'package.json'));
|
|
29
|
+
options.framework = pkg.egg.framework;
|
|
30
|
+
} catch (_) {
|
|
31
|
+
// ignore
|
|
32
|
+
}
|
|
33
|
+
}
|
|
34
|
+
let AgentClass = Agent;
|
|
35
|
+
let ApplicationClass = Application;
|
|
36
|
+
if (options.framework) {
|
|
37
|
+
const framework = await importModule(options.framework, { paths: [ options.baseDir ] });
|
|
38
|
+
AgentClass = framework.Agent;
|
|
39
|
+
ApplicationClass = framework.Application;
|
|
40
|
+
}
|
|
41
|
+
|
|
42
|
+
const agent = new AgentClass({
|
|
43
|
+
...options,
|
|
44
|
+
});
|
|
45
|
+
await agent.ready();
|
|
46
|
+
const application = new ApplicationClass({
|
|
47
|
+
...options,
|
|
48
|
+
});
|
|
49
|
+
application.agent = agent;
|
|
50
|
+
agent.application = application;
|
|
51
|
+
await application.ready();
|
|
52
|
+
|
|
53
|
+
// emit egg-ready message in agent and application
|
|
54
|
+
application.messenger.broadcast('egg-ready');
|
|
55
|
+
return application;
|
|
56
|
+
}
|
package/src/lib/type.ts
ADDED
|
@@ -0,0 +1,329 @@
|
|
|
1
|
+
import type { Socket } from 'node:net';
|
|
2
|
+
import type {
|
|
3
|
+
RequestOptions as HttpClientRequestOptions,
|
|
4
|
+
} from 'urllib';
|
|
5
|
+
import type {
|
|
6
|
+
EggLoggerOptions, EggLoggersOptions,
|
|
7
|
+
} from 'egg-logger';
|
|
8
|
+
import type {
|
|
9
|
+
FileLoaderOptions,
|
|
10
|
+
} from '@eggjs/core';
|
|
11
|
+
import type {
|
|
12
|
+
EggApplicationCore, ContextDelegation,
|
|
13
|
+
} from './egg.js';
|
|
14
|
+
import type { MetaMiddlewareOptions } from '../app/middleware/meta.js';
|
|
15
|
+
import type { NotFoundMiddlewareOptions } from '../app/middleware/notfound.js';
|
|
16
|
+
import type { SiteFileMiddlewareOptions } from '../app/middleware/site_file.js';
|
|
17
|
+
|
|
18
|
+
// import @eggjs/watcher types
|
|
19
|
+
// import '@eggjs/watcher';
|
|
20
|
+
|
|
21
|
+
type IgnoreItem = string | RegExp | ((ctx: ContextDelegation) => boolean);
|
|
22
|
+
type IgnoreOrMatch = IgnoreItem | IgnoreItem[];
|
|
23
|
+
|
|
24
|
+
export interface ClientErrorResponse {
|
|
25
|
+
body: string | Buffer;
|
|
26
|
+
status: number;
|
|
27
|
+
headers: { [key: string]: string };
|
|
28
|
+
}
|
|
29
|
+
|
|
30
|
+
/** egg env type */
|
|
31
|
+
export type EggEnvType = 'local' | 'unittest' | 'prod' | string;
|
|
32
|
+
|
|
33
|
+
/** logger config of egg */
|
|
34
|
+
export interface EggLoggerConfig extends Omit<EggLoggersOptions, 'type'> {
|
|
35
|
+
/** custom config of coreLogger */
|
|
36
|
+
coreLogger?: Partial<EggLoggerOptions>;
|
|
37
|
+
/** allow debug log at prod, defaults to `false` */
|
|
38
|
+
allowDebugAtProd?: boolean;
|
|
39
|
+
/** disable logger console after app ready. defaults to `false` on local and unittest env, others is `true`. */
|
|
40
|
+
disableConsoleAfterReady?: boolean;
|
|
41
|
+
/** [deprecated] Defaults to `true`. */
|
|
42
|
+
enablePerformanceTimer?: boolean;
|
|
43
|
+
/** using the app logger instead of EggContextLogger, defaults to `false` */
|
|
44
|
+
enableFastContextLogger?: boolean;
|
|
45
|
+
}
|
|
46
|
+
|
|
47
|
+
/** Custom Loader Configuration */
|
|
48
|
+
export interface CustomLoaderConfig extends Omit<FileLoaderOptions, 'inject' | 'target'> {
|
|
49
|
+
/**
|
|
50
|
+
* an object you wanner load to, value can only be 'ctx' or 'app'. default to app
|
|
51
|
+
*/
|
|
52
|
+
inject?: 'ctx' | 'app';
|
|
53
|
+
/**
|
|
54
|
+
* whether need to load files in plugins or framework, default to false
|
|
55
|
+
*/
|
|
56
|
+
loadunit?: boolean;
|
|
57
|
+
}
|
|
58
|
+
|
|
59
|
+
export interface EggAppConfig {
|
|
60
|
+
workerStartTimeout: number;
|
|
61
|
+
baseDir: string;
|
|
62
|
+
middleware: string[];
|
|
63
|
+
coreMiddleware: string[];
|
|
64
|
+
|
|
65
|
+
/**
|
|
66
|
+
* The option of `bodyParser` middleware
|
|
67
|
+
*
|
|
68
|
+
* @member Config#bodyParser
|
|
69
|
+
* @property {Boolean} enable - enable bodyParser or not, default to true
|
|
70
|
+
* @property {String | RegExp | Function | Array} ignore - won't parse request body when url path hit ignore pattern, can not set `ignore` when `match` presented
|
|
71
|
+
* @property {String | RegExp | Function | Array} match - will parse request body only when url path hit match pattern
|
|
72
|
+
* @property {String} encoding - body encoding config, default utf8
|
|
73
|
+
* @property {String} formLimit - form body size limit, default 1mb
|
|
74
|
+
* @property {String} jsonLimit - json body size limit, default 1mb
|
|
75
|
+
* @property {String} textLimit - json body size limit, default 1mb
|
|
76
|
+
* @property {Boolean} strict - json body strict mode, if set strict value true, then only receive object and array json body
|
|
77
|
+
* @property {Number} queryString.arrayLimit - from item array length limit, default 100
|
|
78
|
+
* @property {Number} queryString.depth - json value deep length, default 5
|
|
79
|
+
* @property {Number} queryString.parameterLimit - parameter number limit, default 1000
|
|
80
|
+
* @property {String[]} enableTypes - parser will only parse when request type hits enableTypes, default is ['json', 'form']
|
|
81
|
+
* @property {Object} extendTypes - support extend types
|
|
82
|
+
* @property {String} onProtoPoisoning - Defines what action must take when parsing a JSON object with `__proto__`. Possible values are `'error'`, `'remove'` and `'ignore'`. Default is `'error'`, it will return `400` response when `Prototype-Poisoning` happen.
|
|
83
|
+
*/
|
|
84
|
+
bodyParser: {
|
|
85
|
+
enable: boolean;
|
|
86
|
+
encoding: string;
|
|
87
|
+
formLimit: string;
|
|
88
|
+
jsonLimit: string;
|
|
89
|
+
textLimit: string;
|
|
90
|
+
strict: boolean;
|
|
91
|
+
queryString: {
|
|
92
|
+
arrayLimit: number;
|
|
93
|
+
depth: number;
|
|
94
|
+
parameterLimit: number;
|
|
95
|
+
};
|
|
96
|
+
ignore?: IgnoreOrMatch;
|
|
97
|
+
match?: IgnoreOrMatch;
|
|
98
|
+
enableTypes?: string[];
|
|
99
|
+
extendTypes?: {
|
|
100
|
+
json: string[];
|
|
101
|
+
form: string[];
|
|
102
|
+
text: string[];
|
|
103
|
+
};
|
|
104
|
+
/** Default is `'error'`, it will return `400` response when `Prototype-Poisoning` happen. */
|
|
105
|
+
onProtoPoisoning: 'error' | 'remove' | 'ignore';
|
|
106
|
+
onerror(err: any, ctx: ContextDelegation): void;
|
|
107
|
+
};
|
|
108
|
+
|
|
109
|
+
/**
|
|
110
|
+
* logger options
|
|
111
|
+
* @member Config#logger
|
|
112
|
+
* @property {String} dir - directory of log files
|
|
113
|
+
* @property {String} encoding - log file encoding, defaults to utf8
|
|
114
|
+
* @property {String} level - default log level, could be: DEBUG, INFO, WARN, ERROR or NONE, defaults to INFO in production
|
|
115
|
+
* @property {String} consoleLevel - log level of stdout, defaults to `INFO` in local serverEnv, defaults to `WARN` in unittest, others is `NONE`
|
|
116
|
+
* @property {Boolean} disableConsoleAfterReady - disable logger console after app ready. defaults to `false` on local and unittest env, others is `true`.
|
|
117
|
+
* @property {Boolean} outputJSON - log as JSON or not, defaults to `false`
|
|
118
|
+
* @property {Boolean} buffer - if enabled, flush logs to disk at a certain frequency to improve performance, defaults to true
|
|
119
|
+
* @property {String} errorLogName - file name of errorLogger
|
|
120
|
+
* @property {String} coreLogName - file name of coreLogger
|
|
121
|
+
* @property {String} agentLogName - file name of agent worker log
|
|
122
|
+
* @property {Object} coreLogger - custom config of coreLogger
|
|
123
|
+
* @property {Boolean} allowDebugAtProd - allow debug log at prod, defaults to false
|
|
124
|
+
* @property {Boolean} enableFastContextLogger - using the app logger instead of EggContextLogger, defaults to false
|
|
125
|
+
*/
|
|
126
|
+
logger: Partial<EggLoggerConfig>;
|
|
127
|
+
|
|
128
|
+
/** custom logger of egg */
|
|
129
|
+
customLogger: {
|
|
130
|
+
[key: string]: EggLoggerOptions;
|
|
131
|
+
};
|
|
132
|
+
|
|
133
|
+
/** Configuration of httpclient in egg. */
|
|
134
|
+
httpclient: {
|
|
135
|
+
/** Request timeout */
|
|
136
|
+
timeout?: number;
|
|
137
|
+
/** Default request args for httpclient */
|
|
138
|
+
request?: HttpClientRequestOptions;
|
|
139
|
+
};
|
|
140
|
+
|
|
141
|
+
development: {
|
|
142
|
+
/**
|
|
143
|
+
* dirs needed watch, when files under these change, application will reload, use relative path
|
|
144
|
+
*/
|
|
145
|
+
watchDirs: string[];
|
|
146
|
+
/**
|
|
147
|
+
* dirs don't need watch, including subdirectories, use relative path
|
|
148
|
+
*/
|
|
149
|
+
ignoreDirs: string[];
|
|
150
|
+
/**
|
|
151
|
+
* don't wait all plugins ready, default is true.
|
|
152
|
+
*/
|
|
153
|
+
fastReady: boolean;
|
|
154
|
+
/**
|
|
155
|
+
* whether reload on debug, default is true.
|
|
156
|
+
*/
|
|
157
|
+
reloadOnDebug: boolean;
|
|
158
|
+
/**
|
|
159
|
+
* whether override default watchDirs, default is false.
|
|
160
|
+
*/
|
|
161
|
+
overrideDefault: boolean;
|
|
162
|
+
/**
|
|
163
|
+
* whether override default ignoreDirs, default is false.
|
|
164
|
+
*/
|
|
165
|
+
overrideIgnore: boolean;
|
|
166
|
+
/**
|
|
167
|
+
* whether to reload, use https://github.com/sindresorhus/multimatch
|
|
168
|
+
*/
|
|
169
|
+
reloadPattern: string[] | string;
|
|
170
|
+
};
|
|
171
|
+
|
|
172
|
+
/**
|
|
173
|
+
* customLoader config
|
|
174
|
+
*/
|
|
175
|
+
customLoader: {
|
|
176
|
+
[key: string]: CustomLoaderConfig;
|
|
177
|
+
};
|
|
178
|
+
|
|
179
|
+
/**
|
|
180
|
+
* It will ignore special keys when dumpConfig
|
|
181
|
+
*/
|
|
182
|
+
dump: {
|
|
183
|
+
ignore: Set<string | RegExp>;
|
|
184
|
+
timing: {
|
|
185
|
+
slowBootActionMinDuration: number;
|
|
186
|
+
};
|
|
187
|
+
};
|
|
188
|
+
|
|
189
|
+
/**
|
|
190
|
+
* The environment of egg
|
|
191
|
+
*/
|
|
192
|
+
env: EggEnvType;
|
|
193
|
+
|
|
194
|
+
/**
|
|
195
|
+
* The current HOME directory
|
|
196
|
+
*/
|
|
197
|
+
HOME: string;
|
|
198
|
+
|
|
199
|
+
hostHeaders: string;
|
|
200
|
+
|
|
201
|
+
/**
|
|
202
|
+
* I18n options
|
|
203
|
+
*/
|
|
204
|
+
i18n: {
|
|
205
|
+
/**
|
|
206
|
+
* default value EN_US
|
|
207
|
+
*/
|
|
208
|
+
defaultLocale: string;
|
|
209
|
+
/**
|
|
210
|
+
* i18n resource file dir, not recommend to change default value
|
|
211
|
+
*/
|
|
212
|
+
dirs: string[];
|
|
213
|
+
/**
|
|
214
|
+
* custom the locale value field, default `query.locale`, you can modify this config, such as `query.lang`
|
|
215
|
+
*/
|
|
216
|
+
queryField: string;
|
|
217
|
+
/**
|
|
218
|
+
* The locale value key in the cookie, default is locale.
|
|
219
|
+
*/
|
|
220
|
+
cookieField: string;
|
|
221
|
+
/**
|
|
222
|
+
* Locale cookie expire time, default `1y`, If pass number value, the unit will be ms
|
|
223
|
+
*/
|
|
224
|
+
cookieMaxAge: string | number;
|
|
225
|
+
};
|
|
226
|
+
|
|
227
|
+
/**
|
|
228
|
+
* Detect request' ip from specified headers, not case-sensitive. Only worked when config.proxy set to true.
|
|
229
|
+
*/
|
|
230
|
+
ipHeaders: string;
|
|
231
|
+
|
|
232
|
+
protocolHeaders: string;
|
|
233
|
+
maxProxyCount: number;
|
|
234
|
+
maxIpsCount: number;
|
|
235
|
+
proxy: boolean;
|
|
236
|
+
cookies: {
|
|
237
|
+
sameSite?: string;
|
|
238
|
+
httpOnly?: boolean;
|
|
239
|
+
};
|
|
240
|
+
|
|
241
|
+
/**
|
|
242
|
+
* jsonp options
|
|
243
|
+
* @member Config#jsonp
|
|
244
|
+
* @property {String} callback - jsonp callback method key, default to `_callback`
|
|
245
|
+
* @property {Number} limit - callback method name's max length, default to `50`
|
|
246
|
+
* @property {Boolean} csrf - enable csrf check or not. default to false
|
|
247
|
+
* @property {String|RegExp|Array} whiteList - referrer white list
|
|
248
|
+
*/
|
|
249
|
+
jsonp: {
|
|
250
|
+
limit: number;
|
|
251
|
+
callback: string;
|
|
252
|
+
csrf: boolean;
|
|
253
|
+
whiteList: string | RegExp | Array<string | RegExp>;
|
|
254
|
+
};
|
|
255
|
+
|
|
256
|
+
/**
|
|
257
|
+
* The key that signing cookies. It can contain multiple keys separated by .
|
|
258
|
+
*/
|
|
259
|
+
keys: string;
|
|
260
|
+
|
|
261
|
+
/**
|
|
262
|
+
* The name of the application
|
|
263
|
+
*/
|
|
264
|
+
name: string;
|
|
265
|
+
|
|
266
|
+
/**
|
|
267
|
+
* package.json
|
|
268
|
+
*/
|
|
269
|
+
pkg: Record<string, any>;
|
|
270
|
+
|
|
271
|
+
rundir: string;
|
|
272
|
+
|
|
273
|
+
security: {
|
|
274
|
+
domainWhiteList: string[];
|
|
275
|
+
protocolWhiteList: string[];
|
|
276
|
+
defaultMiddleware: string;
|
|
277
|
+
csrf: any;
|
|
278
|
+
ssrf: {
|
|
279
|
+
ipBlackList: string[];
|
|
280
|
+
ipExceptionList: string[];
|
|
281
|
+
checkAddress?(ip: string): boolean;
|
|
282
|
+
};
|
|
283
|
+
xframe: {
|
|
284
|
+
enable: boolean;
|
|
285
|
+
value: 'SAMEORIGIN' | 'DENY' | 'ALLOW-FROM';
|
|
286
|
+
};
|
|
287
|
+
hsts: any;
|
|
288
|
+
methodnoallow: { enable: boolean };
|
|
289
|
+
noopen: { enable: boolean; }
|
|
290
|
+
xssProtection: any;
|
|
291
|
+
csp: any;
|
|
292
|
+
};
|
|
293
|
+
|
|
294
|
+
siteFile: SiteFileMiddlewareOptions;
|
|
295
|
+
meta: MetaMiddlewareOptions;
|
|
296
|
+
notfound: NotFoundMiddlewareOptions;
|
|
297
|
+
overrideMethod: {
|
|
298
|
+
enable: boolean;
|
|
299
|
+
allowedMethods: string[];
|
|
300
|
+
};
|
|
301
|
+
|
|
302
|
+
watcher: Record<string, any>;
|
|
303
|
+
|
|
304
|
+
onClientError?(err: Error, socket: Socket, app: EggApplicationCore): ClientErrorResponse | Promise<ClientErrorResponse>;
|
|
305
|
+
|
|
306
|
+
/**
|
|
307
|
+
* server timeout in milliseconds, default to 0 (no timeout).
|
|
308
|
+
*
|
|
309
|
+
* for special request, just use `ctx.req.setTimeout(ms)`
|
|
310
|
+
*
|
|
311
|
+
* @see https://nodejs.org/api/http.html#http_server_timeout
|
|
312
|
+
*/
|
|
313
|
+
serverTimeout: number | null;
|
|
314
|
+
|
|
315
|
+
cluster: {
|
|
316
|
+
listen: {
|
|
317
|
+
path: string,
|
|
318
|
+
port: number,
|
|
319
|
+
hostname: string,
|
|
320
|
+
};
|
|
321
|
+
};
|
|
322
|
+
|
|
323
|
+
clusterClient: {
|
|
324
|
+
maxWaitTime: number;
|
|
325
|
+
responseTimeout: number;
|
|
326
|
+
};
|
|
327
|
+
|
|
328
|
+
[prop: string]: any;
|
|
329
|
+
}
|
package/src/lib/utils.ts
ADDED
|
@@ -0,0 +1,16 @@
|
|
|
1
|
+
|
|
2
|
+
import path from 'node:path';
|
|
3
|
+
import { fileURLToPath } from 'node:url';
|
|
4
|
+
|
|
5
|
+
export function getSourceDirname() {
|
|
6
|
+
if (typeof __dirname !== 'undefined') {
|
|
7
|
+
return path.dirname(__dirname);
|
|
8
|
+
}
|
|
9
|
+
// eslint-disable-next-line @typescript-eslint/ban-ts-comment
|
|
10
|
+
// @ts-ignore
|
|
11
|
+
return path.dirname(path.dirname(fileURLToPath(import.meta.url)));
|
|
12
|
+
}
|
|
13
|
+
|
|
14
|
+
export function getSourceFile(filename: string) {
|
|
15
|
+
return path.join(getSourceDirname(), filename);
|
|
16
|
+
}
|