@sme.up/kokos-sdk-node 2.4.0 → 3.0.0-SNAPSHOT
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/docs/assets/hierarchy.js +1 -1
- package/docs/assets/highlight.css +56 -0
- package/docs/assets/navigation.js +1 -1
- package/docs/assets/search.js +1 -1
- package/docs/classes/App.html +2 -2
- package/docs/classes/BatchContext.html +2 -2
- package/docs/classes/EntityOav.html +2 -2
- package/docs/classes/EntitySlice.html +2 -2
- package/docs/classes/ErrorWithStatus.html +28 -10
- package/docs/classes/ExecuteFunPayload.html +2 -2
- package/docs/classes/ExecutionContext.html +2 -2
- package/docs/classes/Fun.html +2 -2
- package/docs/classes/FunObject.html +2 -2
- package/docs/classes/KokosEntityDAOService.html +8 -8
- package/docs/classes/Registry.html +2 -2
- package/docs/classes/SmeupDataStructureWriter.html +5 -5
- package/docs/classes/SourceLibrary.html +2 -2
- package/docs/classes/User.html +2 -2
- package/docs/enums/ApiVersion.html +2 -2
- package/docs/enums/DynamismEvents.html +2 -2
- package/docs/enums/Format.html +2 -2
- package/docs/enums/FunStatus.html +2 -2
- package/docs/enums/Level.html +2 -2
- package/docs/enums/LoadType.html +2 -2
- package/docs/enums/SectionTypes.html +2 -2
- package/docs/enums/Shapes.html +2 -2
- package/docs/enums/SmeupDataStructureType.html +5 -5
- package/docs/enums/SmeupLayoutSectionType.html +2 -2
- package/docs/enums/ToolbarState.html +2 -2
- package/docs/enums/YesNo.html +2 -2
- package/docs/functions/clearLoggerContext.html +1 -1
- package/docs/functions/closeEventUtils.html +1 -1
- package/docs/functions/configureLogger.html +1 -1
- package/docs/functions/createLoggerContext.html +1 -1
- package/docs/functions/executeFun.html +1 -1
- package/docs/functions/funObjectToString.html +1 -1
- package/docs/functions/funToString.html +1 -1
- package/docs/functions/getSmeupDataStructureType.html +1 -1
- package/docs/functions/parseArrayString.html +4 -4
- package/docs/functions/parseFieldValues.html +1 -1
- package/docs/functions/parseKeyValueBetweenBrackets.html +1 -1
- package/docs/functions/parseUpdatePayload.html +1 -1
- package/docs/functions/parseUpdatePayloadMultipleRows.html +1 -1
- package/docs/functions/startServer.html +1 -1
- package/docs/functions/startServerWithCustomConfig.html +1 -1
- package/docs/functions/stringToFun.html +1 -1
- package/docs/functions/submitBusinessEvent.html +1 -1
- package/docs/functions/toDateCell.html +1 -1
- package/docs/functions/toIconButtonCell.html +1 -1
- package/docs/functions/toNumberCell.html +1 -1
- package/docs/functions/toSingleChipCell.html +1 -1
- package/docs/functions/toStringCell.html +1 -1
- package/docs/functions/toTextButtonCell.html +1 -1
- package/docs/functions/toTimeCell.html +1 -1
- package/docs/hierarchy.html +1 -1
- package/docs/interfaces/ComponentOptions.html +2 -2
- package/docs/interfaces/DebugInfo.html +2 -2
- package/docs/interfaces/DocumentDatabaseDataSource.html +2 -2
- package/docs/interfaces/IKokosEntityDAOService.html +2 -2
- package/docs/interfaces/IKokosInputPanelService.html +2 -2
- package/docs/interfaces/KokosEntityDAOServiceMethods.html +7 -7
- package/docs/interfaces/KokosInputPanelServiceMethods.html +6 -6
- package/docs/interfaces/KokosService.html +2 -2
- package/docs/interfaces/KokosServiceMethods.html +1 -1
- package/docs/interfaces/KokosServiceModule.html +2 -2
- package/docs/interfaces/LoggerContext.html +2 -2
- package/docs/interfaces/MicroExecutorConfiguration.html +2 -2
- package/docs/interfaces/RawDynamism.html +7 -7
- package/docs/interfaces/SmeupAction.html +2 -2
- package/docs/interfaces/SmeupBusinessEvent.html +2 -2
- package/docs/interfaces/SmeupDataCell.html +2 -2
- package/docs/interfaces/SmeupDataColumn.html +2 -2
- package/docs/interfaces/SmeupDataNode.html +2 -2
- package/docs/interfaces/SmeupDataRow.html +2 -2
- package/docs/interfaces/SmeupDataStructure.html +2 -2
- package/docs/interfaces/SmeupDataTable.html +2 -2
- package/docs/interfaces/SmeupDataTree.html +2 -2
- package/docs/interfaces/SmeupFeedback.html +2 -2
- package/docs/interfaces/SmeupLayout.html +2 -2
- package/docs/interfaces/SmeupLayoutField.html +2 -2
- package/docs/interfaces/SmeupLayoutSection.html +2 -2
- package/docs/interfaces/SmeupMessage.html +2 -2
- package/docs/interfaces/SmeupSch.html +3 -3
- package/docs/interfaces/SmeupSchComponent.html +2 -2
- package/docs/interfaces/SmeupSchSection.html +2 -2
- package/docs/interfaces/SmeupSetup.html +2 -2
- package/docs/interfaces/SmeupStyle.html +2 -2
- package/docs/interfaces/SmeupStyleOptions.html +2 -2
- package/docs/interfaces/SmeupVariable.html +2 -2
- package/docs/interfaces/UpdateResult.html +2 -2
- package/docs/modules.html +1 -1
- package/docs/types/SmeupDataCellInputSettingsKeys.html +1 -1
- package/docs/types/SmeupDataCellInputSettingsValue.html +1 -1
- package/docs/types/SmeupDataCellShapes.html +1 -1
- package/docs/types/SmeupMessageGravity.html +1 -1
- package/docs/types/SmeupSetupBase.html +1 -1
- package/docs/types/SmeupVariableType.html +1 -1
- package/docs/variables/DEFAULT_TTL.html +1 -1
- package/docs/variables/LOGGER.html +1 -1
- package/docs/variables/SMEUP_ACTION_TYPE.html +1 -1
- package/docs/variables/SMEUP_DATA_CELL_INPUT_SETTINGS_KEYS.html +1 -1
- package/docs/variables/SMEUP_MESSAGE_GRAVITY.html +1 -1
- package/docs/variables/SMEUP_MESSAGE_MODE.html +1 -1
- package/docs/variables/SMEUP_VARIABLE_TYPE.html +1 -1
- package/docs/variables/SmeupDataCellShapes.html +1 -1
- package/lib/caller/executeFun.js +9 -6
- package/lib/caller/executeFun.js.map +1 -1
- package/lib/caller/microExecutorServiceCaller.js +13 -7
- package/lib/caller/microExecutorServiceCaller.js.map +1 -1
- package/lib/caller/serviceCaller.js +43 -78
- package/lib/caller/serviceCaller.js.map +1 -1
- package/lib/configuration/configuration.js +28 -20
- package/lib/configuration/configuration.js.map +1 -1
- package/lib/entrypoint/restapi/executeFunPayloadValidator.js +5 -3
- package/lib/entrypoint/restapi/executeFunPayloadValidator.js.map +1 -1
- package/lib/entrypoint/restapi/index.js +4 -2
- package/lib/entrypoint/restapi/index.js.map +1 -1
- package/lib/entrypoint/restapi/restapi.js +50 -47
- package/lib/entrypoint/restapi/restapi.js.map +1 -1
- package/lib/events/eventUtils.js +16 -11
- package/lib/events/eventUtils.js.map +1 -1
- package/lib/events/rabbitmq.js +26 -16
- package/lib/events/rabbitmq.js.map +1 -1
- package/lib/index.js +32 -16
- package/lib/index.js.map +1 -1
- package/lib/logger/logger.js +21 -12
- package/lib/logger/logger.js.map +1 -1
- package/lib/services/JS_00_01.js +17 -15
- package/lib/services/JS_00_01.js.map +1 -1
- package/lib/services/JS_00_02.js +3 -1
- package/lib/services/JS_00_02.js.map +1 -1
- package/lib/types/component.js +7 -4
- package/lib/types/component.js.map +1 -1
- package/lib/types/data-structures/smeupDataStructure.js +16 -12
- package/lib/types/data-structures/smeupDataStructure.js.map +1 -1
- package/lib/types/data-structures/smeupDataTable.js +4 -1
- package/lib/types/data-structures/smeupDataTable.js.map +1 -1
- package/lib/types/data-structures/smeupDataTree.js +2 -1
- package/lib/types/data-structures/smeupSch.js +5 -2
- package/lib/types/data-structures/smeupSch.js.map +1 -1
- package/lib/types/dynamism.js +7 -4
- package/lib/types/dynamism.js.map +1 -1
- package/lib/types/exceptions/application.js +5 -3
- package/lib/types/exceptions/application.js.map +1 -1
- package/lib/types/exceptions/validation.js +6 -2
- package/lib/types/exceptions/validation.js.map +1 -1
- package/lib/types/general.js +33 -61
- package/lib/types/general.js.map +1 -1
- package/lib/types/helpers.js +7 -4
- package/lib/types/helpers.js.map +1 -1
- package/lib/utils/batchUtils.js +23 -17
- package/lib/utils/batchUtils.js.map +1 -1
- package/lib/utils/cells.js +16 -7
- package/lib/utils/cells.js.map +1 -1
- package/lib/utils/dataStructureStream.js +7 -3
- package/lib/utils/dataStructureStream.js.map +1 -1
- package/lib/utils/fun.js +10 -5
- package/lib/utils/fun.js.map +1 -1
- package/lib/utils/path.js +12 -6
- package/lib/utils/path.js.map +1 -1
- package/lib/utils/regex.js +22 -18
- package/lib/utils/regex.js.map +1 -1
- package/lib/utils/smeupDataStructureWriter.js +43 -37
- package/lib/utils/smeupDataStructureWriter.js.map +1 -1
- package/package.json +8 -12
- package/tsconfig.json +15 -27
- package/docs/interfaces/SmeupDataCellOption.html +0 -4
- package/lib/caller/executeFun.d.ts +0 -10
- package/lib/caller/microExecutorServiceCaller.d.ts +0 -11
- package/lib/caller/serviceCaller.d.ts +0 -33
- package/lib/configuration/configuration.d.ts +0 -13
- package/lib/entrypoint/restapi/executeFunPayloadValidator.d.ts +0 -1
- package/lib/entrypoint/restapi/index.d.ts +0 -1
- package/lib/entrypoint/restapi/restapi.d.ts +0 -3
- package/lib/events/eventUtils.d.ts +0 -12
- package/lib/events/rabbitmq.d.ts +0 -21
- package/lib/index.d.ts +0 -22
- package/lib/logger/logger.d.ts +0 -26
- package/lib/services/JS_00_01.d.ts +0 -3
- package/lib/services/JS_00_02.d.ts +0 -11
- package/lib/types/component.d.ts +0 -53
- package/lib/types/data-structures/smeupDataStructure.d.ts +0 -215
- package/lib/types/data-structures/smeupDataTable.d.ts +0 -117
- package/lib/types/data-structures/smeupDataTree.d.ts +0 -13
- package/lib/types/data-structures/smeupSch.d.ts +0 -72
- package/lib/types/dynamism.d.ts +0 -45
- package/lib/types/exceptions/application.d.ts +0 -8
- package/lib/types/exceptions/validation.d.ts +0 -7
- package/lib/types/general.d.ts +0 -221
- package/lib/types/helpers.d.ts +0 -9
- package/lib/utils/batchUtils.d.ts +0 -6
- package/lib/utils/cells.d.ts +0 -8
- package/lib/utils/dataStructureStream.d.ts +0 -8
- package/lib/utils/fun.d.ts +0 -4
- package/lib/utils/path.d.ts +0 -5
- package/lib/utils/regex.d.ts +0 -48
- package/lib/utils/smeupDataStructureWriter.d.ts +0 -51
|
@@ -1,6 +1,8 @@
|
|
|
1
|
-
|
|
2
|
-
|
|
3
|
-
|
|
1
|
+
"use strict";
|
|
2
|
+
Object.defineProperty(exports, "__esModule", { value: true });
|
|
3
|
+
exports.executeFunPayloadValidator = void 0;
|
|
4
|
+
const express_validator_1 = require("express-validator");
|
|
5
|
+
exports.executeFunPayloadValidator = (0, express_validator_1.checkSchema)({
|
|
4
6
|
fun: {
|
|
5
7
|
in: ["body"],
|
|
6
8
|
isObject: true,
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"executeFunPayloadValidator.js","sourceRoot":"","sources":["../../../src/entrypoint/restapi/executeFunPayloadValidator.ts"],"names":[],"mappings":"AAAA,
|
|
1
|
+
{"version":3,"file":"executeFunPayloadValidator.js","sourceRoot":"","sources":["../../../src/entrypoint/restapi/executeFunPayloadValidator.ts"],"names":[],"mappings":"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"}
|
|
@@ -1,3 +1,5 @@
|
|
|
1
|
-
|
|
2
|
-
|
|
1
|
+
"use strict";
|
|
2
|
+
Object.defineProperty(exports, "__esModule", { value: true });
|
|
3
|
+
const restapi_1 = require("./restapi");
|
|
4
|
+
(0, restapi_1.startServer)("me-node-example");
|
|
3
5
|
//# sourceMappingURL=index.js.map
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"index.js","sourceRoot":"","sources":["../../../src/entrypoint/restapi/index.ts"],"names":[],"mappings":"AAAA,
|
|
1
|
+
{"version":3,"file":"index.js","sourceRoot":"","sources":["../../../src/entrypoint/restapi/index.ts"],"names":[],"mappings":";;AAAA,uCAAwC;AAExC,IAAA,qBAAW,EAAC,iBAAiB,CAAC,CAAC"}
|
|
@@ -1,49 +1,52 @@
|
|
|
1
|
-
|
|
2
|
-
|
|
3
|
-
|
|
4
|
-
|
|
5
|
-
|
|
6
|
-
|
|
7
|
-
|
|
8
|
-
|
|
9
|
-
|
|
10
|
-
|
|
11
|
-
|
|
12
|
-
|
|
13
|
-
|
|
14
|
-
|
|
15
|
-
|
|
16
|
-
const
|
|
17
|
-
const
|
|
18
|
-
|
|
1
|
+
"use strict";
|
|
2
|
+
var __importDefault = (this && this.__importDefault) || function (mod) {
|
|
3
|
+
return (mod && mod.__esModule) ? mod : { "default": mod };
|
|
4
|
+
};
|
|
5
|
+
Object.defineProperty(exports, "__esModule", { value: true });
|
|
6
|
+
exports.startServer = startServer;
|
|
7
|
+
exports.startServerWithCustomConfig = startServerWithCustomConfig;
|
|
8
|
+
const express_1 = __importDefault(require("express"));
|
|
9
|
+
const body_parser_1 = __importDefault(require("body-parser"));
|
|
10
|
+
const serviceCaller_1 = require("../../caller/serviceCaller");
|
|
11
|
+
const path_1 = require("path");
|
|
12
|
+
const stream_1 = __importDefault(require("stream"));
|
|
13
|
+
const smeupDataStructure_1 = require("../../types/data-structures/smeupDataStructure");
|
|
14
|
+
const configuration_1 = require("../../configuration/configuration");
|
|
15
|
+
const logger_1 = require("../../logger/logger");
|
|
16
|
+
const express_validator_1 = require("express-validator");
|
|
17
|
+
const executeFunPayloadValidator_1 = require("./executeFunPayloadValidator");
|
|
18
|
+
const validation_1 = require("../../types/exceptions/validation");
|
|
19
|
+
const smeupDataStructureWriter_1 = require("../../utils/smeupDataStructureWriter");
|
|
20
|
+
const crypto_1 = require("crypto");
|
|
21
|
+
function startServer(microExecutorId) {
|
|
19
22
|
startServerWithCustomConfig(microExecutorId, {
|
|
20
23
|
server: {
|
|
21
24
|
port: 8011,
|
|
22
25
|
},
|
|
23
26
|
logger: {
|
|
24
|
-
format: Format.TXT,
|
|
25
|
-
level: Level.DEBUG,
|
|
27
|
+
format: logger_1.Format.TXT,
|
|
28
|
+
level: logger_1.Level.DEBUG,
|
|
26
29
|
},
|
|
27
30
|
});
|
|
28
31
|
}
|
|
29
|
-
|
|
32
|
+
function startServerWithCustomConfig(microExecutorId, defaultConfigurationClass, callback) {
|
|
30
33
|
// load config
|
|
31
|
-
const configuration = init(microExecutorId, defaultConfigurationClass);
|
|
34
|
+
const configuration = (0, configuration_1.init)(microExecutorId, defaultConfigurationClass);
|
|
32
35
|
if (callback) {
|
|
33
36
|
// call callback
|
|
34
37
|
callback(configuration);
|
|
35
38
|
}
|
|
36
|
-
configureLogger(configuration.logger?.level, configuration.logger?.format);
|
|
39
|
+
(0, logger_1.configureLogger)(configuration.logger?.level, configuration.logger?.format);
|
|
37
40
|
// create server
|
|
38
|
-
const app =
|
|
41
|
+
const app = (0, express_1.default)();
|
|
39
42
|
// body parse middleware
|
|
40
|
-
app.use(
|
|
43
|
+
app.use(body_parser_1.default.json());
|
|
41
44
|
// swagger
|
|
42
|
-
const swaggerPath = normalize(`${__dirname}/../../../swagger`);
|
|
43
|
-
app.use("/swagger",
|
|
45
|
+
const swaggerPath = (0, path_1.normalize)(`${__dirname}/../../../swagger`);
|
|
46
|
+
app.use("/swagger", express_1.default.static(swaggerPath));
|
|
44
47
|
// docs
|
|
45
|
-
const docsPath = normalize(`${__dirname}/../../../docs`);
|
|
46
|
-
app.use("/docs",
|
|
48
|
+
const docsPath = (0, path_1.normalize)(`${__dirname}/../../../docs`);
|
|
49
|
+
app.use("/docs", express_1.default.static(docsPath));
|
|
47
50
|
/**
|
|
48
51
|
* REST API Entrypoint
|
|
49
52
|
*/
|
|
@@ -53,23 +56,23 @@ export function startServerWithCustomConfig(microExecutorId, defaultConfiguratio
|
|
|
53
56
|
/**
|
|
54
57
|
* /executeFun API
|
|
55
58
|
*/
|
|
56
|
-
app.use("/api/:version/executeFun", validationMiddleware(executeFunPayloadValidator), (req, res, next) => {
|
|
59
|
+
app.use("/api/:version/executeFun", validationMiddleware(executeFunPayloadValidator_1.executeFunPayloadValidator), (req, res, next) => {
|
|
57
60
|
// get version
|
|
58
|
-
const version = ApiVersion.V2;
|
|
61
|
+
const version = smeupDataStructure_1.ApiVersion.V2;
|
|
59
62
|
// get body
|
|
60
63
|
const { fun, context } = req.body;
|
|
61
64
|
// set status
|
|
62
65
|
res.status(200);
|
|
63
66
|
res.setHeader("Content-Type", "application/json");
|
|
64
67
|
// create stream
|
|
65
|
-
const out = new
|
|
68
|
+
const out = new stream_1.default.Writable({
|
|
66
69
|
write(chunk, encoding, callback) {
|
|
67
70
|
res.write(chunk, encoding);
|
|
68
71
|
callback();
|
|
69
72
|
},
|
|
70
73
|
});
|
|
71
74
|
// call service caller
|
|
72
|
-
serviceCaller(fun, context, out, version)
|
|
75
|
+
(0, serviceCaller_1.serviceCaller)(fun, context, out, version)
|
|
73
76
|
.then(() => {
|
|
74
77
|
res.end();
|
|
75
78
|
})
|
|
@@ -80,31 +83,31 @@ export function startServerWithCustomConfig(microExecutorId, defaultConfiguratio
|
|
|
80
83
|
/**
|
|
81
84
|
* /executeBatchFun API
|
|
82
85
|
*/
|
|
83
|
-
app.use("/api/:version/executeBatchFun", validationMiddleware(executeFunPayloadValidator), (req, res, next) => {
|
|
86
|
+
app.use("/api/:version/executeBatchFun", validationMiddleware(executeFunPayloadValidator_1.executeFunPayloadValidator), (req, res, next) => {
|
|
84
87
|
// get version
|
|
85
|
-
const version = ApiVersion.V2;
|
|
88
|
+
const version = smeupDataStructure_1.ApiVersion.V2;
|
|
86
89
|
// get body
|
|
87
90
|
const { fun, context } = req.body;
|
|
88
91
|
// set status
|
|
89
92
|
res.status(200);
|
|
90
93
|
res.setHeader("Content-Type", "application/json");
|
|
91
94
|
// create stream
|
|
92
|
-
const out = new
|
|
95
|
+
const out = new stream_1.default.Writable({
|
|
93
96
|
write(chunk, encoding, callback) {
|
|
94
97
|
res.write(chunk, encoding);
|
|
95
98
|
callback();
|
|
96
99
|
},
|
|
97
100
|
});
|
|
98
|
-
const batchJobId = randomUUID();
|
|
101
|
+
const batchJobId = (0, crypto_1.randomUUID)();
|
|
99
102
|
context.batchContext = {
|
|
100
103
|
batchJobId: batchJobId,
|
|
101
104
|
};
|
|
102
105
|
// fire and forget
|
|
103
|
-
serviceCaller(fun, context, out, version, true);
|
|
104
|
-
const writer = new SmeupDataStructureWriter(out, version);
|
|
106
|
+
(0, serviceCaller_1.serviceCaller)(fun, context, out, version, true);
|
|
107
|
+
const writer = new smeupDataStructureWriter_1.SmeupDataStructureWriter(out, version);
|
|
105
108
|
writer.writeMessage({
|
|
106
|
-
gravity: SMEUP_MESSAGE_GRAVITY.INFO,
|
|
107
|
-
mode: SMEUP_MESSAGE_MODE.TN,
|
|
109
|
+
gravity: smeupDataStructure_1.SMEUP_MESSAGE_GRAVITY.INFO,
|
|
110
|
+
mode: smeupDataStructure_1.SMEUP_MESSAGE_MODE.TN,
|
|
108
111
|
message: `Batch job started with id: ` + batchJobId,
|
|
109
112
|
});
|
|
110
113
|
writer.writeDataStructureFinalization(fun);
|
|
@@ -134,7 +137,7 @@ export function startServerWithCustomConfig(microExecutorId, defaultConfiguratio
|
|
|
134
137
|
// start server
|
|
135
138
|
const PORT = configuration.server.port || 3000;
|
|
136
139
|
app.listen(PORT, () => {
|
|
137
|
-
LOGGER.info(`App listening on the port ${PORT}`);
|
|
140
|
+
logger_1.LOGGER.info(`App listening on the port ${PORT}`);
|
|
138
141
|
});
|
|
139
142
|
/**
|
|
140
143
|
* MIDDLEWARES
|
|
@@ -144,13 +147,13 @@ export function startServerWithCustomConfig(microExecutorId, defaultConfiguratio
|
|
|
144
147
|
for (const validator of validators) {
|
|
145
148
|
await validator.run(req);
|
|
146
149
|
}
|
|
147
|
-
const errors = validationResult(req);
|
|
150
|
+
const errors = (0, express_validator_1.validationResult)(req);
|
|
148
151
|
if (!errors.isEmpty()) {
|
|
149
152
|
const message = errors
|
|
150
153
|
.array()
|
|
151
154
|
.map((error) => error.msg)
|
|
152
155
|
.join(", ");
|
|
153
|
-
next(new ValidationException(message));
|
|
156
|
+
next(new validation_1.ValidationException(message));
|
|
154
157
|
}
|
|
155
158
|
next();
|
|
156
159
|
};
|
|
@@ -165,13 +168,13 @@ export function startServerWithCustomConfig(microExecutorId, defaultConfiguratio
|
|
|
165
168
|
function errorMiddleware(error, _request, response, _next) {
|
|
166
169
|
const status = error.status || 500;
|
|
167
170
|
const message = error.message || "Something went wrong";
|
|
168
|
-
LOGGER.error(error);
|
|
171
|
+
logger_1.LOGGER.error(error);
|
|
169
172
|
response.status(status).json({
|
|
170
173
|
messages: [
|
|
171
174
|
{
|
|
172
|
-
gravity: SMEUP_MESSAGE_GRAVITY.ERROR,
|
|
175
|
+
gravity: smeupDataStructure_1.SMEUP_MESSAGE_GRAVITY.ERROR,
|
|
173
176
|
message: message,
|
|
174
|
-
mode: SMEUP_MESSAGE_MODE.PN,
|
|
177
|
+
mode: smeupDataStructure_1.SMEUP_MESSAGE_MODE.PN,
|
|
175
178
|
},
|
|
176
179
|
],
|
|
177
180
|
});
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"restapi.js","sourceRoot":"","sources":["../../../src/entrypoint/restapi/restapi.ts"],"names":[],"mappings":"
|
|
1
|
+
{"version":3,"file":"restapi.js","sourceRoot":"","sources":["../../../src/entrypoint/restapi/restapi.ts"],"names":[],"mappings":"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"}
|
package/lib/events/eventUtils.js
CHANGED
|
@@ -1,23 +1,26 @@
|
|
|
1
|
-
|
|
2
|
-
|
|
1
|
+
"use strict";
|
|
2
|
+
Object.defineProperty(exports, "__esModule", { value: true });
|
|
3
|
+
exports.closeEventUtils = exports.submitBusinessEvent = exports.DEFAULT_TTL = void 0;
|
|
4
|
+
const rabbitmq_1 = require("./rabbitmq");
|
|
5
|
+
exports.DEFAULT_TTL = 30000;
|
|
3
6
|
let rabbitMQManager = null;
|
|
4
|
-
|
|
7
|
+
const submitBusinessEvent = async (event) => {
|
|
5
8
|
try {
|
|
6
9
|
if (rabbitMQManager === null) {
|
|
7
|
-
const connection = await generateConnection();
|
|
8
|
-
const channel = await createChannelWithExchange(connection, SMEUP_EXCHANGE_BUSINESS_EVT);
|
|
10
|
+
const connection = await (0, rabbitmq_1.generateConnection)();
|
|
11
|
+
const channel = await (0, rabbitmq_1.createChannelWithExchange)(connection, rabbitmq_1.SMEUP_EXCHANGE_BUSINESS_EVT);
|
|
9
12
|
rabbitMQManager = { connection, channel };
|
|
10
13
|
}
|
|
11
14
|
try {
|
|
12
15
|
// Check if queue exists (equivalent to queueDeclarePassive)
|
|
13
|
-
await rabbitMQManager.channel.checkQueue(BUSINESS_EVT_QUEUE_NAME);
|
|
16
|
+
await rabbitMQManager.channel.checkQueue(rabbitmq_1.BUSINESS_EVT_QUEUE_NAME);
|
|
14
17
|
// Publish message
|
|
15
|
-
const messageBuffer = Buffer.from(JSON.stringify(event),
|
|
16
|
-
const routingKey = BUSINESS_EVT_QUEUE_NAME + SUFFIX_ROUTING_KEY;
|
|
17
|
-
rabbitMQManager.channel.publish(SMEUP_EXCHANGE_BUSINESS_EVT, routingKey, messageBuffer);
|
|
18
|
+
const messageBuffer = Buffer.from(JSON.stringify(event), "utf8");
|
|
19
|
+
const routingKey = rabbitmq_1.BUSINESS_EVT_QUEUE_NAME + rabbitmq_1.SUFFIX_ROUTING_KEY;
|
|
20
|
+
rabbitMQManager.channel.publish(rabbitmq_1.SMEUP_EXCHANGE_BUSINESS_EVT, routingKey, messageBuffer);
|
|
18
21
|
}
|
|
19
22
|
catch (error) {
|
|
20
|
-
throw new Error(`Queue ${BUSINESS_EVT_QUEUE_NAME} doesn't exist`);
|
|
23
|
+
throw new Error(`Queue ${rabbitmq_1.BUSINESS_EVT_QUEUE_NAME} doesn't exist`);
|
|
21
24
|
}
|
|
22
25
|
}
|
|
23
26
|
catch (error) {
|
|
@@ -27,7 +30,8 @@ export const submitBusinessEvent = async (event) => {
|
|
|
27
30
|
throw new Error(`Failed to submit business event: ${error}`);
|
|
28
31
|
}
|
|
29
32
|
};
|
|
30
|
-
|
|
33
|
+
exports.submitBusinessEvent = submitBusinessEvent;
|
|
34
|
+
const closeEventUtils = async () => {
|
|
31
35
|
if (rabbitMQManager) {
|
|
32
36
|
if (rabbitMQManager.channel) {
|
|
33
37
|
await rabbitMQManager.channel.close();
|
|
@@ -38,4 +42,5 @@ export const closeEventUtils = async () => {
|
|
|
38
42
|
rabbitMQManager = null;
|
|
39
43
|
}
|
|
40
44
|
};
|
|
45
|
+
exports.closeEventUtils = closeEventUtils;
|
|
41
46
|
//# sourceMappingURL=eventUtils.js.map
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"eventUtils.js","sourceRoot":"","sources":["../../src/events/eventUtils.ts"],"names":[],"mappings":"AACA,
|
|
1
|
+
{"version":3,"file":"eventUtils.js","sourceRoot":"","sources":["../../src/events/eventUtils.ts"],"names":[],"mappings":";;;AACA,yCAMoB;AAEP,QAAA,WAAW,GAAG,KAAK,CAAC;AAYjC,IAAI,eAAe,GAGR,IAAI,CAAC;AAET,MAAM,mBAAmB,GAAG,KAAK,EACtC,KAAyB,EACV,EAAE;IACjB,IAAI,CAAC;QACH,IAAI,eAAe,KAAK,IAAI,EAAE,CAAC;YAC7B,MAAM,UAAU,GAAG,MAAM,IAAA,6BAAkB,GAAE,CAAC;YAC9C,MAAM,OAAO,GAAG,MAAM,IAAA,oCAAyB,EAC7C,UAAU,EACV,sCAA2B,CAC5B,CAAC;YACF,eAAe,GAAG,EAAE,UAAU,EAAE,OAAO,EAAE,CAAC;QAC5C,CAAC;QAED,IAAI,CAAC;YACH,4DAA4D;YAC5D,MAAM,eAAe,CAAC,OAAO,CAAC,UAAU,CAAC,kCAAuB,CAAC,CAAC;YAElE,kBAAkB;YAClB,MAAM,aAAa,GAAG,MAAM,CAAC,IAAI,CAAC,IAAI,CAAC,SAAS,CAAC,KAAK,CAAC,EAAE,MAAM,CAAC,CAAC;YACjE,MAAM,UAAU,GAAG,kCAAuB,GAAG,6BAAkB,CAAC;YAEhE,eAAe,CAAC,OAAO,CAAC,OAAO,CAC7B,sCAA2B,EAC3B,UAAU,EACV,aAAa,CACd,CAAC;QACJ,CAAC;QAAC,OAAO,KAAK,EAAE,CAAC;YACf,MAAM,IAAI,KAAK,CAAC,SAAS,kCAAuB,gBAAgB,CAAC,CAAC;QACpE,CAAC;IACH,CAAC;IAAC,OAAO,KAAK,EAAE,CAAC;QACf,IAAI,KAAK,YAAY,KAAK,EAAE,CAAC;YAC3B,MAAM,KAAK,CAAC;QACd,CAAC;QACD,MAAM,IAAI,KAAK,CAAC,oCAAoC,KAAK,EAAE,CAAC,CAAC;IAC/D,CAAC;AACH,CAAC,CAAC;AAnCW,QAAA,mBAAmB,uBAmC9B;AAEK,MAAM,eAAe,GAAG,KAAK,IAAmB,EAAE;IACvD,IAAI,eAAe,EAAE,CAAC;QACpB,IAAI,eAAe,CAAC,OAAO,EAAE,CAAC;YAC5B,MAAM,eAAe,CAAC,OAAO,CAAC,KAAK,EAAE,CAAC;QACxC,CAAC;QACD,IAAI,eAAe,CAAC,UAAU,EAAE,CAAC;YAC/B,MAAM,eAAe,CAAC,UAAU,CAAC,KAAK,EAAE,CAAC;QAC3C,CAAC;QACD,eAAe,GAAG,IAAI,CAAC;IACzB,CAAC;AACH,CAAC,CAAC;AAVW,QAAA,eAAe,mBAU1B"}
|
package/lib/events/rabbitmq.js
CHANGED
|
@@ -1,13 +1,19 @@
|
|
|
1
|
-
|
|
2
|
-
|
|
3
|
-
|
|
4
|
-
|
|
5
|
-
|
|
6
|
-
|
|
7
|
-
|
|
8
|
-
|
|
9
|
-
|
|
10
|
-
|
|
1
|
+
"use strict";
|
|
2
|
+
var __importDefault = (this && this.__importDefault) || function (mod) {
|
|
3
|
+
return (mod && mod.__esModule) ? mod : { "default": mod };
|
|
4
|
+
};
|
|
5
|
+
Object.defineProperty(exports, "__esModule", { value: true });
|
|
6
|
+
exports.closeConnection = exports.createChannelWithQueue = exports.createChannelWithExchange = exports.generateConnection = exports.MAX_CONNECTION_RETRY = exports.SUFFIX_CONSUMER_TAG = exports.SUFFIX_ROUTING_KEY = exports.SENDER_PREFIX = exports.BUSINESS_EVT_QUEUE_NAME = exports.SMEUP_EXCHANGE_BUSINESS_EVT = exports.SMEUP_EXCHANGE_CMD = exports.SMEUP_EXCHANGE_EVT = void 0;
|
|
7
|
+
const amqplib_1 = __importDefault(require("amqplib"));
|
|
8
|
+
exports.SMEUP_EXCHANGE_EVT = "smeupEvtExchange";
|
|
9
|
+
exports.SMEUP_EXCHANGE_CMD = "smeupCmdExchange";
|
|
10
|
+
exports.SMEUP_EXCHANGE_BUSINESS_EVT = "smeupBusinessEvtExchange";
|
|
11
|
+
exports.BUSINESS_EVT_QUEUE_NAME = "BUSINESS_EVT_QUEUE";
|
|
12
|
+
exports.SENDER_PREFIX = "CMD-";
|
|
13
|
+
exports.SUFFIX_ROUTING_KEY = ".in";
|
|
14
|
+
exports.SUFFIX_CONSUMER_TAG = ".tag";
|
|
15
|
+
exports.MAX_CONNECTION_RETRY = 5;
|
|
16
|
+
const generateConnection = async () => {
|
|
11
17
|
const host = process.env.RABBITMQ_HOST;
|
|
12
18
|
if (!host) {
|
|
13
19
|
throw new Error("Missing required environment variable RABBITMQ_HOST");
|
|
@@ -29,18 +35,20 @@ export const generateConnection = async () => {
|
|
|
29
35
|
throw new Error("RABBITMQ_PORT must be a valid number");
|
|
30
36
|
}
|
|
31
37
|
const connectionUrl = `amqp://${user}:${password}@${host}:${port}`;
|
|
32
|
-
return await
|
|
38
|
+
return await amqplib_1.default.connect(connectionUrl);
|
|
33
39
|
};
|
|
34
|
-
|
|
40
|
+
exports.generateConnection = generateConnection;
|
|
41
|
+
const createChannelWithExchange = async (connection, exchange) => {
|
|
35
42
|
const channel = await connection.createChannel();
|
|
36
43
|
await channel.assertExchange(exchange, 'topic', { durable: true });
|
|
37
44
|
return channel;
|
|
38
45
|
};
|
|
39
|
-
|
|
46
|
+
exports.createChannelWithExchange = createChannelWithExchange;
|
|
47
|
+
const createChannelWithQueue = async (connection, exchange, queueName, options) => {
|
|
40
48
|
const args = {
|
|
41
49
|
'x-message-ttl': options.ttl
|
|
42
50
|
};
|
|
43
|
-
const channel = await createChannelWithExchange(connection, exchange);
|
|
51
|
+
const channel = await (0, exports.createChannelWithExchange)(connection, exchange);
|
|
44
52
|
await channel.assertQueue(queueName, {
|
|
45
53
|
durable: true,
|
|
46
54
|
exclusive: false,
|
|
@@ -50,13 +58,15 @@ export const createChannelWithQueue = async (connection, exchange, queueName, op
|
|
|
50
58
|
if (options.qos !== undefined) {
|
|
51
59
|
await channel.prefetch(options.qos);
|
|
52
60
|
}
|
|
53
|
-
await channel.bindQueue(queueName, exchange, queueName + SUFFIX_ROUTING_KEY);
|
|
61
|
+
await channel.bindQueue(queueName, exchange, queueName + exports.SUFFIX_ROUTING_KEY);
|
|
54
62
|
return channel;
|
|
55
63
|
};
|
|
56
|
-
|
|
64
|
+
exports.createChannelWithQueue = createChannelWithQueue;
|
|
65
|
+
const closeConnection = async (connection, channel) => {
|
|
57
66
|
if (channel) {
|
|
58
67
|
await channel.close();
|
|
59
68
|
}
|
|
60
69
|
await connection.close();
|
|
61
70
|
};
|
|
71
|
+
exports.closeConnection = closeConnection;
|
|
62
72
|
//# sourceMappingURL=rabbitmq.js.map
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"rabbitmq.js","sourceRoot":"","sources":["../../src/events/rabbitmq.ts"],"names":[],"mappings":"AAAA,
|
|
1
|
+
{"version":3,"file":"rabbitmq.js","sourceRoot":"","sources":["../../src/events/rabbitmq.ts"],"names":[],"mappings":"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"}
|
package/lib/index.js
CHANGED
|
@@ -1,23 +1,39 @@
|
|
|
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 });
|
|
1
17
|
/** TYPES */
|
|
2
|
-
|
|
3
|
-
|
|
4
|
-
|
|
5
|
-
|
|
18
|
+
__exportStar(require("./types/general"), exports);
|
|
19
|
+
__exportStar(require("./types/component"), exports);
|
|
20
|
+
__exportStar(require("./types/dynamism"), exports);
|
|
21
|
+
__exportStar(require("./types/helpers"), exports);
|
|
6
22
|
/** DATA STRUCTURES */
|
|
7
|
-
|
|
8
|
-
|
|
9
|
-
|
|
10
|
-
|
|
23
|
+
__exportStar(require("./types/data-structures/smeupDataStructure"), exports);
|
|
24
|
+
__exportStar(require("./types/data-structures/smeupDataTable"), exports);
|
|
25
|
+
__exportStar(require("./types/data-structures/smeupDataTree"), exports);
|
|
26
|
+
__exportStar(require("./types/data-structures/smeupSch"), exports);
|
|
11
27
|
/** ENTRYPOINT */
|
|
12
|
-
|
|
28
|
+
__exportStar(require("./entrypoint/restapi/restapi"), exports);
|
|
13
29
|
/** LOGGER */
|
|
14
|
-
|
|
30
|
+
__exportStar(require("./logger/logger"), exports);
|
|
15
31
|
/** CALLER */
|
|
16
|
-
|
|
32
|
+
__exportStar(require("./caller/executeFun"), exports);
|
|
17
33
|
/** UTILS */
|
|
18
|
-
|
|
19
|
-
|
|
20
|
-
|
|
21
|
-
|
|
22
|
-
|
|
34
|
+
__exportStar(require("./utils/smeupDataStructureWriter"), exports);
|
|
35
|
+
__exportStar(require("./utils/regex"), exports);
|
|
36
|
+
__exportStar(require("./utils/fun"), exports);
|
|
37
|
+
__exportStar(require("./utils/cells"), exports);
|
|
38
|
+
__exportStar(require("./events/eventUtils"), exports);
|
|
23
39
|
//# sourceMappingURL=index.js.map
|
package/lib/index.js.map
CHANGED
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"index.js","sourceRoot":"","sources":["../src/index.ts"],"names":[],"mappings":"AAAA,YAAY;AACZ,
|
|
1
|
+
{"version":3,"file":"index.js","sourceRoot":"","sources":["../src/index.ts"],"names":[],"mappings":";;;;;;;;;;;;;;;;AAAA,YAAY;AACZ,kDAAgC;AAChC,oDAAkC;AAClC,mDAAiC;AACjC,kDAAgC;AAEhC,sBAAsB;AACtB,6EAA2D;AAC3D,yEAAuD;AACvD,wEAAsD;AACtD,mEAAiD;AAEjD,iBAAiB;AACjB,+DAA6C;AAE7C,aAAa;AACb,kDAAgC;AAEhC,aAAa;AACb,sDAAoC;AAEpC,YAAY;AACZ,mEAAiD;AACjD,gDAA8B;AAC9B,8CAA4B;AAC5B,gDAA8B;AAC9B,sDAAoC"}
|
package/lib/logger/logger.js
CHANGED
|
@@ -1,36 +1,45 @@
|
|
|
1
|
-
|
|
2
|
-
|
|
1
|
+
"use strict";
|
|
2
|
+
var __importDefault = (this && this.__importDefault) || function (mod) {
|
|
3
|
+
return (mod && mod.__esModule) ? mod : { "default": mod };
|
|
4
|
+
};
|
|
5
|
+
Object.defineProperty(exports, "__esModule", { value: true });
|
|
6
|
+
exports.LOGGER = exports.clearLoggerContext = exports.createLoggerContext = exports.configureLogger = exports.Format = exports.Level = void 0;
|
|
7
|
+
const async_hooks_1 = __importDefault(require("async_hooks"));
|
|
8
|
+
var Level;
|
|
3
9
|
(function (Level) {
|
|
4
10
|
Level["INFO"] = "INFO";
|
|
5
11
|
Level["DEBUG"] = "DEBUG";
|
|
6
12
|
Level["ERROR"] = "ERROR";
|
|
7
|
-
})(Level || (Level = {}));
|
|
8
|
-
|
|
13
|
+
})(Level || (exports.Level = Level = {}));
|
|
14
|
+
var Format;
|
|
9
15
|
(function (Format) {
|
|
10
16
|
Format["JSON"] = "JSON";
|
|
11
17
|
Format["TXT"] = "TXT";
|
|
12
|
-
})(Format || (Format = {}));
|
|
18
|
+
})(Format || (exports.Format = Format = {}));
|
|
13
19
|
const LOGGER_SETTING = {
|
|
14
20
|
level: Level.DEBUG,
|
|
15
21
|
format: Format.TXT,
|
|
16
22
|
};
|
|
17
23
|
const LOGGER_CONTEXT_MAP = {};
|
|
18
|
-
|
|
24
|
+
const configureLogger = (level, format) => {
|
|
19
25
|
LOGGER_SETTING.level = level ? level : Level.DEBUG;
|
|
20
26
|
LOGGER_SETTING.format = format ? format : Format.TXT;
|
|
21
27
|
};
|
|
22
|
-
|
|
28
|
+
exports.configureLogger = configureLogger;
|
|
29
|
+
const createLoggerContext = (context) => {
|
|
23
30
|
// get the async execution id
|
|
24
|
-
const id =
|
|
31
|
+
const id = async_hooks_1.default.executionAsyncId();
|
|
25
32
|
// save to context map
|
|
26
33
|
LOGGER_CONTEXT_MAP[id] = context;
|
|
27
34
|
};
|
|
28
|
-
|
|
35
|
+
exports.createLoggerContext = createLoggerContext;
|
|
36
|
+
const clearLoggerContext = () => {
|
|
29
37
|
// get the async execution id
|
|
30
|
-
const id =
|
|
38
|
+
const id = async_hooks_1.default.executionAsyncId();
|
|
31
39
|
// delete from context map
|
|
32
40
|
delete LOGGER_CONTEXT_MAP[id];
|
|
33
41
|
};
|
|
42
|
+
exports.clearLoggerContext = clearLoggerContext;
|
|
34
43
|
class Logger {
|
|
35
44
|
info(message) {
|
|
36
45
|
this._log(Level.INFO, message);
|
|
@@ -47,7 +56,7 @@ class Logger {
|
|
|
47
56
|
return;
|
|
48
57
|
}
|
|
49
58
|
// get the async execution id
|
|
50
|
-
const id =
|
|
59
|
+
const id = async_hooks_1.default.executionAsyncId();
|
|
51
60
|
// get context
|
|
52
61
|
const context = LOGGER_CONTEXT_MAP[id];
|
|
53
62
|
// create log record
|
|
@@ -84,5 +93,5 @@ class Logger {
|
|
|
84
93
|
}
|
|
85
94
|
}
|
|
86
95
|
}
|
|
87
|
-
|
|
96
|
+
exports.LOGGER = new Logger();
|
|
88
97
|
//# sourceMappingURL=logger.js.map
|
package/lib/logger/logger.js.map
CHANGED
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"logger.js","sourceRoot":"","sources":["../../src/logger/logger.ts"],"names":[],"mappings":"AAAA,
|
|
1
|
+
{"version":3,"file":"logger.js","sourceRoot":"","sources":["../../src/logger/logger.ts"],"names":[],"mappings":"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"}
|