@enxoval/messaging 1.0.2 → 1.0.4
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/dist/admin.d.ts.map +1 -1
- package/dist/admin.js +4 -1
- package/dist/admin.js.map +1 -1
- package/dist/config.d.ts.map +1 -1
- package/dist/config.js +20 -4
- package/dist/config.js.map +1 -1
- package/dist/consumer/index.d.ts +1 -1
- package/dist/consumer/index.d.ts.map +1 -1
- package/dist/consumer/index.js +6 -5
- package/dist/consumer/index.js.map +1 -1
- package/dist/index.d.ts +2 -1
- package/dist/index.d.ts.map +1 -1
- package/dist/index.js +6 -2
- package/dist/index.js.map +1 -1
- package/dist/kafka.js +1 -1
- package/dist/kafka.js.map +1 -1
- package/dist/schemas/harkonnen.d.ts +20 -0
- package/dist/schemas/harkonnen.d.ts.map +1 -0
- package/dist/schemas/harkonnen.js +24 -0
- package/dist/schemas/harkonnen.js.map +1 -0
- package/package.json +5 -4
package/dist/admin.d.ts.map
CHANGED
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"admin.d.ts","sourceRoot":"","sources":["../admin.ts"],"names":[],"mappings":"AASA,wBAAsB,YAAY,IAAI,OAAO,CAAC,IAAI,CAAC,
|
|
1
|
+
{"version":3,"file":"admin.d.ts","sourceRoot":"","sources":["../admin.ts"],"names":[],"mappings":"AASA,wBAAsB,YAAY,IAAI,OAAO,CAAC,IAAI,CAAC,CAyBlD"}
|
package/dist/admin.js
CHANGED
|
@@ -5,7 +5,10 @@ const kafka_1 = require("./kafka");
|
|
|
5
5
|
const node_fs_1 = require("node:fs");
|
|
6
6
|
const node_path_1 = require("node:path");
|
|
7
7
|
async function ensureTopics() {
|
|
8
|
-
const
|
|
8
|
+
const configFileName = process.env.SERVICE_NAME
|
|
9
|
+
? `${process.env.SERVICE_NAME}.json`
|
|
10
|
+
: 'student-journey.json';
|
|
11
|
+
const configPath = (0, node_path_1.resolve)(process.cwd(), configFileName);
|
|
9
12
|
if (!(0, node_fs_1.existsSync)(configPath))
|
|
10
13
|
return;
|
|
11
14
|
const config = JSON.parse((0, node_fs_1.readFileSync)(configPath, 'utf-8'));
|
package/dist/admin.js.map
CHANGED
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"admin.js","sourceRoot":"","sources":["../admin.ts"],"names":[],"mappings":";;AASA,
|
|
1
|
+
{"version":3,"file":"admin.js","sourceRoot":"","sources":["../admin.ts"],"names":[],"mappings":";;AASA,oCAyBC;AAlCD,mCAAgC;AAChC,qCAAmD;AACnD,yCAAoC;AAO7B,KAAK,UAAU,YAAY;IAChC,MAAM,cAAc,GAAG,OAAO,CAAC,GAAG,CAAC,YAAY;QAC7C,CAAC,CAAC,GAAG,OAAO,CAAC,GAAG,CAAC,YAAY,OAAO;QACpC,CAAC,CAAC,sBAAsB,CAAC;IAC3B,MAAM,UAAU,GAAG,IAAA,mBAAO,EAAC,OAAO,CAAC,GAAG,EAAE,EAAE,cAAc,CAAC,CAAC;IAC1D,IAAI,CAAC,IAAA,oBAAU,EAAC,UAAU,CAAC;QAAE,OAAO;IAEpC,MAAM,MAAM,GAAkB,IAAI,CAAC,KAAK,CAAC,IAAA,sBAAY,EAAC,UAAU,EAAE,OAAO,CAAC,CAAC,CAAC;IAC5E,MAAM,YAAY,GAAG,MAAM,CAAC,YAAY,IAAI,EAAE,CAAC;IAE/C,MAAM,KAAK,GAAG,aAAK,CAAC,KAAK,EAAE,CAAC;IAC5B,MAAM,KAAK,CAAC,OAAO,EAAE,CAAC;IAEtB,MAAM,QAAQ,GAAG,IAAI,GAAG,CAAC,MAAM,KAAK,CAAC,UAAU,EAAE,CAAC,CAAC;IACnD,MAAM,QAAQ,GAAG,MAAM,CAAC,MAAM,CAAC,YAAY,CAAC;SACzC,GAAG,CAAC,CAAC,EAAE,KAAK,EAAE,EAAE,EAAE,CAAC,KAAK,CAAC;SACzB,MAAM,CAAC,CAAC,KAAK,EAAE,EAAE,CAAC,CAAC,QAAQ,CAAC,GAAG,CAAC,KAAK,CAAC,CAAC,CAAC;IAE3C,IAAI,QAAQ,CAAC,MAAM,GAAG,CAAC,EAAE,CAAC;QACxB,MAAM,KAAK,CAAC,YAAY,CAAC;YACvB,MAAM,EAAE,QAAQ,CAAC,GAAG,CAAC,CAAC,KAAK,EAAE,EAAE,CAAC,CAAC,EAAE,KAAK,EAAE,aAAa,EAAE,CAAC,EAAE,iBAAiB,EAAE,CAAC,EAAE,CAAC,CAAC;SACrF,CAAC,CAAC;IACL,CAAC;IAED,MAAM,KAAK,CAAC,UAAU,EAAE,CAAC;AAC3B,CAAC"}
|
package/dist/config.d.ts.map
CHANGED
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"config.d.ts","sourceRoot":"","sources":["../config.ts"],"names":[],"mappings":"
|
|
1
|
+
{"version":3,"file":"config.d.ts","sourceRoot":"","sources":["../config.ts"],"names":[],"mappings":"AAoCA,wBAAgB,aAAa,CAAC,IAAI,EAAE,MAAM,GAAG,MAAM,CAOlD;AAED,wBAAgB,eAAe,CAAC,IAAI,EAAE,MAAM,GAAG;IAAE,GAAG,EAAE,MAAM,CAAA;CAAE,CAU7D"}
|
package/dist/config.js
CHANGED
|
@@ -4,21 +4,37 @@ exports.getKafkaTopic = getKafkaTopic;
|
|
|
4
4
|
exports.getHttpEndpoint = getHttpEndpoint;
|
|
5
5
|
const node_fs_1 = require("node:fs");
|
|
6
6
|
const node_path_1 = require("node:path");
|
|
7
|
-
|
|
7
|
+
let _config = null;
|
|
8
|
+
function getConfig() {
|
|
9
|
+
if (_config)
|
|
10
|
+
return _config;
|
|
11
|
+
const configFileName = process.env.SERVICE_NAME
|
|
12
|
+
? `${process.env.SERVICE_NAME}.json`
|
|
13
|
+
: 'student-journey.json';
|
|
14
|
+
const configPath = (0, node_path_1.resolve)(process.cwd(), configFileName);
|
|
15
|
+
if (!(0, node_fs_1.existsSync)(configPath)) {
|
|
16
|
+
_config = { kafka_topics: {}, http_mapped: {} };
|
|
17
|
+
return _config;
|
|
18
|
+
}
|
|
19
|
+
_config = JSON.parse((0, node_fs_1.readFileSync)(configPath, 'utf-8'));
|
|
20
|
+
return _config;
|
|
21
|
+
}
|
|
8
22
|
function getKafkaTopic(name) {
|
|
23
|
+
const config = getConfig();
|
|
9
24
|
const entry = config.kafka_topics?.[name];
|
|
10
25
|
if (!entry) {
|
|
11
|
-
throw new Error(`Kafka topic "${name}" is not configured
|
|
26
|
+
throw new Error(`Kafka topic "${name}" is not configured`);
|
|
12
27
|
}
|
|
13
28
|
return entry.topic;
|
|
14
29
|
}
|
|
15
30
|
function getHttpEndpoint(name) {
|
|
31
|
+
const config = getConfig();
|
|
16
32
|
const entry = config.http_mapped?.[name];
|
|
17
33
|
if (!entry) {
|
|
18
|
-
throw new Error(`HTTP endpoint "${name}" is not configured
|
|
34
|
+
throw new Error(`HTTP endpoint "${name}" is not configured`);
|
|
19
35
|
}
|
|
20
36
|
if (!entry.service) {
|
|
21
|
-
throw new Error(`HTTP endpoint "${name}" has no service configured
|
|
37
|
+
throw new Error(`HTTP endpoint "${name}" has no service configured`);
|
|
22
38
|
}
|
|
23
39
|
return { url: `${entry.service}${entry.path}` };
|
|
24
40
|
}
|
package/dist/config.js.map
CHANGED
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"config.js","sourceRoot":"","sources":["../config.ts"],"names":[],"mappings":";;
|
|
1
|
+
{"version":3,"file":"config.js","sourceRoot":"","sources":["../config.ts"],"names":[],"mappings":";;AAoCA,sCAOC;AAED,0CAUC;AAvDD,qCAAmD;AACnD,yCAAoC;AAmBpC,IAAI,OAAO,GAAqB,IAAI,CAAC;AAErC,SAAS,SAAS;IAChB,IAAI,OAAO;QAAE,OAAO,OAAO,CAAC;IAC5B,MAAM,cAAc,GAAG,OAAO,CAAC,GAAG,CAAC,YAAY;QAC7C,CAAC,CAAC,GAAG,OAAO,CAAC,GAAG,CAAC,YAAY,OAAO;QACpC,CAAC,CAAC,sBAAsB,CAAC;IAC3B,MAAM,UAAU,GAAG,IAAA,mBAAO,EAAC,OAAO,CAAC,GAAG,EAAE,EAAE,cAAc,CAAC,CAAC;IAC1D,IAAI,CAAC,IAAA,oBAAU,EAAC,UAAU,CAAC,EAAE,CAAC;QAC5B,OAAO,GAAG,EAAE,YAAY,EAAE,EAAE,EAAE,WAAW,EAAE,EAAE,EAAE,CAAC;QAChD,OAAO,OAAO,CAAC;IACjB,CAAC;IACD,OAAO,GAAG,IAAI,CAAC,KAAK,CAAC,IAAA,sBAAY,EAAC,UAAU,EAAE,OAAO,CAAC,CAAc,CAAC;IACrE,OAAO,OAAO,CAAC;AACjB,CAAC;AAED,SAAgB,aAAa,CAAC,IAAY;IACxC,MAAM,MAAM,GAAG,SAAS,EAAE,CAAC;IAC3B,MAAM,KAAK,GAAG,MAAM,CAAC,YAAY,EAAE,CAAC,IAAI,CAAC,CAAC;IAC1C,IAAI,CAAC,KAAK,EAAE,CAAC;QACX,MAAM,IAAI,KAAK,CAAC,gBAAgB,IAAI,qBAAqB,CAAC,CAAC;IAC7D,CAAC;IACD,OAAO,KAAK,CAAC,KAAK,CAAC;AACrB,CAAC;AAED,SAAgB,eAAe,CAAC,IAAY;IAC1C,MAAM,MAAM,GAAG,SAAS,EAAE,CAAC;IAC3B,MAAM,KAAK,GAAG,MAAM,CAAC,WAAW,EAAE,CAAC,IAAI,CAAC,CAAC;IACzC,IAAI,CAAC,KAAK,EAAE,CAAC;QACX,MAAM,IAAI,KAAK,CAAC,kBAAkB,IAAI,qBAAqB,CAAC,CAAC;IAC/D,CAAC;IACD,IAAI,CAAC,KAAK,CAAC,OAAO,EAAE,CAAC;QACnB,MAAM,IAAI,KAAK,CAAC,kBAAkB,IAAI,6BAA6B,CAAC,CAAC;IACvE,CAAC;IACD,OAAO,EAAE,GAAG,EAAE,GAAG,KAAK,CAAC,OAAO,GAAG,KAAK,CAAC,IAAI,EAAE,EAAE,CAAC;AAClD,CAAC"}
|
package/dist/consumer/index.d.ts
CHANGED
|
@@ -1,3 +1,3 @@
|
|
|
1
1
|
export type MessageHandler<T = unknown> = (message: T) => Promise<void> | void;
|
|
2
|
-
export declare function
|
|
2
|
+
export declare function consume<T extends Record<string, unknown>>(name: string, handler: MessageHandler<T>): void;
|
|
3
3
|
//# sourceMappingURL=index.d.ts.map
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"index.d.ts","sourceRoot":"","sources":["../../consumer/index.ts"],"names":[],"mappings":"AAMA,MAAM,MAAM,cAAc,CAAC,CAAC,GAAG,OAAO,IAAI,CAAC,OAAO,EAAE,CAAC,KAAK,OAAO,CAAC,IAAI,CAAC,GAAG,IAAI,CAAC;
|
|
1
|
+
{"version":3,"file":"index.d.ts","sourceRoot":"","sources":["../../consumer/index.ts"],"names":[],"mappings":"AAMA,MAAM,MAAM,cAAc,CAAC,CAAC,GAAG,OAAO,IAAI,CAAC,OAAO,EAAE,CAAC,KAAK,OAAO,CAAC,IAAI,CAAC,GAAG,IAAI,CAAC;AAkB/E,wBAAgB,OAAO,CAAC,CAAC,SAAS,MAAM,CAAC,MAAM,EAAE,OAAO,CAAC,EACvD,IAAI,EAAE,MAAM,EACZ,OAAO,EAAE,cAAc,CAAC,CAAC,CAAC,GACzB,IAAI,CAsCN"}
|
package/dist/consumer/index.js
CHANGED
|
@@ -1,13 +1,12 @@
|
|
|
1
1
|
"use strict";
|
|
2
2
|
Object.defineProperty(exports, "__esModule", { value: true });
|
|
3
|
-
exports.
|
|
3
|
+
exports.consume = consume;
|
|
4
4
|
const observability_1 = require("@enxoval/observability");
|
|
5
5
|
const config_1 = require("../config");
|
|
6
6
|
const observability_2 = require("@enxoval/observability");
|
|
7
7
|
const kafka_1 = require("../kafka");
|
|
8
8
|
const index_1 = require("../producer/index");
|
|
9
9
|
const MAX_RETRIES = 3;
|
|
10
|
-
const DLQ_TOPIC = 'student-journey-dlq';
|
|
11
10
|
function sleep(ms) {
|
|
12
11
|
return new Promise((resolve) => setTimeout(resolve, ms));
|
|
13
12
|
}
|
|
@@ -22,9 +21,11 @@ async function withRetry(fn, attemptsLeft, delayMs) {
|
|
|
22
21
|
await withRetry(fn, attemptsLeft - 1, delayMs * 2);
|
|
23
22
|
}
|
|
24
23
|
}
|
|
25
|
-
function
|
|
24
|
+
function consume(name, handler) {
|
|
26
25
|
const topic = (0, config_1.getKafkaTopic)(name);
|
|
27
|
-
const
|
|
26
|
+
const serviceName = process.env.SERVICE_NAME || name;
|
|
27
|
+
const dlqTopic = `${serviceName}-dlq`;
|
|
28
|
+
const consumer = kafka_1.kafka.consumer({ groupId: `${serviceName}-${name}` });
|
|
28
29
|
consumer
|
|
29
30
|
.connect()
|
|
30
31
|
.then(() => consumer.subscribe({ topic, fromBeginning: false }))
|
|
@@ -44,7 +45,7 @@ function subscribe(name, handler) {
|
|
|
44
45
|
}
|
|
45
46
|
catch (err) {
|
|
46
47
|
observability_1.logger.error({ err, cid, topic, name, payload }, 'consumer: message failed after retries, sending to DLQ');
|
|
47
|
-
await (0, index_1.publishRaw)(
|
|
48
|
+
await (0, index_1.publishRaw)(dlqTopic, {
|
|
48
49
|
originalTopic: topic,
|
|
49
50
|
name,
|
|
50
51
|
payload,
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"index.js","sourceRoot":"","sources":["../../consumer/index.ts"],"names":[],"mappings":";;
|
|
1
|
+
{"version":3,"file":"index.js","sourceRoot":"","sources":["../../consumer/index.ts"],"names":[],"mappings":";;AAwBA,0BAyCC;AAjED,0DAAgD;AAChD,sCAA0C;AAC1C,0DAAiD;AACjD,oCAAiC;AACjC,6CAA+C;AAI/C,MAAM,WAAW,GAAG,CAAC,CAAC;AAEtB,SAAS,KAAK,CAAC,EAAU;IACvB,OAAO,IAAI,OAAO,CAAC,CAAC,OAAO,EAAE,EAAE,CAAC,UAAU,CAAC,OAAO,EAAE,EAAE,CAAC,CAAC,CAAC;AAC3D,CAAC;AAED,KAAK,UAAU,SAAS,CAAC,EAAuB,EAAE,YAAoB,EAAE,OAAe;IACrF,IAAI,CAAC;QACH,MAAM,EAAE,EAAE,CAAC;IACb,CAAC;IAAC,OAAO,GAAG,EAAE,CAAC;QACb,IAAI,YAAY,IAAI,CAAC;YAAE,MAAM,GAAG,CAAC;QACjC,MAAM,KAAK,CAAC,OAAO,CAAC,CAAC;QACrB,MAAM,SAAS,CAAC,EAAE,EAAE,YAAY,GAAG,CAAC,EAAE,OAAO,GAAG,CAAC,CAAC,CAAC;IACrD,CAAC;AACH,CAAC;AAED,SAAgB,OAAO,CACrB,IAAY,EACZ,OAA0B;IAE1B,MAAM,KAAK,GAAG,IAAA,sBAAa,EAAC,IAAI,CAAC,CAAC;IAClC,MAAM,WAAW,GAAG,OAAO,CAAC,GAAG,CAAC,YAAY,IAAI,IAAI,CAAC;IACrD,MAAM,QAAQ,GAAG,GAAG,WAAW,MAAM,CAAC;IACtC,MAAM,QAAQ,GAAG,aAAK,CAAC,QAAQ,CAAC,EAAE,OAAO,EAAE,GAAG,WAAW,IAAI,IAAI,EAAE,EAAE,CAAC,CAAC;IAEvE,QAAQ;SACL,OAAO,EAAE;SACT,IAAI,CAAC,GAAG,EAAE,CAAC,QAAQ,CAAC,SAAS,CAAC,EAAE,KAAK,EAAE,aAAa,EAAE,KAAK,EAAE,CAAC,CAAC;SAC/D,IAAI,CAAC,GAAG,EAAE;QACT,sBAAM,CAAC,IAAI,CAAC,EAAE,KAAK,EAAE,IAAI,EAAE,EAAE,sBAAsB,CAAC,CAAC;QACrD,OAAO,QAAQ,CAAC,GAAG,CAAC;YAClB,WAAW,EAAE,KAAK,EAAE,EAAE,OAAO,EAAE,EAAE,EAAE;gBACjC,MAAM,GAAG,GAAG,OAAO,CAAC,KAAK,EAAE,QAAQ,EAAE,CAAC;gBACtC,IAAI,CAAC,GAAG;oBAAE,OAAO;gBACjB,MAAM,OAAO,GAAG,IAAI,CAAC,KAAK,CAAC,GAAG,CAAM,CAAC;gBACrC,MAAM,QAAQ,GAAI,OAA4B,CAAC,GAAG,CAAC;gBACnD,MAAM,GAAG,GAAG,QAAQ,CAAC,CAAC,CAAC,IAAA,uBAAO,EAAC,QAAQ,CAAC,CAAC,CAAC,CAAC,SAAS,CAAC;gBACrD,sBAAM,CAAC,IAAI,CAAC,EAAE,GAAG,EAAE,KAAK,EAAE,IAAI,EAAE,OAAO,EAAG,OAAgC,CAAC,OAAO,EAAE,EAAE,4BAA4B,CAAC,CAAC;gBAEpH,IAAI,CAAC;oBACH,MAAM,SAAS,CAAC,GAAG,EAAE,CAAC,OAAO,CAAC,OAAO,CAAC,OAAO,CAAC,OAAO,CAAC,CAAC,EAAE,WAAW,EAAE,GAAG,CAAC,CAAC;gBAC7E,CAAC;gBAAC,OAAO,GAAG,EAAE,CAAC;oBACb,sBAAM,CAAC,KAAK,CAAC,EAAE,GAAG,EAAE,GAAG,EAAE,KAAK,EAAE,IAAI,EAAE,OAAO,EAAE,EAAE,wDAAwD,CAAC,CAAC;oBAC3G,MAAM,IAAA,kBAAU,EAAC,QAAQ,EAAE;wBACzB,aAAa,EAAE,KAAK;wBACpB,IAAI;wBACJ,OAAO;wBACP,KAAK,EAAE,GAAG,YAAY,KAAK,CAAC,CAAC,CAAC,GAAG,CAAC,OAAO,CAAC,CAAC,CAAC,MAAM,CAAC,GAAG,CAAC;wBACvD,QAAQ,EAAE,IAAI,IAAI,EAAE,CAAC,WAAW,EAAE;qBACnC,CAAC,CAAC;gBACL,CAAC;YACH,CAAC;SACF,CAAC,CAAC;IACL,CAAC,CAAC;SACD,KAAK,CAAC,CAAC,GAAG,EAAE,EAAE;QACb,sBAAM,CAAC,KAAK,CAAC,EAAE,GAAG,EAAE,KAAK,EAAE,IAAI,EAAE,EAAE,2BAA2B,CAAC,CAAC;IAClE,CAAC,CAAC,CAAC;AACP,CAAC"}
|
package/dist/index.d.ts
CHANGED
|
@@ -1,6 +1,7 @@
|
|
|
1
1
|
export { publish, publishRaw, connect, disconnect } from './producer/index';
|
|
2
|
-
export {
|
|
2
|
+
export { consume } from './consumer/index';
|
|
3
3
|
export type { MessageHandler } from './consumer/index';
|
|
4
4
|
export { ensureTopics } from './admin';
|
|
5
5
|
export { kafka } from './kafka';
|
|
6
|
+
export { HarkonnenMessage, HarkonnenMessageInput, HARKONNEN_STATUSES } from './schemas/harkonnen';
|
|
6
7
|
//# sourceMappingURL=index.d.ts.map
|
package/dist/index.d.ts.map
CHANGED
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"index.d.ts","sourceRoot":"","sources":["../index.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,OAAO,EAAE,UAAU,EAAE,OAAO,EAAE,UAAU,EAAE,MAAM,kBAAkB,CAAC;AAC5E,OAAO,EAAE,
|
|
1
|
+
{"version":3,"file":"index.d.ts","sourceRoot":"","sources":["../index.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,OAAO,EAAE,UAAU,EAAE,OAAO,EAAE,UAAU,EAAE,MAAM,kBAAkB,CAAC;AAC5E,OAAO,EAAE,OAAO,EAAE,MAAM,kBAAkB,CAAC;AAC3C,YAAY,EAAE,cAAc,EAAE,MAAM,kBAAkB,CAAC;AACvD,OAAO,EAAE,YAAY,EAAE,MAAM,SAAS,CAAC;AACvC,OAAO,EAAE,KAAK,EAAE,MAAM,SAAS,CAAC;AAChC,OAAO,EAAE,gBAAgB,EAAE,qBAAqB,EAAE,kBAAkB,EAAE,MAAM,qBAAqB,CAAC"}
|
package/dist/index.js
CHANGED
|
@@ -1,15 +1,19 @@
|
|
|
1
1
|
"use strict";
|
|
2
2
|
Object.defineProperty(exports, "__esModule", { value: true });
|
|
3
|
-
exports.kafka = exports.ensureTopics = exports.
|
|
3
|
+
exports.HARKONNEN_STATUSES = exports.HarkonnenMessageInput = exports.HarkonnenMessage = exports.kafka = exports.ensureTopics = exports.consume = exports.disconnect = exports.connect = exports.publishRaw = exports.publish = void 0;
|
|
4
4
|
var index_1 = require("./producer/index");
|
|
5
5
|
Object.defineProperty(exports, "publish", { enumerable: true, get: function () { return index_1.publish; } });
|
|
6
6
|
Object.defineProperty(exports, "publishRaw", { enumerable: true, get: function () { return index_1.publishRaw; } });
|
|
7
7
|
Object.defineProperty(exports, "connect", { enumerable: true, get: function () { return index_1.connect; } });
|
|
8
8
|
Object.defineProperty(exports, "disconnect", { enumerable: true, get: function () { return index_1.disconnect; } });
|
|
9
9
|
var index_2 = require("./consumer/index");
|
|
10
|
-
Object.defineProperty(exports, "
|
|
10
|
+
Object.defineProperty(exports, "consume", { enumerable: true, get: function () { return index_2.consume; } });
|
|
11
11
|
var admin_1 = require("./admin");
|
|
12
12
|
Object.defineProperty(exports, "ensureTopics", { enumerable: true, get: function () { return admin_1.ensureTopics; } });
|
|
13
13
|
var kafka_1 = require("./kafka");
|
|
14
14
|
Object.defineProperty(exports, "kafka", { enumerable: true, get: function () { return kafka_1.kafka; } });
|
|
15
|
+
var harkonnen_1 = require("./schemas/harkonnen");
|
|
16
|
+
Object.defineProperty(exports, "HarkonnenMessage", { enumerable: true, get: function () { return harkonnen_1.HarkonnenMessage; } });
|
|
17
|
+
Object.defineProperty(exports, "HarkonnenMessageInput", { enumerable: true, get: function () { return harkonnen_1.HarkonnenMessageInput; } });
|
|
18
|
+
Object.defineProperty(exports, "HARKONNEN_STATUSES", { enumerable: true, get: function () { return harkonnen_1.HARKONNEN_STATUSES; } });
|
|
15
19
|
//# sourceMappingURL=index.js.map
|
package/dist/index.js.map
CHANGED
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"index.js","sourceRoot":"","sources":["../index.ts"],"names":[],"mappings":";;;AAAA,0CAA4E;AAAnE,gGAAA,OAAO,OAAA;AAAE,mGAAA,UAAU,OAAA;AAAE,gGAAA,OAAO,OAAA;AAAE,mGAAA,UAAU,OAAA;AACjD,
|
|
1
|
+
{"version":3,"file":"index.js","sourceRoot":"","sources":["../index.ts"],"names":[],"mappings":";;;AAAA,0CAA4E;AAAnE,gGAAA,OAAO,OAAA;AAAE,mGAAA,UAAU,OAAA;AAAE,gGAAA,OAAO,OAAA;AAAE,mGAAA,UAAU,OAAA;AACjD,0CAA2C;AAAlC,gGAAA,OAAO,OAAA;AAEhB,iCAAuC;AAA9B,qGAAA,YAAY,OAAA;AACrB,iCAAgC;AAAvB,8FAAA,KAAK,OAAA;AACd,iDAAkG;AAAzF,6GAAA,gBAAgB,OAAA;AAAE,kHAAA,qBAAqB,OAAA;AAAE,+GAAA,kBAAkB,OAAA"}
|
package/dist/kafka.js
CHANGED
|
@@ -3,7 +3,7 @@ Object.defineProperty(exports, "__esModule", { value: true });
|
|
|
3
3
|
exports.kafka = void 0;
|
|
4
4
|
const kafkajs_1 = require("kafkajs");
|
|
5
5
|
exports.kafka = new kafkajs_1.Kafka({
|
|
6
|
-
clientId: '
|
|
6
|
+
clientId: process.env.SERVICE_NAME || 'enxoval-service',
|
|
7
7
|
brokers: [process.env.KAFKA_BROKER || 'localhost:29092'],
|
|
8
8
|
retry: {
|
|
9
9
|
initialRetryTime: 300,
|
package/dist/kafka.js.map
CHANGED
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"kafka.js","sourceRoot":"","sources":["../kafka.ts"],"names":[],"mappings":";;;AAAA,qCAAgC;AAEnB,QAAA,KAAK,GAAG,IAAI,eAAK,CAAC;IAC7B,QAAQ,EAAE,iBAAiB;
|
|
1
|
+
{"version":3,"file":"kafka.js","sourceRoot":"","sources":["../kafka.ts"],"names":[],"mappings":";;;AAAA,qCAAgC;AAEnB,QAAA,KAAK,GAAG,IAAI,eAAK,CAAC;IAC7B,QAAQ,EAAE,OAAO,CAAC,GAAG,CAAC,YAAY,IAAI,iBAAiB;IACvD,OAAO,EAAE,CAAC,OAAO,CAAC,GAAG,CAAC,YAAY,IAAI,iBAAiB,CAAC;IACxD,KAAK,EAAE;QACL,gBAAgB,EAAE,GAAG;QACrB,OAAO,EAAE,EAAE;KACZ;CACF,CAAC,CAAC"}
|
|
@@ -0,0 +1,20 @@
|
|
|
1
|
+
export declare const HARKONNEN_STATUSES: readonly ["pending", "reprocessed", "dismissed"];
|
|
2
|
+
export declare const HarkonnenMessage: import("@enxoval/types").Schema<{
|
|
3
|
+
id: import("@enxoval/types").UUID;
|
|
4
|
+
originalTopic: string;
|
|
5
|
+
name: string;
|
|
6
|
+
payload: string;
|
|
7
|
+
error: string;
|
|
8
|
+
failedAt: string;
|
|
9
|
+
status: "pending" | "reprocessed" | "dismissed";
|
|
10
|
+
reprocessedAt: string | null;
|
|
11
|
+
createdAt: string;
|
|
12
|
+
}>;
|
|
13
|
+
export declare const HarkonnenMessageInput: import("@enxoval/types").Schema<{
|
|
14
|
+
originalTopic: string;
|
|
15
|
+
name: string;
|
|
16
|
+
payload: string;
|
|
17
|
+
error: string;
|
|
18
|
+
failedAt: string;
|
|
19
|
+
}>;
|
|
20
|
+
//# sourceMappingURL=harkonnen.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"harkonnen.d.ts","sourceRoot":"","sources":["../../schemas/harkonnen.ts"],"names":[],"mappings":"AAEA,eAAO,MAAM,kBAAkB,kDAAmD,CAAC;AAEnF,eAAO,MAAM,gBAAgB;;;;;;;;;;EAU3B,CAAC;AAEH,eAAO,MAAM,qBAAqB;;;;;;EAMhC,CAAC"}
|
|
@@ -0,0 +1,24 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
Object.defineProperty(exports, "__esModule", { value: true });
|
|
3
|
+
exports.HarkonnenMessageInput = exports.HarkonnenMessage = exports.HARKONNEN_STATUSES = void 0;
|
|
4
|
+
const types_1 = require("@enxoval/types");
|
|
5
|
+
exports.HARKONNEN_STATUSES = ['pending', 'reprocessed', 'dismissed'];
|
|
6
|
+
exports.HarkonnenMessage = (0, types_1.createSchema)({
|
|
7
|
+
id: types_1.field.uuid(),
|
|
8
|
+
originalTopic: types_1.field.string(),
|
|
9
|
+
name: types_1.field.string(),
|
|
10
|
+
payload: types_1.field.string(),
|
|
11
|
+
error: types_1.field.string(),
|
|
12
|
+
failedAt: types_1.field.string(),
|
|
13
|
+
status: types_1.field.literal(...exports.HARKONNEN_STATUSES),
|
|
14
|
+
reprocessedAt: types_1.field.nullable(types_1.field.string()),
|
|
15
|
+
createdAt: types_1.field.string(),
|
|
16
|
+
});
|
|
17
|
+
exports.HarkonnenMessageInput = (0, types_1.createSchema)({
|
|
18
|
+
originalTopic: types_1.field.string(),
|
|
19
|
+
name: types_1.field.string(),
|
|
20
|
+
payload: types_1.field.string(),
|
|
21
|
+
error: types_1.field.string(),
|
|
22
|
+
failedAt: types_1.field.string(),
|
|
23
|
+
});
|
|
24
|
+
//# sourceMappingURL=harkonnen.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"harkonnen.js","sourceRoot":"","sources":["../../schemas/harkonnen.ts"],"names":[],"mappings":";;;AAAA,0CAAqD;AAExC,QAAA,kBAAkB,GAAG,CAAC,SAAS,EAAE,aAAa,EAAE,WAAW,CAAU,CAAC;AAEtE,QAAA,gBAAgB,GAAG,IAAA,oBAAY,EAAC;IAC3C,EAAE,EAAE,aAAK,CAAC,IAAI,EAAE;IAChB,aAAa,EAAE,aAAK,CAAC,MAAM,EAAE;IAC7B,IAAI,EAAE,aAAK,CAAC,MAAM,EAAE;IACpB,OAAO,EAAE,aAAK,CAAC,MAAM,EAAE;IACvB,KAAK,EAAE,aAAK,CAAC,MAAM,EAAE;IACrB,QAAQ,EAAE,aAAK,CAAC,MAAM,EAAE;IACxB,MAAM,EAAE,aAAK,CAAC,OAAO,CAAC,GAAG,0BAAkB,CAAC;IAC5C,aAAa,EAAE,aAAK,CAAC,QAAQ,CAAC,aAAK,CAAC,MAAM,EAAE,CAAC;IAC7C,SAAS,EAAE,aAAK,CAAC,MAAM,EAAE;CAC1B,CAAC,CAAC;AAEU,QAAA,qBAAqB,GAAG,IAAA,oBAAY,EAAC;IAChD,aAAa,EAAE,aAAK,CAAC,MAAM,EAAE;IAC7B,IAAI,EAAE,aAAK,CAAC,MAAM,EAAE;IACpB,OAAO,EAAE,aAAK,CAAC,MAAM,EAAE;IACvB,KAAK,EAAE,aAAK,CAAC,MAAM,EAAE;IACrB,QAAQ,EAAE,aAAK,CAAC,MAAM,EAAE;CACzB,CAAC,CAAC"}
|
package/package.json
CHANGED
|
@@ -1,7 +1,7 @@
|
|
|
1
1
|
{
|
|
2
2
|
"name": "@enxoval/messaging",
|
|
3
|
-
"version": "1.0.
|
|
4
|
-
"description": "KafkaJS wrapper exposing publish,
|
|
3
|
+
"version": "1.0.4",
|
|
4
|
+
"description": "KafkaJS wrapper exposing publish, consume and ensureTopics",
|
|
5
5
|
"main": "dist/index.js",
|
|
6
6
|
"types": "dist/index.d.ts",
|
|
7
7
|
"files": [
|
|
@@ -19,9 +19,10 @@
|
|
|
19
19
|
"license": "MIT",
|
|
20
20
|
"dependencies": {
|
|
21
21
|
"kafkajs": "^2.2.4",
|
|
22
|
-
"@enxoval/observability": "^1.0.0"
|
|
22
|
+
"@enxoval/observability": "^1.0.0",
|
|
23
|
+
"@enxoval/types": "^1.0.25"
|
|
23
24
|
},
|
|
24
25
|
"devDependencies": {
|
|
25
26
|
"typescript": "^5.7.2"
|
|
26
27
|
}
|
|
27
|
-
}
|
|
28
|
+
}
|