@sima-land/isomorph 11.0.0-alpha.0 → 11.0.0-alpha.11
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/{dist/cache → cache}/types.d.ts +0 -0
- package/{dist/utils/webpack/module-federation → cache}/types.js +0 -0
- package/{dist/cache → cache}/types.js.map +0 -0
- package/{dist/config/index.d.ts → config/base.d.ts} +0 -0
- package/{dist/config/index.js → config/base.js} +1 -1
- package/config/base.js.map +1 -0
- package/{dist/config → config}/browser.d.ts +0 -0
- package/config/browser.js +22 -0
- package/config/browser.js.map +1 -0
- package/{dist/config → config}/node.d.ts +0 -0
- package/{dist/config → config}/node.js +10 -5
- package/config/node.js.map +1 -0
- package/{dist/config → config}/types.d.ts +0 -0
- package/{dist/tracer → config}/types.js +0 -0
- package/{dist/config → config}/types.js.map +0 -0
- package/di/application.d.ts +6 -0
- package/{dist/container → di}/application.js +17 -8
- package/di/application.js.map +1 -0
- package/di/container.d.ts +6 -0
- package/di/container.js +49 -0
- package/di/container.js.map +1 -0
- package/di/errors.d.ts +21 -0
- package/di/errors.js +33 -0
- package/di/errors.js.map +1 -0
- package/di/index.d.ts +6 -0
- package/di/index.js +16 -0
- package/di/index.js.map +1 -0
- package/di/preset.d.ts +9 -0
- package/di/preset.js +27 -0
- package/di/preset.js.map +1 -0
- package/di/token.d.ts +7 -0
- package/di/token.js +17 -0
- package/di/token.js.map +1 -0
- package/di/types.d.ts +32 -0
- package/{dist/saga-runner → di}/types.js +0 -0
- package/{dist/preset → di}/types.js.map +1 -1
- package/error-tracking/index.d.ts +22 -0
- package/{dist/error-tracker/utils.js → error-tracking/index.js} +14 -3
- package/error-tracking/index.js.map +1 -0
- package/error-tracking/types.d.ts +13 -0
- package/{dist/preset → error-tracking}/types.js +0 -0
- package/{dist/container → error-tracking}/types.js.map +1 -1
- package/{dist/http-client → http-client}/middleware/cookie.d.ts +0 -0
- package/{dist/http-client → http-client}/middleware/cookie.js +0 -0
- package/{dist/http-client → http-client}/middleware/cookie.js.map +0 -0
- package/http-client/middleware/logging.d.ts +15 -0
- package/http-client/middleware/logging.js +93 -0
- package/http-client/middleware/logging.js.map +1 -0
- package/{dist/http-client → http-client}/middleware/tracing.d.ts +0 -0
- package/{dist/http-client → http-client}/middleware/tracing.js +0 -0
- package/{dist/http-client → http-client}/middleware/tracing.js.map +0 -0
- package/{dist/http-client/utils.d.ts → http-client/sauce/index.d.ts} +0 -9
- package/{dist/http-client/utils.js → http-client/sauce/index.js} +2 -18
- package/http-client/sauce/index.js.map +1 -0
- package/{dist/http-client → http-client}/types.d.ts +0 -0
- package/{dist/logger → http-client}/types.js +0 -0
- package/{dist/http-client → http-client}/types.js.map +0 -0
- package/http-client/utils.d.ts +9 -0
- package/http-client/utils.js +20 -0
- package/http-client/utils.js.map +1 -0
- package/{dist/http-server → http-server}/constants.d.ts +0 -0
- package/{dist/http-server → http-server}/constants.js +0 -0
- package/{dist/http-server → http-server}/constants.js.map +0 -0
- package/{dist/http-server → http-server}/handler/health-check.d.ts +0 -0
- package/{dist/http-server → http-server}/handler/health-check.js +0 -0
- package/{dist/http-server → http-server}/handler/health-check.js.map +0 -0
- package/{dist/http-server → http-server}/middleware/logging.d.ts +0 -0
- package/{dist/http-server → http-server}/middleware/logging.js +0 -0
- package/{dist/http-server → http-server}/middleware/logging.js.map +0 -0
- package/{dist/http-server → http-server}/middleware/metrics.d.ts +0 -0
- package/{dist/http-server → http-server}/middleware/metrics.js +0 -0
- package/{dist/http-server → http-server}/middleware/metrics.js.map +0 -0
- package/http-server/middleware/tracing.d.ts +14 -0
- package/{dist/http-server → http-server}/middleware/tracing.js +22 -3
- package/http-server/middleware/tracing.js.map +1 -0
- package/http-server/template/index.d.ts +1 -0
- package/http-server/template/index.js +36 -0
- package/http-server/template/index.js.map +1 -0
- package/{dist/http-server → http-server}/types.d.ts +8 -0
- package/{dist/http-server → http-server}/types.js +0 -0
- package/{dist/http-server → http-server}/types.js.map +0 -0
- package/{dist/http-server → http-server}/utils.d.ts +5 -1
- package/{dist/http-server → http-server}/utils.js +16 -4
- package/http-server/utils.js.map +1 -0
- package/{dist/logger → logger}/handler/console.d.ts +1 -1
- package/{dist/logger → logger}/handler/console.js +8 -1
- package/logger/handler/console.js.map +1 -0
- package/logger/handler/sentry.d.ts +8 -0
- package/{dist/logger → logger}/handler/sentry.js +13 -7
- package/logger/handler/sentry.js.map +1 -0
- package/logger/index.d.ts +2 -0
- package/logger/index.js +6 -0
- package/logger/index.js.map +1 -0
- package/{dist/logger/index.d.ts → logger/logger.d.ts} +0 -0
- package/{dist/logger/index.js → logger/logger.js} +1 -1
- package/logger/logger.js.map +1 -0
- package/{dist/logger → logger}/types.d.ts +0 -0
- package/{dist/http-client → logger}/types.js +0 -0
- package/{dist/logger → logger}/types.js.map +0 -0
- package/{dist/metrics → metrics}/constants.d.ts +0 -0
- package/{dist/metrics → metrics}/constants.js +0 -0
- package/{dist/metrics → metrics}/constants.js.map +0 -0
- package/{dist/metrics → metrics}/node.d.ts +0 -0
- package/{dist/metrics → metrics}/node.js +0 -0
- package/{dist/metrics → metrics}/node.js.map +0 -0
- package/package.json +8 -11
- package/preset/browser/index.d.ts +8 -0
- package/preset/browser/index.js +48 -0
- package/preset/browser/index.js.map +1 -0
- package/preset/node/index.d.ts +19 -0
- package/preset/node/index.js +127 -0
- package/preset/node/index.js.map +1 -0
- package/preset/node/response.d.ts +20 -0
- package/preset/node/response.js +82 -0
- package/preset/node/response.js.map +1 -0
- package/tokens.d.ts +48 -0
- package/tokens.js +50 -0
- package/tokens.js.map +1 -0
- package/tracing/index.d.ts +9 -0
- package/tracing/index.js +20 -0
- package/tracing/index.js.map +1 -0
- package/{dist/utils → utils}/browser/analytics/data-layer.d.ts +0 -0
- package/{dist/utils → utils}/browser/analytics/data-layer.js +0 -0
- package/{dist/utils → utils}/browser/analytics/data-layer.js.map +0 -0
- package/{dist/utils → utils}/browser/analytics/oko.d.ts +0 -0
- package/{dist/utils → utils}/browser/analytics/oko.js +0 -0
- package/{dist/utils → utils}/browser/analytics/oko.js.map +0 -0
- package/{dist/utils → utils}/browser/storage/index.d.ts +0 -0
- package/{dist/utils → utils}/browser/storage/index.js +0 -0
- package/{dist/utils → utils}/browser/storage/index.js.map +0 -0
- package/{dist/utils → utils}/number.d.ts +0 -0
- package/{dist/utils → utils}/number.js +0 -0
- package/{dist/utils → utils}/number.js.map +0 -0
- package/{dist/utils → utils}/react/error-handlers/index.d.ts +0 -0
- package/{dist/utils → utils}/react/error-handlers/index.js +1 -0
- package/utils/react/error-handlers/index.js.map +1 -0
- package/{dist/utils → utils}/redux/remote-data.d.ts +0 -0
- package/{dist/utils → utils}/redux/remote-data.js +0 -0
- package/{dist/utils → utils}/redux/remote-data.js.map +0 -0
- package/utils/redux-saga/index.d.ts +3 -0
- package/utils/redux-saga/index.js +8 -0
- package/utils/redux-saga/index.js.map +1 -0
- package/utils/redux-saga/middleware.d.ts +9 -0
- package/utils/redux-saga/middleware.js +87 -0
- package/utils/redux-saga/middleware.js.map +1 -0
- package/{dist/utils → utils}/redux-saga/take-chain.d.ts +0 -0
- package/{dist/utils → utils}/redux-saga/take-chain.js +0 -0
- package/{dist/utils → utils}/redux-saga/take-chain.js.map +0 -0
- package/utils/redux-saga/types.d.ts +6 -0
- package/{dist/error-tracker → utils/redux-saga}/types.js +0 -0
- package/{dist/error-tracker → utils/redux-saga}/types.js.map +1 -1
- package/utils/ssr/index.d.ts +30 -0
- package/utils/ssr/index.js +51 -0
- package/utils/ssr/index.js.map +1 -0
- package/utils/webpack/index.d.ts +23 -0
- package/utils/webpack/index.js +66 -0
- package/utils/webpack/index.js.map +1 -0
- package/{dist/utils → utils}/webpack/module-federation/index.d.ts +0 -0
- package/{dist/utils → utils}/webpack/module-federation/index.js +0 -0
- package/{dist/utils → utils}/webpack/module-federation/index.js.map +0 -0
- package/{dist/utils → utils}/webpack/module-federation/types.d.ts +0 -0
- package/{dist/container → utils/webpack/module-federation}/types.js +0 -0
- package/{dist/utils → utils}/webpack/module-federation/types.js.map +0 -0
- package/{dist/utils → utils}/webpack/module-federation/utils.d.ts +0 -0
- package/{dist/utils → utils}/webpack/module-federation/utils.js +0 -0
- package/{dist/utils → utils}/webpack/module-federation/utils.js.map +0 -0
- package/LICENSE +0 -201
- package/dist/cache/types.js +0 -3
- package/dist/config/browser.js +0 -13
- package/dist/config/browser.js.map +0 -1
- package/dist/config/index.js.map +0 -1
- package/dist/config/node.js.map +0 -1
- package/dist/config/types.js +0 -3
- package/dist/config/utils.d.ts +0 -5
- package/dist/config/utils.js +0 -12
- package/dist/config/utils.js.map +0 -1
- package/dist/container/application.d.ts +0 -25
- package/dist/container/application.js.map +0 -1
- package/dist/container/index.d.ts +0 -18
- package/dist/container/index.js +0 -74
- package/dist/container/index.js.map +0 -1
- package/dist/container/types.d.ts +0 -14
- package/dist/error-tracker/browser.d.ts +0 -8
- package/dist/error-tracker/browser.js +0 -40
- package/dist/error-tracker/browser.js.map +0 -1
- package/dist/error-tracker/node.d.ts +0 -8
- package/dist/error-tracker/node.js +0 -40
- package/dist/error-tracker/node.js.map +0 -1
- package/dist/error-tracker/types.d.ts +0 -18
- package/dist/error-tracker/utils.d.ts +0 -12
- package/dist/error-tracker/utils.js.map +0 -1
- package/dist/http-client/utils.js.map +0 -1
- package/dist/http-server/middleware/tracing.d.ts +0 -8
- package/dist/http-server/middleware/tracing.js.map +0 -1
- package/dist/http-server/utils.js.map +0 -1
- package/dist/logger/handler/console.js.map +0 -1
- package/dist/logger/handler/sentry.d.ts +0 -8
- package/dist/logger/handler/sentry.js.map +0 -1
- package/dist/logger/index.js.map +0 -1
- package/dist/preset/index.d.ts +0 -7
- package/dist/preset/index.js +0 -23
- package/dist/preset/index.js.map +0 -1
- package/dist/preset/node/index.d.ts +0 -15
- package/dist/preset/node/index.js +0 -90
- package/dist/preset/node/index.js.map +0 -1
- package/dist/preset/node/response.d.ts +0 -12
- package/dist/preset/node/response.js +0 -52
- package/dist/preset/node/response.js.map +0 -1
- package/dist/preset/types.d.ts +0 -7
- package/dist/saga-runner/index.d.ts +0 -8
- package/dist/saga-runner/index.js +0 -77
- package/dist/saga-runner/index.js.map +0 -1
- package/dist/saga-runner/types.d.ts +0 -10
- package/dist/saga-runner/types.js.map +0 -1
- package/dist/tokens.d.ts +0 -40
- package/dist/tokens.js +0 -43
- package/dist/tokens.js.map +0 -1
- package/dist/tracer/node.d.ts +0 -10
- package/dist/tracer/node.js +0 -38
- package/dist/tracer/node.js.map +0 -1
- package/dist/tracer/types.d.ts +0 -2
- package/dist/tracer/types.js.map +0 -1
- package/dist/utils/react/error-handlers/index.js.map +0 -1
- package/readme.md +0 -23
- package/src/cache/types.ts +0 -7
- package/src/config/browser.ts +0 -10
- package/src/config/index.ts +0 -18
- package/src/config/node.ts +0 -18
- package/src/config/types.ts +0 -9
- package/src/config/utils.ts +0 -7
- package/src/container/application.ts +0 -91
- package/src/container/index.ts +0 -79
- package/src/container/types.ts +0 -17
- package/src/error-tracker/browser.ts +0 -14
- package/src/error-tracker/node.ts +0 -14
- package/src/error-tracker/types.ts +0 -22
- package/src/error-tracker/utils.ts +0 -18
- package/src/http-client/middleware/cookie.ts +0 -73
- package/src/http-client/middleware/tracing.ts +0 -79
- package/src/http-client/types.ts +0 -8
- package/src/http-client/utils.ts +0 -76
- package/src/http-server/constants.ts +0 -4
- package/src/http-server/handler/health-check.ts +0 -13
- package/src/http-server/middleware/logging.ts +0 -34
- package/src/http-server/middleware/metrics.ts +0 -87
- package/src/http-server/middleware/tracing.ts +0 -35
- package/src/http-server/types.ts +0 -29
- package/src/http-server/utils.ts +0 -105
- package/src/logger/handler/console.ts +0 -35
- package/src/logger/handler/sentry.ts +0 -38
- package/src/logger/index.ts +0 -31
- package/src/logger/types.ts +0 -28
- package/src/metrics/constants.ts +0 -4
- package/src/metrics/node.ts +0 -54
- package/src/preset/index.ts +0 -24
- package/src/preset/node/index.ts +0 -101
- package/src/preset/node/response.ts +0 -57
- package/src/preset/types.ts +0 -9
- package/src/saga-runner/index.ts +0 -59
- package/src/saga-runner/types.ts +0 -13
- package/src/tokens.ts +0 -54
- package/src/tracer/node.ts +0 -40
- package/src/tracer/types.ts +0 -3
- package/src/utils/browser/analytics/__test__/data-layer.test.ts +0 -50
- package/src/utils/browser/analytics/__test__/oko.test.tsx +0 -143
- package/src/utils/browser/analytics/data-layer.ts +0 -12
- package/src/utils/browser/analytics/oko.ts +0 -44
- package/src/utils/browser/storage/index.ts +0 -75
- package/src/utils/number.ts +0 -8
- package/src/utils/react/error-handlers/__test__/__snapshots__/index.test.tsx.snap +0 -27
- package/src/utils/react/error-handlers/__test__/index.test.tsx +0 -64
- package/src/utils/react/error-handlers/index.tsx +0 -62
- package/src/utils/redux/__test__/remote-data.test.ts +0 -50
- package/src/utils/redux/remote-data.ts +0 -34
- package/src/utils/redux-saga/__test__/take-chain.test.ts +0 -141
- package/src/utils/redux-saga/take-chain.ts +0 -65
- package/src/utils/webpack/module-federation/__test__/index.test.ts +0 -246
- package/src/utils/webpack/module-federation/index.ts +0 -92
- package/src/utils/webpack/module-federation/types.ts +0 -44
- package/src/utils/webpack/module-federation/utils.ts +0 -43
|
@@ -1,13 +0,0 @@
|
|
|
1
|
-
import type { Handler } from 'express';
|
|
2
|
-
|
|
3
|
-
/**
|
|
4
|
-
* Обработчик, отвечающий данными о времени работы приложения.
|
|
5
|
-
* @return Обработчик http-запроса.
|
|
6
|
-
*/
|
|
7
|
-
export function healthCheck(): Handler {
|
|
8
|
-
const startTime = Date.now();
|
|
9
|
-
|
|
10
|
-
return (req, res) => {
|
|
11
|
-
res.json({ uptime: Date.now() - startTime });
|
|
12
|
-
};
|
|
13
|
-
}
|
|
@@ -1,34 +0,0 @@
|
|
|
1
|
-
import type { Handler } from 'express';
|
|
2
|
-
import type { BaseConfig } from '../../config/types';
|
|
3
|
-
import type { Logger, ConventionalFluentInfo } from '../../logger/types';
|
|
4
|
-
import { getXClientIp } from '../utils';
|
|
5
|
-
import { toMilliseconds } from '../../utils/number';
|
|
6
|
-
|
|
7
|
-
/**
|
|
8
|
-
* Возвращает новый middleware для логирования запросов.
|
|
9
|
-
* @param config Конфиг.
|
|
10
|
-
* @param logger Logger.
|
|
11
|
-
* @return Middleware.
|
|
12
|
-
*/
|
|
13
|
-
export function loggingMiddleware(config: BaseConfig, logger: Logger): Handler {
|
|
14
|
-
return function (req, res, next) {
|
|
15
|
-
const start = process.hrtime.bigint();
|
|
16
|
-
|
|
17
|
-
res.once('finish', () => {
|
|
18
|
-
const finish = process.hrtime.bigint();
|
|
19
|
-
|
|
20
|
-
const message: ConventionalFluentInfo = {
|
|
21
|
-
version: config.appVersion,
|
|
22
|
-
route: req.originalUrl,
|
|
23
|
-
method: req.method,
|
|
24
|
-
status: res.statusCode,
|
|
25
|
-
remote_ip: getXClientIp(req),
|
|
26
|
-
latency: toMilliseconds(finish - start),
|
|
27
|
-
};
|
|
28
|
-
|
|
29
|
-
logger.info(message);
|
|
30
|
-
});
|
|
31
|
-
|
|
32
|
-
next();
|
|
33
|
-
};
|
|
34
|
-
}
|
|
@@ -1,87 +0,0 @@
|
|
|
1
|
-
import type { Request, Response, Handler } from 'express';
|
|
2
|
-
import type { BaseConfig } from '../../config/types';
|
|
3
|
-
import * as PromClient from 'prom-client';
|
|
4
|
-
import { toMilliseconds } from '../../utils/number';
|
|
5
|
-
import { RESPONSE_EVENT } from '../constants';
|
|
6
|
-
import { ConventionalLabels } from '../../metrics/constants';
|
|
7
|
-
|
|
8
|
-
/**
|
|
9
|
-
* Возвращает новый middleware для формирования метрик входящего запроса.
|
|
10
|
-
* @param config Конфиг.
|
|
11
|
-
* @param metrics Метрики - счетчик запросов и гистограмма длительности ответа.
|
|
12
|
-
* @return Middleware.
|
|
13
|
-
*/
|
|
14
|
-
export function responseMetricsMiddleware(
|
|
15
|
-
config: BaseConfig,
|
|
16
|
-
metrics: {
|
|
17
|
-
counter: PromClient.Counter<typeof ConventionalLabels.HTTP_RESPONSE[number]>;
|
|
18
|
-
histogram: PromClient.Histogram<typeof ConventionalLabels.HTTP_RESPONSE[number]>;
|
|
19
|
-
},
|
|
20
|
-
): Handler {
|
|
21
|
-
// eslint-disable-next-line require-jsdoc, jsdoc/require-jsdoc
|
|
22
|
-
function resolveLabels(
|
|
23
|
-
req: Request,
|
|
24
|
-
res: Response,
|
|
25
|
-
): Record<typeof ConventionalLabels.HTTP_RESPONSE[number], string | number> {
|
|
26
|
-
return {
|
|
27
|
-
version: config.appVersion,
|
|
28
|
-
route: req.baseUrl + req.path,
|
|
29
|
-
code: res.statusCode,
|
|
30
|
-
method: req.method,
|
|
31
|
-
};
|
|
32
|
-
}
|
|
33
|
-
|
|
34
|
-
return (req, res, next) => {
|
|
35
|
-
const start = process.hrtime.bigint();
|
|
36
|
-
|
|
37
|
-
metrics.counter.inc(resolveLabels(req, res), 1);
|
|
38
|
-
|
|
39
|
-
res.once('finish', () => {
|
|
40
|
-
const finish = process.hrtime.bigint();
|
|
41
|
-
|
|
42
|
-
metrics.histogram.observe(resolveLabels(req, res), toMilliseconds(finish - start));
|
|
43
|
-
});
|
|
44
|
-
|
|
45
|
-
next();
|
|
46
|
-
};
|
|
47
|
-
}
|
|
48
|
-
|
|
49
|
-
/**
|
|
50
|
-
* Возвращает новый middleware для формирования метрик рендеринга верстки.
|
|
51
|
-
* @param config Конфиг.
|
|
52
|
-
* @param metrics Метрики - гистограмма длительности рендеринга.
|
|
53
|
-
* @return Middleware.
|
|
54
|
-
*/
|
|
55
|
-
export function renderMetricsMiddleware(
|
|
56
|
-
config: BaseConfig,
|
|
57
|
-
metrics: {
|
|
58
|
-
histogram: PromClient.Histogram<typeof ConventionalLabels.SSR[number]>;
|
|
59
|
-
},
|
|
60
|
-
): Handler {
|
|
61
|
-
return (req, res, next) => {
|
|
62
|
-
let start: bigint | undefined;
|
|
63
|
-
|
|
64
|
-
res.once(RESPONSE_EVENT.renderStart, () => {
|
|
65
|
-
start = process.hrtime.bigint();
|
|
66
|
-
});
|
|
67
|
-
|
|
68
|
-
res.once(RESPONSE_EVENT.renderFinish, () => {
|
|
69
|
-
if (typeof start !== 'bigint') {
|
|
70
|
-
throw Error('Looks like "render start" event not emitted');
|
|
71
|
-
}
|
|
72
|
-
|
|
73
|
-
const finish = process.hrtime.bigint();
|
|
74
|
-
|
|
75
|
-
metrics.histogram.observe(
|
|
76
|
-
{
|
|
77
|
-
version: config.appVersion,
|
|
78
|
-
method: req.method,
|
|
79
|
-
route: req.baseUrl + req.path,
|
|
80
|
-
},
|
|
81
|
-
toMilliseconds(finish - start),
|
|
82
|
-
);
|
|
83
|
-
});
|
|
84
|
-
|
|
85
|
-
next();
|
|
86
|
-
};
|
|
87
|
-
}
|
|
@@ -1,35 +0,0 @@
|
|
|
1
|
-
import { RESPONSE_EVENT } from '../constants';
|
|
2
|
-
import { propagation, ROOT_CONTEXT } from '@opentelemetry/api';
|
|
3
|
-
import type { Tracer } from '../../tracer/types';
|
|
4
|
-
import type { Handler } from 'express';
|
|
5
|
-
|
|
6
|
-
/**
|
|
7
|
-
* Возвращает новый middleware для трассировки стадий входящего запроса.
|
|
8
|
-
* @param tracer Tracer.
|
|
9
|
-
* @return Middleware.
|
|
10
|
-
*/
|
|
11
|
-
export function tracingMiddleware(tracer: Tracer): Handler {
|
|
12
|
-
return (req, res, next) => {
|
|
13
|
-
const rootContext = propagation.extract(ROOT_CONTEXT, req.headers);
|
|
14
|
-
const rootSpan = tracer.startSpan('response', undefined, rootContext);
|
|
15
|
-
|
|
16
|
-
res.locals.tracing = {
|
|
17
|
-
rootSpan,
|
|
18
|
-
rootContext,
|
|
19
|
-
};
|
|
20
|
-
|
|
21
|
-
res.once(RESPONSE_EVENT.renderStart, () => {
|
|
22
|
-
res.locals.tracing.renderSpan = tracer.startSpan('render', undefined, rootContext);
|
|
23
|
-
});
|
|
24
|
-
|
|
25
|
-
res.once(RESPONSE_EVENT.renderFinish, () => {
|
|
26
|
-
res.locals.tracing.renderSpan.end();
|
|
27
|
-
});
|
|
28
|
-
|
|
29
|
-
res.once('finish', () => {
|
|
30
|
-
rootSpan.end();
|
|
31
|
-
});
|
|
32
|
-
|
|
33
|
-
next();
|
|
34
|
-
};
|
|
35
|
-
}
|
package/src/http-server/types.ts
DELETED
|
@@ -1,29 +0,0 @@
|
|
|
1
|
-
import type { Request, Response, NextFunction, Handler, ErrorRequestHandler } from 'express';
|
|
2
|
-
|
|
3
|
-
export interface ResponseContext {
|
|
4
|
-
req: Request;
|
|
5
|
-
res: Response;
|
|
6
|
-
next: NextFunction;
|
|
7
|
-
}
|
|
8
|
-
|
|
9
|
-
export interface PageAssets {
|
|
10
|
-
js: string;
|
|
11
|
-
css: string;
|
|
12
|
-
}
|
|
13
|
-
|
|
14
|
-
export interface ConventionalJson {
|
|
15
|
-
markup: string;
|
|
16
|
-
bundle_js: string;
|
|
17
|
-
bundle_css: string;
|
|
18
|
-
critical_js?: string;
|
|
19
|
-
critical_css?: string;
|
|
20
|
-
meta?: any;
|
|
21
|
-
}
|
|
22
|
-
|
|
23
|
-
export interface DefaultMiddleware {
|
|
24
|
-
start: Handler[];
|
|
25
|
-
logging: Handler[];
|
|
26
|
-
tracing: Handler[];
|
|
27
|
-
metrics: Handler[];
|
|
28
|
-
finish: Array<Handler | ErrorRequestHandler>;
|
|
29
|
-
}
|
package/src/http-server/utils.ts
DELETED
|
@@ -1,105 +0,0 @@
|
|
|
1
|
-
import type { Request, Response } from 'express';
|
|
2
|
-
import type { ConventionalJson, PageAssets } from './types';
|
|
3
|
-
import { isIP } from 'net';
|
|
4
|
-
|
|
5
|
-
/**
|
|
6
|
-
* Определяет IP входящего запроса.
|
|
7
|
-
* @param req Входящий запрос.
|
|
8
|
-
* @return IP.
|
|
9
|
-
*/
|
|
10
|
-
export function getXClientIp(req: Request): string {
|
|
11
|
-
const headerValue =
|
|
12
|
-
req.get('x-client-ip') || req.get('x-forwarded-for') || req.socket.remoteAddress || '';
|
|
13
|
-
|
|
14
|
-
return isIP(headerValue) ? headerValue : '';
|
|
15
|
-
}
|
|
16
|
-
|
|
17
|
-
/**
|
|
18
|
-
* Определяет служебные заголовки по соглашению.
|
|
19
|
-
* @param req Входящий запрос.
|
|
20
|
-
* @return Служебные заголовки.
|
|
21
|
-
*/
|
|
22
|
-
export function getServiceHeaders(req: Request): Record<string, string | undefined> {
|
|
23
|
-
const result: Record<string, string | undefined> = {};
|
|
24
|
-
|
|
25
|
-
for (const [key] of Object.entries(req.headers)) {
|
|
26
|
-
if (key.toLowerCase().indexOf('simaland-') === 0) {
|
|
27
|
-
result[key] = req.header(key);
|
|
28
|
-
}
|
|
29
|
-
}
|
|
30
|
-
|
|
31
|
-
return result;
|
|
32
|
-
}
|
|
33
|
-
|
|
34
|
-
/* eslint-disable require-jsdoc, jsdoc/require-jsdoc */
|
|
35
|
-
export class PageResponse {
|
|
36
|
-
private type: 'html' | 'json';
|
|
37
|
-
private html: string;
|
|
38
|
-
private assets: PageAssets;
|
|
39
|
-
|
|
40
|
-
static create() {
|
|
41
|
-
return new PageResponse();
|
|
42
|
-
}
|
|
43
|
-
|
|
44
|
-
static defineFormat(req: Request): PageResponse['type'] {
|
|
45
|
-
let result: PageResponse['type'] = 'html';
|
|
46
|
-
|
|
47
|
-
if ((req.header('accept') || '').toLowerCase().includes('application/json')) {
|
|
48
|
-
result = 'json';
|
|
49
|
-
}
|
|
50
|
-
|
|
51
|
-
return result;
|
|
52
|
-
}
|
|
53
|
-
|
|
54
|
-
constructor() {
|
|
55
|
-
this.type = 'html';
|
|
56
|
-
this.html = '';
|
|
57
|
-
this.assets = { js: '', css: '' };
|
|
58
|
-
}
|
|
59
|
-
|
|
60
|
-
markup(html: string) {
|
|
61
|
-
this.html = html;
|
|
62
|
-
return this;
|
|
63
|
-
}
|
|
64
|
-
|
|
65
|
-
script(url: string) {
|
|
66
|
-
this.assets.js = url;
|
|
67
|
-
return this;
|
|
68
|
-
}
|
|
69
|
-
|
|
70
|
-
style(url: string) {
|
|
71
|
-
this.assets.css = url;
|
|
72
|
-
return this;
|
|
73
|
-
}
|
|
74
|
-
|
|
75
|
-
format(type: PageResponse['type']) {
|
|
76
|
-
this.type = type;
|
|
77
|
-
return this;
|
|
78
|
-
}
|
|
79
|
-
|
|
80
|
-
send(res: Response) {
|
|
81
|
-
switch (this.type) {
|
|
82
|
-
case 'json': {
|
|
83
|
-
const result: ConventionalJson = {
|
|
84
|
-
markup: this.html,
|
|
85
|
-
bundle_js: this.assets.js,
|
|
86
|
-
bundle_css: this.assets.css,
|
|
87
|
-
};
|
|
88
|
-
|
|
89
|
-
res.json(result);
|
|
90
|
-
break;
|
|
91
|
-
}
|
|
92
|
-
case 'html': {
|
|
93
|
-
res.setHeader('simaland-bundle-js', this.assets.js);
|
|
94
|
-
res.setHeader('simaland-bundle-css', this.assets.css);
|
|
95
|
-
|
|
96
|
-
// @todo dev-шаблон?
|
|
97
|
-
res.send(this.html);
|
|
98
|
-
break;
|
|
99
|
-
}
|
|
100
|
-
default:
|
|
101
|
-
throw Error(`Unknown response format ${String(this.type)}`);
|
|
102
|
-
}
|
|
103
|
-
}
|
|
104
|
-
}
|
|
105
|
-
/* eslint-enable require-jsdoc, jsdoc/require-jsdoc */
|
|
@@ -1,35 +0,0 @@
|
|
|
1
|
-
import type { BaseConfig } from '../../config/types';
|
|
2
|
-
import pino from 'pino';
|
|
3
|
-
import pinoPretty from 'pino-pretty';
|
|
4
|
-
import { LoggerEventHandler } from '../types';
|
|
5
|
-
|
|
6
|
-
/**
|
|
7
|
-
* Возвращает новый handler для logger'а для вывода событий в терминал.
|
|
8
|
-
* @param config Конфиг.
|
|
9
|
-
* @return Handler.
|
|
10
|
-
*/
|
|
11
|
-
export function createConsoleHandler(config: BaseConfig): LoggerEventHandler {
|
|
12
|
-
const isProd = config.env === 'production';
|
|
13
|
-
|
|
14
|
-
const logger = pino(
|
|
15
|
-
isProd
|
|
16
|
-
? {
|
|
17
|
-
formatters: {
|
|
18
|
-
// ВАЖНО: для Fluent необходимо наличие поля level: string
|
|
19
|
-
level: label => ({ level: label }),
|
|
20
|
-
},
|
|
21
|
-
}
|
|
22
|
-
: pinoPretty({ colorize: true }),
|
|
23
|
-
);
|
|
24
|
-
|
|
25
|
-
return function (event) {
|
|
26
|
-
switch (event.type) {
|
|
27
|
-
case 'info':
|
|
28
|
-
logger.info(event.data);
|
|
29
|
-
break;
|
|
30
|
-
case 'error':
|
|
31
|
-
logger.error(event.data);
|
|
32
|
-
break;
|
|
33
|
-
}
|
|
34
|
-
};
|
|
35
|
-
}
|
|
@@ -1,38 +0,0 @@
|
|
|
1
|
-
import type { SentryLib } from '../../error-tracker/types';
|
|
2
|
-
import type { LoggerEventHandler } from '../types';
|
|
3
|
-
import { SentryError } from '../../error-tracker/utils';
|
|
4
|
-
|
|
5
|
-
/**
|
|
6
|
-
* Возвращает новый handler для logger'а для отправки событий в Sentry.
|
|
7
|
-
* @param sentry Набор данных для работы с Sentry.
|
|
8
|
-
* @return Handler.
|
|
9
|
-
*/
|
|
10
|
-
export function createSentryHandler(sentry: SentryLib): LoggerEventHandler {
|
|
11
|
-
return event => {
|
|
12
|
-
if (event.type === 'error') {
|
|
13
|
-
const error = event.data;
|
|
14
|
-
|
|
15
|
-
if (error instanceof SentryError) {
|
|
16
|
-
const { level, context, extra } = error.data;
|
|
17
|
-
|
|
18
|
-
sentry.withScope(scope => {
|
|
19
|
-
if (level) {
|
|
20
|
-
scope.setLevel(level);
|
|
21
|
-
}
|
|
22
|
-
|
|
23
|
-
if (context) {
|
|
24
|
-
scope.setContext(context.key, context.data);
|
|
25
|
-
}
|
|
26
|
-
|
|
27
|
-
if (extra) {
|
|
28
|
-
scope.setExtra(extra.key, extra.data);
|
|
29
|
-
}
|
|
30
|
-
|
|
31
|
-
sentry.client.captureException(error);
|
|
32
|
-
});
|
|
33
|
-
} else {
|
|
34
|
-
sentry.client.captureException(error);
|
|
35
|
-
}
|
|
36
|
-
}
|
|
37
|
-
};
|
|
38
|
-
}
|
package/src/logger/index.ts
DELETED
|
@@ -1,31 +0,0 @@
|
|
|
1
|
-
import type { Logger, LoggerEvent, LoggerEventType, LoggerEventHandler } from './types';
|
|
2
|
-
|
|
3
|
-
/**
|
|
4
|
-
* Возвращает новый logger - объект для журналирования событий подобно console.
|
|
5
|
-
* @return Logger.
|
|
6
|
-
*/
|
|
7
|
-
export function createLogger(): Logger {
|
|
8
|
-
const handlers: LoggerEventHandler[] = [];
|
|
9
|
-
|
|
10
|
-
// eslint-disable-next-line require-jsdoc, jsdoc/require-jsdoc
|
|
11
|
-
function createMethod(type: LoggerEventType) {
|
|
12
|
-
return function (data: any) {
|
|
13
|
-
const event: LoggerEvent = { type, data };
|
|
14
|
-
for (const handler of handlers) {
|
|
15
|
-
handler(event);
|
|
16
|
-
}
|
|
17
|
-
};
|
|
18
|
-
}
|
|
19
|
-
|
|
20
|
-
return {
|
|
21
|
-
log: createMethod('log'),
|
|
22
|
-
info: createMethod('info'),
|
|
23
|
-
warn: createMethod('warn'),
|
|
24
|
-
error: createMethod('error'),
|
|
25
|
-
debug: createMethod('debug'),
|
|
26
|
-
|
|
27
|
-
subscribe: handler => {
|
|
28
|
-
handlers.push(handler);
|
|
29
|
-
},
|
|
30
|
-
};
|
|
31
|
-
}
|
package/src/logger/types.ts
DELETED
|
@@ -1,28 +0,0 @@
|
|
|
1
|
-
export type LoggerEventType = 'error' | 'log' | 'info' | 'warn' | 'debug';
|
|
2
|
-
|
|
3
|
-
export interface LoggerEvent {
|
|
4
|
-
type: LoggerEventType;
|
|
5
|
-
data: unknown;
|
|
6
|
-
}
|
|
7
|
-
|
|
8
|
-
export interface LoggerEventHandler {
|
|
9
|
-
(event: LoggerEvent): void;
|
|
10
|
-
}
|
|
11
|
-
|
|
12
|
-
export interface Logger {
|
|
13
|
-
error(data: any): void;
|
|
14
|
-
log(data: any): void;
|
|
15
|
-
info(data: any): void;
|
|
16
|
-
warn(data: any): void;
|
|
17
|
-
debug(data: any): void;
|
|
18
|
-
subscribe(handler: LoggerEventHandler): void;
|
|
19
|
-
}
|
|
20
|
-
|
|
21
|
-
export interface ConventionalFluentInfo {
|
|
22
|
-
version: string;
|
|
23
|
-
latency: number;
|
|
24
|
-
method: string;
|
|
25
|
-
remote_ip: string;
|
|
26
|
-
route: string;
|
|
27
|
-
status: number;
|
|
28
|
-
}
|
package/src/metrics/constants.ts
DELETED
package/src/metrics/node.ts
DELETED
|
@@ -1,54 +0,0 @@
|
|
|
1
|
-
import express, { Application } from 'express';
|
|
2
|
-
import * as PromClient from 'prom-client';
|
|
3
|
-
import { ConventionalLabels } from './constants';
|
|
4
|
-
|
|
5
|
-
export interface DefaultNodeMetrics {
|
|
6
|
-
requestCount: PromClient.Counter<typeof ConventionalLabels.HTTP_RESPONSE[number]>;
|
|
7
|
-
responseDuration: PromClient.Histogram<typeof ConventionalLabels.HTTP_RESPONSE[number]>;
|
|
8
|
-
renderDuration: PromClient.Histogram<typeof ConventionalLabels.SSR[number]>;
|
|
9
|
-
}
|
|
10
|
-
|
|
11
|
-
/**
|
|
12
|
-
* Возвращает новое express-приложение, настроенное для выдачи информации о метриках.
|
|
13
|
-
* @return Приложение.
|
|
14
|
-
*/
|
|
15
|
-
export function createMetricsHttpApp(): Application {
|
|
16
|
-
const app = express();
|
|
17
|
-
|
|
18
|
-
PromClient.collectDefaultMetrics();
|
|
19
|
-
|
|
20
|
-
app.get('/', async function (req, res) {
|
|
21
|
-
const metrics = await PromClient.register.metrics();
|
|
22
|
-
|
|
23
|
-
res.setHeader('Content-Type', PromClient.register.contentType);
|
|
24
|
-
res.send(metrics);
|
|
25
|
-
});
|
|
26
|
-
|
|
27
|
-
return app;
|
|
28
|
-
}
|
|
29
|
-
|
|
30
|
-
/**
|
|
31
|
-
* Возвращает набор готовых метрик по умолчанию для приложений.
|
|
32
|
-
* @return Набор метрик.
|
|
33
|
-
*/
|
|
34
|
-
export function createDefaultMetrics(): DefaultNodeMetrics {
|
|
35
|
-
return {
|
|
36
|
-
requestCount: new PromClient.Counter({
|
|
37
|
-
name: 'http_request_count',
|
|
38
|
-
help: 'Incoming HTTP request count',
|
|
39
|
-
labelNames: ConventionalLabels.HTTP_RESPONSE,
|
|
40
|
-
}),
|
|
41
|
-
responseDuration: new PromClient.Histogram({
|
|
42
|
-
name: 'http_response_duration_ms',
|
|
43
|
-
help: 'Duration of incoming HTTP requests in ms',
|
|
44
|
-
labelNames: ConventionalLabels.HTTP_RESPONSE,
|
|
45
|
-
buckets: [30, 100, 200, 500, 1000, 2500, 5000, 10000],
|
|
46
|
-
}),
|
|
47
|
-
renderDuration: new PromClient.Histogram({
|
|
48
|
-
name: 'render_duration_ms',
|
|
49
|
-
help: 'Duration of SSR ms',
|
|
50
|
-
labelNames: ConventionalLabels.SSR,
|
|
51
|
-
buckets: [0.1, 15, 50, 100, 250, 500, 800, 1500],
|
|
52
|
-
}),
|
|
53
|
-
};
|
|
54
|
-
}
|
package/src/preset/index.ts
DELETED
|
@@ -1,24 +0,0 @@
|
|
|
1
|
-
import type { Application } from '../container/application';
|
|
2
|
-
import type { Provider, Token } from '../container/types';
|
|
3
|
-
import type { Preset, PresetEntry } from './types';
|
|
4
|
-
|
|
5
|
-
/**
|
|
6
|
-
* Возвращает новый "preset" приложения - набор предустановленных компонентов которые можно переопределять.
|
|
7
|
-
* @param defaults Предустановленные зависимости.
|
|
8
|
-
* @return Preset.
|
|
9
|
-
*/
|
|
10
|
-
export function createPreset(defaults: PresetEntry[]): Preset {
|
|
11
|
-
const registry = new Map<Token<any>, Provider<any>>(defaults);
|
|
12
|
-
|
|
13
|
-
return {
|
|
14
|
-
override: <T>(token: Token<T>, provider: Provider<T>) => {
|
|
15
|
-
registry.set(token, provider);
|
|
16
|
-
},
|
|
17
|
-
|
|
18
|
-
apply: (container: Application) => {
|
|
19
|
-
for (const [token, provider] of registry) {
|
|
20
|
-
container.bind(token).toProvider(provider);
|
|
21
|
-
}
|
|
22
|
-
},
|
|
23
|
-
};
|
|
24
|
-
}
|
package/src/preset/node/index.ts
DELETED
|
@@ -1,101 +0,0 @@
|
|
|
1
|
-
/* eslint-disable require-jsdoc */
|
|
2
|
-
import type { Preset } from '../types';
|
|
3
|
-
import type { Provider } from '../../container/types';
|
|
4
|
-
import type { BaseConfig } from '../../config/types';
|
|
5
|
-
import type { Logger } from '../../logger/types';
|
|
6
|
-
import type { Tracer } from '@opentelemetry/api';
|
|
7
|
-
import type { DefaultMiddleware } from '../../http-server/types';
|
|
8
|
-
import { KnownToken as Token } from '../../tokens';
|
|
9
|
-
import { createPreset } from '..';
|
|
10
|
-
import { createConfigSource } from '../../config/node';
|
|
11
|
-
import { createBaseConfig } from '../../config';
|
|
12
|
-
import { createLogger } from '../../logger';
|
|
13
|
-
import { createTracer } from '../../tracer/node';
|
|
14
|
-
import { createConsoleHandler } from '../../logger/handler/console';
|
|
15
|
-
import { createSentryHandler } from '../../logger/handler/sentry';
|
|
16
|
-
import { createSentryLib } from '../../error-tracker/node';
|
|
17
|
-
import { loggingMiddleware } from '../../http-server/middleware/logging';
|
|
18
|
-
import { tracingMiddleware } from '../../http-server/middleware/tracing';
|
|
19
|
-
import {
|
|
20
|
-
renderMetricsMiddleware,
|
|
21
|
-
responseMetricsMiddleware,
|
|
22
|
-
} from '../../http-server/middleware/metrics';
|
|
23
|
-
import { createDefaultMetrics, createMetricsHttpApp } from '../../metrics/node';
|
|
24
|
-
import { JaegerExporter } from '@opentelemetry/exporter-jaeger';
|
|
25
|
-
import { create } from 'middleware-axios';
|
|
26
|
-
import Express from 'express';
|
|
27
|
-
import { Handlers } from '@sentry/node';
|
|
28
|
-
|
|
29
|
-
/**
|
|
30
|
-
* Возвращает preset с зависимостями по умолчанию для frontend-микросервисов на Node.js.
|
|
31
|
-
* @return Preset.
|
|
32
|
-
*/
|
|
33
|
-
export function PresetNode(): Preset {
|
|
34
|
-
return createPreset([
|
|
35
|
-
[Token.Config.source, createConfigSource],
|
|
36
|
-
[Token.Config.base, provideBaseConfig],
|
|
37
|
-
[Token.logger, provideLogger],
|
|
38
|
-
[Token.tracer, provideTracer],
|
|
39
|
-
[Token.Http.Client.factory, () => create],
|
|
40
|
-
[Token.Http.Server.factory, () => Express],
|
|
41
|
-
[Token.Http.Server.Defaults.middleware, provideDefaultMiddleware],
|
|
42
|
-
[Token.Metrics.httpApp, createMetricsHttpApp],
|
|
43
|
-
]);
|
|
44
|
-
}
|
|
45
|
-
|
|
46
|
-
export const provideBaseConfig: Provider<BaseConfig> = resolve => {
|
|
47
|
-
const source = resolve(Token.Config.source);
|
|
48
|
-
|
|
49
|
-
return createBaseConfig(source);
|
|
50
|
-
};
|
|
51
|
-
|
|
52
|
-
export const provideLogger: Provider<Logger> = resolve => {
|
|
53
|
-
const source = resolve(Token.Config.source);
|
|
54
|
-
const config = resolve(Token.Config.base);
|
|
55
|
-
|
|
56
|
-
const sentry = createSentryLib({
|
|
57
|
-
dsn: source.get('SENTRY_DSN'),
|
|
58
|
-
release: source.get('SENTRY_RELEASE'),
|
|
59
|
-
environment: source.get('SENTRY_ENVIRONMENT'),
|
|
60
|
-
});
|
|
61
|
-
|
|
62
|
-
const logger = createLogger();
|
|
63
|
-
logger.subscribe(createConsoleHandler(config));
|
|
64
|
-
logger.subscribe(createSentryHandler(sentry));
|
|
65
|
-
|
|
66
|
-
return logger;
|
|
67
|
-
};
|
|
68
|
-
|
|
69
|
-
export const provideTracer: Provider<Tracer> = resolve => {
|
|
70
|
-
const source = resolve(Token.Config.source);
|
|
71
|
-
|
|
72
|
-
const exporter = new JaegerExporter({
|
|
73
|
-
endpoint: source.require('JAEGER_ENDPOINT'),
|
|
74
|
-
});
|
|
75
|
-
|
|
76
|
-
return createTracer(resolve(Token.Config.base), exporter);
|
|
77
|
-
};
|
|
78
|
-
|
|
79
|
-
export const provideDefaultMiddleware: Provider<DefaultMiddleware> = resolve => {
|
|
80
|
-
const config = resolve(Token.Config.base);
|
|
81
|
-
const logger = resolve(Token.logger);
|
|
82
|
-
const tracer = resolve(Token.tracer);
|
|
83
|
-
|
|
84
|
-
const metrics = createDefaultMetrics();
|
|
85
|
-
|
|
86
|
-
return {
|
|
87
|
-
start: [Handlers.requestHandler()],
|
|
88
|
-
logging: [loggingMiddleware(config, logger)],
|
|
89
|
-
tracing: [tracingMiddleware(tracer)],
|
|
90
|
-
metrics: [
|
|
91
|
-
responseMetricsMiddleware(config, {
|
|
92
|
-
counter: metrics.requestCount,
|
|
93
|
-
histogram: metrics.responseDuration,
|
|
94
|
-
}),
|
|
95
|
-
renderMetricsMiddleware(config, {
|
|
96
|
-
histogram: metrics.renderDuration,
|
|
97
|
-
}),
|
|
98
|
-
],
|
|
99
|
-
finish: [Handlers.errorHandler()],
|
|
100
|
-
};
|
|
101
|
-
};
|
|
@@ -1,57 +0,0 @@
|
|
|
1
|
-
/* eslint-disable require-jsdoc */
|
|
2
|
-
import type { Preset } from '../types';
|
|
3
|
-
import type { Provider } from '../../container/types';
|
|
4
|
-
import type { SagaRunner } from '../../saga-runner/types';
|
|
5
|
-
import { KnownToken } from '../../tokens';
|
|
6
|
-
import { createPreset } from '..';
|
|
7
|
-
import { renderToString } from 'react-dom/server';
|
|
8
|
-
import { createSagaRunner } from '../../saga-runner';
|
|
9
|
-
import { RESPONSE_EVENT } from '../../http-server/constants';
|
|
10
|
-
import { PageResponse } from '../../http-server/utils';
|
|
11
|
-
|
|
12
|
-
/**
|
|
13
|
-
* Возвращает preset с зависимостями по умолчанию для работы в рамках ответа на http-запрос.
|
|
14
|
-
* @return Preset.
|
|
15
|
-
*/
|
|
16
|
-
export function PresetResponse(): Preset {
|
|
17
|
-
return createPreset([
|
|
18
|
-
[KnownToken.Response.sagaRunner, provideSagaRunner],
|
|
19
|
-
[KnownToken.Response.render, provideRender],
|
|
20
|
-
[KnownToken.Response.main, provideMain],
|
|
21
|
-
]);
|
|
22
|
-
}
|
|
23
|
-
|
|
24
|
-
export const provideSagaRunner: Provider<SagaRunner> = resolve => {
|
|
25
|
-
const logger = resolve(KnownToken.logger);
|
|
26
|
-
return createSagaRunner(logger);
|
|
27
|
-
};
|
|
28
|
-
|
|
29
|
-
export const provideRender: Provider<(el: JSX.Element) => string | Promise<string>> = resolve => {
|
|
30
|
-
const { res } = resolve(KnownToken.Response.context);
|
|
31
|
-
|
|
32
|
-
return function render(element: JSX.Element): string {
|
|
33
|
-
res.emit(RESPONSE_EVENT.renderStart);
|
|
34
|
-
|
|
35
|
-
const result = renderToString(element);
|
|
36
|
-
|
|
37
|
-
res.emit(RESPONSE_EVENT.renderFinish);
|
|
38
|
-
|
|
39
|
-
return result;
|
|
40
|
-
};
|
|
41
|
-
};
|
|
42
|
-
|
|
43
|
-
export const provideMain: Provider<() => void> = resolve => {
|
|
44
|
-
const context = resolve(KnownToken.Response.context);
|
|
45
|
-
const assets = resolve(KnownToken.Response.assets);
|
|
46
|
-
const prepare = resolve(KnownToken.Response.prepare);
|
|
47
|
-
const render = resolve(KnownToken.Response.render);
|
|
48
|
-
|
|
49
|
-
return async function main() {
|
|
50
|
-
PageResponse.create()
|
|
51
|
-
.markup(await render(await prepare()))
|
|
52
|
-
.script(assets.js)
|
|
53
|
-
.style(assets.css)
|
|
54
|
-
.format(PageResponse.defineFormat(context.req))
|
|
55
|
-
.send(context.res);
|
|
56
|
-
};
|
|
57
|
-
};
|