@steedos/server 3.0.0-beta.8
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/LICENSE.txt +661 -0
- package/README.md +10 -0
- package/dist/app.controller.d.ts +7 -0
- package/dist/app.controller.js +35 -0
- package/dist/app.controller.js.map +1 -0
- package/dist/app.module.d.ts +4 -0
- package/dist/app.module.js +84 -0
- package/dist/app.module.js.map +1 -0
- package/dist/app.moleculer.d.ts +9 -0
- package/dist/app.moleculer.js +129 -0
- package/dist/app.moleculer.js.map +1 -0
- package/dist/bootstrap.d.ts +1 -0
- package/dist/bootstrap.js +156 -0
- package/dist/bootstrap.js.map +1 -0
- package/dist/config/env.config.d.ts +1 -0
- package/dist/config/env.config.js +128 -0
- package/dist/config/env.config.js.map +1 -0
- package/dist/config/index.d.ts +9 -0
- package/dist/config/index.js +46 -0
- package/dist/config/index.js.map +1 -0
- package/dist/config/moleculler.config.d.ts +63 -0
- package/dist/config/moleculler.config.js +96 -0
- package/dist/config/moleculler.config.js.map +1 -0
- package/dist/config/project.config.d.ts +1 -0
- package/dist/config/project.config.js +15 -0
- package/dist/config/project.config.js.map +1 -0
- package/dist/config/steedos.config.d.ts +13 -0
- package/dist/config/steedos.config.js +163 -0
- package/dist/config/steedos.config.js.map +1 -0
- package/dist/filters/all-exceptions.filter.d.ts +5 -0
- package/dist/filters/all-exceptions.filter.js +62 -0
- package/dist/filters/all-exceptions.filter.js.map +1 -0
- package/dist/index.d.ts +1 -0
- package/dist/index.js +18 -0
- package/dist/index.js.map +1 -0
- package/dist/main.d.ts +1 -0
- package/dist/main.js +5 -0
- package/dist/main.js.map +1 -0
- package/package.json +136 -0
|
@@ -0,0 +1,46 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
var __awaiter = (this && this.__awaiter) || function (thisArg, _arguments, P, generator) {
|
|
3
|
+
function adopt(value) { return value instanceof P ? value : new P(function (resolve) { resolve(value); }); }
|
|
4
|
+
return new (P || (P = Promise))(function (resolve, reject) {
|
|
5
|
+
function fulfilled(value) { try { step(generator.next(value)); } catch (e) { reject(e); } }
|
|
6
|
+
function rejected(value) { try { step(generator["throw"](value)); } catch (e) { reject(e); } }
|
|
7
|
+
function step(result) { result.done ? resolve(result.value) : adopt(result.value).then(fulfilled, rejected); }
|
|
8
|
+
step((generator = generator.apply(thisArg, _arguments || [])).next());
|
|
9
|
+
});
|
|
10
|
+
};
|
|
11
|
+
var __importDefault = (this && this.__importDefault) || function (mod) {
|
|
12
|
+
return (mod && mod.__esModule) ? mod : { "default": mod };
|
|
13
|
+
};
|
|
14
|
+
Object.defineProperty(exports, "__esModule", { value: true });
|
|
15
|
+
exports.getEnvConfigs = exports.configs = exports.steedosConfig = exports.projectConfigs = void 0;
|
|
16
|
+
exports.getDbConfigs = getDbConfigs;
|
|
17
|
+
exports.getSteedosConfigs = getSteedosConfigs;
|
|
18
|
+
exports.getMoleculerConfigs = getMoleculerConfigs;
|
|
19
|
+
exports.getConfigs = getConfigs;
|
|
20
|
+
const steedos_config_1 = __importDefault(require("./steedos.config"));
|
|
21
|
+
const env_config_1 = __importDefault(require("./env.config"));
|
|
22
|
+
exports.getEnvConfigs = env_config_1.default;
|
|
23
|
+
const moleculler_config_1 = __importDefault(require("./moleculler.config"));
|
|
24
|
+
const project_config_1 = __importDefault(require("./project.config"));
|
|
25
|
+
exports.projectConfigs = (0, project_config_1.default)(process.cwd());
|
|
26
|
+
exports.steedosConfig = steedos_config_1.default.getSteedosConfig();
|
|
27
|
+
global.Steedos = {
|
|
28
|
+
settings: exports.steedosConfig.settings
|
|
29
|
+
};
|
|
30
|
+
function getDbConfigs() {
|
|
31
|
+
return __awaiter(this, void 0, void 0, function* () {
|
|
32
|
+
return {};
|
|
33
|
+
});
|
|
34
|
+
}
|
|
35
|
+
function getSteedosConfigs() {
|
|
36
|
+
return exports.steedosConfig;
|
|
37
|
+
}
|
|
38
|
+
function getMoleculerConfigs() {
|
|
39
|
+
const { moleculer } = (0, env_config_1.default)();
|
|
40
|
+
return Object.assign(Object.assign({}, moleculler_config_1.default), moleculer);
|
|
41
|
+
}
|
|
42
|
+
function getConfigs() {
|
|
43
|
+
return Object.assign(Object.assign({}, exports.steedosConfig), (0, env_config_1.default)());
|
|
44
|
+
}
|
|
45
|
+
exports.configs = getConfigs();
|
|
46
|
+
//# sourceMappingURL=index.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"index.js","sourceRoot":"","sources":["../../src/config/index.ts"],"names":[],"mappings":";;;;;;;;;;;;;;;AAmBA,oCAEC;AAED,8CAEC;AAED,kDAMC;AAED,gCAKC;AAjCD,sEAA6C;AAC7C,8DAAyC;AAoChC,wBApCF,oBAAa,CAoCE;AAnCtB,4EAAmD;AACnD,sEAAiD;AAEpC,QAAA,cAAc,GAAG,IAAA,wBAAiB,EAAC,OAAO,CAAC,GAAG,EAAE,CAAC,CAAC;AAClD,QAAA,aAAa,GAAG,wBAAa,CAAC,gBAAgB,EAAE,CAAC;AAE9D,MAAM,CAAC,OAAO,GAAG;IACf,QAAQ,EAAE,qBAAa,CAAC,QAAQ;CACjC,CAAC;AAEF,SAAsB,YAAY;;QAChC,OAAO,EAAE,CAAC;IACZ,CAAC;CAAA;AAED,SAAgB,iBAAiB;IAC/B,OAAO,qBAAa,CAAC;AACvB,CAAC;AAED,SAAgB,mBAAmB;IACjC,MAAM,EAAE,SAAS,EAAE,GAAG,IAAA,oBAAa,GAAE,CAAC;IACtC,uCACK,2BAAgB,GAChB,SAAS,EACZ;AACJ,CAAC;AAED,SAAgB,UAAU;IACxB,uCACK,qBAAa,GACb,IAAA,oBAAa,GAAE,EAClB;AACJ,CAAC;AAEY,QAAA,OAAO,GAAG,UAAU,EAAE,CAAC"}
|
|
@@ -0,0 +1,63 @@
|
|
|
1
|
+
declare const _default: {
|
|
2
|
+
namespace: string;
|
|
3
|
+
nodeID: any;
|
|
4
|
+
metadata: {};
|
|
5
|
+
logger: {
|
|
6
|
+
type: string;
|
|
7
|
+
options: {
|
|
8
|
+
level: string;
|
|
9
|
+
colors: boolean;
|
|
10
|
+
moduleColors: boolean;
|
|
11
|
+
formatter: string;
|
|
12
|
+
objectPrinter: any;
|
|
13
|
+
autoPadding: boolean;
|
|
14
|
+
};
|
|
15
|
+
};
|
|
16
|
+
transporter: string;
|
|
17
|
+
cacher: string;
|
|
18
|
+
serializer: string;
|
|
19
|
+
requestTimeout: number;
|
|
20
|
+
retryPolicy: {
|
|
21
|
+
enabled: boolean;
|
|
22
|
+
};
|
|
23
|
+
maxCallLevel: number;
|
|
24
|
+
heartbeatInterval: number;
|
|
25
|
+
heartbeatTimeout: number;
|
|
26
|
+
contextParamsCloning: boolean;
|
|
27
|
+
tracking: {
|
|
28
|
+
enabled: boolean;
|
|
29
|
+
};
|
|
30
|
+
disableBalancer: boolean;
|
|
31
|
+
registry: {
|
|
32
|
+
strategy: string;
|
|
33
|
+
preferLocal: boolean;
|
|
34
|
+
};
|
|
35
|
+
circuitBreaker: {
|
|
36
|
+
enabled: boolean;
|
|
37
|
+
threshold: number;
|
|
38
|
+
minRequestCount: number;
|
|
39
|
+
windowTime: number;
|
|
40
|
+
halfOpenTime: number;
|
|
41
|
+
check: (err: any) => boolean;
|
|
42
|
+
};
|
|
43
|
+
bulkhead: {
|
|
44
|
+
enabled: boolean;
|
|
45
|
+
concurrency: number;
|
|
46
|
+
maxQueueSize: number;
|
|
47
|
+
};
|
|
48
|
+
validator: boolean;
|
|
49
|
+
errorHandler: any;
|
|
50
|
+
metrics: {
|
|
51
|
+
enabled: boolean;
|
|
52
|
+
};
|
|
53
|
+
tracing: {
|
|
54
|
+
enabled: boolean;
|
|
55
|
+
};
|
|
56
|
+
middlewares: any[];
|
|
57
|
+
replCommands: any;
|
|
58
|
+
skipProcessEventRegistration: boolean;
|
|
59
|
+
created(broker: any): void;
|
|
60
|
+
started(broker: any): void;
|
|
61
|
+
stopped(broker: any): void;
|
|
62
|
+
};
|
|
63
|
+
export default _default;
|
|
@@ -0,0 +1,96 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
var __awaiter = (this && this.__awaiter) || function (thisArg, _arguments, P, generator) {
|
|
3
|
+
function adopt(value) { return value instanceof P ? value : new P(function (resolve) { resolve(value); }); }
|
|
4
|
+
return new (P || (P = Promise))(function (resolve, reject) {
|
|
5
|
+
function fulfilled(value) { try { step(generator.next(value)); } catch (e) { reject(e); } }
|
|
6
|
+
function rejected(value) { try { step(generator["throw"](value)); } catch (e) { reject(e); } }
|
|
7
|
+
function step(result) { result.done ? resolve(result.value) : adopt(result.value).then(fulfilled, rejected); }
|
|
8
|
+
step((generator = generator.apply(thisArg, _arguments || [])).next());
|
|
9
|
+
});
|
|
10
|
+
};
|
|
11
|
+
Object.defineProperty(exports, "__esModule", { value: true });
|
|
12
|
+
exports.default = {
|
|
13
|
+
namespace: "steedos",
|
|
14
|
+
nodeID: null,
|
|
15
|
+
metadata: {},
|
|
16
|
+
logger: {
|
|
17
|
+
type: "Console",
|
|
18
|
+
options: {
|
|
19
|
+
level: process.env.B6_MO_LOG_LEVEL,
|
|
20
|
+
colors: true,
|
|
21
|
+
moduleColors: false,
|
|
22
|
+
formatter: "[MO] {timestamp} {level} [{mod}] {msg}",
|
|
23
|
+
objectPrinter: null,
|
|
24
|
+
autoPadding: false,
|
|
25
|
+
},
|
|
26
|
+
},
|
|
27
|
+
transporter: process.env.B6_TRANSPORTER,
|
|
28
|
+
cacher: process.env.B6_CACHER,
|
|
29
|
+
serializer: "JSON",
|
|
30
|
+
requestTimeout: 0,
|
|
31
|
+
retryPolicy: {
|
|
32
|
+
enabled: false,
|
|
33
|
+
},
|
|
34
|
+
maxCallLevel: 100,
|
|
35
|
+
heartbeatInterval: 10,
|
|
36
|
+
heartbeatTimeout: 30,
|
|
37
|
+
contextParamsCloning: false,
|
|
38
|
+
tracking: {
|
|
39
|
+
enabled: false,
|
|
40
|
+
},
|
|
41
|
+
disableBalancer: false,
|
|
42
|
+
registry: {
|
|
43
|
+
strategy: "RoundRobin",
|
|
44
|
+
preferLocal: true,
|
|
45
|
+
},
|
|
46
|
+
circuitBreaker: {
|
|
47
|
+
enabled: false,
|
|
48
|
+
threshold: 0.5,
|
|
49
|
+
minRequestCount: 20,
|
|
50
|
+
windowTime: 60,
|
|
51
|
+
halfOpenTime: 10000,
|
|
52
|
+
check: (err) => err && err.code >= 500,
|
|
53
|
+
},
|
|
54
|
+
bulkhead: {
|
|
55
|
+
enabled: false,
|
|
56
|
+
concurrency: 10,
|
|
57
|
+
maxQueueSize: 100,
|
|
58
|
+
},
|
|
59
|
+
validator: true,
|
|
60
|
+
errorHandler: null,
|
|
61
|
+
metrics: {
|
|
62
|
+
enabled: false,
|
|
63
|
+
},
|
|
64
|
+
tracing: {
|
|
65
|
+
enabled: false,
|
|
66
|
+
},
|
|
67
|
+
middlewares: [],
|
|
68
|
+
replCommands: null,
|
|
69
|
+
skipProcessEventRegistration: true,
|
|
70
|
+
created(broker) {
|
|
71
|
+
global.broker = broker;
|
|
72
|
+
broker.logger.warn("Clear all cache entries on startup.");
|
|
73
|
+
broker.cacher.clean();
|
|
74
|
+
const objectql = require("@steedos/objectql");
|
|
75
|
+
objectql.broker.init(broker);
|
|
76
|
+
process.on("SIGTERM", close.bind(broker, "SIGTERM"));
|
|
77
|
+
process.on("SIGINT", close.bind(broker, "SIGINT"));
|
|
78
|
+
function close(signal) {
|
|
79
|
+
return __awaiter(this, void 0, void 0, function* () {
|
|
80
|
+
try {
|
|
81
|
+
yield this.cacher.clean();
|
|
82
|
+
yield this.cacher.close();
|
|
83
|
+
}
|
|
84
|
+
catch (error) {
|
|
85
|
+
}
|
|
86
|
+
console.log(`[${signal}]服务已停止: namespace: ${this.namespace}, nodeID: ${this.nodeID}`);
|
|
87
|
+
process.exit(0);
|
|
88
|
+
});
|
|
89
|
+
}
|
|
90
|
+
},
|
|
91
|
+
started(broker) {
|
|
92
|
+
},
|
|
93
|
+
stopped(broker) {
|
|
94
|
+
},
|
|
95
|
+
};
|
|
96
|
+
//# sourceMappingURL=moleculler.config.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"moleculler.config.js","sourceRoot":"","sources":["../../src/config/moleculler.config.ts"],"names":[],"mappings":"AAAA,YAAY,CAAC;;;;;;;;;;;AAWb,kBAAe;IACb,SAAS,EAAE,SAAS;IACpB,MAAM,EAAE,IAAI;IACZ,QAAQ,EAAE,EAAE;IAYZ,MAAM,EAAE;QACN,IAAI,EAAE,SAAS;QACf,OAAO,EAAE;YAEP,KAAK,EAAE,OAAO,CAAC,GAAG,CAAC,eAAe;YAElC,MAAM,EAAE,IAAI;YAEZ,YAAY,EAAE,KAAK;YAEnB,SAAS,EAAE,wCAAwC;YAEnD,aAAa,EAAE,IAAI;YAEnB,WAAW,EAAE,KAAK;SACnB;KACF;IAED,WAAW,EAAE,OAAO,CAAC,GAAG,CAAC,cAAc;IAEvC,MAAM,EAAE,OAAO,CAAC,GAAG,CAAC,SAAS;IAE7B,UAAU,EAAE,MAAM;IAElB,cAAc,EAAE,CAAC;IAEjB,WAAW,EAAE;QACX,OAAO,EAAE,KAAK;KACf;IAED,YAAY,EAAE,GAAG;IAEjB,iBAAiB,EAAE,EAAE;IACrB,gBAAgB,EAAE,EAAE;IAEpB,oBAAoB,EAAE,KAAK;IAE3B,QAAQ,EAAE;QACR,OAAO,EAAE,KAAK;KACf;IAED,eAAe,EAAE,KAAK;IAEtB,QAAQ,EAAE;QACR,QAAQ,EAAE,YAAY;QACtB,WAAW,EAAE,IAAI;KAClB;IAED,cAAc,EAAE;QACd,OAAO,EAAE,KAAK;QACd,SAAS,EAAE,GAAG;QACd,eAAe,EAAE,EAAE;QACnB,UAAU,EAAE,EAAE;QACd,YAAY,EAAE,KAAK;QACnB,KAAK,EAAE,CAAC,GAAQ,EAAE,EAAE,CAAC,GAAG,IAAI,GAAG,CAAC,IAAI,IAAI,GAAG;KAC5C;IAED,QAAQ,EAAE;QACR,OAAO,EAAE,KAAK;QACd,WAAW,EAAE,EAAE;QACf,YAAY,EAAE,GAAG;KAClB;IAED,SAAS,EAAE,IAAI;IAEf,YAAY,EAAE,IAAI;IAElB,OAAO,EAAE;QACP,OAAO,EAAE,KAAK;KACf;IAED,OAAO,EAAE;QACP,OAAO,EAAE,KAAK;KACf;IAED,WAAW,EAAE,EAAE;IAEf,YAAY,EAAE,IAAI;IAElB,4BAA4B,EAAE,IAAI;IAElC,OAAO,CAAC,MAAW;QACjB,MAAM,CAAC,MAAM,GAAG,MAAM,CAAC;QAEvB,MAAM,CAAC,MAAM,CAAC,IAAI,CAAC,qCAAqC,CAAC,CAAC;QAC1D,MAAM,CAAC,MAAM,CAAC,KAAK,EAAE,CAAC;QACtB,MAAM,QAAQ,GAAG,OAAO,CAAC,mBAAmB,CAAC,CAAC;QAC9C,QAAQ,CAAC,MAAM,CAAC,IAAI,CAAC,MAAM,CAAC,CAAC;QAE7B,OAAO,CAAC,EAAE,CAAC,SAAS,EAAE,KAAK,CAAC,IAAI,CAAC,MAAM,EAAE,SAAS,CAAC,CAAC,CAAC;QACrD,OAAO,CAAC,EAAE,CAAC,QAAQ,EAAE,KAAK,CAAC,IAAI,CAAC,MAAM,EAAE,QAAQ,CAAC,CAAC,CAAC;QACnD,SAAe,KAAK,CAAC,MAAM;;gBACzB,IAAI,CAAC;oBACH,MAAM,IAAI,CAAC,MAAM,CAAC,KAAK,EAAE,CAAC;oBAC1B,MAAM,IAAI,CAAC,MAAM,CAAC,KAAK,EAAE,CAAC;gBAC5B,CAAC;gBAAC,OAAO,KAAK,EAAE,CAAC;gBAEjB,CAAC;gBACD,OAAO,CAAC,GAAG,CACT,IAAI,MAAM,sBAAsB,IAAI,CAAC,SAAS,aAAa,IAAI,CAAC,MAAM,EAAE,CACzE,CAAC;gBACF,OAAO,CAAC,IAAI,CAAC,CAAC,CAAC,CAAC;YAClB,CAAC;SAAA;IACH,CAAC;IAED,OAAO,CAAC,MAAW;IAEnB,CAAC;IAED,OAAO,CAAC,MAAW;IAEnB,CAAC;CACF,CAAC"}
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
export default function getProjectConfigs(projectDir: string): any | null;
|
|
@@ -0,0 +1,15 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
Object.defineProperty(exports, "__esModule", { value: true });
|
|
3
|
+
exports.default = getProjectConfigs;
|
|
4
|
+
const fs_1 = require("fs");
|
|
5
|
+
const path_1 = require("path");
|
|
6
|
+
function getProjectConfigs(projectDir) {
|
|
7
|
+
const configPath = (0, path_1.join)(projectDir, 'b6.config.js');
|
|
8
|
+
if ((0, fs_1.existsSync)(configPath)) {
|
|
9
|
+
return require(configPath);
|
|
10
|
+
}
|
|
11
|
+
else {
|
|
12
|
+
return {};
|
|
13
|
+
}
|
|
14
|
+
}
|
|
15
|
+
//# sourceMappingURL=project.config.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"project.config.js","sourceRoot":"","sources":["../../src/config/project.config.ts"],"names":[],"mappings":";;AAGA,oCAQC;AAXD,2BAAgC;AAChC,+BAA4B;AAE5B,SAAwB,iBAAiB,CAAC,UAAkB;IAC1D,MAAM,UAAU,GAAG,IAAA,WAAI,EAAC,UAAU,EAAE,cAAc,CAAC,CAAC;IAEpD,IAAI,IAAA,eAAU,EAAC,UAAU,CAAC,EAAE,CAAC;QAC3B,OAAO,OAAO,CAAC,UAAU,CAAC,CAAC;IAC7B,CAAC;SAAM,CAAC;QACN,OAAO,EAAE,CAAC;IACZ,CAAC;AACH,CAAC"}
|
|
@@ -0,0 +1,13 @@
|
|
|
1
|
+
export default class SteedosConfig {
|
|
2
|
+
static loadSettings: (filePath: string) => any;
|
|
3
|
+
static loadDefaultSettings(): any;
|
|
4
|
+
static loadProjectSettings(): any;
|
|
5
|
+
static getSteedosConfig(): any;
|
|
6
|
+
static mergeSchemaLifecycleHandlers(src: any, target: any): unknown[];
|
|
7
|
+
static flatten(arr: any): any;
|
|
8
|
+
}
|
|
9
|
+
export declare function isObject(value: any): boolean;
|
|
10
|
+
export declare function isFunction(value: any): boolean;
|
|
11
|
+
export declare function isPlainObject(value: any): boolean;
|
|
12
|
+
export declare function isJsonMap(value: any): boolean;
|
|
13
|
+
export declare const steedosConfig: any;
|
|
@@ -0,0 +1,163 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
Object.defineProperty(exports, "__esModule", { value: true });
|
|
3
|
+
exports.steedosConfig = void 0;
|
|
4
|
+
exports.isObject = isObject;
|
|
5
|
+
exports.isFunction = isFunction;
|
|
6
|
+
exports.isPlainObject = isPlainObject;
|
|
7
|
+
exports.isJsonMap = isJsonMap;
|
|
8
|
+
const lodash_1 = require("lodash");
|
|
9
|
+
const path = require("path");
|
|
10
|
+
const fs = require("fs");
|
|
11
|
+
const clone = require("clone");
|
|
12
|
+
const validator = require('validator');
|
|
13
|
+
const yaml = require('js-yaml');
|
|
14
|
+
function calcString(str, content = process.env) {
|
|
15
|
+
if (!(0, lodash_1.isString)(str)) {
|
|
16
|
+
return str;
|
|
17
|
+
}
|
|
18
|
+
let calcFun = null;
|
|
19
|
+
var reg = /(\${[^{}]*\})/g;
|
|
20
|
+
let rev = str.replace(reg, function (m, $1) {
|
|
21
|
+
return $1.replace(/\{\s*/, "{args[\"").replace(/\s*\}/, "\"]}");
|
|
22
|
+
});
|
|
23
|
+
eval(`calcFun = function(args){return \`${rev}\`}`);
|
|
24
|
+
let val = calcFun.call({}, content);
|
|
25
|
+
if ((0, lodash_1.isString)(val) && val) {
|
|
26
|
+
return val.replace(/\\r/g, '\r').replace(/\\n/g, '\n').replace(/undefined/g, '');
|
|
27
|
+
}
|
|
28
|
+
else {
|
|
29
|
+
return null;
|
|
30
|
+
}
|
|
31
|
+
}
|
|
32
|
+
function calcSteedosConfig(config) {
|
|
33
|
+
(0, lodash_1.each)(config, (v, k) => {
|
|
34
|
+
if (isJsonMap(v)) {
|
|
35
|
+
let _d = (0, lodash_1.get)(config, k);
|
|
36
|
+
if (isJsonMap(_d)) {
|
|
37
|
+
config[k] = calcSteedosConfig(clone(_d));
|
|
38
|
+
}
|
|
39
|
+
else {
|
|
40
|
+
config[k] = calcString(v);
|
|
41
|
+
if (k && (0, lodash_1.isString)(k) && k.startsWith('enable_') && config[k] && (0, lodash_1.isString)(config[k])) {
|
|
42
|
+
config[k] = validator.toBoolean(config[k], true);
|
|
43
|
+
}
|
|
44
|
+
}
|
|
45
|
+
}
|
|
46
|
+
else {
|
|
47
|
+
config[k] = calcString(v);
|
|
48
|
+
if (k && (0, lodash_1.isString)(k) && k.startsWith('enable_') && config[k] && (0, lodash_1.isString)(config[k])) {
|
|
49
|
+
config[k] = validator.toBoolean(config[k], true);
|
|
50
|
+
}
|
|
51
|
+
}
|
|
52
|
+
});
|
|
53
|
+
return config;
|
|
54
|
+
}
|
|
55
|
+
class SteedosConfig {
|
|
56
|
+
static loadDefaultSettings() {
|
|
57
|
+
const filePath = path.join(__dirname, '..', '..', "default.steedos.settings.yml");
|
|
58
|
+
if (fs.existsSync(filePath) && !fs.statSync(filePath).isDirectory()) {
|
|
59
|
+
return SteedosConfig.loadSettings(filePath);
|
|
60
|
+
}
|
|
61
|
+
else {
|
|
62
|
+
return null;
|
|
63
|
+
}
|
|
64
|
+
}
|
|
65
|
+
static loadProjectSettings() {
|
|
66
|
+
let configPath = path.join(process.cwd(), 'steedos-config.yml');
|
|
67
|
+
if (fs.existsSync(configPath) && !fs.statSync(configPath).isDirectory()) {
|
|
68
|
+
return SteedosConfig.loadSettings(configPath);
|
|
69
|
+
}
|
|
70
|
+
else {
|
|
71
|
+
return {};
|
|
72
|
+
}
|
|
73
|
+
}
|
|
74
|
+
static getSteedosConfig() {
|
|
75
|
+
const loadProjectSettings = SteedosConfig.loadProjectSettings();
|
|
76
|
+
const _projectConfig = (0, lodash_1.defaultsDeep)({}, { settings: loadProjectSettings });
|
|
77
|
+
const defaultSettings = SteedosConfig.loadDefaultSettings();
|
|
78
|
+
const _defaultConfig = (0, lodash_1.defaultsDeep)({}, { settings: defaultSettings });
|
|
79
|
+
const res = (0, lodash_1.cloneDeep)(_defaultConfig);
|
|
80
|
+
const mods = (0, lodash_1.cloneDeep)(_projectConfig);
|
|
81
|
+
Object.keys(mods).forEach(key => {
|
|
82
|
+
if (["created", "started", "stopped"].indexOf(key) !== -1) {
|
|
83
|
+
const functionArray = SteedosConfig.mergeSchemaLifecycleHandlers(mods[key], res[key]);
|
|
84
|
+
if (functionArray.length > 0) {
|
|
85
|
+
res[key] = function (broker) {
|
|
86
|
+
functionArray.forEach((fn) => fn.call(this, broker));
|
|
87
|
+
};
|
|
88
|
+
}
|
|
89
|
+
}
|
|
90
|
+
else if (["tracing", "metrics", "logger"].indexOf(key) !== -1) {
|
|
91
|
+
res[key] = mods[key];
|
|
92
|
+
}
|
|
93
|
+
else {
|
|
94
|
+
res[key] = (0, lodash_1.defaultsDeep)({ [key]: mods[key] }, { [key]: res[key] })[key];
|
|
95
|
+
}
|
|
96
|
+
});
|
|
97
|
+
return res;
|
|
98
|
+
}
|
|
99
|
+
static mergeSchemaLifecycleHandlers(src, target) {
|
|
100
|
+
return (0, lodash_1.compact)(SteedosConfig.flatten([target, src]));
|
|
101
|
+
}
|
|
102
|
+
static flatten(arr) {
|
|
103
|
+
return Array.prototype.reduce.call(arr, (a, b) => a.concat(b), []);
|
|
104
|
+
}
|
|
105
|
+
}
|
|
106
|
+
SteedosConfig.loadSettings = (filePath) => {
|
|
107
|
+
try {
|
|
108
|
+
const settings = yaml.load(fs.readFileSync(filePath, 'utf8'));
|
|
109
|
+
if (settings.env) {
|
|
110
|
+
(0, lodash_1.each)(settings.env, function (item, key) {
|
|
111
|
+
process.env[key] = calcString(item);
|
|
112
|
+
});
|
|
113
|
+
}
|
|
114
|
+
let emailConfig = settings.email;
|
|
115
|
+
if (emailConfig) {
|
|
116
|
+
if (!emailConfig.url && emailConfig.host && emailConfig.port && emailConfig.username && emailConfig.password) {
|
|
117
|
+
let url = `smtps://${emailConfig.username}:${emailConfig.password}@${emailConfig.host}:${emailConfig.port}/`;
|
|
118
|
+
emailConfig.url = url;
|
|
119
|
+
}
|
|
120
|
+
if (emailConfig.url) {
|
|
121
|
+
process.env["MAIL_URL"] = calcString(emailConfig.url);
|
|
122
|
+
}
|
|
123
|
+
if (emailConfig.from) {
|
|
124
|
+
process.env["MAIL_FROM"] = calcString(emailConfig.from);
|
|
125
|
+
}
|
|
126
|
+
}
|
|
127
|
+
const res = calcSteedosConfig(settings);
|
|
128
|
+
if (res) {
|
|
129
|
+
res.setTenant = (tenant) => {
|
|
130
|
+
res.tenant = (0, lodash_1.defaultsDeep)(tenant, res.tenant);
|
|
131
|
+
};
|
|
132
|
+
}
|
|
133
|
+
return res;
|
|
134
|
+
}
|
|
135
|
+
catch (error) {
|
|
136
|
+
console.error('loadFile error', filePath, error);
|
|
137
|
+
}
|
|
138
|
+
};
|
|
139
|
+
exports.default = SteedosConfig;
|
|
140
|
+
function isObject(value) {
|
|
141
|
+
return value != null && (typeof value === 'object' || typeof value === 'function');
|
|
142
|
+
}
|
|
143
|
+
function isFunction(value) {
|
|
144
|
+
return typeof value === 'function';
|
|
145
|
+
}
|
|
146
|
+
function isPlainObject(value) {
|
|
147
|
+
const isObjectObject = (o) => isObject(o) && Object.prototype.toString.call(o) === '[object Object]';
|
|
148
|
+
if (!isObjectObject(value))
|
|
149
|
+
return false;
|
|
150
|
+
const ctor = value.constructor;
|
|
151
|
+
if (!isFunction(ctor))
|
|
152
|
+
return false;
|
|
153
|
+
if (!isObjectObject(ctor.prototype))
|
|
154
|
+
return false;
|
|
155
|
+
if (!ctor.prototype.hasOwnProperty('isPrototypeOf'))
|
|
156
|
+
return false;
|
|
157
|
+
return true;
|
|
158
|
+
}
|
|
159
|
+
function isJsonMap(value) {
|
|
160
|
+
return isPlainObject(value);
|
|
161
|
+
}
|
|
162
|
+
exports.steedosConfig = SteedosConfig.getSteedosConfig();
|
|
163
|
+
//# sourceMappingURL=steedos.config.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"steedos.config.js","sourceRoot":"","sources":["../../src/config/steedos.config.ts"],"names":[],"mappings":"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"}
|
|
@@ -0,0 +1,62 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
var __decorate = (this && this.__decorate) || function (decorators, target, key, desc) {
|
|
3
|
+
var c = arguments.length, r = c < 3 ? target : desc === null ? desc = Object.getOwnPropertyDescriptor(target, key) : desc, d;
|
|
4
|
+
if (typeof Reflect === "object" && typeof Reflect.decorate === "function") r = Reflect.decorate(decorators, target, key, desc);
|
|
5
|
+
else for (var i = decorators.length - 1; i >= 0; i--) if (d = decorators[i]) r = (c < 3 ? d(r) : c > 3 ? d(target, key, r) : d(target, key)) || r;
|
|
6
|
+
return c > 3 && r && Object.defineProperty(target, key, r), r;
|
|
7
|
+
};
|
|
8
|
+
var AllExceptionsFilter_1;
|
|
9
|
+
Object.defineProperty(exports, "__esModule", { value: true });
|
|
10
|
+
exports.AllExceptionsFilter = void 0;
|
|
11
|
+
const common_1 = require("@nestjs/common");
|
|
12
|
+
let AllExceptionsFilter = AllExceptionsFilter_1 = class AllExceptionsFilter {
|
|
13
|
+
constructor() {
|
|
14
|
+
this.logger = new common_1.Logger(AllExceptionsFilter_1.name);
|
|
15
|
+
}
|
|
16
|
+
catch(exception, host) {
|
|
17
|
+
var _a, _b, _c, _d, _e;
|
|
18
|
+
try {
|
|
19
|
+
const ctx = host.switchToHttp();
|
|
20
|
+
const response = ctx.getResponse();
|
|
21
|
+
const request = ctx.getRequest();
|
|
22
|
+
this.logger.error({
|
|
23
|
+
method: request.method,
|
|
24
|
+
url: request.url,
|
|
25
|
+
headers: request.headers,
|
|
26
|
+
exception,
|
|
27
|
+
}, exception.stack);
|
|
28
|
+
let errorResponse;
|
|
29
|
+
const message = ((_b = (_a = exception === null || exception === void 0 ? void 0 : exception.response) === null || _a === void 0 ? void 0 : _a.error) === null || _b === void 0 ? void 0 : _b.message) ||
|
|
30
|
+
((_c = exception === null || exception === void 0 ? void 0 : exception.response) === null || _c === void 0 ? void 0 : _c.message) ||
|
|
31
|
+
exception.message;
|
|
32
|
+
const code = ((_e = (_d = exception === null || exception === void 0 ? void 0 : exception.response) === null || _d === void 0 ? void 0 : _d.error) === null || _e === void 0 ? void 0 : _e.code) || (exception === null || exception === void 0 ? void 0 : exception.code);
|
|
33
|
+
if (exception instanceof common_1.HttpException) {
|
|
34
|
+
errorResponse = {
|
|
35
|
+
status: exception.getStatus(),
|
|
36
|
+
message,
|
|
37
|
+
};
|
|
38
|
+
}
|
|
39
|
+
else {
|
|
40
|
+
errorResponse = {
|
|
41
|
+
message,
|
|
42
|
+
status: common_1.HttpStatus.INTERNAL_SERVER_ERROR,
|
|
43
|
+
};
|
|
44
|
+
}
|
|
45
|
+
response.status(errorResponse.status).json({
|
|
46
|
+
statusCode: errorResponse.status,
|
|
47
|
+
timestamp: new Date().toISOString(),
|
|
48
|
+
path: request.url,
|
|
49
|
+
message: errorResponse.message,
|
|
50
|
+
code: code,
|
|
51
|
+
});
|
|
52
|
+
}
|
|
53
|
+
catch (error) {
|
|
54
|
+
this.logger.error('Error while processing uncaught exception', error.stack);
|
|
55
|
+
}
|
|
56
|
+
}
|
|
57
|
+
};
|
|
58
|
+
exports.AllExceptionsFilter = AllExceptionsFilter;
|
|
59
|
+
exports.AllExceptionsFilter = AllExceptionsFilter = AllExceptionsFilter_1 = __decorate([
|
|
60
|
+
(0, common_1.Catch)()
|
|
61
|
+
], AllExceptionsFilter);
|
|
62
|
+
//# sourceMappingURL=all-exceptions.filter.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"all-exceptions.filter.js","sourceRoot":"","sources":["../../src/filters/all-exceptions.filter.ts"],"names":[],"mappings":";;;;;;;;;;AAAA,2CAOwB;AAQjB,IAAM,mBAAmB,2BAAzB,MAAM,mBAAmB;IAAzB;QACG,WAAM,GAAW,IAAI,eAAM,CAAC,qBAAmB,CAAC,IAAI,CAAC,CAAC;IAkDhE,CAAC;IAjDC,KAAK,CAAC,SAAc,EAAE,IAAmB;;QACvC,IAAI,CAAC;YACH,MAAM,GAAG,GAAG,IAAI,CAAC,YAAY,EAAE,CAAC;YAChC,MAAM,QAAQ,GAAG,GAAG,CAAC,WAAW,EAAE,CAAC;YACnC,MAAM,OAAO,GAAG,GAAG,CAAC,UAAU,EAAE,CAAC;YAEjC,IAAI,CAAC,MAAM,CAAC,KAAK,CACf;gBACE,MAAM,EAAE,OAAO,CAAC,MAAM;gBACtB,GAAG,EAAE,OAAO,CAAC,GAAG;gBAChB,OAAO,EAAE,OAAO,CAAC,OAAO;gBACxB,SAAS;aACV,EACD,SAAS,CAAC,KAAK,CAChB,CAAC;YAEF,IAAI,aAA4B,CAAC;YACjC,MAAM,OAAO,GACX,CAAA,MAAA,MAAA,SAAS,aAAT,SAAS,uBAAT,SAAS,CAAE,QAAQ,0CAAE,KAAK,0CAAE,OAAO;iBACnC,MAAA,SAAS,aAAT,SAAS,uBAAT,SAAS,CAAE,QAAQ,0CAAE,OAAO,CAAA;gBAC5B,SAAS,CAAC,OAAO,CAAC;YACpB,MAAM,IAAI,GAAG,CAAA,MAAA,MAAA,SAAS,aAAT,SAAS,uBAAT,SAAS,CAAE,QAAQ,0CAAE,KAAK,0CAAE,IAAI,MAAI,SAAS,aAAT,SAAS,uBAAT,SAAS,CAAE,IAAI,CAAA,CAAC;YAEjE,IAAI,SAAS,YAAY,sBAAa,EAAE,CAAC;gBACvC,aAAa,GAAG;oBACd,MAAM,EAAE,SAAS,CAAC,SAAS,EAAE;oBAC7B,OAAO;iBACR,CAAC;YACJ,CAAC;iBAAM,CAAC;gBACN,aAAa,GAAG;oBACd,OAAO;oBACP,MAAM,EAAE,mBAAU,CAAC,qBAAqB;iBACzC,CAAC;YACJ,CAAC;YAED,QAAQ,CAAC,MAAM,CAAC,aAAa,CAAC,MAAM,CAAC,CAAC,IAAI,CAAC;gBACzC,UAAU,EAAE,aAAa,CAAC,MAAM;gBAChC,SAAS,EAAE,IAAI,IAAI,EAAE,CAAC,WAAW,EAAE;gBACnC,IAAI,EAAE,OAAO,CAAC,GAAG;gBACjB,OAAO,EAAE,aAAa,CAAC,OAAO;gBAC9B,IAAI,EAAE,IAAI;aACX,CAAC,CAAC;QACL,CAAC;QAAC,OAAO,KAAK,EAAE,CAAC;YACf,IAAI,CAAC,MAAM,CAAC,KAAK,CACf,2CAA2C,EAC3C,KAAK,CAAC,KAAK,CACZ,CAAC;QACJ,CAAC;IACH,CAAC;CACF,CAAA;AAnDY,kDAAmB;8BAAnB,mBAAmB;IAD/B,IAAA,cAAK,GAAE;GACK,mBAAmB,CAmD/B"}
|
package/dist/index.d.ts
ADDED
|
@@ -0,0 +1 @@
|
|
|
1
|
+
export * from './bootstrap';
|
package/dist/index.js
ADDED
|
@@ -0,0 +1,18 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
var __createBinding = (this && this.__createBinding) || (Object.create ? (function(o, m, k, k2) {
|
|
3
|
+
if (k2 === undefined) k2 = k;
|
|
4
|
+
var desc = Object.getOwnPropertyDescriptor(m, k);
|
|
5
|
+
if (!desc || ("get" in desc ? !m.__esModule : desc.writable || desc.configurable)) {
|
|
6
|
+
desc = { enumerable: true, get: function() { return m[k]; } };
|
|
7
|
+
}
|
|
8
|
+
Object.defineProperty(o, k2, desc);
|
|
9
|
+
}) : (function(o, m, k, k2) {
|
|
10
|
+
if (k2 === undefined) k2 = k;
|
|
11
|
+
o[k2] = m[k];
|
|
12
|
+
}));
|
|
13
|
+
var __exportStar = (this && this.__exportStar) || function(m, exports) {
|
|
14
|
+
for (var p in m) if (p !== "default" && !Object.prototype.hasOwnProperty.call(exports, p)) __createBinding(exports, m, p);
|
|
15
|
+
};
|
|
16
|
+
Object.defineProperty(exports, "__esModule", { value: true });
|
|
17
|
+
__exportStar(require("./bootstrap"), exports);
|
|
18
|
+
//# sourceMappingURL=index.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"index.js","sourceRoot":"","sources":["../src/index.ts"],"names":[],"mappings":";;;;;;;;;;;;;;;;AAAA,8CAA4B"}
|
package/dist/main.d.ts
ADDED
|
@@ -0,0 +1 @@
|
|
|
1
|
+
export {};
|
package/dist/main.js
ADDED
package/dist/main.js.map
ADDED
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"main.js","sourceRoot":"","sources":["../src/main.ts"],"names":[],"mappings":";;AAAA,2CAAwC;AAExC,IAAA,qBAAS,GAAE,CAAC"}
|