@sima-land/isomorph 11.0.0-alpha.2 → 11.0.0-alpha.5
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/config/{index.d.ts → base.d.ts} +0 -0
- package/config/{index.js → base.js} +1 -1
- package/config/base.js.map +1 -0
- package/di/application.d.ts +6 -0
- package/{container → di}/application.js +16 -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/{preset/index.d.ts → di/preset.d.ts} +3 -1
- package/{preset/index.js → di/preset.js} +1 -1
- 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/{container → di}/types.js +0 -0
- package/{preset → di}/types.js.map +1 -1
- package/http-server/middleware/tracing.d.ts +8 -2
- package/http-server/middleware/tracing.js +19 -1
- package/http-server/middleware/tracing.js.map +1 -1
- package/package.json +4 -2
- package/preset/browser/index.d.ts +1 -0
- package/preset/browser/index.js +44 -0
- package/preset/browser/index.js.map +1 -0
- package/preset/node/index.d.ts +6 -2
- package/preset/node/index.js +54 -22
- package/preset/node/index.js.map +1 -1
- package/preset/node/response.d.ts +6 -3
- package/preset/node/response.js +9 -5
- package/preset/node/response.js.map +1 -1
- package/tokens.d.ts +24 -17
- package/tokens.js +23 -17
- package/tokens.js.map +1 -1
- package/tracing/utils.d.ts +9 -0
- package/tracing/utils.js +22 -0
- package/tracing/utils.js.map +1 -0
- package/utils/react/error-handlers/index.js +1 -0
- package/utils/react/error-handlers/index.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/config/index.js.map +0 -1
- package/container/application.d.ts +0 -25
- package/container/application.js.map +0 -1
- package/container/index.d.ts +0 -18
- package/container/index.js +0 -74
- package/container/index.js.map +0 -1
- package/container/types.d.ts +0 -14
- package/container/types.js.map +0 -1
- package/preset/index.js.map +0 -1
- package/preset/types.d.ts +0 -7
- package/preset/types.js +0 -3
- package/tracer/node.d.ts +0 -10
- package/tracer/node.js +0 -38
- package/tracer/node.js.map +0 -1
- package/tracer/types.d.ts +0 -2
- package/tracer/types.js +0 -3
- package/tracer/types.js.map +0 -1
|
File without changes
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"base.js","sourceRoot":"","sources":["../../src/config/base.ts"],"names":[],"mappings":";;;AAEA;;;;GAIG;AACH,SAAgB,gBAAgB,CAAC,MAAoB;IACnD,MAAM,GAAG,GAAG,MAAM,CAAC,OAAO,CAAC,UAAU,CAAC,CAAC;IACvC,MAAM,OAAO,GAAG,MAAM,CAAC,OAAO,CAAC,UAAU,CAAC,CAAC;IAC3C,MAAM,UAAU,GAAG,MAAM,CAAC,OAAO,CAAC,aAAa,CAAC,CAAC;IAEjD,OAAO;QACL,GAAG;QACH,OAAO;QACP,UAAU;KACX,CAAC;AACJ,CAAC;AAVD,4CAUC"}
|
|
@@ -1,8 +1,14 @@
|
|
|
1
1
|
"use strict";
|
|
2
2
|
Object.defineProperty(exports, "__esModule", { value: true });
|
|
3
|
-
exports.
|
|
4
|
-
const
|
|
5
|
-
|
|
3
|
+
exports.createApplication = exports.CURRENT_APP = void 0;
|
|
4
|
+
const errors_1 = require("./errors");
|
|
5
|
+
const token_1 = require("./token");
|
|
6
|
+
const container_1 = require("./container");
|
|
7
|
+
/**
|
|
8
|
+
* Токен, с помощью которого можно достать из приложения само приложение.
|
|
9
|
+
*/
|
|
10
|
+
exports.CURRENT_APP = (0, token_1.createToken)('application/self');
|
|
11
|
+
class ApplicationImplementation {
|
|
6
12
|
constructor() {
|
|
7
13
|
this.providers = new Map();
|
|
8
14
|
this.presets = [];
|
|
@@ -22,7 +28,7 @@ class Application {
|
|
|
22
28
|
return this.getContainer().get(token);
|
|
23
29
|
}
|
|
24
30
|
catch (error) {
|
|
25
|
-
if (error instanceof
|
|
31
|
+
if (error instanceof errors_1.NothingBoundError && this.parent) {
|
|
26
32
|
return this.parent.get(token);
|
|
27
33
|
}
|
|
28
34
|
else {
|
|
@@ -37,8 +43,8 @@ class Application {
|
|
|
37
43
|
return this.container;
|
|
38
44
|
}
|
|
39
45
|
configureContainer() {
|
|
40
|
-
const container = (0,
|
|
41
|
-
container.set(
|
|
46
|
+
const container = (0, container_1.createContainer)();
|
|
47
|
+
container.set(exports.CURRENT_APP, () => this);
|
|
42
48
|
for (const preset of this.presets) {
|
|
43
49
|
preset.apply(this);
|
|
44
50
|
}
|
|
@@ -58,6 +64,8 @@ class Application {
|
|
|
58
64
|
fn(...tokens.map(token => this.get(token)));
|
|
59
65
|
}
|
|
60
66
|
}
|
|
61
|
-
|
|
62
|
-
|
|
67
|
+
function createApplication() {
|
|
68
|
+
return new ApplicationImplementation();
|
|
69
|
+
}
|
|
70
|
+
exports.createApplication = createApplication;
|
|
63
71
|
//# sourceMappingURL=application.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"application.js","sourceRoot":"","sources":["../../src/di/application.ts"],"names":[],"mappings":";;;AAWA,qCAA6C;AAC7C,mCAAsC;AACtC,2CAA8C;AAE9C;;GAEG;AACU,QAAA,WAAW,GAAG,IAAA,mBAAW,EAAC,kBAAkB,CAAC,CAAC;AAE3D,MAAM,yBAAyB;IAM7B;QACE,IAAI,CAAC,SAAS,GAAG,IAAI,GAAG,EAAE,CAAC;QAC3B,IAAI,CAAC,OAAO,GAAG,EAAE,CAAC;IACpB,CAAC;IAED,IAAI,CAAI,KAAe;QACrB,OAAO;YACL,OAAO,EAAE,KAAK,CAAC,EAAE;gBACf,IAAI,CAAC,SAAS,CAAC,GAAG,CAAC,KAAK,EAAE,GAAG,EAAE,CAAC,KAAK,CAAC,CAAC;YACzC,CAAC;YACD,UAAU,EAAE,QAAQ,CAAC,EAAE;gBACrB,IAAI,CAAC,SAAS,CAAC,GAAG,CAAC,KAAK,EAAE,QAAQ,CAAC,CAAC;YACtC,CAAC;SACF,CAAC;IACJ,CAAC;IAED,GAAG,CAAI,KAAe;QACpB,IAAI;YACF,OAAO,IAAI,CAAC,YAAY,EAAE,CAAC,GAAG,CAAC,KAAK,CAAC,CAAC;SACvC;QAAC,OAAO,KAAK,EAAE;YACd,IAAI,KAAK,YAAY,0BAAiB,IAAI,IAAI,CAAC,MAAM,EAAE;gBACrD,OAAO,IAAI,CAAC,MAAM,CAAC,GAAG,CAAC,KAAK,CAAC,CAAC;aAC/B;iBAAM;gBACL,MAAM,KAAK,CAAC;aACb;SACF;IACH,CAAC;IAEO,YAAY;QAClB,IAAI,CAAC,IAAI,CAAC,SAAS,EAAE;YACnB,IAAI,CAAC,SAAS,GAAG,IAAI,CAAC,kBAAkB,EAAE,CAAC;SAC5C;QAED,OAAO,IAAI,CAAC,SAAS,CAAC;IACxB,CAAC;IAEO,kBAAkB;QACxB,MAAM,SAAS,GAAG,IAAA,2BAAe,GAAE,CAAC;QAEpC,SAAS,CAAC,GAAG,CAAC,mBAAW,EAAE,GAAG,EAAE,CAAC,IAAI,CAAC,CAAC;QAEvC,KAAK,MAAM,MAAM,IAAI,IAAI,CAAC,OAAO,EAAE;YACjC,MAAM,CAAC,KAAK,CAAC,IAAI,CAAC,CAAC;SACpB;QAED,MAAM,OAAO,GAAY,KAAK,CAAC,EAAE,CAAC,IAAI,CAAC,GAAG,CAAC,KAAK,CAAC,CAAC;QAElD,KAAK,MAAM,CAAC,KAAK,EAAE,QAAQ,CAAC,IAAI,IAAI,CAAC,SAAS,EAAE;YAC9C,SAAS,CAAC,GAAG,CAAC,KAAK,EAAE,GAAG,EAAE,CAAC,QAAQ,CAAC,OAAO,CAAC,CAAC,CAAC;SAC/C;QAED,OAAO,SAAS,CAAC;IACnB,CAAC;IAED,MAAM,CAAC,MAAmB;QACxB,IAAI,CAAC,MAAM,GAAG,MAAM,CAAC;IACvB,CAAC;IAED,MAAM,CAAC,MAAc;QACnB,IAAI,CAAC,OAAO,CAAC,IAAI,CAAC,MAAM,CAAC,CAAC;IAC5B,CAAC;IAED,MAAM,CACJ,MAAmB,EACnB,EAA0C;QAE1C,EAAE,CAAC,GAAI,MAAM,CAAC,GAAG,CAAC,KAAK,CAAC,EAAE,CAAC,IAAI,CAAC,GAAG,CAAC,KAAK,CAAC,CAAS,CAAC,CAAC;IACvD,CAAC;CACF;AAED,SAAgB,iBAAiB;IAC/B,OAAO,IAAI,yBAAyB,EAAE,CAAC;AACzC,CAAC;AAFD,8CAEC"}
|
package/di/container.js
ADDED
|
@@ -0,0 +1,49 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
Object.defineProperty(exports, "__esModule", { value: true });
|
|
3
|
+
exports.createContainer = void 0;
|
|
4
|
+
const errors_1 = require("./errors");
|
|
5
|
+
class ContainerImplementation {
|
|
6
|
+
constructor() {
|
|
7
|
+
this.cache = new Map();
|
|
8
|
+
this.registry = new Map();
|
|
9
|
+
}
|
|
10
|
+
set(token, provider) {
|
|
11
|
+
this.registry.set(token._key, provider);
|
|
12
|
+
}
|
|
13
|
+
get(token) {
|
|
14
|
+
return this.resolve(token, []);
|
|
15
|
+
}
|
|
16
|
+
resolve(token, chain) {
|
|
17
|
+
if (chain.includes(token)) {
|
|
18
|
+
throw new errors_1.CircularDependencyError([...chain, token]);
|
|
19
|
+
}
|
|
20
|
+
else {
|
|
21
|
+
chain.push(token);
|
|
22
|
+
}
|
|
23
|
+
if (this.cache.has(token._key)) {
|
|
24
|
+
return this.cache.get(token._key);
|
|
25
|
+
}
|
|
26
|
+
else if (this.registry.has(token._key)) {
|
|
27
|
+
const provider = this.registry.get(token._key);
|
|
28
|
+
if (typeof provider !== 'function') {
|
|
29
|
+
throw new Error('Provider is not a function');
|
|
30
|
+
}
|
|
31
|
+
const value = provider(otherToken => this.resolve(otherToken, chain));
|
|
32
|
+
// всегда как singleton
|
|
33
|
+
this.cache.set(token._key, value);
|
|
34
|
+
return value;
|
|
35
|
+
}
|
|
36
|
+
else {
|
|
37
|
+
throw new errors_1.NothingBoundError(token._key);
|
|
38
|
+
}
|
|
39
|
+
}
|
|
40
|
+
}
|
|
41
|
+
/**
|
|
42
|
+
* Возвращает новый DI-контейнер.
|
|
43
|
+
* @return DI-контейнер.
|
|
44
|
+
*/
|
|
45
|
+
function createContainer() {
|
|
46
|
+
return new ContainerImplementation();
|
|
47
|
+
}
|
|
48
|
+
exports.createContainer = createContainer;
|
|
49
|
+
//# sourceMappingURL=container.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"container.js","sourceRoot":"","sources":["../../src/di/container.ts"],"names":[],"mappings":";;;AAEA,qCAAsE;AAEtE,MAAM,uBAAuB;IAI3B;QACE,IAAI,CAAC,KAAK,GAAG,IAAI,GAAG,EAAe,CAAC;QACpC,IAAI,CAAC,QAAQ,GAAG,IAAI,GAAG,EAAyB,CAAC;IACnD,CAAC;IAED,GAAG,CAAI,KAAe,EAAE,QAAqB;QAC3C,IAAI,CAAC,QAAQ,CAAC,GAAG,CAAC,KAAK,CAAC,IAAI,EAAE,QAAQ,CAAC,CAAC;IAC1C,CAAC;IAED,GAAG,CAAI,KAAe;QACpB,OAAO,IAAI,CAAC,OAAO,CAAC,KAAK,EAAE,EAAE,CAAC,CAAC;IACjC,CAAC;IAEO,OAAO,CAAI,KAAe,EAAE,KAAmB;QACrD,IAAI,KAAK,CAAC,QAAQ,CAAC,KAAK,CAAC,EAAE;YACzB,MAAM,IAAI,gCAAuB,CAAC,CAAC,GAAG,KAAK,EAAE,KAAK,CAAC,CAAC,CAAC;SACtD;aAAM;YACL,KAAK,CAAC,IAAI,CAAC,KAAK,CAAC,CAAC;SACnB;QAED,IAAI,IAAI,CAAC,KAAK,CAAC,GAAG,CAAC,KAAK,CAAC,IAAI,CAAC,EAAE;YAC9B,OAAO,IAAI,CAAC,KAAK,CAAC,GAAG,CAAC,KAAK,CAAC,IAAI,CAAC,CAAC;SACnC;aAAM,IAAI,IAAI,CAAC,QAAQ,CAAC,GAAG,CAAC,KAAK,CAAC,IAAI,CAAC,EAAE;YACxC,MAAM,QAAQ,GAAG,IAAI,CAAC,QAAQ,CAAC,GAAG,CAAC,KAAK,CAAC,IAAI,CAAC,CAAC;YAE/C,IAAI,OAAO,QAAQ,KAAK,UAAU,EAAE;gBAClC,MAAM,IAAI,KAAK,CAAC,4BAA4B,CAAC,CAAC;aAC/C;YAED,MAAM,KAAK,GAAG,QAAQ,CAAC,UAAU,CAAC,EAAE,CAAC,IAAI,CAAC,OAAO,CAAC,UAAU,EAAE,KAAK,CAAC,CAAC,CAAC;YAEtE,uBAAuB;YACvB,IAAI,CAAC,KAAK,CAAC,GAAG,CAAC,KAAK,CAAC,IAAI,EAAE,KAAK,CAAC,CAAC;YAElC,OAAO,KAAK,CAAC;SACd;aAAM;YACL,MAAM,IAAI,0BAAiB,CAAC,KAAK,CAAC,IAAI,CAAC,CAAC;SACzC;IACH,CAAC;CACF;AAED;;;GAGG;AACH,SAAgB,eAAe;IAC7B,OAAO,IAAI,uBAAuB,EAAE,CAAC;AACvC,CAAC;AAFD,0CAEC"}
|
package/di/errors.d.ts
ADDED
|
@@ -0,0 +1,21 @@
|
|
|
1
|
+
import type { Token } from './types';
|
|
2
|
+
/**
|
|
3
|
+
* Ошибка, сообщающая, что в контейнере нет сервиса по заданному ключу.
|
|
4
|
+
*/
|
|
5
|
+
export declare class NothingBoundError extends Error {
|
|
6
|
+
/**
|
|
7
|
+
* Конструктор.
|
|
8
|
+
* @param key Ключ целевой зависимости.
|
|
9
|
+
*/
|
|
10
|
+
constructor(key: symbol);
|
|
11
|
+
}
|
|
12
|
+
/**
|
|
13
|
+
* Ошибка, сообщающая, что обнаружена циклическая зависимость.
|
|
14
|
+
*/
|
|
15
|
+
export declare class CircularDependencyError extends Error {
|
|
16
|
+
/**
|
|
17
|
+
* Конструктор.
|
|
18
|
+
* @param trace Список токенов, в котором обнаружен цикл.
|
|
19
|
+
*/
|
|
20
|
+
constructor(trace: Token<any>[]);
|
|
21
|
+
}
|
package/di/errors.js
ADDED
|
@@ -0,0 +1,33 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
Object.defineProperty(exports, "__esModule", { value: true });
|
|
3
|
+
exports.CircularDependencyError = exports.NothingBoundError = void 0;
|
|
4
|
+
/**
|
|
5
|
+
* Ошибка, сообщающая, что в контейнере нет сервиса по заданному ключу.
|
|
6
|
+
*/
|
|
7
|
+
class NothingBoundError extends Error {
|
|
8
|
+
/**
|
|
9
|
+
* Конструктор.
|
|
10
|
+
* @param key Ключ целевой зависимости.
|
|
11
|
+
*/
|
|
12
|
+
constructor(key) {
|
|
13
|
+
super(`Nothing bound to ${String(key)}`);
|
|
14
|
+
this.name = 'NothingBoundError';
|
|
15
|
+
}
|
|
16
|
+
}
|
|
17
|
+
exports.NothingBoundError = NothingBoundError;
|
|
18
|
+
/**
|
|
19
|
+
* Ошибка, сообщающая, что обнаружена циклическая зависимость.
|
|
20
|
+
*/
|
|
21
|
+
class CircularDependencyError extends Error {
|
|
22
|
+
/**
|
|
23
|
+
* Конструктор.
|
|
24
|
+
* @param trace Список токенов, в котором обнаружен цикл.
|
|
25
|
+
*/
|
|
26
|
+
constructor(trace) {
|
|
27
|
+
const names = trace.map(token => String(token._key)).join(' >> ');
|
|
28
|
+
super(`Circular dependency found, trace: ${names}`);
|
|
29
|
+
this.name = 'CircularDependencyError';
|
|
30
|
+
}
|
|
31
|
+
}
|
|
32
|
+
exports.CircularDependencyError = CircularDependencyError;
|
|
33
|
+
//# sourceMappingURL=errors.js.map
|
package/di/errors.js.map
ADDED
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"errors.js","sourceRoot":"","sources":["../../src/di/errors.ts"],"names":[],"mappings":";;;AAEA;;GAEG;AACH,MAAa,iBAAkB,SAAQ,KAAK;IAC1C;;;OAGG;IACH,YAAY,GAAW;QACrB,KAAK,CAAC,oBAAoB,MAAM,CAAC,GAAG,CAAC,EAAE,CAAC,CAAC;QACzC,IAAI,CAAC,IAAI,GAAG,mBAAmB,CAAC;IAClC,CAAC;CACF;AATD,8CASC;AAED;;GAEG;AACH,MAAa,uBAAwB,SAAQ,KAAK;IAChD;;;OAGG;IACH,YAAY,KAAmB;QAC7B,MAAM,KAAK,GAAG,KAAK,CAAC,GAAG,CAAC,KAAK,CAAC,EAAE,CAAC,MAAM,CAAC,KAAK,CAAC,IAAI,CAAC,CAAC,CAAC,IAAI,CAAC,MAAM,CAAC,CAAC;QAClE,KAAK,CAAC,qCAAqC,KAAK,EAAE,CAAC,CAAC;QACpD,IAAI,CAAC,IAAI,GAAG,yBAAyB,CAAC;IACxC,CAAC;CACF;AAVD,0DAUC"}
|
package/di/index.d.ts
ADDED
|
@@ -0,0 +1,6 @@
|
|
|
1
|
+
export { Token, Resolve, Provider, Container, Application, Preset } from './types';
|
|
2
|
+
export { NothingBoundError, CircularDependencyError } from './errors';
|
|
3
|
+
export { createToken } from './token';
|
|
4
|
+
export { createContainer } from './container';
|
|
5
|
+
export { createPreset } from './preset';
|
|
6
|
+
export { createApplication, CURRENT_APP } from './application';
|
package/di/index.js
ADDED
|
@@ -0,0 +1,16 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
Object.defineProperty(exports, "__esModule", { value: true });
|
|
3
|
+
exports.CURRENT_APP = exports.createApplication = exports.createPreset = exports.createContainer = exports.createToken = exports.CircularDependencyError = exports.NothingBoundError = void 0;
|
|
4
|
+
var errors_1 = require("./errors");
|
|
5
|
+
Object.defineProperty(exports, "NothingBoundError", { enumerable: true, get: function () { return errors_1.NothingBoundError; } });
|
|
6
|
+
Object.defineProperty(exports, "CircularDependencyError", { enumerable: true, get: function () { return errors_1.CircularDependencyError; } });
|
|
7
|
+
var token_1 = require("./token");
|
|
8
|
+
Object.defineProperty(exports, "createToken", { enumerable: true, get: function () { return token_1.createToken; } });
|
|
9
|
+
var container_1 = require("./container");
|
|
10
|
+
Object.defineProperty(exports, "createContainer", { enumerable: true, get: function () { return container_1.createContainer; } });
|
|
11
|
+
var preset_1 = require("./preset");
|
|
12
|
+
Object.defineProperty(exports, "createPreset", { enumerable: true, get: function () { return preset_1.createPreset; } });
|
|
13
|
+
var application_1 = require("./application");
|
|
14
|
+
Object.defineProperty(exports, "createApplication", { enumerable: true, get: function () { return application_1.createApplication; } });
|
|
15
|
+
Object.defineProperty(exports, "CURRENT_APP", { enumerable: true, get: function () { return application_1.CURRENT_APP; } });
|
|
16
|
+
//# sourceMappingURL=index.js.map
|
package/di/index.js.map
ADDED
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"index.js","sourceRoot":"","sources":["../../src/di/index.ts"],"names":[],"mappings":";;;AACA,mCAAsE;AAA7D,2GAAA,iBAAiB,OAAA;AAAE,iHAAA,uBAAuB,OAAA;AACnD,iCAAsC;AAA7B,oGAAA,WAAW,OAAA;AACpB,yCAA8C;AAArC,4GAAA,eAAe,OAAA;AACxB,mCAAwC;AAA/B,sGAAA,YAAY,OAAA;AACrB,6CAA+D;AAAtD,gHAAA,iBAAiB,OAAA;AAAE,0GAAA,WAAW,OAAA"}
|
|
@@ -1,7 +1,9 @@
|
|
|
1
|
-
import type {
|
|
1
|
+
import type { Provider, Token, Preset } from './types';
|
|
2
|
+
declare type PresetEntry<T = any> = [Token<T>, Provider<T>];
|
|
2
3
|
/**
|
|
3
4
|
* Возвращает новый "preset" приложения - набор предустановленных компонентов которые можно переопределять.
|
|
4
5
|
* @param defaults Предустановленные зависимости.
|
|
5
6
|
* @return Preset.
|
|
6
7
|
*/
|
|
7
8
|
export declare function createPreset(defaults: PresetEntry[]): Preset;
|
|
9
|
+
export {};
|
package/di/preset.js.map
ADDED
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"preset.js","sourceRoot":"","sources":["../../src/di/preset.ts"],"names":[],"mappings":";;;AAIA;;;;GAIG;AACH,SAAgB,YAAY,CAAC,QAAuB;IAClD,MAAM,QAAQ,GAAG,IAAI,GAAG,CAA4B,QAAQ,CAAC,CAAC;IAE9D,MAAM,MAAM,GAAG;QACb,QAAQ,EAAE,CAAI,KAAe,EAAE,QAAqB,EAAE,EAAE;YACtD,QAAQ,CAAC,GAAG,CAAC,KAAK,EAAE,QAAQ,CAAC,CAAC;YAC9B,OAAO,MAAM,CAAC;QAChB,CAAC;QAED,KAAK,EAAE,CAAC,GAAgB,EAAE,EAAE;YAC1B,KAAK,MAAM,CAAC,KAAK,EAAE,QAAQ,CAAC,IAAI,QAAQ,EAAE;gBACxC,GAAG,CAAC,IAAI,CAAC,KAAK,CAAC,CAAC,UAAU,CAAC,QAAQ,CAAC,CAAC;aACtC;QACH,CAAC;KACF,CAAC;IAEF,OAAO,MAAM,CAAC;AAChB,CAAC;AAjBD,oCAiBC"}
|
package/di/token.d.ts
ADDED
package/di/token.js
ADDED
|
@@ -0,0 +1,17 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
Object.defineProperty(exports, "__esModule", { value: true });
|
|
3
|
+
exports.createToken = void 0;
|
|
4
|
+
/**
|
|
5
|
+
* Возвращает новый токен.
|
|
6
|
+
* @param name Имя токена для отладки в случае ошибок.
|
|
7
|
+
* @return Токен.
|
|
8
|
+
*/
|
|
9
|
+
function createToken(name) {
|
|
10
|
+
const key = Symbol(name);
|
|
11
|
+
return {
|
|
12
|
+
_key: key,
|
|
13
|
+
_resolve: source => source.get(key),
|
|
14
|
+
};
|
|
15
|
+
}
|
|
16
|
+
exports.createToken = createToken;
|
|
17
|
+
//# sourceMappingURL=token.js.map
|
package/di/token.js.map
ADDED
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"token.js","sourceRoot":"","sources":["../../src/di/token.ts"],"names":[],"mappings":";;;AAEA;;;;GAIG;AACH,SAAgB,WAAW,CAAY,IAAa;IAClD,MAAM,GAAG,GAAG,MAAM,CAAC,IAAI,CAAC,CAAC;IAEzB,OAAO;QACL,IAAI,EAAE,GAAG;QACT,QAAQ,EAAE,MAAM,CAAC,EAAE,CAAC,MAAM,CAAC,GAAG,CAAC,GAAG,CAAC;KACpC,CAAC;AACJ,CAAC;AAPD,kCAOC"}
|
package/di/types.d.ts
ADDED
|
@@ -0,0 +1,32 @@
|
|
|
1
|
+
export interface Token<T> {
|
|
2
|
+
readonly _key: symbol;
|
|
3
|
+
readonly _resolve: (registry: Map<symbol, any>) => T;
|
|
4
|
+
}
|
|
5
|
+
export interface Resolve {
|
|
6
|
+
<T>(token: Token<T>): T;
|
|
7
|
+
}
|
|
8
|
+
export interface Provider<T> {
|
|
9
|
+
(resolve: Resolve): T;
|
|
10
|
+
}
|
|
11
|
+
export interface Container {
|
|
12
|
+
set: <T = never>(token: Token<T>, provider: Provider<T>) => void;
|
|
13
|
+
get: Resolve;
|
|
14
|
+
}
|
|
15
|
+
export interface Binding<T> {
|
|
16
|
+
toValue: (value: T) => void;
|
|
17
|
+
toProvider: (provider: Provider<T>) => void;
|
|
18
|
+
}
|
|
19
|
+
export declare type ExtractType<T extends readonly Token<any>[]> = {
|
|
20
|
+
[index in keyof T]: T[index] extends T[number] ? ReturnType<T[index]['_resolve']> : never;
|
|
21
|
+
};
|
|
22
|
+
export interface Application {
|
|
23
|
+
preset(preset: Preset): void;
|
|
24
|
+
attach(parent: Application): void;
|
|
25
|
+
bind<T>(token: Token<T>): Binding<T>;
|
|
26
|
+
get<T>(token: Token<T>): T;
|
|
27
|
+
invoke<Tokens extends readonly Token<any>[]>(tokens: [...Tokens], fn: (...args: ExtractType<Tokens>) => void): void;
|
|
28
|
+
}
|
|
29
|
+
export interface Preset {
|
|
30
|
+
override: <T>(token: Token<T>, provider: Provider<T>) => this;
|
|
31
|
+
apply: (app: Application) => void;
|
|
32
|
+
}
|
|
File without changes
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"types.js","sourceRoot":"","sources":["../../src/
|
|
1
|
+
{"version":3,"file":"types.js","sourceRoot":"","sources":["../../src/di/types.ts"],"names":[],"mappings":""}
|
|
@@ -1,8 +1,14 @@
|
|
|
1
|
-
import
|
|
2
|
-
import type { Handler } from 'express';
|
|
1
|
+
import { Tracer } from '@opentelemetry/api';
|
|
2
|
+
import type { Request, Handler } from 'express';
|
|
3
3
|
/**
|
|
4
4
|
* Возвращает новый middleware для трассировки стадий входящего запроса.
|
|
5
5
|
* @param tracer Tracer.
|
|
6
6
|
* @return Middleware.
|
|
7
7
|
*/
|
|
8
8
|
export declare function tracingMiddleware(tracer: Tracer): Handler;
|
|
9
|
+
/**
|
|
10
|
+
* Возвращает набор стандартных атрибутов для спана.
|
|
11
|
+
* @param req Входящий http-запрос.
|
|
12
|
+
* @return Атрибуты.
|
|
13
|
+
*/
|
|
14
|
+
export declare function getConventionalRequestAttrs(req: Request): Record<string, string | undefined>;
|
|
@@ -1,6 +1,6 @@
|
|
|
1
1
|
"use strict";
|
|
2
2
|
Object.defineProperty(exports, "__esModule", { value: true });
|
|
3
|
-
exports.tracingMiddleware = void 0;
|
|
3
|
+
exports.getConventionalRequestAttrs = exports.tracingMiddleware = void 0;
|
|
4
4
|
const constants_1 = require("../constants");
|
|
5
5
|
const api_1 = require("@opentelemetry/api");
|
|
6
6
|
/**
|
|
@@ -12,6 +12,7 @@ function tracingMiddleware(tracer) {
|
|
|
12
12
|
return (req, res, next) => {
|
|
13
13
|
const externalContext = api_1.propagation.extract(api_1.ROOT_CONTEXT, req.headers);
|
|
14
14
|
const rootSpan = tracer.startSpan('response', undefined, externalContext);
|
|
15
|
+
rootSpan.setAttributes(getConventionalRequestAttrs(req));
|
|
15
16
|
const rootContext = api_1.trace.setSpan(externalContext, rootSpan);
|
|
16
17
|
res.locals.tracing = {
|
|
17
18
|
rootSpan,
|
|
@@ -30,4 +31,21 @@ function tracingMiddleware(tracer) {
|
|
|
30
31
|
};
|
|
31
32
|
}
|
|
32
33
|
exports.tracingMiddleware = tracingMiddleware;
|
|
34
|
+
/**
|
|
35
|
+
* Возвращает набор стандартных атрибутов для спана.
|
|
36
|
+
* @param req Входящий http-запрос.
|
|
37
|
+
* @return Атрибуты.
|
|
38
|
+
*/
|
|
39
|
+
function getConventionalRequestAttrs(req) {
|
|
40
|
+
const result = {
|
|
41
|
+
'request.path': req.originalUrl,
|
|
42
|
+
};
|
|
43
|
+
for (const headerName in req.headers) {
|
|
44
|
+
if (headerName.toLowerCase().startsWith('simaland-')) {
|
|
45
|
+
result[headerName] = req.header(headerName);
|
|
46
|
+
}
|
|
47
|
+
}
|
|
48
|
+
return result;
|
|
49
|
+
}
|
|
50
|
+
exports.getConventionalRequestAttrs = getConventionalRequestAttrs;
|
|
33
51
|
//# sourceMappingURL=tracing.js.map
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"tracing.js","sourceRoot":"","sources":["../../../src/http-server/middleware/tracing.ts"],"names":[],"mappings":";;;AAAA,4CAA8C;AAC9C,
|
|
1
|
+
{"version":3,"file":"tracing.js","sourceRoot":"","sources":["../../../src/http-server/middleware/tracing.ts"],"names":[],"mappings":";;;AAAA,4CAA8C;AAC9C,4CAA8E;AAG9E;;;;GAIG;AACH,SAAgB,iBAAiB,CAAC,MAAc;IAC9C,OAAO,CAAC,GAAG,EAAE,GAAG,EAAE,IAAI,EAAE,EAAE;QACxB,MAAM,eAAe,GAAG,iBAAW,CAAC,OAAO,CAAC,kBAAY,EAAE,GAAG,CAAC,OAAO,CAAC,CAAC;QACvE,MAAM,QAAQ,GAAG,MAAM,CAAC,SAAS,CAAC,UAAU,EAAE,SAAS,EAAE,eAAe,CAAC,CAAC;QAE1E,QAAQ,CAAC,aAAa,CAAC,2BAA2B,CAAC,GAAG,CAAC,CAAC,CAAC;QAEzD,MAAM,WAAW,GAAG,WAAK,CAAC,OAAO,CAAC,eAAe,EAAE,QAAQ,CAAC,CAAC;QAE7D,GAAG,CAAC,MAAM,CAAC,OAAO,GAAG;YACnB,QAAQ;YACR,WAAW;SACZ,CAAC;QAEF,GAAG,CAAC,IAAI,CAAC,0BAAc,CAAC,WAAW,EAAE,GAAG,EAAE;YACxC,GAAG,CAAC,MAAM,CAAC,OAAO,CAAC,UAAU,GAAG,MAAM,CAAC,SAAS,CAAC,QAAQ,EAAE,SAAS,EAAE,WAAW,CAAC,CAAC;QACrF,CAAC,CAAC,CAAC;QAEH,GAAG,CAAC,IAAI,CAAC,0BAAc,CAAC,YAAY,EAAE,GAAG,EAAE;YACzC,GAAG,CAAC,MAAM,CAAC,OAAO,CAAC,UAAU,CAAC,GAAG,EAAE,CAAC;QACtC,CAAC,CAAC,CAAC;QAEH,GAAG,CAAC,IAAI,CAAC,QAAQ,EAAE,GAAG,EAAE;YACtB,QAAQ,CAAC,GAAG,EAAE,CAAC;QACjB,CAAC,CAAC,CAAC;QAEH,IAAI,EAAE,CAAC;IACT,CAAC,CAAC;AACJ,CAAC;AA5BD,8CA4BC;AAED;;;;GAIG;AACH,SAAgB,2BAA2B,CAAC,GAAY;IACtD,MAAM,MAAM,GAAuC;QACjD,cAAc,EAAE,GAAG,CAAC,WAAW;KAChC,CAAC;IAEF,KAAK,MAAM,UAAU,IAAI,GAAG,CAAC,OAAO,EAAE;QACpC,IAAI,UAAU,CAAC,WAAW,EAAE,CAAC,UAAU,CAAC,WAAW,CAAC,EAAE;YACpD,MAAM,CAAC,UAAU,CAAC,GAAG,GAAG,CAAC,MAAM,CAAC,UAAU,CAAC,CAAC;SAC7C;KACF;IAED,OAAO,MAAM,CAAC;AAChB,CAAC;AAZD,kEAYC"}
|
package/package.json
CHANGED
|
@@ -1,6 +1,6 @@
|
|
|
1
1
|
{
|
|
2
2
|
"name": "@sima-land/isomorph",
|
|
3
|
-
"version": "11.0.0-alpha.
|
|
3
|
+
"version": "11.0.0-alpha.5",
|
|
4
4
|
"description": "Tiny framework for fast start frontend microservices",
|
|
5
5
|
"author": "www.sima-land.ru team",
|
|
6
6
|
"license": "Apache-2.0",
|
|
@@ -22,6 +22,7 @@
|
|
|
22
22
|
"@types/ejs": "^3.1.1",
|
|
23
23
|
"@types/express": "^4.17.13",
|
|
24
24
|
"@types/jest": "^27.4.1",
|
|
25
|
+
"@types/jsesc": "^3.0.1",
|
|
25
26
|
"@types/lodash": "^4.14.182",
|
|
26
27
|
"@types/react": "^17.0.40",
|
|
27
28
|
"@types/react-dom": "^17.0.13",
|
|
@@ -32,7 +33,7 @@
|
|
|
32
33
|
},
|
|
33
34
|
"dependencies": {
|
|
34
35
|
"@humanwhocodes/env": "^2.2.0",
|
|
35
|
-
"@opentelemetry/api": "^1.0
|
|
36
|
+
"@opentelemetry/api": "^1.1.0",
|
|
36
37
|
"@opentelemetry/exporter-jaeger": "^1.0.1",
|
|
37
38
|
"@opentelemetry/instrumentation": "^0.27.0",
|
|
38
39
|
"@opentelemetry/instrumentation-express": "^0.28.0",
|
|
@@ -46,6 +47,7 @@
|
|
|
46
47
|
"dotenv": "^16.0.0",
|
|
47
48
|
"ejs": "^3.1.8",
|
|
48
49
|
"express": "^4.17.3",
|
|
50
|
+
"jsesc": "^3.0.2",
|
|
49
51
|
"middleware-axios": "^2.1.2",
|
|
50
52
|
"pino": "^7.9.1",
|
|
51
53
|
"pino-pretty": "^7.5.4",
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
export declare function PresetBrowser(): import("../../di").Preset;
|
|
@@ -0,0 +1,44 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
Object.defineProperty(exports, "__esModule", { value: true });
|
|
3
|
+
exports.PresetBrowser = void 0;
|
|
4
|
+
/* eslint-disable require-jsdoc, jsdoc/require-jsdoc */
|
|
5
|
+
const di_1 = require("../../di");
|
|
6
|
+
const tokens_1 = require("../../tokens");
|
|
7
|
+
const base_1 = require("../../config/base");
|
|
8
|
+
const browser_1 = require("../../config/browser");
|
|
9
|
+
const browser_2 = require("../../error-tracker/browser");
|
|
10
|
+
const logger_1 = require("../../logger");
|
|
11
|
+
const sentry_1 = require("../../logger/handler/sentry");
|
|
12
|
+
const saga_runner_1 = require("../../saga-runner");
|
|
13
|
+
const browser_3 = require("@sentry/browser");
|
|
14
|
+
function PresetBrowser() {
|
|
15
|
+
return (0, di_1.createPreset)([
|
|
16
|
+
[tokens_1.KnownToken.Config.source, browser_1.createConfigSource],
|
|
17
|
+
[tokens_1.KnownToken.Config.base, provideBaseConfig],
|
|
18
|
+
[tokens_1.KnownToken.logger, provideLogger],
|
|
19
|
+
[tokens_1.KnownToken.sagaRunner, provideSagaRunner],
|
|
20
|
+
]);
|
|
21
|
+
}
|
|
22
|
+
exports.PresetBrowser = PresetBrowser;
|
|
23
|
+
function provideBaseConfig(resolve) {
|
|
24
|
+
const source = resolve(tokens_1.KnownToken.Config.source);
|
|
25
|
+
return (0, base_1.createBaseConfig)(source);
|
|
26
|
+
}
|
|
27
|
+
function provideLogger(resolve) {
|
|
28
|
+
const source = resolve(tokens_1.KnownToken.Config.source);
|
|
29
|
+
// @todo брать клиент и библиотеку из di-контейнера
|
|
30
|
+
const sentry = (0, browser_2.createSentryLib)({
|
|
31
|
+
dsn: source.get('SENTRY_CLIENT_DSN'),
|
|
32
|
+
release: source.get('SENTRY_RELEASE'),
|
|
33
|
+
environment: source.get('SENTRY_ENVIRONMENT'),
|
|
34
|
+
integrations: browser_3.defaultIntegrations,
|
|
35
|
+
});
|
|
36
|
+
const logger = (0, logger_1.createLogger)();
|
|
37
|
+
logger.subscribe((0, sentry_1.createSentryHandler)(sentry));
|
|
38
|
+
return logger;
|
|
39
|
+
}
|
|
40
|
+
function provideSagaRunner(resolve) {
|
|
41
|
+
const logger = resolve(tokens_1.KnownToken.logger);
|
|
42
|
+
return (0, saga_runner_1.createSagaRunner)(logger);
|
|
43
|
+
}
|
|
44
|
+
//# sourceMappingURL=index.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"index.js","sourceRoot":"","sources":["../../../src/preset/browser/index.ts"],"names":[],"mappings":";;;AAAA,wDAAwD;AACxD,iCAAiD;AACjD,yCAA0C;AAC1C,4CAAqD;AACrD,kDAA0D;AAC1D,yDAA8D;AAC9D,yCAA4C;AAC5C,wDAAkE;AAClE,mDAAqD;AACrD,6CAAsD;AAKtD,SAAgB,aAAa;IAC3B,OAAO,IAAA,iBAAY,EAAC;QAClB,CAAC,mBAAU,CAAC,MAAM,CAAC,MAAM,EAAE,4BAAkB,CAAC;QAC9C,CAAC,mBAAU,CAAC,MAAM,CAAC,IAAI,EAAE,iBAAiB,CAAC;QAC3C,CAAC,mBAAU,CAAC,MAAM,EAAE,aAAa,CAAC;QAClC,CAAC,mBAAU,CAAC,UAAU,EAAE,iBAAiB,CAAC;KAC3C,CAAC,CAAC;AACL,CAAC;AAPD,sCAOC;AAED,SAAS,iBAAiB,CAAC,OAAgB;IACzC,MAAM,MAAM,GAAG,OAAO,CAAC,mBAAU,CAAC,MAAM,CAAC,MAAM,CAAC,CAAC;IAEjD,OAAO,IAAA,uBAAgB,EAAC,MAAM,CAAC,CAAC;AAClC,CAAC;AAED,SAAS,aAAa,CAAC,OAAgB;IACrC,MAAM,MAAM,GAAG,OAAO,CAAC,mBAAU,CAAC,MAAM,CAAC,MAAM,CAAC,CAAC;IAEjD,mDAAmD;IACnD,MAAM,MAAM,GAAG,IAAA,yBAAe,EAAC;QAC7B,GAAG,EAAE,MAAM,CAAC,GAAG,CAAC,mBAAmB,CAAC;QACpC,OAAO,EAAE,MAAM,CAAC,GAAG,CAAC,gBAAgB,CAAC;QACrC,WAAW,EAAE,MAAM,CAAC,GAAG,CAAC,oBAAoB,CAAC;QAC7C,YAAY,EAAE,6BAAmB;KAClC,CAAC,CAAC;IAEH,MAAM,MAAM,GAAG,IAAA,qBAAY,GAAE,CAAC;IAE9B,MAAM,CAAC,SAAS,CAAC,IAAA,4BAAmB,EAAC,MAAM,CAAC,CAAC,CAAC;IAE9C,OAAO,MAAM,CAAC;AAChB,CAAC;AAED,SAAS,iBAAiB,CAAC,OAAgB;IACzC,MAAM,MAAM,GAAG,OAAO,CAAC,mBAAU,CAAC,MAAM,CAAC,CAAC;IAE1C,OAAO,IAAA,8BAAgB,EAAC,MAAM,CAAC,CAAC;AAClC,CAAC"}
|
package/preset/node/index.d.ts
CHANGED
|
@@ -1,9 +1,10 @@
|
|
|
1
|
-
import type { Preset } from '../types';
|
|
2
|
-
import type { Provider } from '../../container/types';
|
|
3
1
|
import type { BaseConfig } from '../../config/types';
|
|
4
2
|
import type { Logger } from '../../logger/types';
|
|
5
3
|
import type { Tracer } from '@opentelemetry/api';
|
|
6
4
|
import type { DefaultMiddleware } from '../../http-server/types';
|
|
5
|
+
import { Provider, Preset } from '../../di';
|
|
6
|
+
import { BasicTracerProvider, SpanExporter } from '@opentelemetry/tracing';
|
|
7
|
+
import { Resource } from '@opentelemetry/resources';
|
|
7
8
|
/**
|
|
8
9
|
* Возвращает preset с зависимостями по умолчанию для frontend-микросервисов на Node.js.
|
|
9
10
|
* @return Preset.
|
|
@@ -12,4 +13,7 @@ export declare function PresetNode(): Preset;
|
|
|
12
13
|
export declare const provideBaseConfig: Provider<BaseConfig>;
|
|
13
14
|
export declare const provideLogger: Provider<Logger>;
|
|
14
15
|
export declare const provideTracer: Provider<Tracer>;
|
|
16
|
+
export declare const provideSpanExporter: Provider<SpanExporter>;
|
|
17
|
+
export declare const provideTracerProvider: Provider<BasicTracerProvider>;
|
|
18
|
+
export declare const provideTracerProviderResource: Provider<Resource>;
|
|
15
19
|
export declare const provideDefaultMiddleware: Provider<DefaultMiddleware>;
|
package/preset/node/index.js
CHANGED
|
@@ -3,51 +3,58 @@ var __importDefault = (this && this.__importDefault) || function (mod) {
|
|
|
3
3
|
return (mod && mod.__esModule) ? mod : { "default": mod };
|
|
4
4
|
};
|
|
5
5
|
Object.defineProperty(exports, "__esModule", { value: true });
|
|
6
|
-
exports.provideDefaultMiddleware = exports.provideTracer = exports.provideLogger = exports.provideBaseConfig = exports.PresetNode = void 0;
|
|
6
|
+
exports.provideDefaultMiddleware = exports.provideTracerProviderResource = exports.provideTracerProvider = exports.provideSpanExporter = exports.provideTracer = exports.provideLogger = exports.provideBaseConfig = exports.PresetNode = void 0;
|
|
7
|
+
const di_1 = require("../../di");
|
|
8
|
+
const tracing_1 = require("@opentelemetry/tracing");
|
|
7
9
|
const tokens_1 = require("../../tokens");
|
|
8
|
-
const __1 = require("..");
|
|
9
10
|
const node_1 = require("../../config/node");
|
|
10
|
-
const
|
|
11
|
+
const base_1 = require("../../config/base");
|
|
11
12
|
const logger_1 = require("../../logger");
|
|
12
|
-
const node_2 = require("../../tracer/node");
|
|
13
13
|
const console_1 = require("../../logger/handler/console");
|
|
14
14
|
const sentry_1 = require("../../logger/handler/sentry");
|
|
15
|
-
const
|
|
15
|
+
const node_2 = require("../../error-tracker/node");
|
|
16
16
|
const logging_1 = require("../../http-server/middleware/logging");
|
|
17
|
-
const
|
|
17
|
+
const tracing_2 = require("../../http-server/middleware/tracing");
|
|
18
18
|
const metrics_1 = require("../../http-server/middleware/metrics");
|
|
19
|
-
const
|
|
19
|
+
const node_3 = require("../../metrics/node");
|
|
20
20
|
const exporter_jaeger_1 = require("@opentelemetry/exporter-jaeger");
|
|
21
21
|
const middleware_axios_1 = require("middleware-axios");
|
|
22
22
|
const express_1 = __importDefault(require("express"));
|
|
23
|
-
const
|
|
23
|
+
const node_4 = require("@sentry/node");
|
|
24
|
+
const sdk_trace_node_1 = require("@opentelemetry/sdk-trace-node");
|
|
25
|
+
const propagator_jaeger_1 = require("@opentelemetry/propagator-jaeger");
|
|
26
|
+
const utils_1 = require("../../tracing/utils");
|
|
24
27
|
/**
|
|
25
28
|
* Возвращает preset с зависимостями по умолчанию для frontend-микросервисов на Node.js.
|
|
26
29
|
* @return Preset.
|
|
27
30
|
*/
|
|
28
31
|
function PresetNode() {
|
|
29
|
-
return (0,
|
|
32
|
+
return (0, di_1.createPreset)([
|
|
30
33
|
[tokens_1.KnownToken.Config.source, node_1.createConfigSource],
|
|
31
34
|
[tokens_1.KnownToken.Config.base, exports.provideBaseConfig],
|
|
32
35
|
[tokens_1.KnownToken.logger, exports.provideLogger],
|
|
33
|
-
[tokens_1.KnownToken.tracer, exports.provideTracer],
|
|
36
|
+
[tokens_1.KnownToken.Tracing.tracer, exports.provideTracer],
|
|
37
|
+
[tokens_1.KnownToken.Tracing.spanExporter, exports.provideSpanExporter],
|
|
38
|
+
[tokens_1.KnownToken.Tracing.tracerProvider, exports.provideTracerProvider],
|
|
39
|
+
[tokens_1.KnownToken.Tracing.tracerProviderResource, exports.provideTracerProviderResource],
|
|
34
40
|
[tokens_1.KnownToken.Http.Client.factory, () => middleware_axios_1.create],
|
|
35
41
|
[tokens_1.KnownToken.Http.Server.factory, () => express_1.default],
|
|
36
42
|
[tokens_1.KnownToken.Http.Server.Defaults.middleware, exports.provideDefaultMiddleware],
|
|
37
|
-
[tokens_1.KnownToken.Metrics.httpApp,
|
|
43
|
+
[tokens_1.KnownToken.Metrics.httpApp, node_3.createMetricsHttpApp],
|
|
38
44
|
]);
|
|
39
45
|
}
|
|
40
46
|
exports.PresetNode = PresetNode;
|
|
41
47
|
const provideBaseConfig = resolve => {
|
|
42
48
|
const source = resolve(tokens_1.KnownToken.Config.source);
|
|
43
|
-
return (0,
|
|
49
|
+
return (0, base_1.createBaseConfig)(source);
|
|
44
50
|
};
|
|
45
51
|
exports.provideBaseConfig = provideBaseConfig;
|
|
46
52
|
const provideLogger = resolve => {
|
|
47
53
|
const source = resolve(tokens_1.KnownToken.Config.source);
|
|
48
54
|
const config = resolve(tokens_1.KnownToken.Config.base);
|
|
49
|
-
|
|
50
|
-
|
|
55
|
+
// @todo брать клиент и библиотеку из контейнера
|
|
56
|
+
const sentry = (0, node_2.createSentryLib)({
|
|
57
|
+
dsn: source.get('SENTRY_SERVER_DSN'),
|
|
51
58
|
release: source.get('SENTRY_RELEASE'),
|
|
52
59
|
environment: source.get('SENTRY_ENVIRONMENT'),
|
|
53
60
|
});
|
|
@@ -58,22 +65,47 @@ const provideLogger = resolve => {
|
|
|
58
65
|
};
|
|
59
66
|
exports.provideLogger = provideLogger;
|
|
60
67
|
const provideTracer = resolve => {
|
|
68
|
+
const config = resolve(tokens_1.KnownToken.Config.base);
|
|
69
|
+
const provider = resolve(tokens_1.KnownToken.Tracing.tracerProvider);
|
|
70
|
+
return provider.getTracer(config.appName, config.appVersion);
|
|
71
|
+
};
|
|
72
|
+
exports.provideTracer = provideTracer;
|
|
73
|
+
const provideSpanExporter = resolve => {
|
|
61
74
|
const source = resolve(tokens_1.KnownToken.Config.source);
|
|
62
75
|
const exporter = new exporter_jaeger_1.JaegerExporter({
|
|
63
|
-
|
|
76
|
+
host: source.require('JAEGER_AGENT_HOST'),
|
|
77
|
+
port: parseInt(source.require('JAEGER_AGENT_PORT')) || undefined,
|
|
64
78
|
});
|
|
65
|
-
return
|
|
79
|
+
return exporter;
|
|
66
80
|
};
|
|
67
|
-
exports.
|
|
81
|
+
exports.provideSpanExporter = provideSpanExporter;
|
|
82
|
+
const provideTracerProvider = resolve => {
|
|
83
|
+
const exporter = resolve(tokens_1.KnownToken.Tracing.spanExporter);
|
|
84
|
+
const resource = resolve(tokens_1.KnownToken.Tracing.tracerProviderResource);
|
|
85
|
+
const provider = new sdk_trace_node_1.NodeTracerProvider({
|
|
86
|
+
resource,
|
|
87
|
+
});
|
|
88
|
+
provider.addSpanProcessor(new tracing_1.BatchSpanProcessor(exporter)); // @todo разобраться с as any
|
|
89
|
+
provider.register({
|
|
90
|
+
propagator: new propagator_jaeger_1.JaegerPropagator(),
|
|
91
|
+
});
|
|
92
|
+
return provider; // @todo разобраться с as any
|
|
93
|
+
};
|
|
94
|
+
exports.provideTracerProvider = provideTracerProvider;
|
|
95
|
+
const provideTracerProviderResource = resolve => {
|
|
96
|
+
const config = resolve(tokens_1.KnownToken.Config.base);
|
|
97
|
+
return (0, utils_1.getConventionalResource)(config);
|
|
98
|
+
};
|
|
99
|
+
exports.provideTracerProviderResource = provideTracerProviderResource;
|
|
68
100
|
const provideDefaultMiddleware = resolve => {
|
|
69
101
|
const config = resolve(tokens_1.KnownToken.Config.base);
|
|
70
102
|
const logger = resolve(tokens_1.KnownToken.logger);
|
|
71
|
-
const tracer = resolve(tokens_1.KnownToken.tracer);
|
|
72
|
-
const metrics = (0,
|
|
103
|
+
const tracer = resolve(tokens_1.KnownToken.Tracing.tracer);
|
|
104
|
+
const metrics = (0, node_3.createDefaultMetrics)();
|
|
73
105
|
return {
|
|
74
|
-
start: [
|
|
106
|
+
start: [node_4.Handlers.requestHandler()],
|
|
75
107
|
logging: [(0, logging_1.loggingMiddleware)(config, logger)],
|
|
76
|
-
tracing: [(0,
|
|
108
|
+
tracing: [(0, tracing_2.tracingMiddleware)(tracer)],
|
|
77
109
|
metrics: [
|
|
78
110
|
(0, metrics_1.responseMetricsMiddleware)(config, {
|
|
79
111
|
counter: metrics.requestCount,
|
|
@@ -83,7 +115,7 @@ const provideDefaultMiddleware = resolve => {
|
|
|
83
115
|
histogram: metrics.renderDuration,
|
|
84
116
|
}),
|
|
85
117
|
],
|
|
86
|
-
finish: [
|
|
118
|
+
finish: [node_4.Handlers.errorHandler()],
|
|
87
119
|
};
|
|
88
120
|
};
|
|
89
121
|
exports.provideDefaultMiddleware = provideDefaultMiddleware;
|