@sima-land/isomorph 11.0.0-alpha.0 → 11.0.0-alpha.1
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 → config}/browser.d.ts +0 -0
- package/{dist/config → config}/browser.js +0 -0
- package/{dist/config → config}/browser.js.map +0 -0
- package/{dist/config → config}/index.d.ts +0 -0
- package/{dist/config → config}/index.js +0 -0
- package/{dist/config → config}/index.js.map +0 -0
- package/{dist/config → config}/node.d.ts +0 -0
- package/{dist/config → config}/node.js +0 -0
- package/{dist/config → config}/node.js.map +0 -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/{dist/config → config}/utils.d.ts +0 -0
- package/{dist/config → config}/utils.js +0 -0
- package/{dist/config → config}/utils.js.map +0 -0
- package/{dist/container → container}/application.d.ts +0 -0
- package/{dist/container → container}/application.js +0 -0
- package/{dist/container → container}/application.js.map +0 -0
- package/{dist/container → container}/index.d.ts +0 -0
- package/{dist/container → container}/index.js +0 -0
- package/{dist/container → container}/index.js.map +0 -0
- package/{dist/container → container}/types.d.ts +0 -0
- package/{dist/saga-runner → container}/types.js +0 -0
- package/{dist/container → container}/types.js.map +0 -0
- package/{dist/error-tracker → error-tracker}/browser.d.ts +0 -0
- package/{dist/error-tracker → error-tracker}/browser.js +0 -0
- package/{dist/error-tracker → error-tracker}/browser.js.map +0 -0
- package/{dist/error-tracker → error-tracker}/node.d.ts +0 -0
- package/{dist/error-tracker → error-tracker}/node.js +0 -0
- package/{dist/error-tracker → error-tracker}/node.js.map +0 -0
- package/{dist/error-tracker → error-tracker}/types.d.ts +0 -0
- package/{dist/preset → error-tracker}/types.js +0 -0
- package/{dist/error-tracker → error-tracker}/types.js.map +0 -0
- package/{dist/error-tracker → error-tracker}/utils.d.ts +0 -0
- package/{dist/error-tracker → error-tracker}/utils.js +0 -0
- package/{dist/error-tracker → error-tracker}/utils.js.map +0 -0
- 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/{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 → 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/{dist/http-client → http-client}/utils.d.ts +0 -0
- package/{dist/http-client → http-client}/utils.js +0 -0
- package/{dist/http-client → http-client}/utils.js.map +0 -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/{dist/http-server → http-server}/middleware/tracing.d.ts +0 -0
- package/{dist/http-server → http-server}/middleware/tracing.js +0 -0
- package/{dist/http-server → http-server}/middleware/tracing.js.map +0 -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 +0 -0
- package/{dist/logger → logger}/handler/console.js +0 -0
- package/{dist/logger → logger}/handler/console.js.map +0 -0
- package/{dist/logger → logger}/handler/sentry.d.ts +0 -0
- package/{dist/logger → logger}/handler/sentry.js +0 -0
- package/{dist/logger → logger}/handler/sentry.js.map +0 -0
- package/{dist/logger → logger}/index.d.ts +0 -0
- package/{dist/logger → logger}/index.js +0 -0
- package/{dist/logger → logger}/index.js.map +0 -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 +5 -10
- package/{dist/preset → preset}/index.d.ts +0 -0
- package/{dist/preset → preset}/index.js +5 -3
- package/preset/index.js.map +1 -0
- package/{dist/preset → preset}/node/index.d.ts +0 -0
- package/{dist/preset → preset}/node/index.js +0 -0
- package/{dist/preset → preset}/node/index.js.map +0 -0
- package/{dist/preset → preset}/node/response.d.ts +6 -1
- package/{dist/preset → preset}/node/response.js +28 -2
- package/preset/node/response.js.map +1 -0
- package/{dist/preset → preset}/types.d.ts +2 -2
- package/{dist/error-tracker → preset}/types.js +0 -0
- package/{dist/preset → preset}/types.js.map +0 -0
- package/{dist/saga-runner → saga-runner}/index.d.ts +0 -0
- package/{dist/saga-runner → saga-runner}/index.js +3 -1
- package/saga-runner/index.js.map +1 -0
- package/{dist/saga-runner → saga-runner}/types.d.ts +0 -0
- package/{dist/container → saga-runner}/types.js +0 -0
- package/{dist/saga-runner → saga-runner}/types.js.map +0 -0
- package/{dist/tokens.d.ts → tokens.d.ts} +2 -1
- package/{dist/tokens.js → tokens.js} +1 -0
- package/{dist/tokens.js.map → tokens.js.map} +1 -1
- package/{dist/tracer → tracer}/node.d.ts +0 -0
- package/{dist/tracer → tracer}/node.js +0 -0
- package/{dist/tracer → tracer}/node.js.map +0 -0
- package/{dist/tracer → tracer}/types.d.ts +0 -0
- package/{dist/config → tracer}/types.js +0 -0
- package/{dist/tracer → tracer}/types.js.map +0 -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 +0 -0
- package/{dist/utils → utils}/react/error-handlers/index.js.map +0 -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/{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/{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/cache → 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/http-server/utils.js.map +0 -1
- package/dist/preset/index.js.map +0 -1
- package/dist/preset/node/response.js.map +0 -1
- package/dist/saga-runner/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
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
|
-
};
|
package/src/preset/types.ts
DELETED
|
@@ -1,9 +0,0 @@
|
|
|
1
|
-
import type { Application } from '../container/application';
|
|
2
|
-
import type { Token, Provider } from '../container/types';
|
|
3
|
-
|
|
4
|
-
export type PresetEntry<T = any> = [Token<T>, Provider<T>];
|
|
5
|
-
|
|
6
|
-
export interface Preset {
|
|
7
|
-
override: <T>(token: Token<T>, provider: Provider<T>) => void;
|
|
8
|
-
apply: (application: Application) => void;
|
|
9
|
-
}
|
package/src/saga-runner/index.ts
DELETED
|
@@ -1,59 +0,0 @@
|
|
|
1
|
-
import type { Store } from '@reduxjs/toolkit';
|
|
2
|
-
import type { Logger } from '../logger/types';
|
|
3
|
-
import type { SagaRunner } from './types';
|
|
4
|
-
import createSagaMiddleware, { Saga, END } from 'redux-saga';
|
|
5
|
-
import { SentryError } from '../error-tracker/utils';
|
|
6
|
-
|
|
7
|
-
/**
|
|
8
|
-
* Возвращает новый runner для redux-saga.
|
|
9
|
-
* @param logger Logger.
|
|
10
|
-
* @return Runner.
|
|
11
|
-
*/
|
|
12
|
-
export function createSagaRunner(logger: Logger): SagaRunner {
|
|
13
|
-
const middleware = createSagaMiddleware({
|
|
14
|
-
onError: (error, { sagaStack }) => {
|
|
15
|
-
logger.error(
|
|
16
|
-
new SentryError(error.message, {
|
|
17
|
-
extra: { key: 'Saga stack', data: sagaStack },
|
|
18
|
-
}),
|
|
19
|
-
);
|
|
20
|
-
},
|
|
21
|
-
});
|
|
22
|
-
|
|
23
|
-
return {
|
|
24
|
-
middleware,
|
|
25
|
-
|
|
26
|
-
// eslint-disable-next-line require-jsdoc, jsdoc/require-jsdoc
|
|
27
|
-
prepare(store: Store, { timeout }: { timeout?: number } = {}) {
|
|
28
|
-
return {
|
|
29
|
-
// eslint-disable-next-line require-jsdoc, jsdoc/require-jsdoc
|
|
30
|
-
async run<S extends Saga>(saga: S, ...args: Parameters<S>) {
|
|
31
|
-
let ready = false;
|
|
32
|
-
|
|
33
|
-
await Promise.race([
|
|
34
|
-
// ждем пока сага выполнится
|
|
35
|
-
middleware
|
|
36
|
-
.run(saga, ...args)
|
|
37
|
-
.toPromise()
|
|
38
|
-
.then(() => {
|
|
39
|
-
ready = true;
|
|
40
|
-
}),
|
|
41
|
-
|
|
42
|
-
// если сага не выполнилась за положенное время - прерываем
|
|
43
|
-
typeof timeout === 'number' &&
|
|
44
|
-
Number.isFinite(timeout) &&
|
|
45
|
-
new Promise<void>(resolve => {
|
|
46
|
-
setTimeout(() => {
|
|
47
|
-
if (!ready) {
|
|
48
|
-
logger.error(Error('Сага прервана по таймауту'));
|
|
49
|
-
store.dispatch(END);
|
|
50
|
-
}
|
|
51
|
-
resolve();
|
|
52
|
-
}, timeout);
|
|
53
|
-
}),
|
|
54
|
-
]);
|
|
55
|
-
},
|
|
56
|
-
};
|
|
57
|
-
},
|
|
58
|
-
};
|
|
59
|
-
}
|
package/src/saga-runner/types.ts
DELETED
|
@@ -1,13 +0,0 @@
|
|
|
1
|
-
import type { Saga, SagaMiddleware } from 'redux-saga';
|
|
2
|
-
import type { Store } from '@reduxjs/toolkit';
|
|
3
|
-
|
|
4
|
-
export interface SagaRunner {
|
|
5
|
-
middleware: SagaMiddleware<any>;
|
|
6
|
-
|
|
7
|
-
prepare: (
|
|
8
|
-
store: Store,
|
|
9
|
-
options?: { timeout?: number },
|
|
10
|
-
) => {
|
|
11
|
-
run: <S extends Saga>(saga: S, ...args: Parameters<S>) => Promise<void>;
|
|
12
|
-
};
|
|
13
|
-
}
|
package/src/tokens.ts
DELETED
|
@@ -1,54 +0,0 @@
|
|
|
1
|
-
import { createToken } from './container';
|
|
2
|
-
import type { Application } from 'express';
|
|
3
|
-
import type { DefaultMiddleware, PageAssets, ResponseContext } from './http-server/types';
|
|
4
|
-
import type { SagaRunner } from './saga-runner/types';
|
|
5
|
-
import type { Logger } from './logger/types';
|
|
6
|
-
import type { HttpClientFactory } from './http-client/types';
|
|
7
|
-
import type { ConfigSource, BaseConfig } from './config/types';
|
|
8
|
-
import type { Tracer } from './tracer/types';
|
|
9
|
-
import type { Cache } from './cache/types';
|
|
10
|
-
|
|
11
|
-
export const KnownToken = {
|
|
12
|
-
// config
|
|
13
|
-
Config: {
|
|
14
|
-
source: createToken<ConfigSource>('config.source'),
|
|
15
|
-
base: createToken<BaseConfig>('config.base'),
|
|
16
|
-
},
|
|
17
|
-
|
|
18
|
-
// cache
|
|
19
|
-
cache: createToken<Cache>('cache'),
|
|
20
|
-
|
|
21
|
-
// logging
|
|
22
|
-
logger: createToken<Logger>('logger'),
|
|
23
|
-
|
|
24
|
-
// tracing
|
|
25
|
-
tracer: createToken<Tracer>('tracer'),
|
|
26
|
-
|
|
27
|
-
// metrics
|
|
28
|
-
Metrics: {
|
|
29
|
-
httpApp: createToken<Application>('metrics.http-app'),
|
|
30
|
-
},
|
|
31
|
-
|
|
32
|
-
// http
|
|
33
|
-
Http: {
|
|
34
|
-
Client: {
|
|
35
|
-
factory: createToken<HttpClientFactory>('http.client.factory'),
|
|
36
|
-
},
|
|
37
|
-
Server: {
|
|
38
|
-
factory: createToken<() => Application>('http.server.factory'),
|
|
39
|
-
Defaults: {
|
|
40
|
-
middleware: createToken<DefaultMiddleware>('http.server.defaults.middleware'),
|
|
41
|
-
},
|
|
42
|
-
},
|
|
43
|
-
},
|
|
44
|
-
|
|
45
|
-
// scope: page response
|
|
46
|
-
Response: {
|
|
47
|
-
context: createToken<ResponseContext>('response/context'),
|
|
48
|
-
assets: createToken<PageAssets>('response/assets'),
|
|
49
|
-
prepare: createToken<() => JSX.Element | Promise<JSX.Element>>('response/prepare'),
|
|
50
|
-
render: createToken<(element: JSX.Element) => string | Promise<string>>('response/render'),
|
|
51
|
-
main: createToken<() => void>('response/main'),
|
|
52
|
-
sagaRunner: createToken<SagaRunner>('response/saga-runner'),
|
|
53
|
-
},
|
|
54
|
-
} as const;
|
package/src/tracer/node.ts
DELETED
|
@@ -1,40 +0,0 @@
|
|
|
1
|
-
import type { Tracer } from './types';
|
|
2
|
-
import type { BaseConfig } from '../config/types';
|
|
3
|
-
import { NodeTracerProvider } from '@opentelemetry/sdk-trace-node';
|
|
4
|
-
import { BatchSpanProcessor, SpanExporter } from '@opentelemetry/tracing';
|
|
5
|
-
import { SemanticResourceAttributes } from '@opentelemetry/semantic-conventions';
|
|
6
|
-
import { registerInstrumentations } from '@opentelemetry/instrumentation';
|
|
7
|
-
import { ExpressInstrumentation } from '@opentelemetry/instrumentation-express';
|
|
8
|
-
import { HttpInstrumentation } from '@opentelemetry/instrumentation-http';
|
|
9
|
-
import { Resource } from '@opentelemetry/resources';
|
|
10
|
-
import { JaegerPropagator } from '@opentelemetry/propagator-jaeger';
|
|
11
|
-
|
|
12
|
-
/**
|
|
13
|
-
* Возвращает новый tracer - объект для трассировки стадий различных процессов.
|
|
14
|
-
* @param config Конфиг.
|
|
15
|
-
* @param exporter Экспортер данных трассировки.
|
|
16
|
-
* @return Tracer.
|
|
17
|
-
*/
|
|
18
|
-
export function createTracer(config: BaseConfig, exporter: SpanExporter): Tracer {
|
|
19
|
-
// @todo доделать по инструкции: https://selvaganesh93.medium.com/tracing-node-js-application-with-opentelemetry-jaeger-ui-9523c0ac8453
|
|
20
|
-
const provider = new NodeTracerProvider({
|
|
21
|
-
resource: new Resource({
|
|
22
|
-
[SemanticResourceAttributes.SERVICE_NAME]: config.appName,
|
|
23
|
-
[SemanticResourceAttributes.SERVICE_VERSION]: config.appVersion,
|
|
24
|
-
[SemanticResourceAttributes.DEPLOYMENT_ENVIRONMENT]: config.env,
|
|
25
|
-
}),
|
|
26
|
-
});
|
|
27
|
-
|
|
28
|
-
// @todo выяснить, почему не сходятся типы и приходится оставлять as any
|
|
29
|
-
provider.addSpanProcessor(new BatchSpanProcessor(exporter) as any);
|
|
30
|
-
|
|
31
|
-
provider.register({
|
|
32
|
-
propagator: new JaegerPropagator(),
|
|
33
|
-
});
|
|
34
|
-
|
|
35
|
-
registerInstrumentations({
|
|
36
|
-
instrumentations: [new ExpressInstrumentation(), new HttpInstrumentation()],
|
|
37
|
-
});
|
|
38
|
-
|
|
39
|
-
return provider.getTracer(config.appName, config.appVersion);
|
|
40
|
-
}
|
package/src/tracer/types.ts
DELETED
|
@@ -1,50 +0,0 @@
|
|
|
1
|
-
import { dataLayerPush } from '../data-layer';
|
|
2
|
-
|
|
3
|
-
describe('dataLayerPush', () => {
|
|
4
|
-
beforeAll(() => {
|
|
5
|
-
(window as any).dataLayer = {
|
|
6
|
-
checkContext: () => 123,
|
|
7
|
-
|
|
8
|
-
push: jest.fn(function (this: any, data) {
|
|
9
|
-
// имитируем реальную работу window.dataLayer.push: в процессе удаляет data.n
|
|
10
|
-
delete data.n;
|
|
11
|
-
|
|
12
|
-
// имитируем реальную работу window.dataLayer.push: в процессе вызывает другие методы с this
|
|
13
|
-
this.checkContext();
|
|
14
|
-
}),
|
|
15
|
-
};
|
|
16
|
-
});
|
|
17
|
-
|
|
18
|
-
afterAll(() => {
|
|
19
|
-
delete (window as any).dataLayer;
|
|
20
|
-
});
|
|
21
|
-
|
|
22
|
-
it('should handle window.dataLayer.push mutates object argument', () => {
|
|
23
|
-
const testData = {
|
|
24
|
-
n: 'test-event',
|
|
25
|
-
prop1: 1,
|
|
26
|
-
prop2: 2,
|
|
27
|
-
};
|
|
28
|
-
|
|
29
|
-
expect((window as any).dataLayer.push).toBeCalledTimes(0);
|
|
30
|
-
|
|
31
|
-
dataLayerPush(testData);
|
|
32
|
-
|
|
33
|
-
expect((window as any).dataLayer.push).toBeCalledTimes(1);
|
|
34
|
-
expect((window as any).dataLayer.push.mock.calls[0][0]).toEqual({
|
|
35
|
-
prop1: 1,
|
|
36
|
-
prop2: 2,
|
|
37
|
-
});
|
|
38
|
-
expect(testData).toEqual({
|
|
39
|
-
n: 'test-event',
|
|
40
|
-
prop1: 1,
|
|
41
|
-
prop2: 2,
|
|
42
|
-
});
|
|
43
|
-
});
|
|
44
|
-
|
|
45
|
-
it('should handle window.dataLayer.push absence', () => {
|
|
46
|
-
delete (window as any).dataLayer;
|
|
47
|
-
|
|
48
|
-
expect(() => dataLayerPush({ n: 'test-123' })).not.toThrow();
|
|
49
|
-
});
|
|
50
|
-
});
|
|
@@ -1,143 +0,0 @@
|
|
|
1
|
-
import React, { createElement } from 'react';
|
|
2
|
-
import { render } from 'react-dom';
|
|
3
|
-
import { act, Simulate } from 'react-dom/test-utils';
|
|
4
|
-
import { okoPush, useOkoPush } from '../oko';
|
|
5
|
-
|
|
6
|
-
describe('useOkoPush', () => {
|
|
7
|
-
const TestComponent = ({ prop }: any) => {
|
|
8
|
-
const fn = useOkoPush({
|
|
9
|
-
n: 'test-event',
|
|
10
|
-
prop,
|
|
11
|
-
});
|
|
12
|
-
|
|
13
|
-
return createElement('div', { 'data-testid': 'test-block', onClick: fn });
|
|
14
|
-
};
|
|
15
|
-
|
|
16
|
-
beforeAll(() => {
|
|
17
|
-
(window as any).oko = {
|
|
18
|
-
push: jest.fn(),
|
|
19
|
-
};
|
|
20
|
-
});
|
|
21
|
-
|
|
22
|
-
afterAll(() => {
|
|
23
|
-
delete (window as any).oko;
|
|
24
|
-
});
|
|
25
|
-
|
|
26
|
-
it('should call', () => {
|
|
27
|
-
const container = document.createElement('div');
|
|
28
|
-
|
|
29
|
-
document.body.append(container);
|
|
30
|
-
|
|
31
|
-
render(<TestComponent prop={123} />, container);
|
|
32
|
-
|
|
33
|
-
expect((window as any).oko.push).toHaveBeenCalledTimes(0);
|
|
34
|
-
|
|
35
|
-
act(() => {
|
|
36
|
-
Simulate.click(container.querySelector('[data-testid="test-block"]') as HTMLElement);
|
|
37
|
-
});
|
|
38
|
-
|
|
39
|
-
expect((window as any).oko.push).toHaveBeenCalledTimes(1);
|
|
40
|
-
expect((window as any).oko.push).toHaveBeenCalledWith({
|
|
41
|
-
n: 'test-event',
|
|
42
|
-
prop: 123,
|
|
43
|
-
});
|
|
44
|
-
});
|
|
45
|
-
|
|
46
|
-
it('should throw error', async () => {
|
|
47
|
-
const container = document.createElement('div');
|
|
48
|
-
|
|
49
|
-
document.body.append(container);
|
|
50
|
-
|
|
51
|
-
render(<TestComponent prop={1} />, container);
|
|
52
|
-
|
|
53
|
-
const renderWithError = () => {
|
|
54
|
-
render(<TestComponent prop={2} />, container);
|
|
55
|
-
};
|
|
56
|
-
|
|
57
|
-
expect(renderWithError).toThrow(
|
|
58
|
-
Error(
|
|
59
|
-
[
|
|
60
|
-
'useAnalytics: Данные для аналитики изменились.',
|
|
61
|
-
'Если необходимо использовать динамические данные, вынесите логику из React-компонента.',
|
|
62
|
-
].join('\n'),
|
|
63
|
-
),
|
|
64
|
-
);
|
|
65
|
-
});
|
|
66
|
-
|
|
67
|
-
it('should do not throw for complex object structure', () => {
|
|
68
|
-
const ComplexTest = () => {
|
|
69
|
-
const fn = useOkoPush({
|
|
70
|
-
n: 'custom',
|
|
71
|
-
category: 'balance_goods',
|
|
72
|
-
custom_str: ['minus'],
|
|
73
|
-
});
|
|
74
|
-
|
|
75
|
-
return <div data-testid='test-block' onClick={fn} />;
|
|
76
|
-
};
|
|
77
|
-
|
|
78
|
-
const container = document.createElement('div');
|
|
79
|
-
|
|
80
|
-
document.body.append(container);
|
|
81
|
-
|
|
82
|
-
act(() => {
|
|
83
|
-
render(<ComplexTest />, container);
|
|
84
|
-
});
|
|
85
|
-
|
|
86
|
-
const secondRender = () => {
|
|
87
|
-
act(() => {
|
|
88
|
-
render(<ComplexTest />, container);
|
|
89
|
-
});
|
|
90
|
-
};
|
|
91
|
-
|
|
92
|
-
expect(secondRender).not.toThrow();
|
|
93
|
-
});
|
|
94
|
-
});
|
|
95
|
-
|
|
96
|
-
describe('okoPush', () => {
|
|
97
|
-
beforeAll(() => {
|
|
98
|
-
(window as any).oko = {
|
|
99
|
-
checkContext: () => 123,
|
|
100
|
-
|
|
101
|
-
push: jest.fn(function (this: any, data) {
|
|
102
|
-
// имитируем реальную работу window.oko.push: в процессе удаляет data.n
|
|
103
|
-
delete data.n;
|
|
104
|
-
|
|
105
|
-
// имитируем реальную работу window.oko.push: в процессе вызывает другие методы с this
|
|
106
|
-
this.checkContext();
|
|
107
|
-
}),
|
|
108
|
-
};
|
|
109
|
-
});
|
|
110
|
-
|
|
111
|
-
afterAll(() => {
|
|
112
|
-
delete (window as any).oko;
|
|
113
|
-
});
|
|
114
|
-
|
|
115
|
-
it('should handle window.oko.push mutates object argument', () => {
|
|
116
|
-
const testData = {
|
|
117
|
-
n: 'test-event',
|
|
118
|
-
prop1: 1,
|
|
119
|
-
prop2: 2,
|
|
120
|
-
};
|
|
121
|
-
|
|
122
|
-
expect((window as any).oko.push).toBeCalledTimes(0);
|
|
123
|
-
|
|
124
|
-
okoPush(testData);
|
|
125
|
-
|
|
126
|
-
expect((window as any).oko.push).toBeCalledTimes(1);
|
|
127
|
-
expect((window as any).oko.push.mock.calls[0][0]).toEqual({
|
|
128
|
-
prop1: 1,
|
|
129
|
-
prop2: 2,
|
|
130
|
-
});
|
|
131
|
-
expect(testData).toEqual({
|
|
132
|
-
n: 'test-event',
|
|
133
|
-
prop1: 1,
|
|
134
|
-
prop2: 2,
|
|
135
|
-
});
|
|
136
|
-
});
|
|
137
|
-
|
|
138
|
-
it('should handle window.oko.push absence', () => {
|
|
139
|
-
delete (window as any).oko;
|
|
140
|
-
|
|
141
|
-
expect(() => okoPush({ n: 'test-123' })).not.toThrow();
|
|
142
|
-
});
|
|
143
|
-
});
|