@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.
@@ -1 +1 @@
1
- {"version":3,"file":"admin.d.ts","sourceRoot":"","sources":["../admin.ts"],"names":[],"mappings":"AASA,wBAAsB,YAAY,IAAI,OAAO,CAAC,IAAI,CAAC,CAsBlD"}
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 configPath = (0, node_path_1.resolve)(process.cwd(), 'config.json');
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,oCAsBC;AA/BD,mCAAgC;AAChC,qCAAmD;AACnD,yCAAoC;AAO7B,KAAK,UAAU,YAAY;IAChC,MAAM,UAAU,GAAG,IAAA,mBAAO,EAAC,OAAO,CAAC,GAAG,EAAE,EAAE,aAAa,CAAC,CAAC;IACzD,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"}
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"}
@@ -1 +1 @@
1
- {"version":3,"file":"config.d.ts","sourceRoot":"","sources":["../config.ts"],"names":[],"mappings":"AAwBA,wBAAgB,aAAa,CAAC,IAAI,EAAE,MAAM,GAAG,MAAM,CAMlD;AAED,wBAAgB,eAAe,CAAC,IAAI,EAAE,MAAM,GAAG;IAAE,GAAG,EAAE,MAAM,CAAA;CAAE,CAS7D"}
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
- const config = JSON.parse((0, node_fs_1.readFileSync)((0, node_path_1.resolve)(process.cwd(), 'student-journey.json'), 'utf-8'));
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 in student-journey.json`);
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 in student-journey.json`);
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 in student-journey.json`);
37
+ throw new Error(`HTTP endpoint "${name}" has no service configured`);
22
38
  }
23
39
  return { url: `${entry.service}${entry.path}` };
24
40
  }
@@ -1 +1 @@
1
- {"version":3,"file":"config.js","sourceRoot":"","sources":["../config.ts"],"names":[],"mappings":";;AAwBA,sCAMC;AAED,0CASC;AAzCD,qCAAuC;AACvC,yCAAoC;AAmBpC,MAAM,MAAM,GAAc,IAAI,CAAC,KAAK,CAClC,IAAA,sBAAY,EAAC,IAAA,mBAAO,EAAC,OAAO,CAAC,GAAG,EAAE,EAAE,sBAAsB,CAAC,EAAE,OAAO,CAAC,CACtE,CAAC;AAEF,SAAgB,aAAa,CAAC,IAAY;IACxC,MAAM,KAAK,GAAG,MAAM,CAAC,YAAY,EAAE,CAAC,IAAI,CAAC,CAAC;IAC1C,IAAI,CAAC,KAAK,EAAE,CAAC;QACX,MAAM,IAAI,KAAK,CAAC,gBAAgB,IAAI,6CAA6C,CAAC,CAAC;IACrF,CAAC;IACD,OAAO,KAAK,CAAC,KAAK,CAAC;AACrB,CAAC;AAED,SAAgB,eAAe,CAAC,IAAY;IAC1C,MAAM,KAAK,GAAG,MAAM,CAAC,WAAW,EAAE,CAAC,IAAI,CAAC,CAAC;IACzC,IAAI,CAAC,KAAK,EAAE,CAAC;QACX,MAAM,IAAI,KAAK,CAAC,kBAAkB,IAAI,6CAA6C,CAAC,CAAC;IACvF,CAAC;IACD,IAAI,CAAC,KAAK,CAAC,OAAO,EAAE,CAAC;QACnB,MAAM,IAAI,KAAK,CAAC,kBAAkB,IAAI,qDAAqD,CAAC,CAAC;IAC/F,CAAC;IACD,OAAO,EAAE,GAAG,EAAE,GAAG,KAAK,CAAC,OAAO,GAAG,KAAK,CAAC,IAAI,EAAE,EAAE,CAAC;AAClD,CAAC"}
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"}
@@ -1,3 +1,3 @@
1
1
  export type MessageHandler<T = unknown> = (message: T) => Promise<void> | void;
2
- export declare function subscribe<T extends Record<string, unknown>>(name: string, handler: MessageHandler<T>): void;
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;AAmB/E,wBAAgB,SAAS,CAAC,CAAC,SAAS,MAAM,CAAC,MAAM,EAAE,OAAO,CAAC,EACzD,IAAI,EAAE,MAAM,EACZ,OAAO,EAAE,cAAc,CAAC,CAAC,CAAC,GACzB,IAAI,CAoCN"}
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"}
@@ -1,13 +1,12 @@
1
1
  "use strict";
2
2
  Object.defineProperty(exports, "__esModule", { value: true });
3
- exports.subscribe = subscribe;
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 subscribe(name, handler) {
24
+ function consume(name, handler) {
26
25
  const topic = (0, config_1.getKafkaTopic)(name);
27
- const consumer = kafka_1.kafka.consumer({ groupId: `student-journey-${name}` });
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)(DLQ_TOPIC, {
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":"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"}
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 { subscribe } from './consumer/index';
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
@@ -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,SAAS,EAAE,MAAM,kBAAkB,CAAC;AAC7C,YAAY,EAAE,cAAc,EAAE,MAAM,kBAAkB,CAAC;AACvD,OAAO,EAAE,YAAY,EAAE,MAAM,SAAS,CAAC;AACvC,OAAO,EAAE,KAAK,EAAE,MAAM,SAAS,CAAC"}
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.subscribe = exports.disconnect = exports.connect = exports.publishRaw = exports.publish = void 0;
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, "subscribe", { enumerable: true, get: function () { return index_2.subscribe; } });
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,0CAA6C;AAApC,kGAAA,SAAS,OAAA;AAElB,iCAAuC;AAA9B,qGAAA,YAAY,OAAA;AACrB,iCAAgC;AAAvB,8FAAA,KAAK,OAAA"}
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: 'student-journey',
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;IAC3B,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"}
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.2",
4
- "description": "KafkaJS wrapper exposing publish, subscribe and ensureTopics",
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
+ }