@l-etabli/events 0.4.1 → 0.4.2

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.
@@ -21,24 +21,38 @@ __export(KyselyEventRepository_exports, {
21
21
  createKyselyEventRepository: () => createKyselyEventRepository
22
22
  });
23
23
  module.exports = __toCommonJS(KyselyEventRepository_exports);
24
+ var import_kysely = require("kysely");
25
+ const jsonb = (value) => import_kysely.sql`${JSON.stringify(value)}::jsonb`;
24
26
  const createKyselyEventRepository = (db) => ({
25
27
  save: async (event) => {
26
- await db.insertInto("events").values(event).onConflict(
28
+ await db.insertInto("events").values({
29
+ ...event,
30
+ payload: jsonb(event.payload),
31
+ context: jsonb(event.context),
32
+ publications: jsonb(event.publications)
33
+ }).onConflict(
27
34
  (oc) => oc.column("id").doUpdateSet({
28
35
  topic: event.topic,
29
- payload: event.payload,
30
- context: event.context,
36
+ payload: jsonb(event.payload),
37
+ context: jsonb(event.context),
31
38
  status: event.status,
32
39
  triggeredByUserId: event.triggeredByUserId,
33
40
  occurredAt: event.occurredAt,
34
- publications: event.publications,
41
+ publications: jsonb(event.publications),
35
42
  priority: event.priority
36
43
  })
37
44
  ).execute();
38
45
  },
39
46
  saveNewEventsBatch: async (events) => {
40
47
  if (events.length === 0) return;
41
- await db.insertInto("events").values(events).execute();
48
+ await db.insertInto("events").values(
49
+ events.map((event) => ({
50
+ ...event,
51
+ payload: jsonb(event.payload),
52
+ context: jsonb(event.context),
53
+ publications: jsonb(event.publications)
54
+ }))
55
+ ).execute();
42
56
  },
43
57
  markEventsAsInProcess: async (events) => {
44
58
  if (events.length === 0) return;
@@ -1 +1 @@
1
- {"version":3,"sources":["../../../src/adapters/kysely/KyselyEventRepository.ts"],"sourcesContent":["import type { Kysely } from \"kysely\";\nimport type { EventRepository } from \"../../ports/EventRepository.ts\";\nimport type { DefaultContext, GenericEvent } from \"../../types.ts\";\nimport type { EventsTable } from \"./types.ts\";\n\nexport const createKyselyEventRepository = <\n Event extends GenericEvent<string, unknown, DefaultContext>,\n>(\n db: Kysely<EventsTable>,\n): EventRepository<Event> => ({\n save: async (event) => {\n await db\n .insertInto(\"events\")\n .values(event)\n .onConflict((oc) =>\n oc.column(\"id\").doUpdateSet({\n topic: event.topic,\n payload: event.payload,\n context: event.context,\n status: event.status,\n triggeredByUserId: event.triggeredByUserId,\n occurredAt: event.occurredAt,\n publications: event.publications,\n priority: event.priority,\n }),\n )\n .execute();\n },\n\n saveNewEventsBatch: async (events) => {\n if (events.length === 0) return;\n await db.insertInto(\"events\").values(events).execute();\n },\n\n markEventsAsInProcess: async (events) => {\n if (events.length === 0) return;\n const ids = events.map((e) => e.id);\n\n // Lock the rows to prevent concurrent processing\n const lockedRows = await db\n .selectFrom(\"events\")\n .select(\"id\")\n .where(\"id\", \"in\", ids)\n .forUpdate()\n .skipLocked()\n .execute();\n\n if (lockedRows.length === 0) return;\n const lockedIds = lockedRows.map((r) => r.id);\n\n // Update status to in-process (only for locked rows)\n await db\n .updateTable(\"events\")\n .set({ status: \"in-process\" })\n .where(\"id\", \"in\", lockedIds)\n .execute();\n },\n});\n"],"mappings":";;;;;;;;;;;;;;;;;;AAAA;AAAA;AAAA;AAAA;AAAA;AAKO,MAAM,8BAA8B,CAGzC,QAC4B;AAAA,EAC5B,MAAM,OAAO,UAAU;AACrB,UAAM,GACH,WAAW,QAAQ,EACnB,OAAO,KAAK,EACZ;AAAA,MAAW,CAAC,OACX,GAAG,OAAO,IAAI,EAAE,YAAY;AAAA,QAC1B,OAAO,MAAM;AAAA,QACb,SAAS,MAAM;AAAA,QACf,SAAS,MAAM;AAAA,QACf,QAAQ,MAAM;AAAA,QACd,mBAAmB,MAAM;AAAA,QACzB,YAAY,MAAM;AAAA,QAClB,cAAc,MAAM;AAAA,QACpB,UAAU,MAAM;AAAA,MAClB,CAAC;AAAA,IACH,EACC,QAAQ;AAAA,EACb;AAAA,EAEA,oBAAoB,OAAO,WAAW;AACpC,QAAI,OAAO,WAAW,EAAG;AACzB,UAAM,GAAG,WAAW,QAAQ,EAAE,OAAO,MAAM,EAAE,QAAQ;AAAA,EACvD;AAAA,EAEA,uBAAuB,OAAO,WAAW;AACvC,QAAI,OAAO,WAAW,EAAG;AACzB,UAAM,MAAM,OAAO,IAAI,CAAC,MAAM,EAAE,EAAE;AAGlC,UAAM,aAAa,MAAM,GACtB,WAAW,QAAQ,EACnB,OAAO,IAAI,EACX,MAAM,MAAM,MAAM,GAAG,EACrB,UAAU,EACV,WAAW,EACX,QAAQ;AAEX,QAAI,WAAW,WAAW,EAAG;AAC7B,UAAM,YAAY,WAAW,IAAI,CAAC,MAAM,EAAE,EAAE;AAG5C,UAAM,GACH,YAAY,QAAQ,EACpB,IAAI,EAAE,QAAQ,aAAa,CAAC,EAC5B,MAAM,MAAM,MAAM,SAAS,EAC3B,QAAQ;AAAA,EACb;AACF;","names":[]}
1
+ {"version":3,"sources":["../../../src/adapters/kysely/KyselyEventRepository.ts"],"sourcesContent":["import { type Kysely, type RawBuilder, sql } from \"kysely\";\nimport type { EventRepository } from \"../../ports/EventRepository.ts\";\nimport type { DefaultContext, GenericEvent } from \"../../types.ts\";\nimport type { EventsTable } from \"./types.ts\";\n\nconst jsonb = <T>(value: T): RawBuilder<T> =>\n sql`${JSON.stringify(value)}::jsonb`;\n\nexport const createKyselyEventRepository = <\n Event extends GenericEvent<string, unknown, DefaultContext>,\n>(\n db: Kysely<EventsTable>,\n): EventRepository<Event> => ({\n save: async (event) => {\n await db\n .insertInto(\"events\")\n .values({\n ...event,\n payload: jsonb(event.payload),\n context: jsonb(event.context),\n publications: jsonb(event.publications),\n })\n .onConflict((oc) =>\n oc.column(\"id\").doUpdateSet({\n topic: event.topic,\n payload: jsonb(event.payload),\n context: jsonb(event.context),\n status: event.status,\n triggeredByUserId: event.triggeredByUserId,\n occurredAt: event.occurredAt,\n publications: jsonb(event.publications),\n priority: event.priority,\n }),\n )\n .execute();\n },\n\n saveNewEventsBatch: async (events) => {\n if (events.length === 0) return;\n await db\n .insertInto(\"events\")\n .values(\n events.map((event) => ({\n ...event,\n payload: jsonb(event.payload),\n context: jsonb(event.context),\n publications: jsonb(event.publications),\n })),\n )\n .execute();\n },\n\n markEventsAsInProcess: async (events) => {\n if (events.length === 0) return;\n const ids = events.map((e) => e.id);\n\n // Lock the rows to prevent concurrent processing\n const lockedRows = await db\n .selectFrom(\"events\")\n .select(\"id\")\n .where(\"id\", \"in\", ids)\n .forUpdate()\n .skipLocked()\n .execute();\n\n if (lockedRows.length === 0) return;\n const lockedIds = lockedRows.map((r) => r.id);\n\n // Update status to in-process (only for locked rows)\n await db\n .updateTable(\"events\")\n .set({ status: \"in-process\" })\n .where(\"id\", \"in\", lockedIds)\n .execute();\n },\n});\n"],"mappings":";;;;;;;;;;;;;;;;;;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA,oBAAkD;AAKlD,MAAM,QAAQ,CAAI,UAChB,oBAAM,KAAK,UAAU,KAAK,CAAC;AAEtB,MAAM,8BAA8B,CAGzC,QAC4B;AAAA,EAC5B,MAAM,OAAO,UAAU;AACrB,UAAM,GACH,WAAW,QAAQ,EACnB,OAAO;AAAA,MACN,GAAG;AAAA,MACH,SAAS,MAAM,MAAM,OAAO;AAAA,MAC5B,SAAS,MAAM,MAAM,OAAO;AAAA,MAC5B,cAAc,MAAM,MAAM,YAAY;AAAA,IACxC,CAAC,EACA;AAAA,MAAW,CAAC,OACX,GAAG,OAAO,IAAI,EAAE,YAAY;AAAA,QAC1B,OAAO,MAAM;AAAA,QACb,SAAS,MAAM,MAAM,OAAO;AAAA,QAC5B,SAAS,MAAM,MAAM,OAAO;AAAA,QAC5B,QAAQ,MAAM;AAAA,QACd,mBAAmB,MAAM;AAAA,QACzB,YAAY,MAAM;AAAA,QAClB,cAAc,MAAM,MAAM,YAAY;AAAA,QACtC,UAAU,MAAM;AAAA,MAClB,CAAC;AAAA,IACH,EACC,QAAQ;AAAA,EACb;AAAA,EAEA,oBAAoB,OAAO,WAAW;AACpC,QAAI,OAAO,WAAW,EAAG;AACzB,UAAM,GACH,WAAW,QAAQ,EACnB;AAAA,MACC,OAAO,IAAI,CAAC,WAAW;AAAA,QACrB,GAAG;AAAA,QACH,SAAS,MAAM,MAAM,OAAO;AAAA,QAC5B,SAAS,MAAM,MAAM,OAAO;AAAA,QAC5B,cAAc,MAAM,MAAM,YAAY;AAAA,MACxC,EAAE;AAAA,IACJ,EACC,QAAQ;AAAA,EACb;AAAA,EAEA,uBAAuB,OAAO,WAAW;AACvC,QAAI,OAAO,WAAW,EAAG;AACzB,UAAM,MAAM,OAAO,IAAI,CAAC,MAAM,EAAE,EAAE;AAGlC,UAAM,aAAa,MAAM,GACtB,WAAW,QAAQ,EACnB,OAAO,IAAI,EACX,MAAM,MAAM,MAAM,GAAG,EACrB,UAAU,EACV,WAAW,EACX,QAAQ;AAEX,QAAI,WAAW,WAAW,EAAG;AAC7B,UAAM,YAAY,WAAW,IAAI,CAAC,MAAM,EAAE,EAAE;AAG5C,UAAM,GACH,YAAY,QAAQ,EACpB,IAAI,EAAE,QAAQ,aAAa,CAAC,EAC5B,MAAM,MAAM,MAAM,SAAS,EAC3B,QAAQ;AAAA,EACb;AACF;","names":[]}
@@ -1,21 +1,35 @@
1
+ import { sql } from "kysely";
2
+ const jsonb = (value) => sql`${JSON.stringify(value)}::jsonb`;
1
3
  const createKyselyEventRepository = (db) => ({
2
4
  save: async (event) => {
3
- await db.insertInto("events").values(event).onConflict(
5
+ await db.insertInto("events").values({
6
+ ...event,
7
+ payload: jsonb(event.payload),
8
+ context: jsonb(event.context),
9
+ publications: jsonb(event.publications)
10
+ }).onConflict(
4
11
  (oc) => oc.column("id").doUpdateSet({
5
12
  topic: event.topic,
6
- payload: event.payload,
7
- context: event.context,
13
+ payload: jsonb(event.payload),
14
+ context: jsonb(event.context),
8
15
  status: event.status,
9
16
  triggeredByUserId: event.triggeredByUserId,
10
17
  occurredAt: event.occurredAt,
11
- publications: event.publications,
18
+ publications: jsonb(event.publications),
12
19
  priority: event.priority
13
20
  })
14
21
  ).execute();
15
22
  },
16
23
  saveNewEventsBatch: async (events) => {
17
24
  if (events.length === 0) return;
18
- await db.insertInto("events").values(events).execute();
25
+ await db.insertInto("events").values(
26
+ events.map((event) => ({
27
+ ...event,
28
+ payload: jsonb(event.payload),
29
+ context: jsonb(event.context),
30
+ publications: jsonb(event.publications)
31
+ }))
32
+ ).execute();
19
33
  },
20
34
  markEventsAsInProcess: async (events) => {
21
35
  if (events.length === 0) return;
@@ -1 +1 @@
1
- {"version":3,"sources":["../../../src/adapters/kysely/KyselyEventRepository.ts"],"sourcesContent":["import type { Kysely } from \"kysely\";\nimport type { EventRepository } from '../../ports/EventRepository.mjs';\nimport type { DefaultContext, GenericEvent } from '../../types.mjs';\nimport type { EventsTable } from './types.mjs';\n\nexport const createKyselyEventRepository = <\n Event extends GenericEvent<string, unknown, DefaultContext>,\n>(\n db: Kysely<EventsTable>,\n): EventRepository<Event> => ({\n save: async (event) => {\n await db\n .insertInto(\"events\")\n .values(event)\n .onConflict((oc) =>\n oc.column(\"id\").doUpdateSet({\n topic: event.topic,\n payload: event.payload,\n context: event.context,\n status: event.status,\n triggeredByUserId: event.triggeredByUserId,\n occurredAt: event.occurredAt,\n publications: event.publications,\n priority: event.priority,\n }),\n )\n .execute();\n },\n\n saveNewEventsBatch: async (events) => {\n if (events.length === 0) return;\n await db.insertInto(\"events\").values(events).execute();\n },\n\n markEventsAsInProcess: async (events) => {\n if (events.length === 0) return;\n const ids = events.map((e) => e.id);\n\n // Lock the rows to prevent concurrent processing\n const lockedRows = await db\n .selectFrom(\"events\")\n .select(\"id\")\n .where(\"id\", \"in\", ids)\n .forUpdate()\n .skipLocked()\n .execute();\n\n if (lockedRows.length === 0) return;\n const lockedIds = lockedRows.map((r) => r.id);\n\n // Update status to in-process (only for locked rows)\n await db\n .updateTable(\"events\")\n .set({ status: \"in-process\" })\n .where(\"id\", \"in\", lockedIds)\n .execute();\n },\n});\n"],"mappings":"AAKO,MAAM,8BAA8B,CAGzC,QAC4B;AAAA,EAC5B,MAAM,OAAO,UAAU;AACrB,UAAM,GACH,WAAW,QAAQ,EACnB,OAAO,KAAK,EACZ;AAAA,MAAW,CAAC,OACX,GAAG,OAAO,IAAI,EAAE,YAAY;AAAA,QAC1B,OAAO,MAAM;AAAA,QACb,SAAS,MAAM;AAAA,QACf,SAAS,MAAM;AAAA,QACf,QAAQ,MAAM;AAAA,QACd,mBAAmB,MAAM;AAAA,QACzB,YAAY,MAAM;AAAA,QAClB,cAAc,MAAM;AAAA,QACpB,UAAU,MAAM;AAAA,MAClB,CAAC;AAAA,IACH,EACC,QAAQ;AAAA,EACb;AAAA,EAEA,oBAAoB,OAAO,WAAW;AACpC,QAAI,OAAO,WAAW,EAAG;AACzB,UAAM,GAAG,WAAW,QAAQ,EAAE,OAAO,MAAM,EAAE,QAAQ;AAAA,EACvD;AAAA,EAEA,uBAAuB,OAAO,WAAW;AACvC,QAAI,OAAO,WAAW,EAAG;AACzB,UAAM,MAAM,OAAO,IAAI,CAAC,MAAM,EAAE,EAAE;AAGlC,UAAM,aAAa,MAAM,GACtB,WAAW,QAAQ,EACnB,OAAO,IAAI,EACX,MAAM,MAAM,MAAM,GAAG,EACrB,UAAU,EACV,WAAW,EACX,QAAQ;AAEX,QAAI,WAAW,WAAW,EAAG;AAC7B,UAAM,YAAY,WAAW,IAAI,CAAC,MAAM,EAAE,EAAE;AAG5C,UAAM,GACH,YAAY,QAAQ,EACpB,IAAI,EAAE,QAAQ,aAAa,CAAC,EAC5B,MAAM,MAAM,MAAM,SAAS,EAC3B,QAAQ;AAAA,EACb;AACF;","names":[]}
1
+ {"version":3,"sources":["../../../src/adapters/kysely/KyselyEventRepository.ts"],"sourcesContent":["import { type Kysely, type RawBuilder, sql } from \"kysely\";\nimport type { EventRepository } from '../../ports/EventRepository.mjs';\nimport type { DefaultContext, GenericEvent } from '../../types.mjs';\nimport type { EventsTable } from './types.mjs';\n\nconst jsonb = <T>(value: T): RawBuilder<T> =>\n sql`${JSON.stringify(value)}::jsonb`;\n\nexport const createKyselyEventRepository = <\n Event extends GenericEvent<string, unknown, DefaultContext>,\n>(\n db: Kysely<EventsTable>,\n): EventRepository<Event> => ({\n save: async (event) => {\n await db\n .insertInto(\"events\")\n .values({\n ...event,\n payload: jsonb(event.payload),\n context: jsonb(event.context),\n publications: jsonb(event.publications),\n })\n .onConflict((oc) =>\n oc.column(\"id\").doUpdateSet({\n topic: event.topic,\n payload: jsonb(event.payload),\n context: jsonb(event.context),\n status: event.status,\n triggeredByUserId: event.triggeredByUserId,\n occurredAt: event.occurredAt,\n publications: jsonb(event.publications),\n priority: event.priority,\n }),\n )\n .execute();\n },\n\n saveNewEventsBatch: async (events) => {\n if (events.length === 0) return;\n await db\n .insertInto(\"events\")\n .values(\n events.map((event) => ({\n ...event,\n payload: jsonb(event.payload),\n context: jsonb(event.context),\n publications: jsonb(event.publications),\n })),\n )\n .execute();\n },\n\n markEventsAsInProcess: async (events) => {\n if (events.length === 0) return;\n const ids = events.map((e) => e.id);\n\n // Lock the rows to prevent concurrent processing\n const lockedRows = await db\n .selectFrom(\"events\")\n .select(\"id\")\n .where(\"id\", \"in\", ids)\n .forUpdate()\n .skipLocked()\n .execute();\n\n if (lockedRows.length === 0) return;\n const lockedIds = lockedRows.map((r) => r.id);\n\n // Update status to in-process (only for locked rows)\n await db\n .updateTable(\"events\")\n .set({ status: \"in-process\" })\n .where(\"id\", \"in\", lockedIds)\n .execute();\n },\n});\n"],"mappings":"AAAA,SAAuC,WAAW;AAKlD,MAAM,QAAQ,CAAI,UAChB,MAAM,KAAK,UAAU,KAAK,CAAC;AAEtB,MAAM,8BAA8B,CAGzC,QAC4B;AAAA,EAC5B,MAAM,OAAO,UAAU;AACrB,UAAM,GACH,WAAW,QAAQ,EACnB,OAAO;AAAA,MACN,GAAG;AAAA,MACH,SAAS,MAAM,MAAM,OAAO;AAAA,MAC5B,SAAS,MAAM,MAAM,OAAO;AAAA,MAC5B,cAAc,MAAM,MAAM,YAAY;AAAA,IACxC,CAAC,EACA;AAAA,MAAW,CAAC,OACX,GAAG,OAAO,IAAI,EAAE,YAAY;AAAA,QAC1B,OAAO,MAAM;AAAA,QACb,SAAS,MAAM,MAAM,OAAO;AAAA,QAC5B,SAAS,MAAM,MAAM,OAAO;AAAA,QAC5B,QAAQ,MAAM;AAAA,QACd,mBAAmB,MAAM;AAAA,QACzB,YAAY,MAAM;AAAA,QAClB,cAAc,MAAM,MAAM,YAAY;AAAA,QACtC,UAAU,MAAM;AAAA,MAClB,CAAC;AAAA,IACH,EACC,QAAQ;AAAA,EACb;AAAA,EAEA,oBAAoB,OAAO,WAAW;AACpC,QAAI,OAAO,WAAW,EAAG;AACzB,UAAM,GACH,WAAW,QAAQ,EACnB;AAAA,MACC,OAAO,IAAI,CAAC,WAAW;AAAA,QACrB,GAAG;AAAA,QACH,SAAS,MAAM,MAAM,OAAO;AAAA,QAC5B,SAAS,MAAM,MAAM,OAAO;AAAA,QAC5B,cAAc,MAAM,MAAM,YAAY;AAAA,MACxC,EAAE;AAAA,IACJ,EACC,QAAQ;AAAA,EACb;AAAA,EAEA,uBAAuB,OAAO,WAAW;AACvC,QAAI,OAAO,WAAW,EAAG;AACzB,UAAM,MAAM,OAAO,IAAI,CAAC,MAAM,EAAE,EAAE;AAGlC,UAAM,aAAa,MAAM,GACtB,WAAW,QAAQ,EACnB,OAAO,IAAI,EACX,MAAM,MAAM,MAAM,GAAG,EACrB,UAAU,EACV,WAAW,EACX,QAAQ;AAEX,QAAI,WAAW,WAAW,EAAG;AAC7B,UAAM,YAAY,WAAW,IAAI,CAAC,MAAM,EAAE,EAAE;AAG5C,UAAM,GACH,YAAY,QAAQ,EACpB,IAAI,EAAE,QAAQ,aAAa,CAAC,EAC5B,MAAM,MAAM,MAAM,SAAS,EAC3B,QAAQ;AAAA,EACb;AACF;","names":[]}
package/package.json CHANGED
@@ -3,7 +3,7 @@
3
3
  "description": "The purpose of this repository is to make it easy to setup event driven architecture using outbox pattern",
4
4
  "module": "src/index.ts",
5
5
  "type": "module",
6
- "version": "0.4.1",
6
+ "version": "0.4.2",
7
7
  "main": "./dist/index.mjs",
8
8
  "types": "./dist/index.d.ts",
9
9
  "files": [
@@ -1,8 +1,11 @@
1
- import type { Kysely } from "kysely";
1
+ import { type Kysely, type RawBuilder, sql } from "kysely";
2
2
  import type { EventRepository } from "../../ports/EventRepository.ts";
3
3
  import type { DefaultContext, GenericEvent } from "../../types.ts";
4
4
  import type { EventsTable } from "./types.ts";
5
5
 
6
+ const jsonb = <T>(value: T): RawBuilder<T> =>
7
+ sql`${JSON.stringify(value)}::jsonb`;
8
+
6
9
  export const createKyselyEventRepository = <
7
10
  Event extends GenericEvent<string, unknown, DefaultContext>,
8
11
  >(
@@ -11,16 +14,21 @@ export const createKyselyEventRepository = <
11
14
  save: async (event) => {
12
15
  await db
13
16
  .insertInto("events")
14
- .values(event)
17
+ .values({
18
+ ...event,
19
+ payload: jsonb(event.payload),
20
+ context: jsonb(event.context),
21
+ publications: jsonb(event.publications),
22
+ })
15
23
  .onConflict((oc) =>
16
24
  oc.column("id").doUpdateSet({
17
25
  topic: event.topic,
18
- payload: event.payload,
19
- context: event.context,
26
+ payload: jsonb(event.payload),
27
+ context: jsonb(event.context),
20
28
  status: event.status,
21
29
  triggeredByUserId: event.triggeredByUserId,
22
30
  occurredAt: event.occurredAt,
23
- publications: event.publications,
31
+ publications: jsonb(event.publications),
24
32
  priority: event.priority,
25
33
  }),
26
34
  )
@@ -29,7 +37,17 @@ export const createKyselyEventRepository = <
29
37
 
30
38
  saveNewEventsBatch: async (events) => {
31
39
  if (events.length === 0) return;
32
- await db.insertInto("events").values(events).execute();
40
+ await db
41
+ .insertInto("events")
42
+ .values(
43
+ events.map((event) => ({
44
+ ...event,
45
+ payload: jsonb(event.payload),
46
+ context: jsonb(event.context),
47
+ publications: jsonb(event.publications),
48
+ })),
49
+ )
50
+ .execute();
33
51
  },
34
52
 
35
53
  markEventsAsInProcess: async (events) => {