@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.
- package/dist/adapters/kysely/KyselyEventRepository.cjs +19 -5
- package/dist/adapters/kysely/KyselyEventRepository.cjs.map +1 -1
- package/dist/adapters/kysely/KyselyEventRepository.mjs +19 -5
- package/dist/adapters/kysely/KyselyEventRepository.mjs.map +1 -1
- package/package.json +1 -1
- package/src/adapters/kysely/KyselyEventRepository.ts +24 -6
|
@@ -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(
|
|
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(
|
|
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
|
|
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(
|
|
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(
|
|
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
|
|
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.
|
|
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
|
|
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(
|
|
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
|
|
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) => {
|