@x12i/memorix-writer 1.3.0 → 1.4.0
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/README.md +32 -1
- package/catalox-seeds/memorix-write-descriptors.manifest.json +175 -0
- package/dist/collections/initialize-entity-collections.d.ts +15 -0
- package/dist/collections/initialize-entity-collections.d.ts.map +1 -0
- package/dist/collections/initialize-entity-collections.js +70 -0
- package/dist/collections/initialize-entity-collections.js.map +1 -0
- package/dist/graph-runs/write-result.d.ts +2 -0
- package/dist/graph-runs/write-result.d.ts.map +1 -1
- package/dist/graph-runs/write-result.js +8 -1
- package/dist/graph-runs/write-result.js.map +1 -1
- package/dist/index.d.ts +16 -1
- package/dist/index.d.ts.map +1 -1
- package/dist/index.js +9 -0
- package/dist/index.js.map +1 -1
- package/dist/job-type-runs/constants.d.ts +2 -0
- package/dist/job-type-runs/constants.d.ts.map +1 -0
- package/dist/job-type-runs/constants.js +2 -0
- package/dist/job-type-runs/constants.js.map +1 -0
- package/dist/job-type-runs/context.d.ts +3 -0
- package/dist/job-type-runs/context.d.ts.map +1 -0
- package/dist/job-type-runs/context.js +6 -0
- package/dist/job-type-runs/context.js.map +1 -0
- package/dist/job-type-runs/ensure-indexes.d.ts +10 -0
- package/dist/job-type-runs/ensure-indexes.d.ts.map +1 -0
- package/dist/job-type-runs/ensure-indexes.js +32 -0
- package/dist/job-type-runs/ensure-indexes.js.map +1 -0
- package/dist/job-type-runs/get-run.d.ts +8 -0
- package/dist/job-type-runs/get-run.d.ts.map +1 -0
- package/dist/job-type-runs/get-run.js +14 -0
- package/dist/job-type-runs/get-run.js.map +1 -0
- package/dist/job-type-runs/logging.d.ts +9 -0
- package/dist/job-type-runs/logging.d.ts.map +1 -0
- package/dist/job-type-runs/logging.js +4 -0
- package/dist/job-type-runs/logging.js.map +1 -0
- package/dist/job-type-runs/mark-completed.d.ts +15 -0
- package/dist/job-type-runs/mark-completed.d.ts.map +1 -0
- package/dist/job-type-runs/mark-completed.js +38 -0
- package/dist/job-type-runs/mark-completed.js.map +1 -0
- package/dist/job-type-runs/mark-failed.d.ts +14 -0
- package/dist/job-type-runs/mark-failed.d.ts.map +1 -0
- package/dist/job-type-runs/mark-failed.js +36 -0
- package/dist/job-type-runs/mark-failed.js.map +1 -0
- package/dist/job-type-runs/mark-started.d.ts +15 -0
- package/dist/job-type-runs/mark-started.d.ts.map +1 -0
- package/dist/job-type-runs/mark-started.js +36 -0
- package/dist/job-type-runs/mark-started.js.map +1 -0
- package/dist/validation/validate-fields.js +1 -1
- package/dist/validation/validate-fields.js.map +1 -1
- package/dist/validation/validate-immutability.d.ts.map +1 -1
- package/dist/validation/validate-immutability.js +1 -0
- package/dist/validation/validate-immutability.js.map +1 -1
- package/docs/JOB-TYPE-RUNS.md +79 -0
- package/package.json +10 -4
package/README.md
CHANGED
|
@@ -70,7 +70,7 @@ Override defaults only when you need to:
|
|
|
70
70
|
|
|
71
71
|
## Collection resolution
|
|
72
72
|
|
|
73
|
-
Writes target **`memorix-entities
|
|
73
|
+
Writes target **`memorix-entities`**, **`memorix-events`**, or **`memorix-knowledge`** based on the write descriptor (`target.kind`, defaulting from `identity.idField`). Database names follow [Memorix Database Conventions](./docs/MEMORIX-DATABASE-CONVENTIONS.md) (`MEMORIX_ENTITIES_DB`, `MEMORIX_EVENTS_DB`, `MEMORIX_KNOWLEDGE_DB`, …).
|
|
74
74
|
|
|
75
75
|
Collection name resolution order:
|
|
76
76
|
|
|
@@ -105,6 +105,8 @@ npm run catalox:seed:write-descriptors:validate
|
|
|
105
105
|
|
|
106
106
|
Seed file: [`catalox-seeds/memorix-write-descriptors.manifest.json`](catalox-seeds/memorix-write-descriptors.manifest.json)
|
|
107
107
|
|
|
108
|
+
Shipped write descriptors include `asset-analysis-write` (entity) and corpus helpers `content-documents-snapshot-write` / `content-documents-chunk-write` (`knowledge` target). Record builders: [`@x12i/memorix-corpus`](../memorix-corpus/README.md).
|
|
109
|
+
|
|
108
110
|
## Acceptance criteria
|
|
109
111
|
|
|
110
112
|
| ID | Status |
|
|
@@ -150,6 +152,35 @@ import {
|
|
|
150
152
|
|
|
151
153
|
Full contract: [docs/GRAPH-RUNS.md](./docs/GRAPH-RUNS.md).
|
|
152
154
|
|
|
155
|
+
## Job-type run tracking (`_jobTypeRuns`) — MRX-CR-003
|
|
156
|
+
|
|
157
|
+
Parallel stamp APIs keyed by `jobTypeId` (shared `GraphRunEntry` shape). Domain writes reject `_jobTypeRuns` in input.
|
|
158
|
+
|
|
159
|
+
```typescript
|
|
160
|
+
import {
|
|
161
|
+
markJobTypeRunStarted,
|
|
162
|
+
markJobTypeRunCompleted,
|
|
163
|
+
markJobTypeRunFailed,
|
|
164
|
+
ensureJobTypeRunIndexes,
|
|
165
|
+
} from "@x12i/memorix-writer";
|
|
166
|
+
```
|
|
167
|
+
|
|
168
|
+
Full contract: [docs/JOB-TYPE-RUNS.md](./docs/JOB-TYPE-RUNS.md).
|
|
169
|
+
|
|
170
|
+
## Entity collection bootstrap — MRX-CR-005
|
|
171
|
+
|
|
172
|
+
```typescript
|
|
173
|
+
import { initializeEntityCollections } from "@x12i/memorix-writer";
|
|
174
|
+
|
|
175
|
+
await initializeEntityCollections(client, "assets", {
|
|
176
|
+
contentTypes: ["core", "inferences"],
|
|
177
|
+
graphRunIndexes: true,
|
|
178
|
+
jobTypeRunIndexes: true,
|
|
179
|
+
});
|
|
180
|
+
```
|
|
181
|
+
|
|
182
|
+
Idempotent: creates missing collections and ensures standard indexes (`idx_updatedAt`, `idx_graphRuns`, optional `idx_jobTypeRuns`, etc.).
|
|
183
|
+
|
|
153
184
|
## Development
|
|
154
185
|
|
|
155
186
|
```bash
|
|
@@ -158,6 +158,181 @@
|
|
|
158
158
|
"defaultMode": "summary"
|
|
159
159
|
}
|
|
160
160
|
}
|
|
161
|
+
},
|
|
162
|
+
{
|
|
163
|
+
"catalogId": "memorix-write-descriptors",
|
|
164
|
+
"data": {
|
|
165
|
+
"id": "content-documents-snapshot-write",
|
|
166
|
+
"entity": "content-documents",
|
|
167
|
+
"title": "Write Content Document Snapshot",
|
|
168
|
+
"target": {
|
|
169
|
+
"kind": "knowledge",
|
|
170
|
+
"contentType": "snapshots"
|
|
171
|
+
},
|
|
172
|
+
"identity": {
|
|
173
|
+
"idField": "knowledgeId",
|
|
174
|
+
"requireExistingCanonical": false
|
|
175
|
+
},
|
|
176
|
+
"operations": {
|
|
177
|
+
"allowed": ["add", "upsert"],
|
|
178
|
+
"default": "upsert"
|
|
179
|
+
},
|
|
180
|
+
"fields": {
|
|
181
|
+
"title": {
|
|
182
|
+
"label": "Title",
|
|
183
|
+
"inputPath": "title",
|
|
184
|
+
"target": { "path": "data.title" },
|
|
185
|
+
"writable": true,
|
|
186
|
+
"valueType": "string"
|
|
187
|
+
},
|
|
188
|
+
"summary": {
|
|
189
|
+
"label": "Summary",
|
|
190
|
+
"inputPath": "summary",
|
|
191
|
+
"target": { "path": "data.summary" },
|
|
192
|
+
"writable": true,
|
|
193
|
+
"valueType": "string"
|
|
194
|
+
},
|
|
195
|
+
"language": {
|
|
196
|
+
"label": "Language",
|
|
197
|
+
"inputPath": "language",
|
|
198
|
+
"target": { "path": "data.language" },
|
|
199
|
+
"writable": true,
|
|
200
|
+
"valueType": "string"
|
|
201
|
+
},
|
|
202
|
+
"sourceKind": {
|
|
203
|
+
"label": "Source kind",
|
|
204
|
+
"inputPath": "sourceKind",
|
|
205
|
+
"target": { "path": "source.kind" },
|
|
206
|
+
"writable": true,
|
|
207
|
+
"valueType": "string"
|
|
208
|
+
},
|
|
209
|
+
"sourceUri": {
|
|
210
|
+
"label": "Source URI",
|
|
211
|
+
"inputPath": "sourceUri",
|
|
212
|
+
"target": { "path": "source.uri" },
|
|
213
|
+
"writable": true,
|
|
214
|
+
"valueType": "string"
|
|
215
|
+
},
|
|
216
|
+
"canonicalUri": {
|
|
217
|
+
"label": "Canonical URI",
|
|
218
|
+
"inputPath": "canonicalUri",
|
|
219
|
+
"target": { "path": "source.canonicalUri" },
|
|
220
|
+
"writable": true,
|
|
221
|
+
"valueType": "string"
|
|
222
|
+
},
|
|
223
|
+
"contentHash": {
|
|
224
|
+
"label": "Content hash",
|
|
225
|
+
"inputPath": "contentHash",
|
|
226
|
+
"target": { "path": "provenance.contentHash" },
|
|
227
|
+
"writable": true,
|
|
228
|
+
"valueType": "string"
|
|
229
|
+
},
|
|
230
|
+
"cleanMarkdown": {
|
|
231
|
+
"label": "Clean Markdown",
|
|
232
|
+
"inputPath": "cleanMarkdown",
|
|
233
|
+
"target": { "path": "content.cleanMarkdown" },
|
|
234
|
+
"writable": true,
|
|
235
|
+
"valueType": "content",
|
|
236
|
+
"content": {
|
|
237
|
+
"enabled": true,
|
|
238
|
+
"objectType": "memorix-content-object",
|
|
239
|
+
"acceptBody": true,
|
|
240
|
+
"acceptPointer": true,
|
|
241
|
+
"format": "markdown",
|
|
242
|
+
"maxBytes": 10485760,
|
|
243
|
+
"contentKeyTemplate": "content-documents/{{knowledgeId}}/{{contentHash}}/clean.md",
|
|
244
|
+
"generatePreview": true,
|
|
245
|
+
"previewMaxChars": 500,
|
|
246
|
+
"computeMetadata": true,
|
|
247
|
+
"storage": {
|
|
248
|
+
"provider": "gcs",
|
|
249
|
+
"bucket": "memorix-content",
|
|
250
|
+
"prefix": "content-documents"
|
|
251
|
+
}
|
|
252
|
+
}
|
|
253
|
+
}
|
|
254
|
+
},
|
|
255
|
+
"content": {
|
|
256
|
+
"allowed": true,
|
|
257
|
+
"allowedFields": ["cleanMarkdown"],
|
|
258
|
+
"generatePreview": true,
|
|
259
|
+
"previewMaxChars": 500,
|
|
260
|
+
"computeMetadata": true,
|
|
261
|
+
"maxBytes": 10485760
|
|
262
|
+
},
|
|
263
|
+
"validation": {
|
|
264
|
+
"rejectUnknownFields": true,
|
|
265
|
+
"requireAtLeastOneWritableField": true
|
|
266
|
+
},
|
|
267
|
+
"return": {
|
|
268
|
+
"defaultMode": "summary"
|
|
269
|
+
}
|
|
270
|
+
}
|
|
271
|
+
},
|
|
272
|
+
{
|
|
273
|
+
"catalogId": "memorix-write-descriptors",
|
|
274
|
+
"data": {
|
|
275
|
+
"id": "content-documents-chunk-write",
|
|
276
|
+
"entity": "content-documents",
|
|
277
|
+
"title": "Write Content Document Chunk",
|
|
278
|
+
"target": {
|
|
279
|
+
"kind": "knowledge",
|
|
280
|
+
"contentType": "chunks"
|
|
281
|
+
},
|
|
282
|
+
"identity": {
|
|
283
|
+
"idField": "knowledgeId",
|
|
284
|
+
"requireExistingCanonical": false
|
|
285
|
+
},
|
|
286
|
+
"operations": {
|
|
287
|
+
"allowed": ["add"],
|
|
288
|
+
"default": "add"
|
|
289
|
+
},
|
|
290
|
+
"fields": {
|
|
291
|
+
"text": {
|
|
292
|
+
"label": "Chunk text",
|
|
293
|
+
"inputPath": "text",
|
|
294
|
+
"target": { "path": "data.text" },
|
|
295
|
+
"required": true,
|
|
296
|
+
"writable": true,
|
|
297
|
+
"valueType": "string"
|
|
298
|
+
},
|
|
299
|
+
"sectionTitle": {
|
|
300
|
+
"label": "Section title",
|
|
301
|
+
"inputPath": "sectionTitle",
|
|
302
|
+
"target": { "path": "data.sectionTitle" },
|
|
303
|
+
"writable": true,
|
|
304
|
+
"valueType": "string"
|
|
305
|
+
},
|
|
306
|
+
"tokenCount": {
|
|
307
|
+
"label": "Token count",
|
|
308
|
+
"inputPath": "tokenCount",
|
|
309
|
+
"target": { "path": "data.tokenCount" },
|
|
310
|
+
"writable": true,
|
|
311
|
+
"valueType": "number"
|
|
312
|
+
},
|
|
313
|
+
"chunkIndex": {
|
|
314
|
+
"label": "Chunk index",
|
|
315
|
+
"inputPath": "chunkIndex",
|
|
316
|
+
"target": { "path": "provenance.chunkIndex" },
|
|
317
|
+
"writable": true,
|
|
318
|
+
"valueType": "number"
|
|
319
|
+
},
|
|
320
|
+
"contentHash": {
|
|
321
|
+
"label": "Parent content hash",
|
|
322
|
+
"inputPath": "contentHash",
|
|
323
|
+
"target": { "path": "parent.contentHash" },
|
|
324
|
+
"writable": true,
|
|
325
|
+
"valueType": "string"
|
|
326
|
+
}
|
|
327
|
+
},
|
|
328
|
+
"validation": {
|
|
329
|
+
"rejectUnknownFields": true,
|
|
330
|
+
"requireAtLeastOneWritableField": true
|
|
331
|
+
},
|
|
332
|
+
"return": {
|
|
333
|
+
"defaultMode": "summary"
|
|
334
|
+
}
|
|
335
|
+
}
|
|
161
336
|
}
|
|
162
337
|
]
|
|
163
338
|
}
|
|
@@ -0,0 +1,15 @@
|
|
|
1
|
+
import type { MemorixWriterClient } from "../client/types.js";
|
|
2
|
+
export type InitializeEntityCollectionsOptions = {
|
|
3
|
+
contentTypes?: ("core" | "event" | "inferences")[];
|
|
4
|
+
graphRunIndexes?: boolean;
|
|
5
|
+
jobTypeRunIndexes?: boolean;
|
|
6
|
+
};
|
|
7
|
+
export type InitializeEntityCollectionsResult = {
|
|
8
|
+
created: string[];
|
|
9
|
+
existing: string[];
|
|
10
|
+
};
|
|
11
|
+
/**
|
|
12
|
+
* Create entity content collections if missing and ensure recommended indexes (MRX-CR-005).
|
|
13
|
+
*/
|
|
14
|
+
export declare function initializeEntityCollections(client: MemorixWriterClient, entity: string, options?: InitializeEntityCollectionsOptions): Promise<InitializeEntityCollectionsResult>;
|
|
15
|
+
//# sourceMappingURL=initialize-entity-collections.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"initialize-entity-collections.d.ts","sourceRoot":"","sources":["../../src/collections/initialize-entity-collections.ts"],"names":[],"mappings":"AAEA,OAAO,KAAK,EAAE,mBAAmB,EAAE,MAAM,oBAAoB,CAAC;AAM9D,MAAM,MAAM,kCAAkC,GAAG;IAC/C,YAAY,CAAC,EAAE,CAAC,MAAM,GAAG,OAAO,GAAG,YAAY,CAAC,EAAE,CAAC;IACnD,eAAe,CAAC,EAAE,OAAO,CAAC;IAC1B,iBAAiB,CAAC,EAAE,OAAO,CAAC;CAC7B,CAAC;AAEF,MAAM,MAAM,iCAAiC,GAAG;IAC9C,OAAO,EAAE,MAAM,EAAE,CAAC;IAClB,QAAQ,EAAE,MAAM,EAAE,CAAC;CACpB,CAAC;AAsCF;;GAEG;AACH,wBAAsB,2BAA2B,CAC/C,MAAM,EAAE,mBAAmB,EAC3B,MAAM,EAAE,MAAM,EACd,OAAO,GAAE,kCAAuC,GAC/C,OAAO,CAAC,iCAAiC,CAAC,CAiD5C"}
|
|
@@ -0,0 +1,70 @@
|
|
|
1
|
+
import { ensureEntityCollectionIndexes } from "@x12i/memorix-mongo";
|
|
2
|
+
import { getWriterMemorixTier } from "../client/ensure-tier.js";
|
|
3
|
+
import { loadMemorixEntityDescriptor } from "../descriptors/load-entity-descriptor.js";
|
|
4
|
+
import { MemorixWriterError } from "../errors/errors.js";
|
|
5
|
+
import { resolveMemorixDbName } from "../mongo/env.js";
|
|
6
|
+
const DEFAULT_CONTENT_TYPES = [
|
|
7
|
+
"core",
|
|
8
|
+
"inferences",
|
|
9
|
+
];
|
|
10
|
+
function resolveContentTypeKeys(entityContentTypes, requested) {
|
|
11
|
+
const keys = Object.keys(entityContentTypes);
|
|
12
|
+
const resolved = [];
|
|
13
|
+
for (const key of requested) {
|
|
14
|
+
if (keys.includes(key)) {
|
|
15
|
+
resolved.push(key);
|
|
16
|
+
continue;
|
|
17
|
+
}
|
|
18
|
+
const byPostfix = keys.find((k) => entityContentTypes[k]?.postfix?.trim().toLowerCase() === key);
|
|
19
|
+
if (byPostfix)
|
|
20
|
+
resolved.push(byPostfix);
|
|
21
|
+
}
|
|
22
|
+
return [...new Set(resolved)];
|
|
23
|
+
}
|
|
24
|
+
function resolveCollectionName(collectionPrefix, contentType, contentTypeKey) {
|
|
25
|
+
if (contentType.collection?.trim())
|
|
26
|
+
return contentType.collection.trim();
|
|
27
|
+
const postfix = contentType.postfix?.trim() || contentTypeKey;
|
|
28
|
+
return `${collectionPrefix.trim()}-${postfix}`;
|
|
29
|
+
}
|
|
30
|
+
/**
|
|
31
|
+
* Create entity content collections if missing and ensure recommended indexes (MRX-CR-005).
|
|
32
|
+
*/
|
|
33
|
+
export async function initializeEntityCollections(client, entity, options = {}) {
|
|
34
|
+
const entityDescriptor = await loadMemorixEntityDescriptor(client, entity);
|
|
35
|
+
const tier = await getWriterMemorixTier(client);
|
|
36
|
+
const env = tier.env;
|
|
37
|
+
const requested = options.contentTypes ?? DEFAULT_CONTENT_TYPES ?? [];
|
|
38
|
+
const contentTypeKeys = resolveContentTypeKeys(entityDescriptor.contentTypes ?? {}, requested);
|
|
39
|
+
if (contentTypeKeys.length === 0) {
|
|
40
|
+
throw new MemorixWriterError("DESCRIPTOR_MISSING", `No matching content types for initializeEntityCollections on "${entity}"`);
|
|
41
|
+
}
|
|
42
|
+
const target = "entity";
|
|
43
|
+
const dbName = resolveMemorixDbName(target, env);
|
|
44
|
+
const db = tier.client.db(dbName);
|
|
45
|
+
const created = [];
|
|
46
|
+
const existing = [];
|
|
47
|
+
const prefix = String(entityDescriptor.collectionPrefix ?? entity).trim();
|
|
48
|
+
for (const contentTypeKey of contentTypeKeys) {
|
|
49
|
+
const ct = entityDescriptor.contentTypes[contentTypeKey];
|
|
50
|
+
if (!ct)
|
|
51
|
+
continue;
|
|
52
|
+
const collectionName = resolveCollectionName(prefix, ct, contentTypeKey);
|
|
53
|
+
const listed = await db.listCollections({ name: collectionName }).toArray();
|
|
54
|
+
const wasExisting = listed.length > 0;
|
|
55
|
+
if (!wasExisting) {
|
|
56
|
+
await db.createCollection(collectionName).catch(() => undefined);
|
|
57
|
+
created.push(collectionName);
|
|
58
|
+
}
|
|
59
|
+
else {
|
|
60
|
+
existing.push(collectionName);
|
|
61
|
+
}
|
|
62
|
+
const coll = db.collection(collectionName);
|
|
63
|
+
await ensureEntityCollectionIndexes(coll, {
|
|
64
|
+
graphRunIndexes: options.graphRunIndexes ?? true,
|
|
65
|
+
jobTypeRunIndexes: options.jobTypeRunIndexes ?? false,
|
|
66
|
+
});
|
|
67
|
+
}
|
|
68
|
+
return { created, existing };
|
|
69
|
+
}
|
|
70
|
+
//# sourceMappingURL=initialize-entity-collections.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"initialize-entity-collections.js","sourceRoot":"","sources":["../../src/collections/initialize-entity-collections.ts"],"names":[],"mappings":"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"}
|
|
@@ -6,6 +6,8 @@ export type WriteGraphRunResultOptions = {
|
|
|
6
6
|
jobRunId: string;
|
|
7
7
|
attempts: number;
|
|
8
8
|
graphVersion?: string;
|
|
9
|
+
/** When set, also stamps `_jobTypeRuns.<jobTypeId>` in the same transaction (MRX-CR-003). */
|
|
10
|
+
jobTypeId?: string;
|
|
9
11
|
};
|
|
10
12
|
export type WriteGraphRunResultResponse = {
|
|
11
13
|
ok: true;
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"write-result.d.ts","sourceRoot":"","sources":["../../src/graph-runs/write-result.ts"],"names":[],"mappings":"AAAA,OAAO,KAAK,EACV,qBAAqB,EACrB,gBAAgB,EAChB,iBAAiB,EAClB,MAAM,iCAAiC,CAAC;AACzC,OAAO,KAAK,EAAE,mBAAmB,EAAE,MAAM,oBAAoB,CAAC;
|
|
1
|
+
{"version":3,"file":"write-result.d.ts","sourceRoot":"","sources":["../../src/graph-runs/write-result.ts"],"names":[],"mappings":"AAAA,OAAO,KAAK,EACV,qBAAqB,EACrB,gBAAgB,EAChB,iBAAiB,EAClB,MAAM,iCAAiC,CAAC;AACzC,OAAO,KAAK,EAAE,mBAAmB,EAAE,MAAM,oBAAoB,CAAC;AAiB9D,MAAM,MAAM,0BAA0B,GAAG;IACvC,aAAa,EAAE,MAAM,CAAC,MAAM,EAAE,OAAO,CAAC,CAAC;IACvC,iBAAiB,EAAE,iBAAiB,CAAC;IACrC,QAAQ,EAAE,MAAM,CAAC;IACjB,QAAQ,EAAE,MAAM,CAAC;IACjB,YAAY,CAAC,EAAE,MAAM,CAAC;IACtB,6FAA6F;IAC7F,SAAS,CAAC,EAAE,MAAM,CAAC;CACpB,CAAC;AAEF,MAAM,MAAM,2BAA2B,GAAG;IACxC,EAAE,EAAE,IAAI,CAAC;IACT,OAAO,EAAE,MAAM,CAAC;IAChB,SAAS,EAAE,gBAAgB,CAAC;IAC5B,MAAM,EAAE,qBAAqB,CAAC;CAC/B,CAAC;AAiBF,wBAAsB,mBAAmB,CACvC,MAAM,EAAE,mBAAmB,EAC3B,GAAG,EAAE,gBAAgB,EACrB,OAAO,EAAE,MAAM,EACf,IAAI,EAAE,0BAA0B,GAC/B,OAAO,CAAC,2BAA2B,CAAC,CA+ItC"}
|
|
@@ -4,6 +4,7 @@ import { MemorixWriterError } from "../errors/errors.js";
|
|
|
4
4
|
import { deepSet } from "../utils/path.js";
|
|
5
5
|
import { graphRunDotPath } from "./constants.js";
|
|
6
6
|
import { readGraphRunEntry } from "./context.js";
|
|
7
|
+
import { jobTypeRunDotPath } from "../job-type-runs/constants.js";
|
|
7
8
|
import { ensurePersistencyRelationDescriptor } from "./ensure-persistency-relation.js";
|
|
8
9
|
import { graphRunLogContext } from "./logging.js";
|
|
9
10
|
import { resolvePersistencyIds } from "./resolve-persistency-ids.js";
|
|
@@ -94,7 +95,13 @@ export async function writeGraphRunResult(client, ref, graphId, opts) {
|
|
|
94
95
|
? { graphVersion: existing.graphVersion }
|
|
95
96
|
: {}),
|
|
96
97
|
};
|
|
97
|
-
const
|
|
98
|
+
const patchPayload = {
|
|
99
|
+
[graphRunDotPath(graphId)]: entry,
|
|
100
|
+
};
|
|
101
|
+
if (opts.jobTypeId) {
|
|
102
|
+
patchPayload[jobTypeRunDotPath(opts.jobTypeId)] = entry;
|
|
103
|
+
}
|
|
104
|
+
const stamp = await sourceAdapter.patch(resolved.collection, resolved.filter, patchPayload, { session });
|
|
98
105
|
if (stamp.matchedCount === 0) {
|
|
99
106
|
throw new MemorixWriterError("RECORD_NOT_FOUND", `Source record disappeared while stamping _graphRuns for ${resolveRecordCollection(ref).collection}`);
|
|
100
107
|
}
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"write-result.js","sourceRoot":"","sources":["../../src/graph-runs/write-result.ts"],"names":[],"mappings":"AAMA,OAAO,EAAE,yBAAyB,EAAE,MAAM,kCAAkC,CAAC;AAC7E,OAAO,EAAE,oBAAoB,EAAE,MAAM,0BAA0B,CAAC;AAChE,OAAO,EAAE,kBAAkB,EAAE,MAAM,qBAAqB,CAAC;AAEzD,OAAO,EAAE,OAAO,EAAE,MAAM,kBAAkB,CAAC;AAC3C,OAAO,EAAE,eAAe,EAAE,MAAM,gBAAgB,CAAC;AACjD,OAAO,EAAE,iBAAiB,EAAE,MAAM,cAAc,CAAC;AACjD,OAAO,EAAE,mCAAmC,EAAE,MAAM,kCAAkC,CAAC;AACvF,OAAO,EAAE,kBAAkB,EAAE,MAAM,cAAc,CAAC;AAClD,OAAO,EAAE,qBAAqB,EAAE,MAAM,8BAA8B,CAAC;AACrE,OAAO,EACL,4BAA4B,EAC5B,uBAAuB,GACxB,MAAM,gCAAgC,CAAC;
|
|
1
|
+
{"version":3,"file":"write-result.js","sourceRoot":"","sources":["../../src/graph-runs/write-result.ts"],"names":[],"mappings":"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"}
|
package/dist/index.d.ts
CHANGED
|
@@ -20,16 +20,31 @@ export { ensureGraphRunIndexes } from "./graph-runs/ensure-indexes.js";
|
|
|
20
20
|
export { GRAPH_RUNS_FIELD, graphRunDotPath } from "./graph-runs/constants.js";
|
|
21
21
|
export { resolveRecordCollection, resolveCollectionFromRef, resolvePersistencyCollection, resolvePersistencyRecordId, } from "./graph-runs/resolve-record-collection.js";
|
|
22
22
|
export { graphRunLogContext } from "./graph-runs/logging.js";
|
|
23
|
+
export { markJobTypeRunStarted } from "./job-type-runs/mark-started.js";
|
|
24
|
+
export { markJobTypeRunFailed } from "./job-type-runs/mark-failed.js";
|
|
25
|
+
export { markJobTypeRunCompleted } from "./job-type-runs/mark-completed.js";
|
|
26
|
+
export { getJobTypeRun } from "./job-type-runs/get-run.js";
|
|
27
|
+
export { ensureJobTypeRunIndexes } from "./job-type-runs/ensure-indexes.js";
|
|
28
|
+
export { JOB_TYPE_RUNS_FIELD, jobTypeRunDotPath, jobTypeRunFieldKey, } from "./job-type-runs/constants.js";
|
|
29
|
+
export { readJobTypeRunEntry } from "./job-type-runs/context.js";
|
|
30
|
+
export { jobTypeRunLogContext } from "./job-type-runs/logging.js";
|
|
23
31
|
export type { MarkGraphRunStartedOptions, MarkGraphRunStartedResult, } from "./graph-runs/mark-started.js";
|
|
24
32
|
export type { MarkGraphRunFailedOptions, MarkGraphRunFailedResult, } from "./graph-runs/mark-failed.js";
|
|
25
33
|
export type { WriteGraphRunResultOptions, WriteGraphRunResultResponse, } from "./graph-runs/write-result.js";
|
|
26
34
|
export type { ClearGraphRunResult } from "./graph-runs/clear-run.js";
|
|
27
35
|
export type { EnsureGraphRunIndexesResult } from "./graph-runs/ensure-indexes.js";
|
|
28
36
|
export type { GraphRunLogContext } from "./graph-runs/logging.js";
|
|
29
|
-
export type {
|
|
37
|
+
export type { MarkJobTypeRunStartedOptions, MarkJobTypeRunStartedResult, } from "./job-type-runs/mark-started.js";
|
|
38
|
+
export type { MarkJobTypeRunFailedOptions, MarkJobTypeRunFailedResult, } from "./job-type-runs/mark-failed.js";
|
|
39
|
+
export type { MarkJobTypeRunCompletedOptions, MarkJobTypeRunCompletedResult, } from "./job-type-runs/mark-completed.js";
|
|
40
|
+
export type { EnsureJobTypeRunIndexesResult } from "./job-type-runs/ensure-indexes.js";
|
|
41
|
+
export type { JobTypeRunLogContext } from "./job-type-runs/logging.js";
|
|
42
|
+
export type { GraphRunStatus, GraphRunResultPointer, GraphRunError, GraphRunEntry, GraphRunsField, JobTypeRunsField, MemorixRecordRef, PersistencyRecordIdSource, PersistencyLinkIntent, PersistencyTarget, } from "@x12i/memorix-descriptors/types";
|
|
30
43
|
export type { MemorixWriterClient, CreateMemorixWriterOptions, CreateMemorixWriterFromEnvOptions, CataloxLike, MemorixObjectWriterLike, MemorixContentWriterRegistry, MemorixRetrievalClient, MemorixWriterDefaults, WriteMemorixRecordRequest, WriteMemorixRecordResponse, WriteMemorixRecordsRequest, WriteMemorixRecordsResponse, ValidateMemorixWriteResponse, } from "./client/types.js";
|
|
31
44
|
export type { MemorixWriteDescriptor, MemorixWriteFieldDescriptor, MemorixIdempotencyDescriptor, } from "./descriptors/write-descriptor-types.js";
|
|
32
45
|
export type { MemorixEntityDescriptor, MemorixContentObject, MemorixContentStorageDescriptor, MemorixContentTypeDescriptor, MemorixPropertyDescriptor, } from "./descriptors/entity-descriptor-types.js";
|
|
33
46
|
export type { MemorixWriteIssue } from "./errors/issues.js";
|
|
47
|
+
export { initializeEntityCollections } from "./collections/initialize-entity-collections.js";
|
|
48
|
+
export type { InitializeEntityCollectionsOptions, InitializeEntityCollectionsResult, } from "./collections/initialize-entity-collections.js";
|
|
34
49
|
export { MemorixWriterError } from "./errors/errors.js";
|
|
35
50
|
//# sourceMappingURL=index.d.ts.map
|
package/dist/index.d.ts.map
CHANGED
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"index.d.ts","sourceRoot":"","sources":["../src/index.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,mBAAmB,EAAE,MAAM,2BAA2B,CAAC;AAChE,OAAO,EAAE,0BAA0B,EAAE,MAAM,6BAA6B,CAAC;AAEzE,OAAO,EAAE,kBAAkB,EAAE,MAAM,0BAA0B,CAAC;AAC9D,OAAO,EAAE,mBAAmB,EAAE,MAAM,2BAA2B,CAAC;AAChE,OAAO,EAAE,oBAAoB,EAAE,MAAM,4BAA4B,CAAC;AAElE,OAAO,EAAE,0BAA0B,EAAE,MAAM,wCAAwC,CAAC;AACpF,OAAO,EAAE,2BAA2B,EAAE,MAAM,yCAAyC,CAAC;AAEtF,OAAO,EACL,iCAAiC,EACjC,mCAAmC,EACnC,qCAAqC,EACrC,iBAAiB,EACjB,iBAAiB,GAClB,MAAM,2BAA2B,CAAC;AACnC,OAAO,EACL,oBAAoB,EACpB,0BAA0B,EAC1B,eAAe,EACf,2BAA2B,EAC3B,sBAAsB,EACtB,yBAAyB,EACzB,oCAAoC,EACpC,mCAAmC,GACpC,MAAM,kBAAkB,CAAC;AAC1B,OAAO,EAAE,mBAAmB,EAAE,MAAM,uBAAuB,CAAC;AAC5D,YAAY,EAAE,aAAa,EAAE,MAAM,mBAAmB,CAAC;AACvD,OAAO,EAAE,8BAA8B,EAAE,MAAM,wCAAwC,CAAC;AACxF,OAAO,EAAE,gCAAgC,EAAE,MAAM,2CAA2C,CAAC;AAC7F,OAAO,EACL,yBAAyB,EACzB,qBAAqB,GACtB,MAAM,mCAAmC,CAAC;AAE3C,OAAO,EAAE,mBAAmB,EAAE,MAAM,8BAA8B,CAAC;AACnE,OAAO,EAAE,kBAAkB,EAAE,MAAM,6BAA6B,CAAC;AACjE,OAAO,EAAE,mBAAmB,EAAE,MAAM,8BAA8B,CAAC;AACnE,OAAO,EAAE,aAAa,EAAE,MAAM,2BAA2B,CAAC;AAC1D,OAAO,EAAE,qBAAqB,EAAE,MAAM,gCAAgC,CAAC;AACvE,OAAO,EAAE,gBAAgB,EAAE,eAAe,EAAE,MAAM,2BAA2B,CAAC;AAC9E,OAAO,EACL,uBAAuB,EACvB,wBAAwB,EACxB,4BAA4B,EAC5B,0BAA0B,GAC3B,MAAM,2CAA2C,CAAC;AACnD,OAAO,EAAE,kBAAkB,EAAE,MAAM,yBAAyB,CAAC;AAE7D,YAAY,EACV,0BAA0B,EAC1B,yBAAyB,GAC1B,MAAM,8BAA8B,CAAC;AACtC,YAAY,EACV,yBAAyB,EACzB,wBAAwB,GACzB,MAAM,6BAA6B,CAAC;AACrC,YAAY,EACV,0BAA0B,EAC1B,2BAA2B,GAC5B,MAAM,8BAA8B,CAAC;AACtC,YAAY,EAAE,mBAAmB,EAAE,MAAM,2BAA2B,CAAC;AACrE,YAAY,EAAE,2BAA2B,EAAE,MAAM,gCAAgC,CAAC;AAClF,YAAY,EAAE,kBAAkB,EAAE,MAAM,yBAAyB,CAAC;
|
|
1
|
+
{"version":3,"file":"index.d.ts","sourceRoot":"","sources":["../src/index.ts"],"names":[],"mappings":"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"}
|
package/dist/index.js
CHANGED
|
@@ -19,5 +19,14 @@ export { ensureGraphRunIndexes } from "./graph-runs/ensure-indexes.js";
|
|
|
19
19
|
export { GRAPH_RUNS_FIELD, graphRunDotPath } from "./graph-runs/constants.js";
|
|
20
20
|
export { resolveRecordCollection, resolveCollectionFromRef, resolvePersistencyCollection, resolvePersistencyRecordId, } from "./graph-runs/resolve-record-collection.js";
|
|
21
21
|
export { graphRunLogContext } from "./graph-runs/logging.js";
|
|
22
|
+
export { markJobTypeRunStarted } from "./job-type-runs/mark-started.js";
|
|
23
|
+
export { markJobTypeRunFailed } from "./job-type-runs/mark-failed.js";
|
|
24
|
+
export { markJobTypeRunCompleted } from "./job-type-runs/mark-completed.js";
|
|
25
|
+
export { getJobTypeRun } from "./job-type-runs/get-run.js";
|
|
26
|
+
export { ensureJobTypeRunIndexes } from "./job-type-runs/ensure-indexes.js";
|
|
27
|
+
export { JOB_TYPE_RUNS_FIELD, jobTypeRunDotPath, jobTypeRunFieldKey, } from "./job-type-runs/constants.js";
|
|
28
|
+
export { readJobTypeRunEntry } from "./job-type-runs/context.js";
|
|
29
|
+
export { jobTypeRunLogContext } from "./job-type-runs/logging.js";
|
|
30
|
+
export { initializeEntityCollections } from "./collections/initialize-entity-collections.js";
|
|
22
31
|
export { MemorixWriterError } from "./errors/errors.js";
|
|
23
32
|
//# sourceMappingURL=index.js.map
|
package/dist/index.js.map
CHANGED
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"index.js","sourceRoot":"","sources":["../src/index.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,mBAAmB,EAAE,MAAM,2BAA2B,CAAC;AAChE,OAAO,EAAE,0BAA0B,EAAE,MAAM,6BAA6B,CAAC;AAEzE,OAAO,EAAE,kBAAkB,EAAE,MAAM,0BAA0B,CAAC;AAC9D,OAAO,EAAE,mBAAmB,EAAE,MAAM,2BAA2B,CAAC;AAChE,OAAO,EAAE,oBAAoB,EAAE,MAAM,4BAA4B,CAAC;AAElE,OAAO,EAAE,0BAA0B,EAAE,MAAM,wCAAwC,CAAC;AACpF,OAAO,EAAE,2BAA2B,EAAE,MAAM,yCAAyC,CAAC;AAEtF,OAAO,EACL,iCAAiC,EACjC,mCAAmC,EACnC,qCAAqC,EACrC,iBAAiB,EACjB,iBAAiB,GAClB,MAAM,2BAA2B,CAAC;AACnC,OAAO,EACL,oBAAoB,EACpB,0BAA0B,EAC1B,eAAe,EACf,2BAA2B,EAC3B,sBAAsB,EACtB,yBAAyB,EACzB,oCAAoC,EACpC,mCAAmC,GACpC,MAAM,kBAAkB,CAAC;AAC1B,OAAO,EAAE,mBAAmB,EAAE,MAAM,uBAAuB,CAAC;AAE5D,OAAO,EAAE,8BAA8B,EAAE,MAAM,wCAAwC,CAAC;AACxF,OAAO,EAAE,gCAAgC,EAAE,MAAM,2CAA2C,CAAC;AAC7F,OAAO,EACL,yBAAyB,EACzB,qBAAqB,GACtB,MAAM,mCAAmC,CAAC;AAE3C,OAAO,EAAE,mBAAmB,EAAE,MAAM,8BAA8B,CAAC;AACnE,OAAO,EAAE,kBAAkB,EAAE,MAAM,6BAA6B,CAAC;AACjE,OAAO,EAAE,mBAAmB,EAAE,MAAM,8BAA8B,CAAC;AACnE,OAAO,EAAE,aAAa,EAAE,MAAM,2BAA2B,CAAC;AAC1D,OAAO,EAAE,qBAAqB,EAAE,MAAM,gCAAgC,CAAC;AACvE,OAAO,EAAE,gBAAgB,EAAE,eAAe,EAAE,MAAM,2BAA2B,CAAC;AAC9E,OAAO,EACL,uBAAuB,EACvB,wBAAwB,EACxB,4BAA4B,EAC5B,0BAA0B,GAC3B,MAAM,2CAA2C,CAAC;AACnD,OAAO,EAAE,kBAAkB,EAAE,MAAM,yBAAyB,CAAC;
|
|
1
|
+
{"version":3,"file":"index.js","sourceRoot":"","sources":["../src/index.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,mBAAmB,EAAE,MAAM,2BAA2B,CAAC;AAChE,OAAO,EAAE,0BAA0B,EAAE,MAAM,6BAA6B,CAAC;AAEzE,OAAO,EAAE,kBAAkB,EAAE,MAAM,0BAA0B,CAAC;AAC9D,OAAO,EAAE,mBAAmB,EAAE,MAAM,2BAA2B,CAAC;AAChE,OAAO,EAAE,oBAAoB,EAAE,MAAM,4BAA4B,CAAC;AAElE,OAAO,EAAE,0BAA0B,EAAE,MAAM,wCAAwC,CAAC;AACpF,OAAO,EAAE,2BAA2B,EAAE,MAAM,yCAAyC,CAAC;AAEtF,OAAO,EACL,iCAAiC,EACjC,mCAAmC,EACnC,qCAAqC,EACrC,iBAAiB,EACjB,iBAAiB,GAClB,MAAM,2BAA2B,CAAC;AACnC,OAAO,EACL,oBAAoB,EACpB,0BAA0B,EAC1B,eAAe,EACf,2BAA2B,EAC3B,sBAAsB,EACtB,yBAAyB,EACzB,oCAAoC,EACpC,mCAAmC,GACpC,MAAM,kBAAkB,CAAC;AAC1B,OAAO,EAAE,mBAAmB,EAAE,MAAM,uBAAuB,CAAC;AAE5D,OAAO,EAAE,8BAA8B,EAAE,MAAM,wCAAwC,CAAC;AACxF,OAAO,EAAE,gCAAgC,EAAE,MAAM,2CAA2C,CAAC;AAC7F,OAAO,EACL,yBAAyB,EACzB,qBAAqB,GACtB,MAAM,mCAAmC,CAAC;AAE3C,OAAO,EAAE,mBAAmB,EAAE,MAAM,8BAA8B,CAAC;AACnE,OAAO,EAAE,kBAAkB,EAAE,MAAM,6BAA6B,CAAC;AACjE,OAAO,EAAE,mBAAmB,EAAE,MAAM,8BAA8B,CAAC;AACnE,OAAO,EAAE,aAAa,EAAE,MAAM,2BAA2B,CAAC;AAC1D,OAAO,EAAE,qBAAqB,EAAE,MAAM,gCAAgC,CAAC;AACvE,OAAO,EAAE,gBAAgB,EAAE,eAAe,EAAE,MAAM,2BAA2B,CAAC;AAC9E,OAAO,EACL,uBAAuB,EACvB,wBAAwB,EACxB,4BAA4B,EAC5B,0BAA0B,GAC3B,MAAM,2CAA2C,CAAC;AACnD,OAAO,EAAE,kBAAkB,EAAE,MAAM,yBAAyB,CAAC;AAE7D,OAAO,EAAE,qBAAqB,EAAE,MAAM,iCAAiC,CAAC;AACxE,OAAO,EAAE,oBAAoB,EAAE,MAAM,gCAAgC,CAAC;AACtE,OAAO,EAAE,uBAAuB,EAAE,MAAM,mCAAmC,CAAC;AAC5E,OAAO,EAAE,aAAa,EAAE,MAAM,4BAA4B,CAAC;AAC3D,OAAO,EAAE,uBAAuB,EAAE,MAAM,mCAAmC,CAAC;AAC5E,OAAO,EACL,mBAAmB,EACnB,iBAAiB,EACjB,kBAAkB,GACnB,MAAM,8BAA8B,CAAC;AACtC,OAAO,EAAE,mBAAmB,EAAE,MAAM,4BAA4B,CAAC;AACjE,OAAO,EAAE,oBAAoB,EAAE,MAAM,4BAA4B,CAAC;AA6ElE,OAAO,EAAE,2BAA2B,EAAE,MAAM,gDAAgD,CAAC;AAO7F,OAAO,EAAE,kBAAkB,EAAE,MAAM,oBAAoB,CAAC"}
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"constants.d.ts","sourceRoot":"","sources":["../../src/job-type-runs/constants.ts"],"names":[],"mappings":"AAAA,OAAO,EACL,mBAAmB,EACnB,iBAAiB,EACjB,kBAAkB,GACnB,MAAM,iCAAiC,CAAC"}
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"constants.js","sourceRoot":"","sources":["../../src/job-type-runs/constants.ts"],"names":[],"mappings":"AAAA,OAAO,EACL,mBAAmB,EACnB,iBAAiB,EACjB,kBAAkB,GACnB,MAAM,iCAAiC,CAAC"}
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"context.d.ts","sourceRoot":"","sources":["../../src/job-type-runs/context.ts"],"names":[],"mappings":"AAAA,OAAO,KAAK,EACV,aAAa,EAEd,MAAM,iCAAiC,CAAC;AAGzC,wBAAgB,mBAAmB,CACjC,GAAG,EAAE,MAAM,CAAC,MAAM,EAAE,OAAO,CAAC,EAC5B,SAAS,EAAE,MAAM,GAChB,aAAa,GAAG,SAAS,CAG3B"}
|
|
@@ -0,0 +1,6 @@
|
|
|
1
|
+
import { JOB_TYPE_RUNS_FIELD, jobTypeRunFieldKey } from "./constants.js";
|
|
2
|
+
export function readJobTypeRunEntry(doc, jobTypeId) {
|
|
3
|
+
const jobTypeRuns = doc[JOB_TYPE_RUNS_FIELD];
|
|
4
|
+
return jobTypeRuns?.[jobTypeRunFieldKey(jobTypeId)];
|
|
5
|
+
}
|
|
6
|
+
//# sourceMappingURL=context.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"context.js","sourceRoot":"","sources":["../../src/job-type-runs/context.ts"],"names":[],"mappings":"AAIA,OAAO,EAAE,mBAAmB,EAAE,kBAAkB,EAAE,MAAM,gBAAgB,CAAC;AAEzE,MAAM,UAAU,mBAAmB,CACjC,GAA4B,EAC5B,SAAiB;IAEjB,MAAM,WAAW,GAAG,GAAG,CAAC,mBAAmB,CAAiC,CAAC;IAC7E,OAAO,WAAW,EAAE,CAAC,kBAAkB,CAAC,SAAS,CAAC,CAAC,CAAC;AACtD,CAAC"}
|
|
@@ -0,0 +1,10 @@
|
|
|
1
|
+
import type { MongoClient } from "mongodb";
|
|
2
|
+
import type { MemorixRecordRef } from "@x12i/memorix-descriptors/types";
|
|
3
|
+
export type EnsureJobTypeRunIndexesResult = {
|
|
4
|
+
ok: true;
|
|
5
|
+
collection: string;
|
|
6
|
+
jobTypeId: string;
|
|
7
|
+
indexes: string[];
|
|
8
|
+
};
|
|
9
|
+
export declare function ensureJobTypeRunIndexes(client: MongoClient, ref: MemorixRecordRef, jobTypeId: string, env?: NodeJS.ProcessEnv): Promise<EnsureJobTypeRunIndexesResult>;
|
|
10
|
+
//# sourceMappingURL=ensure-indexes.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"ensure-indexes.d.ts","sourceRoot":"","sources":["../../src/job-type-runs/ensure-indexes.ts"],"names":[],"mappings":"AAAA,OAAO,KAAK,EAAE,WAAW,EAAE,MAAM,SAAS,CAAC;AAC3C,OAAO,KAAK,EAAE,gBAAgB,EAAE,MAAM,iCAAiC,CAAC;AASxE,MAAM,MAAM,6BAA6B,GAAG;IAC1C,EAAE,EAAE,IAAI,CAAC;IACT,UAAU,EAAE,MAAM,CAAC;IACnB,SAAS,EAAE,MAAM,CAAC;IAClB,OAAO,EAAE,MAAM,EAAE,CAAC;CACnB,CAAC;AAEF,wBAAsB,uBAAuB,CAC3C,MAAM,EAAE,WAAW,EACnB,GAAG,EAAE,gBAAgB,EACrB,SAAS,EAAE,MAAM,EACjB,GAAG,GAAE,MAAM,CAAC,UAAwB,GACnC,OAAO,CAAC,6BAA6B,CAAC,CAuCxC"}
|
|
@@ -0,0 +1,32 @@
|
|
|
1
|
+
import { resolveMemorixDbName } from "../mongo/env.js";
|
|
2
|
+
import { resolveIdFieldForTarget, resolveRecordCollection, } from "../graph-runs/resolve-record-collection.js";
|
|
3
|
+
import { jobTypeRunDotPath } from "./constants.js";
|
|
4
|
+
import { jobTypeRunLogContext } from "./logging.js";
|
|
5
|
+
export async function ensureJobTypeRunIndexes(client, ref, jobTypeId, env = process.env) {
|
|
6
|
+
jobTypeRunLogContext({
|
|
7
|
+
jobRunId: "",
|
|
8
|
+
jobTypeId,
|
|
9
|
+
recordRef: ref,
|
|
10
|
+
operation: "ensureJobTypeRunIndexes",
|
|
11
|
+
});
|
|
12
|
+
const resolved = resolveRecordCollection(ref);
|
|
13
|
+
const dbName = resolveMemorixDbName(resolved.target, env);
|
|
14
|
+
const idField = resolveIdFieldForTarget(ref.target);
|
|
15
|
+
const col = client.db(dbName).collection(resolved.collection);
|
|
16
|
+
const statusIndex = `${jobTypeRunDotPath(jobTypeId)}.status_1_${idField}_1`;
|
|
17
|
+
const completedAtIndex = `${jobTypeRunDotPath(jobTypeId)}.completedAt_-1`;
|
|
18
|
+
const reprocessIndex = `${jobTypeRunDotPath(jobTypeId)}.status_1_completedAt_-1`;
|
|
19
|
+
await col.createIndex({ [jobTypeRunDotPath(jobTypeId) + ".status"]: 1, [idField]: 1 }, { name: statusIndex });
|
|
20
|
+
await col.createIndex({ [jobTypeRunDotPath(jobTypeId) + ".completedAt"]: -1 }, { name: completedAtIndex });
|
|
21
|
+
await col.createIndex({
|
|
22
|
+
[jobTypeRunDotPath(jobTypeId) + ".status"]: 1,
|
|
23
|
+
[jobTypeRunDotPath(jobTypeId) + ".completedAt"]: -1,
|
|
24
|
+
}, { name: reprocessIndex });
|
|
25
|
+
return {
|
|
26
|
+
ok: true,
|
|
27
|
+
collection: resolved.collection,
|
|
28
|
+
jobTypeId,
|
|
29
|
+
indexes: [statusIndex, completedAtIndex, reprocessIndex],
|
|
30
|
+
};
|
|
31
|
+
}
|
|
32
|
+
//# sourceMappingURL=ensure-indexes.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"ensure-indexes.js","sourceRoot":"","sources":["../../src/job-type-runs/ensure-indexes.ts"],"names":[],"mappings":"AAEA,OAAO,EAAE,oBAAoB,EAAE,MAAM,iBAAiB,CAAC;AACvD,OAAO,EACL,uBAAuB,EACvB,uBAAuB,GACxB,MAAM,4CAA4C,CAAC;AACpD,OAAO,EAAE,iBAAiB,EAAE,MAAM,gBAAgB,CAAC;AACnD,OAAO,EAAE,oBAAoB,EAAE,MAAM,cAAc,CAAC;AASpD,MAAM,CAAC,KAAK,UAAU,uBAAuB,CAC3C,MAAmB,EACnB,GAAqB,EACrB,SAAiB,EACjB,MAAyB,OAAO,CAAC,GAAG;IAEpC,oBAAoB,CAAC;QACnB,QAAQ,EAAE,EAAE;QACZ,SAAS;QACT,SAAS,EAAE,GAAG;QACd,SAAS,EAAE,yBAAyB;KACrC,CAAC,CAAC;IAEH,MAAM,QAAQ,GAAG,uBAAuB,CAAC,GAAG,CAAC,CAAC;IAC9C,MAAM,MAAM,GAAG,oBAAoB,CAAC,QAAQ,CAAC,MAAM,EAAE,GAAG,CAAC,CAAC;IAC1D,MAAM,OAAO,GAAG,uBAAuB,CAAC,GAAG,CAAC,MAAM,CAAC,CAAC;IACpD,MAAM,GAAG,GAAG,MAAM,CAAC,EAAE,CAAC,MAAM,CAAC,CAAC,UAAU,CAAC,QAAQ,CAAC,UAAU,CAAC,CAAC;IAE9D,MAAM,WAAW,GAAG,GAAG,iBAAiB,CAAC,SAAS,CAAC,aAAa,OAAO,IAAI,CAAC;IAC5E,MAAM,gBAAgB,GAAG,GAAG,iBAAiB,CAAC,SAAS,CAAC,iBAAiB,CAAC;IAC1E,MAAM,cAAc,GAAG,GAAG,iBAAiB,CAAC,SAAS,CAAC,0BAA0B,CAAC;IAEjF,MAAM,GAAG,CAAC,WAAW,CACnB,EAAE,CAAC,iBAAiB,CAAC,SAAS,CAAC,GAAG,SAAS,CAAC,EAAE,CAAC,EAAE,CAAC,OAAO,CAAC,EAAE,CAAC,EAAE,EAC/D,EAAE,IAAI,EAAE,WAAW,EAAE,CACtB,CAAC;IACF,MAAM,GAAG,CAAC,WAAW,CACnB,EAAE,CAAC,iBAAiB,CAAC,SAAS,CAAC,GAAG,cAAc,CAAC,EAAE,CAAC,CAAC,EAAE,EACvD,EAAE,IAAI,EAAE,gBAAgB,EAAE,CAC3B,CAAC;IACF,MAAM,GAAG,CAAC,WAAW,CACnB;QACE,CAAC,iBAAiB,CAAC,SAAS,CAAC,GAAG,SAAS,CAAC,EAAE,CAAC;QAC7C,CAAC,iBAAiB,CAAC,SAAS,CAAC,GAAG,cAAc,CAAC,EAAE,CAAC,CAAC;KACpD,EACD,EAAE,IAAI,EAAE,cAAc,EAAE,CACzB,CAAC;IAEF,OAAO;QACL,EAAE,EAAE,IAAI;QACR,UAAU,EAAE,QAAQ,CAAC,UAAU;QAC/B,SAAS;QACT,OAAO,EAAE,CAAC,WAAW,EAAE,gBAAgB,EAAE,cAAc,CAAC;KACzD,CAAC;AACJ,CAAC"}
|
|
@@ -0,0 +1,8 @@
|
|
|
1
|
+
import type { GraphRunEntry, MemorixRecordRef } from "@x12i/memorix-descriptors/types";
|
|
2
|
+
import type { MemorixWriterClient } from "../client/types.js";
|
|
3
|
+
/**
|
|
4
|
+
* Read a job-type run stamp from a source record (MRX-CR-003).
|
|
5
|
+
* Returns undefined when the record or stamp is absent (no throw).
|
|
6
|
+
*/
|
|
7
|
+
export declare function getJobTypeRun(client: MemorixWriterClient, ref: MemorixRecordRef, jobTypeId: string): Promise<GraphRunEntry | undefined>;
|
|
8
|
+
//# sourceMappingURL=get-run.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"get-run.d.ts","sourceRoot":"","sources":["../../src/job-type-runs/get-run.ts"],"names":[],"mappings":"AAAA,OAAO,KAAK,EACV,aAAa,EACb,gBAAgB,EACjB,MAAM,iCAAiC,CAAC;AACzC,OAAO,KAAK,EAAE,mBAAmB,EAAE,MAAM,oBAAoB,CAAC;AAM9D;;;GAGG;AACH,wBAAsB,aAAa,CACjC,MAAM,EAAE,mBAAmB,EAC3B,GAAG,EAAE,gBAAgB,EACrB,SAAS,EAAE,MAAM,GAChB,OAAO,CAAC,aAAa,GAAG,SAAS,CAAC,CAKpC"}
|
|
@@ -0,0 +1,14 @@
|
|
|
1
|
+
import { createGraphRunWriterContext, } from "../graph-runs/context.js";
|
|
2
|
+
import { readJobTypeRunEntry } from "./context.js";
|
|
3
|
+
/**
|
|
4
|
+
* Read a job-type run stamp from a source record (MRX-CR-003).
|
|
5
|
+
* Returns undefined when the record or stamp is absent (no throw).
|
|
6
|
+
*/
|
|
7
|
+
export async function getJobTypeRun(client, ref, jobTypeId) {
|
|
8
|
+
const ctx = await createGraphRunWriterContext(client, ref);
|
|
9
|
+
const doc = await ctx.adapter.findOne(ctx.resolved.collection, ctx.resolved.filter);
|
|
10
|
+
if (!doc)
|
|
11
|
+
return undefined;
|
|
12
|
+
return readJobTypeRunEntry(doc, jobTypeId);
|
|
13
|
+
}
|
|
14
|
+
//# sourceMappingURL=get-run.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"get-run.js","sourceRoot":"","sources":["../../src/job-type-runs/get-run.ts"],"names":[],"mappings":"AAKA,OAAO,EACL,2BAA2B,GAC5B,MAAM,0BAA0B,CAAC;AAClC,OAAO,EAAE,mBAAmB,EAAE,MAAM,cAAc,CAAC;AAEnD;;;GAGG;AACH,MAAM,CAAC,KAAK,UAAU,aAAa,CACjC,MAA2B,EAC3B,GAAqB,EACrB,SAAiB;IAEjB,MAAM,GAAG,GAAG,MAAM,2BAA2B,CAAC,MAAM,EAAE,GAAG,CAAC,CAAC;IAC3D,MAAM,GAAG,GAAG,MAAM,GAAG,CAAC,OAAO,CAAC,OAAO,CAAC,GAAG,CAAC,QAAQ,CAAC,UAAU,EAAE,GAAG,CAAC,QAAQ,CAAC,MAAM,CAAC,CAAC;IACpF,IAAI,CAAC,GAAG;QAAE,OAAO,SAAS,CAAC;IAC3B,OAAO,mBAAmB,CAAC,GAAG,EAAE,SAAS,CAAC,CAAC;AAC7C,CAAC"}
|
|
@@ -0,0 +1,9 @@
|
|
|
1
|
+
import type { MemorixRecordRef } from "@x12i/memorix-descriptors/types";
|
|
2
|
+
export type JobTypeRunLogContext = {
|
|
3
|
+
jobRunId: string;
|
|
4
|
+
jobTypeId: string;
|
|
5
|
+
recordRef: MemorixRecordRef;
|
|
6
|
+
operation: "markJobTypeRunStarted" | "markJobTypeRunCompleted" | "markJobTypeRunFailed" | "ensureJobTypeRunIndexes";
|
|
7
|
+
};
|
|
8
|
+
export declare function jobTypeRunLogContext(ctx: JobTypeRunLogContext): JobTypeRunLogContext;
|
|
9
|
+
//# sourceMappingURL=logging.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"logging.d.ts","sourceRoot":"","sources":["../../src/job-type-runs/logging.ts"],"names":[],"mappings":"AAAA,OAAO,KAAK,EAAE,gBAAgB,EAAE,MAAM,iCAAiC,CAAC;AAExE,MAAM,MAAM,oBAAoB,GAAG;IACjC,QAAQ,EAAE,MAAM,CAAC;IACjB,SAAS,EAAE,MAAM,CAAC;IAClB,SAAS,EAAE,gBAAgB,CAAC;IAC5B,SAAS,EACL,uBAAuB,GACvB,yBAAyB,GACzB,sBAAsB,GACtB,yBAAyB,CAAC;CAC/B,CAAC;AAEF,wBAAgB,oBAAoB,CAClC,GAAG,EAAE,oBAAoB,GACxB,oBAAoB,CAEtB"}
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"logging.js","sourceRoot":"","sources":["../../src/job-type-runs/logging.ts"],"names":[],"mappings":"AAaA,MAAM,UAAU,oBAAoB,CAClC,GAAyB;IAEzB,OAAO,GAAG,CAAC;AACb,CAAC"}
|
|
@@ -0,0 +1,15 @@
|
|
|
1
|
+
import type { GraphRunResultPointer, MemorixRecordRef } from "@x12i/memorix-descriptors/types";
|
|
2
|
+
import type { MemorixWriterClient } from "../client/types.js";
|
|
3
|
+
export type MarkJobTypeRunCompletedOptions = {
|
|
4
|
+
jobRunId: string;
|
|
5
|
+
attempts: number;
|
|
6
|
+
result?: GraphRunResultPointer;
|
|
7
|
+
graphVersion?: string;
|
|
8
|
+
};
|
|
9
|
+
export type MarkJobTypeRunCompletedResult = {
|
|
10
|
+
ok: true;
|
|
11
|
+
jobTypeId: string;
|
|
12
|
+
recordRef: MemorixRecordRef;
|
|
13
|
+
};
|
|
14
|
+
export declare function markJobTypeRunCompleted(client: MemorixWriterClient, ref: MemorixRecordRef, jobTypeId: string, opts: MarkJobTypeRunCompletedOptions): Promise<MarkJobTypeRunCompletedResult>;
|
|
15
|
+
//# sourceMappingURL=mark-completed.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"mark-completed.d.ts","sourceRoot":"","sources":["../../src/job-type-runs/mark-completed.ts"],"names":[],"mappings":"AAAA,OAAO,KAAK,EACV,qBAAqB,EACrB,gBAAgB,EACjB,MAAM,iCAAiC,CAAC;AACzC,OAAO,KAAK,EAAE,mBAAmB,EAAE,MAAM,oBAAoB,CAAC;AAU9D,MAAM,MAAM,8BAA8B,GAAG;IAC3C,QAAQ,EAAE,MAAM,CAAC;IACjB,QAAQ,EAAE,MAAM,CAAC;IACjB,MAAM,CAAC,EAAE,qBAAqB,CAAC;IAC/B,YAAY,CAAC,EAAE,MAAM,CAAC;CACvB,CAAC;AAEF,MAAM,MAAM,6BAA6B,GAAG;IAC1C,EAAE,EAAE,IAAI,CAAC;IACT,SAAS,EAAE,MAAM,CAAC;IAClB,SAAS,EAAE,gBAAgB,CAAC;CAC7B,CAAC;AAEF,wBAAsB,uBAAuB,CAC3C,MAAM,EAAE,mBAAmB,EAC3B,GAAG,EAAE,gBAAgB,EACrB,SAAS,EAAE,MAAM,EACjB,IAAI,EAAE,8BAA8B,GACnC,OAAO,CAAC,6BAA6B,CAAC,CAsCxC"}
|
|
@@ -0,0 +1,38 @@
|
|
|
1
|
+
import { MemorixWriterError } from "../errors/errors.js";
|
|
2
|
+
import { createGraphRunWriterContext, loadSourceRecord, } from "../graph-runs/context.js";
|
|
3
|
+
import { jobTypeRunDotPath } from "./constants.js";
|
|
4
|
+
import { readJobTypeRunEntry } from "./context.js";
|
|
5
|
+
import { jobTypeRunLogContext } from "./logging.js";
|
|
6
|
+
export async function markJobTypeRunCompleted(client, ref, jobTypeId, opts) {
|
|
7
|
+
const ctx = await createGraphRunWriterContext(client, ref);
|
|
8
|
+
const doc = await loadSourceRecord(ctx);
|
|
9
|
+
const existing = readJobTypeRunEntry(doc, jobTypeId);
|
|
10
|
+
const completedAt = new Date().toISOString();
|
|
11
|
+
jobTypeRunLogContext({
|
|
12
|
+
jobRunId: opts.jobRunId,
|
|
13
|
+
jobTypeId,
|
|
14
|
+
recordRef: ref,
|
|
15
|
+
operation: "markJobTypeRunCompleted",
|
|
16
|
+
});
|
|
17
|
+
const entry = {
|
|
18
|
+
status: "done",
|
|
19
|
+
startedAt: existing?.startedAt ?? completedAt,
|
|
20
|
+
completedAt,
|
|
21
|
+
lastJobRunId: opts.jobRunId,
|
|
22
|
+
attempts: opts.attempts,
|
|
23
|
+
...(opts.result !== undefined ? { result: opts.result } : existing?.result !== undefined ? { result: existing.result } : {}),
|
|
24
|
+
...(opts.graphVersion !== undefined
|
|
25
|
+
? { graphVersion: opts.graphVersion }
|
|
26
|
+
: existing?.graphVersion !== undefined
|
|
27
|
+
? { graphVersion: existing.graphVersion }
|
|
28
|
+
: {}),
|
|
29
|
+
};
|
|
30
|
+
const stamp = await ctx.adapter.patch(ctx.resolved.collection, ctx.resolved.filter, {
|
|
31
|
+
[jobTypeRunDotPath(jobTypeId)]: entry,
|
|
32
|
+
});
|
|
33
|
+
if (stamp.matchedCount === 0) {
|
|
34
|
+
throw new MemorixWriterError("RECORD_NOT_FOUND", `Source record disappeared while stamping _jobTypeRuns for ${ctx.resolved.collection}`);
|
|
35
|
+
}
|
|
36
|
+
return { ok: true, jobTypeId, recordRef: ref };
|
|
37
|
+
}
|
|
38
|
+
//# sourceMappingURL=mark-completed.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"mark-completed.js","sourceRoot":"","sources":["../../src/job-type-runs/mark-completed.ts"],"names":[],"mappings":"AAKA,OAAO,EAAE,kBAAkB,EAAE,MAAM,qBAAqB,CAAC;AACzD,OAAO,EACL,2BAA2B,EAC3B,gBAAgB,GACjB,MAAM,0BAA0B,CAAC;AAClC,OAAO,EAAE,iBAAiB,EAAE,MAAM,gBAAgB,CAAC;AACnD,OAAO,EAAE,mBAAmB,EAAE,MAAM,cAAc,CAAC;AACnD,OAAO,EAAE,oBAAoB,EAAE,MAAM,cAAc,CAAC;AAepD,MAAM,CAAC,KAAK,UAAU,uBAAuB,CAC3C,MAA2B,EAC3B,GAAqB,EACrB,SAAiB,EACjB,IAAoC;IAEpC,MAAM,GAAG,GAAG,MAAM,2BAA2B,CAAC,MAAM,EAAE,GAAG,CAAC,CAAC;IAC3D,MAAM,GAAG,GAAG,MAAM,gBAAgB,CAAC,GAAG,CAAC,CAAC;IACxC,MAAM,QAAQ,GAAG,mBAAmB,CAAC,GAAG,EAAE,SAAS,CAAC,CAAC;IACrD,MAAM,WAAW,GAAG,IAAI,IAAI,EAAE,CAAC,WAAW,EAAE,CAAC;IAE7C,oBAAoB,CAAC;QACnB,QAAQ,EAAE,IAAI,CAAC,QAAQ;QACvB,SAAS;QACT,SAAS,EAAE,GAAG;QACd,SAAS,EAAE,yBAAyB;KACrC,CAAC,CAAC;IAEH,MAAM,KAAK,GAAG;QACZ,MAAM,EAAE,MAAe;QACvB,SAAS,EAAE,QAAQ,EAAE,SAAS,IAAI,WAAW;QAC7C,WAAW;QACX,YAAY,EAAE,IAAI,CAAC,QAAQ;QAC3B,QAAQ,EAAE,IAAI,CAAC,QAAQ;QACvB,GAAG,CAAC,IAAI,CAAC,MAAM,KAAK,SAAS,CAAC,CAAC,CAAC,EAAE,MAAM,EAAE,IAAI,CAAC,MAAM,EAAE,CAAC,CAAC,CAAC,QAAQ,EAAE,MAAM,KAAK,SAAS,CAAC,CAAC,CAAC,EAAE,MAAM,EAAE,QAAQ,CAAC,MAAM,EAAE,CAAC,CAAC,CAAC,EAAE,CAAC;QAC5H,GAAG,CAAC,IAAI,CAAC,YAAY,KAAK,SAAS;YACjC,CAAC,CAAC,EAAE,YAAY,EAAE,IAAI,CAAC,YAAY,EAAE;YACrC,CAAC,CAAC,QAAQ,EAAE,YAAY,KAAK,SAAS;gBACpC,CAAC,CAAC,EAAE,YAAY,EAAE,QAAQ,CAAC,YAAY,EAAE;gBACzC,CAAC,CAAC,EAAE,CAAC;KACV,CAAC;IAEF,MAAM,KAAK,GAAG,MAAM,GAAG,CAAC,OAAO,CAAC,KAAK,CAAC,GAAG,CAAC,QAAQ,CAAC,UAAU,EAAE,GAAG,CAAC,QAAQ,CAAC,MAAM,EAAE;QAClF,CAAC,iBAAiB,CAAC,SAAS,CAAC,CAAC,EAAE,KAAK;KACtC,CAAC,CAAC;IACH,IAAI,KAAK,CAAC,YAAY,KAAK,CAAC,EAAE,CAAC;QAC7B,MAAM,IAAI,kBAAkB,CAC1B,kBAAkB,EAClB,6DAA6D,GAAG,CAAC,QAAQ,CAAC,UAAU,EAAE,CACvF,CAAC;IACJ,CAAC;IAED,OAAO,EAAE,EAAE,EAAE,IAAI,EAAE,SAAS,EAAE,SAAS,EAAE,GAAG,EAAE,CAAC;AACjD,CAAC"}
|
|
@@ -0,0 +1,14 @@
|
|
|
1
|
+
import type { GraphRunError, MemorixRecordRef } from "@x12i/memorix-descriptors/types";
|
|
2
|
+
import type { MemorixWriterClient } from "../client/types.js";
|
|
3
|
+
export type MarkJobTypeRunFailedOptions = {
|
|
4
|
+
jobRunId: string;
|
|
5
|
+
attempts: number;
|
|
6
|
+
error: GraphRunError;
|
|
7
|
+
};
|
|
8
|
+
export type MarkJobTypeRunFailedResult = {
|
|
9
|
+
ok: true;
|
|
10
|
+
jobTypeId: string;
|
|
11
|
+
recordRef: MemorixRecordRef;
|
|
12
|
+
};
|
|
13
|
+
export declare function markJobTypeRunFailed(client: MemorixWriterClient, ref: MemorixRecordRef, jobTypeId: string, opts: MarkJobTypeRunFailedOptions): Promise<MarkJobTypeRunFailedResult>;
|
|
14
|
+
//# sourceMappingURL=mark-failed.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"mark-failed.d.ts","sourceRoot":"","sources":["../../src/job-type-runs/mark-failed.ts"],"names":[],"mappings":"AAAA,OAAO,KAAK,EACV,aAAa,EACb,gBAAgB,EACjB,MAAM,iCAAiC,CAAC;AACzC,OAAO,KAAK,EAAE,mBAAmB,EAAE,MAAM,oBAAoB,CAAC;AAU9D,MAAM,MAAM,2BAA2B,GAAG;IACxC,QAAQ,EAAE,MAAM,CAAC;IACjB,QAAQ,EAAE,MAAM,CAAC;IACjB,KAAK,EAAE,aAAa,CAAC;CACtB,CAAC;AAEF,MAAM,MAAM,0BAA0B,GAAG;IACvC,EAAE,EAAE,IAAI,CAAC;IACT,SAAS,EAAE,MAAM,CAAC;IAClB,SAAS,EAAE,gBAAgB,CAAC;CAC7B,CAAC;AAEF,wBAAsB,oBAAoB,CACxC,MAAM,EAAE,mBAAmB,EAC3B,GAAG,EAAE,gBAAgB,EACrB,SAAS,EAAE,MAAM,EACjB,IAAI,EAAE,2BAA2B,GAChC,OAAO,CAAC,0BAA0B,CAAC,CAoCrC"}
|
|
@@ -0,0 +1,36 @@
|
|
|
1
|
+
import { MemorixWriterError } from "../errors/errors.js";
|
|
2
|
+
import { createGraphRunWriterContext, loadSourceRecord, } from "../graph-runs/context.js";
|
|
3
|
+
import { jobTypeRunDotPath } from "./constants.js";
|
|
4
|
+
import { readJobTypeRunEntry } from "./context.js";
|
|
5
|
+
import { jobTypeRunLogContext } from "./logging.js";
|
|
6
|
+
export async function markJobTypeRunFailed(client, ref, jobTypeId, opts) {
|
|
7
|
+
const ctx = await createGraphRunWriterContext(client, ref);
|
|
8
|
+
const doc = await loadSourceRecord(ctx);
|
|
9
|
+
const existing = readJobTypeRunEntry(doc, jobTypeId);
|
|
10
|
+
const completedAt = new Date().toISOString();
|
|
11
|
+
jobTypeRunLogContext({
|
|
12
|
+
jobRunId: opts.jobRunId,
|
|
13
|
+
jobTypeId,
|
|
14
|
+
recordRef: ref,
|
|
15
|
+
operation: "markJobTypeRunFailed",
|
|
16
|
+
});
|
|
17
|
+
const entry = {
|
|
18
|
+
status: "failed",
|
|
19
|
+
startedAt: existing?.startedAt ?? completedAt,
|
|
20
|
+
completedAt,
|
|
21
|
+
lastJobRunId: opts.jobRunId,
|
|
22
|
+
attempts: opts.attempts,
|
|
23
|
+
error: opts.error,
|
|
24
|
+
...(existing?.graphVersion !== undefined
|
|
25
|
+
? { graphVersion: existing.graphVersion }
|
|
26
|
+
: {}),
|
|
27
|
+
};
|
|
28
|
+
const stamp = await ctx.adapter.patch(ctx.resolved.collection, ctx.resolved.filter, {
|
|
29
|
+
[jobTypeRunDotPath(jobTypeId)]: entry,
|
|
30
|
+
});
|
|
31
|
+
if (stamp.matchedCount === 0) {
|
|
32
|
+
throw new MemorixWriterError("RECORD_NOT_FOUND", `Source record disappeared while stamping _jobTypeRuns for ${ctx.resolved.collection}`);
|
|
33
|
+
}
|
|
34
|
+
return { ok: true, jobTypeId, recordRef: ref };
|
|
35
|
+
}
|
|
36
|
+
//# sourceMappingURL=mark-failed.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"mark-failed.js","sourceRoot":"","sources":["../../src/job-type-runs/mark-failed.ts"],"names":[],"mappings":"AAKA,OAAO,EAAE,kBAAkB,EAAE,MAAM,qBAAqB,CAAC;AACzD,OAAO,EACL,2BAA2B,EAC3B,gBAAgB,GACjB,MAAM,0BAA0B,CAAC;AAClC,OAAO,EAAE,iBAAiB,EAAE,MAAM,gBAAgB,CAAC;AACnD,OAAO,EAAE,mBAAmB,EAAE,MAAM,cAAc,CAAC;AACnD,OAAO,EAAE,oBAAoB,EAAE,MAAM,cAAc,CAAC;AAcpD,MAAM,CAAC,KAAK,UAAU,oBAAoB,CACxC,MAA2B,EAC3B,GAAqB,EACrB,SAAiB,EACjB,IAAiC;IAEjC,MAAM,GAAG,GAAG,MAAM,2BAA2B,CAAC,MAAM,EAAE,GAAG,CAAC,CAAC;IAC3D,MAAM,GAAG,GAAG,MAAM,gBAAgB,CAAC,GAAG,CAAC,CAAC;IACxC,MAAM,QAAQ,GAAG,mBAAmB,CAAC,GAAG,EAAE,SAAS,CAAC,CAAC;IACrD,MAAM,WAAW,GAAG,IAAI,IAAI,EAAE,CAAC,WAAW,EAAE,CAAC;IAE7C,oBAAoB,CAAC;QACnB,QAAQ,EAAE,IAAI,CAAC,QAAQ;QACvB,SAAS;QACT,SAAS,EAAE,GAAG;QACd,SAAS,EAAE,sBAAsB;KAClC,CAAC,CAAC;IAEH,MAAM,KAAK,GAAG;QACZ,MAAM,EAAE,QAAiB;QACzB,SAAS,EAAE,QAAQ,EAAE,SAAS,IAAI,WAAW;QAC7C,WAAW;QACX,YAAY,EAAE,IAAI,CAAC,QAAQ;QAC3B,QAAQ,EAAE,IAAI,CAAC,QAAQ;QACvB,KAAK,EAAE,IAAI,CAAC,KAAK;QACjB,GAAG,CAAC,QAAQ,EAAE,YAAY,KAAK,SAAS;YACtC,CAAC,CAAC,EAAE,YAAY,EAAE,QAAQ,CAAC,YAAY,EAAE;YACzC,CAAC,CAAC,EAAE,CAAC;KACR,CAAC;IAEF,MAAM,KAAK,GAAG,MAAM,GAAG,CAAC,OAAO,CAAC,KAAK,CAAC,GAAG,CAAC,QAAQ,CAAC,UAAU,EAAE,GAAG,CAAC,QAAQ,CAAC,MAAM,EAAE;QAClF,CAAC,iBAAiB,CAAC,SAAS,CAAC,CAAC,EAAE,KAAK;KACtC,CAAC,CAAC;IACH,IAAI,KAAK,CAAC,YAAY,KAAK,CAAC,EAAE,CAAC;QAC7B,MAAM,IAAI,kBAAkB,CAC1B,kBAAkB,EAClB,6DAA6D,GAAG,CAAC,QAAQ,CAAC,UAAU,EAAE,CACvF,CAAC;IACJ,CAAC;IAED,OAAO,EAAE,EAAE,EAAE,IAAI,EAAE,SAAS,EAAE,SAAS,EAAE,GAAG,EAAE,CAAC;AACjD,CAAC"}
|
|
@@ -0,0 +1,15 @@
|
|
|
1
|
+
import type { MemorixRecordRef } from "@x12i/memorix-descriptors/types";
|
|
2
|
+
import type { MemorixWriterClient } from "../client/types.js";
|
|
3
|
+
export type MarkJobTypeRunStartedOptions = {
|
|
4
|
+
jobRunId: string;
|
|
5
|
+
attempts: number;
|
|
6
|
+
graphVersion?: string;
|
|
7
|
+
};
|
|
8
|
+
export type MarkJobTypeRunStartedResult = {
|
|
9
|
+
ok: true;
|
|
10
|
+
action: "stamped" | "no_op";
|
|
11
|
+
jobTypeId: string;
|
|
12
|
+
recordRef: MemorixRecordRef;
|
|
13
|
+
};
|
|
14
|
+
export declare function markJobTypeRunStarted(client: MemorixWriterClient, ref: MemorixRecordRef, jobTypeId: string, opts: MarkJobTypeRunStartedOptions): Promise<MarkJobTypeRunStartedResult>;
|
|
15
|
+
//# sourceMappingURL=mark-started.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"mark-started.d.ts","sourceRoot":"","sources":["../../src/job-type-runs/mark-started.ts"],"names":[],"mappings":"AAAA,OAAO,KAAK,EAAE,gBAAgB,EAAE,MAAM,iCAAiC,CAAC;AACxE,OAAO,KAAK,EAAE,mBAAmB,EAAE,MAAM,oBAAoB,CAAC;AAU9D,MAAM,MAAM,4BAA4B,GAAG;IACzC,QAAQ,EAAE,MAAM,CAAC;IACjB,QAAQ,EAAE,MAAM,CAAC;IACjB,YAAY,CAAC,EAAE,MAAM,CAAC;CACvB,CAAC;AAEF,MAAM,MAAM,2BAA2B,GAAG;IACxC,EAAE,EAAE,IAAI,CAAC;IACT,MAAM,EAAE,SAAS,GAAG,OAAO,CAAC;IAC5B,SAAS,EAAE,MAAM,CAAC;IAClB,SAAS,EAAE,gBAAgB,CAAC;CAC7B,CAAC;AAEF,wBAAsB,qBAAqB,CACzC,MAAM,EAAE,mBAAmB,EAC3B,GAAG,EAAE,gBAAgB,EACrB,SAAS,EAAE,MAAM,EACjB,IAAI,EAAE,4BAA4B,GACjC,OAAO,CAAC,2BAA2B,CAAC,CAuCtC"}
|
|
@@ -0,0 +1,36 @@
|
|
|
1
|
+
import { MemorixWriterError } from "../errors/errors.js";
|
|
2
|
+
import { createGraphRunWriterContext, loadSourceRecord, } from "../graph-runs/context.js";
|
|
3
|
+
import { jobTypeRunDotPath } from "./constants.js";
|
|
4
|
+
import { readJobTypeRunEntry } from "./context.js";
|
|
5
|
+
import { jobTypeRunLogContext } from "./logging.js";
|
|
6
|
+
export async function markJobTypeRunStarted(client, ref, jobTypeId, opts) {
|
|
7
|
+
const ctx = await createGraphRunWriterContext(client, ref);
|
|
8
|
+
const doc = await loadSourceRecord(ctx);
|
|
9
|
+
const existing = readJobTypeRunEntry(doc, jobTypeId);
|
|
10
|
+
jobTypeRunLogContext({
|
|
11
|
+
jobRunId: opts.jobRunId,
|
|
12
|
+
jobTypeId,
|
|
13
|
+
recordRef: ref,
|
|
14
|
+
operation: "markJobTypeRunStarted",
|
|
15
|
+
});
|
|
16
|
+
if (existing?.status === "in_progress" &&
|
|
17
|
+
existing.lastJobRunId === opts.jobRunId) {
|
|
18
|
+
return { ok: true, action: "no_op", jobTypeId, recordRef: ref };
|
|
19
|
+
}
|
|
20
|
+
const startedAt = new Date().toISOString();
|
|
21
|
+
const entry = {
|
|
22
|
+
status: "in_progress",
|
|
23
|
+
startedAt,
|
|
24
|
+
lastJobRunId: opts.jobRunId,
|
|
25
|
+
attempts: opts.attempts,
|
|
26
|
+
...(opts.graphVersion !== undefined ? { graphVersion: opts.graphVersion } : {}),
|
|
27
|
+
};
|
|
28
|
+
const stamp = await ctx.adapter.patch(ctx.resolved.collection, ctx.resolved.filter, {
|
|
29
|
+
[jobTypeRunDotPath(jobTypeId)]: entry,
|
|
30
|
+
});
|
|
31
|
+
if (stamp.matchedCount === 0) {
|
|
32
|
+
throw new MemorixWriterError("RECORD_NOT_FOUND", `Source record disappeared while stamping _jobTypeRuns for ${ctx.resolved.collection}`);
|
|
33
|
+
}
|
|
34
|
+
return { ok: true, action: "stamped", jobTypeId, recordRef: ref };
|
|
35
|
+
}
|
|
36
|
+
//# sourceMappingURL=mark-started.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"mark-started.js","sourceRoot":"","sources":["../../src/job-type-runs/mark-started.ts"],"names":[],"mappings":"AAEA,OAAO,EAAE,kBAAkB,EAAE,MAAM,qBAAqB,CAAC;AACzD,OAAO,EACL,2BAA2B,EAC3B,gBAAgB,GACjB,MAAM,0BAA0B,CAAC;AAClC,OAAO,EAAE,iBAAiB,EAAE,MAAM,gBAAgB,CAAC;AACnD,OAAO,EAAE,mBAAmB,EAAE,MAAM,cAAc,CAAC;AACnD,OAAO,EAAE,oBAAoB,EAAE,MAAM,cAAc,CAAC;AAepD,MAAM,CAAC,KAAK,UAAU,qBAAqB,CACzC,MAA2B,EAC3B,GAAqB,EACrB,SAAiB,EACjB,IAAkC;IAElC,MAAM,GAAG,GAAG,MAAM,2BAA2B,CAAC,MAAM,EAAE,GAAG,CAAC,CAAC;IAC3D,MAAM,GAAG,GAAG,MAAM,gBAAgB,CAAC,GAAG,CAAC,CAAC;IACxC,MAAM,QAAQ,GAAG,mBAAmB,CAAC,GAAG,EAAE,SAAS,CAAC,CAAC;IAErD,oBAAoB,CAAC;QACnB,QAAQ,EAAE,IAAI,CAAC,QAAQ;QACvB,SAAS;QACT,SAAS,EAAE,GAAG;QACd,SAAS,EAAE,uBAAuB;KACnC,CAAC,CAAC;IAEH,IACE,QAAQ,EAAE,MAAM,KAAK,aAAa;QAClC,QAAQ,CAAC,YAAY,KAAK,IAAI,CAAC,QAAQ,EACvC,CAAC;QACD,OAAO,EAAE,EAAE,EAAE,IAAI,EAAE,MAAM,EAAE,OAAO,EAAE,SAAS,EAAE,SAAS,EAAE,GAAG,EAAE,CAAC;IAClE,CAAC;IAED,MAAM,SAAS,GAAG,IAAI,IAAI,EAAE,CAAC,WAAW,EAAE,CAAC;IAC3C,MAAM,KAAK,GAAG;QACZ,MAAM,EAAE,aAAsB;QAC9B,SAAS;QACT,YAAY,EAAE,IAAI,CAAC,QAAQ;QAC3B,QAAQ,EAAE,IAAI,CAAC,QAAQ;QACvB,GAAG,CAAC,IAAI,CAAC,YAAY,KAAK,SAAS,CAAC,CAAC,CAAC,EAAE,YAAY,EAAE,IAAI,CAAC,YAAY,EAAE,CAAC,CAAC,CAAC,EAAE,CAAC;KAChF,CAAC;IAEF,MAAM,KAAK,GAAG,MAAM,GAAG,CAAC,OAAO,CAAC,KAAK,CAAC,GAAG,CAAC,QAAQ,CAAC,UAAU,EAAE,GAAG,CAAC,QAAQ,CAAC,MAAM,EAAE;QAClF,CAAC,iBAAiB,CAAC,SAAS,CAAC,CAAC,EAAE,KAAK;KACtC,CAAC,CAAC;IACH,IAAI,KAAK,CAAC,YAAY,KAAK,CAAC,EAAE,CAAC;QAC7B,MAAM,IAAI,kBAAkB,CAC1B,kBAAkB,EAClB,6DAA6D,GAAG,CAAC,QAAQ,CAAC,UAAU,EAAE,CACvF,CAAC;IACJ,CAAC;IAED,OAAO,EAAE,EAAE,EAAE,IAAI,EAAE,MAAM,EAAE,SAAS,EAAE,SAAS,EAAE,SAAS,EAAE,GAAG,EAAE,CAAC;AACpE,CAAC"}
|
|
@@ -17,7 +17,7 @@ export function validateInputFields(args) {
|
|
|
17
17
|
}
|
|
18
18
|
if (rejectUnknown) {
|
|
19
19
|
for (const key of Object.keys(input)) {
|
|
20
|
-
if (key === "_graphRuns") {
|
|
20
|
+
if (key === "_graphRuns" || key === "_jobTypeRuns") {
|
|
21
21
|
issues.push(writeIssue("SYSTEM_FIELD_NOT_WRITABLE", `system field "${key}" cannot be written via writeMemorixRecord`, { path: key, severity: "error" }));
|
|
22
22
|
continue;
|
|
23
23
|
}
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"validate-fields.js","sourceRoot":"","sources":["../../src/validation/validate-fields.ts"],"names":[],"mappings":"AAEA,OAAO,EAAE,UAAU,EAAE,MAAM,qBAAqB,CAAC;AACjD,OAAO,EAAE,gBAAgB,EAAE,MAAM,yCAAyC,CAAC;AAE3E,MAAM,UAAU,mBAAmB,CAAC,IAInC;IACC,MAAM,MAAM,GAAwB,EAAE,CAAC;IACvC,MAAM,EAAE,eAAe,EAAE,KAAK,EAAE,iBAAiB,GAAG,EAAE,EAAE,GAAG,IAAI,CAAC;IAChE,MAAM,aAAa,GAAG,eAAe,CAAC,UAAU,EAAE,mBAAmB,IAAI,IAAI,CAAC;IAC9E,MAAM,YAAY,GAAG,MAAM,CAAC,OAAO,CAAC,eAAe,CAAC,MAAM,CAAC,CAAC;IAE5D,MAAM,iBAAiB,GAAG,IAAI,GAAG,EAAU,CAAC;IAC5C,KAAK,MAAM,CAAC,IAAI,EAAE,KAAK,CAAC,IAAI,YAAY,EAAE,CAAC;QACzC,IAAI,KAAK,CAAC,QAAQ,KAAK,KAAK;YAAE,SAAS;QACvC,iBAAiB,CAAC,GAAG,CAAC,gBAAgB,CAAC,IAAI,EAAE,KAAK,CAAC,CAAC,CAAC;QACrD,iBAAiB,CAAC,GAAG,CAAC,IAAI,CAAC,CAAC;IAC9B,CAAC;IACD,KAAK,MAAM,EAAE,IAAI,iBAAiB,EAAE,CAAC;QACnC,iBAAiB,CAAC,GAAG,CAAC,EAAE,CAAC,CAAC;IAC5B,CAAC;IAED,IAAI,aAAa,EAAE,CAAC;QAClB,KAAK,MAAM,GAAG,IAAI,MAAM,CAAC,IAAI,CAAC,KAAK,CAAC,EAAE,CAAC;YACrC,IAAI,GAAG,KAAK,YAAY,EAAE,CAAC;
|
|
1
|
+
{"version":3,"file":"validate-fields.js","sourceRoot":"","sources":["../../src/validation/validate-fields.ts"],"names":[],"mappings":"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"}
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"validate-immutability.d.ts","sourceRoot":"","sources":["../../src/validation/validate-immutability.ts"],"names":[],"mappings":"AAAA,OAAO,KAAK,EAAE,2BAA2B,EAAE,MAAM,0CAA0C,CAAC;AAC5F,OAAO,KAAK,EAAE,iBAAiB,EAAE,MAAM,qBAAqB,CAAC;
|
|
1
|
+
{"version":3,"file":"validate-immutability.d.ts","sourceRoot":"","sources":["../../src/validation/validate-immutability.ts"],"names":[],"mappings":"AAAA,OAAO,KAAK,EAAE,2BAA2B,EAAE,MAAM,0CAA0C,CAAC;AAC5F,OAAO,KAAK,EAAE,iBAAiB,EAAE,MAAM,qBAAqB,CAAC;AAc7D,wBAAgB,8BAA8B,CAAC,IAAI,EAAE;IACnD,QAAQ,EAAE,MAAM,CAAC,MAAM,EAAE,OAAO,CAAC,CAAC;IAClC,MAAM,EAAE,MAAM,CAAC,MAAM,EAAE,2BAA2B,CAAC,CAAC;IACpD,KAAK,EAAE,MAAM,CAAC,MAAM,EAAE,OAAO,CAAC,CAAC;IAC/B,iBAAiB,EAAE,CAAC,IAAI,EAAE,MAAM,EAAE,KAAK,EAAE,2BAA2B,KAAK,MAAM,CAAC;CACjF,GAAG,iBAAiB,EAAE,CA0BtB"}
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"validate-immutability.js","sourceRoot":"","sources":["../../src/validation/validate-immutability.ts"],"names":[],"mappings":"AAEA,OAAO,EAAE,UAAU,EAAE,MAAM,qBAAqB,CAAC;AACjD,OAAO,EAAE,OAAO,EAAE,MAAM,kBAAkB,CAAC;AAE3C,MAAM,eAAe,GAAG,IAAI,GAAG,CAAC;IAC9B,UAAU;IACV,SAAS;IACT,UAAU;IACV,WAAW;IACX,YAAY;IACZ,4BAA4B;CAC7B,CAAC,CAAC;AAEH,MAAM,UAAU,8BAA8B,CAAC,IAK9C;IACC,MAAM,MAAM,GAAwB,EAAE,CAAC;IACvC,KAAK,MAAM,CAAC,IAAI,EAAE,KAAK,CAAC,IAAI,MAAM,CAAC,OAAO,CAAC,IAAI,CAAC,MAAM,CAAC,EAAE,CAAC;QACxD,IAAI,CAAC,KAAK,CAAC,SAAS;YAAE,SAAS;QAC/B,MAAM,SAAS,GAAG,IAAI,CAAC,iBAAiB,CAAC,IAAI,EAAE,KAAK,CAAC,CAAC;QACtD,IAAI,CAAC,CAAC,SAAS,IAAI,IAAI,CAAC,KAAK,CAAC,IAAI,CAAC,CAAC,IAAI,IAAI,IAAI,CAAC,KAAK,CAAC;YAAE,SAAS;QAClE,MAAM,WAAW,GAAG,OAAO,CAAC,IAAI,CAAC,QAAQ,EAAE,KAAK,CAAC,MAAM,CAAC,IAAI,CAAC,CAAC;QAC9D,MAAM,MAAM,GAAG,IAAI,CAAC,KAAK,CAAC,SAAS,CAAC,IAAI,IAAI,CAAC,KAAK,CAAC,IAAI,CAAC,CAAC;QACzD,IAAI,MAAM,KAAK,SAAS,IAAI,MAAM,KAAK,WAAW,EAAE,CAAC;YACnD,MAAM,CAAC,IAAI,CACT,UAAU,CAAC,wBAAwB,EAAE,UAAU,IAAI,gBAAgB,EAAE;gBACnE,IAAI,EAAE,KAAK,CAAC,MAAM,CAAC,IAAI;aACxB,CAAC,CACH,CAAC;QACJ,CAAC;IACH,CAAC;IACD,KAAK,MAAM,IAAI,IAAI,eAAe,EAAE,CAAC;QACnC,IAAI,IAAI,IAAI,IAAI,CAAC,KAAK,EAAE,CAAC;YACvB,MAAM,CAAC,IAAI,CACT,UAAU,CAAC,wBAAwB,EAAE,iBAAiB,IAAI,qBAAqB,EAAE;gBAC/E,IAAI;aACL,CAAC,CACH,CAAC;QACJ,CAAC;IACH,CAAC;IACD,OAAO,MAAM,CAAC;AAChB,CAAC"}
|
|
1
|
+
{"version":3,"file":"validate-immutability.js","sourceRoot":"","sources":["../../src/validation/validate-immutability.ts"],"names":[],"mappings":"AAEA,OAAO,EAAE,UAAU,EAAE,MAAM,qBAAqB,CAAC;AACjD,OAAO,EAAE,OAAO,EAAE,MAAM,kBAAkB,CAAC;AAE3C,MAAM,eAAe,GAAG,IAAI,GAAG,CAAC;IAC9B,UAAU;IACV,SAAS;IACT,UAAU;IACV,WAAW;IACX,YAAY;IACZ,cAAc;IACd,4BAA4B;CAC7B,CAAC,CAAC;AAEH,MAAM,UAAU,8BAA8B,CAAC,IAK9C;IACC,MAAM,MAAM,GAAwB,EAAE,CAAC;IACvC,KAAK,MAAM,CAAC,IAAI,EAAE,KAAK,CAAC,IAAI,MAAM,CAAC,OAAO,CAAC,IAAI,CAAC,MAAM,CAAC,EAAE,CAAC;QACxD,IAAI,CAAC,KAAK,CAAC,SAAS;YAAE,SAAS;QAC/B,MAAM,SAAS,GAAG,IAAI,CAAC,iBAAiB,CAAC,IAAI,EAAE,KAAK,CAAC,CAAC;QACtD,IAAI,CAAC,CAAC,SAAS,IAAI,IAAI,CAAC,KAAK,CAAC,IAAI,CAAC,CAAC,IAAI,IAAI,IAAI,CAAC,KAAK,CAAC;YAAE,SAAS;QAClE,MAAM,WAAW,GAAG,OAAO,CAAC,IAAI,CAAC,QAAQ,EAAE,KAAK,CAAC,MAAM,CAAC,IAAI,CAAC,CAAC;QAC9D,MAAM,MAAM,GAAG,IAAI,CAAC,KAAK,CAAC,SAAS,CAAC,IAAI,IAAI,CAAC,KAAK,CAAC,IAAI,CAAC,CAAC;QACzD,IAAI,MAAM,KAAK,SAAS,IAAI,MAAM,KAAK,WAAW,EAAE,CAAC;YACnD,MAAM,CAAC,IAAI,CACT,UAAU,CAAC,wBAAwB,EAAE,UAAU,IAAI,gBAAgB,EAAE;gBACnE,IAAI,EAAE,KAAK,CAAC,MAAM,CAAC,IAAI;aACxB,CAAC,CACH,CAAC;QACJ,CAAC;IACH,CAAC;IACD,KAAK,MAAM,IAAI,IAAI,eAAe,EAAE,CAAC;QACnC,IAAI,IAAI,IAAI,IAAI,CAAC,KAAK,EAAE,CAAC;YACvB,MAAM,CAAC,IAAI,CACT,UAAU,CAAC,wBAAwB,EAAE,iBAAiB,IAAI,qBAAqB,EAAE;gBAC/E,IAAI;aACL,CAAC,CACH,CAAC;QACJ,CAAC;IACH,CAAC;IACD,OAAO,MAAM,CAAC;AAChB,CAAC"}
|
|
@@ -0,0 +1,79 @@
|
|
|
1
|
+
# Job-type run tracking (`_jobTypeRuns`) — MRX-CR-003
|
|
2
|
+
|
|
3
|
+
Record-level visibility for job-type identity over Memorix entity and event records. Multiple graphs can share one `jobTypeId`; eligibility and reprocessing prefer `_jobTypeRuns[jobTypeId]` over `_graphRuns[graphId]`.
|
|
4
|
+
|
|
5
|
+
## Overview
|
|
6
|
+
|
|
7
|
+
The reserved system field `_jobTypeRuns` is stored **top-level on the Mongo payload document**, parallel to `_graphRuns`. It is keyed by sanitized `jobTypeId` (`.` → `_`) and reuses the `GraphRunEntry` shape.
|
|
8
|
+
|
|
9
|
+
Domain `writeMemorixRecord` operations **must not** accept `_jobTypeRuns` in user input.
|
|
10
|
+
|
|
11
|
+
Shared types and helpers live in `@x12i/memorix-descriptors/types`:
|
|
12
|
+
|
|
13
|
+
- `JobTypeRunsField`, `GraphRunEntry`
|
|
14
|
+
- `jobTypeRunFieldKey(jobTypeId)`, `jobTypeRunDotPath(jobTypeId)`
|
|
15
|
+
|
|
16
|
+
## Writer APIs (`@x12i/memorix-writer`)
|
|
17
|
+
|
|
18
|
+
```typescript
|
|
19
|
+
import {
|
|
20
|
+
markJobTypeRunStarted,
|
|
21
|
+
markJobTypeRunCompleted,
|
|
22
|
+
markJobTypeRunFailed,
|
|
23
|
+
ensureJobTypeRunIndexes,
|
|
24
|
+
writeGraphRunResult,
|
|
25
|
+
} from "@x12i/memorix-writer";
|
|
26
|
+
```
|
|
27
|
+
|
|
28
|
+
### `markJobTypeRunStarted(ref, jobTypeId, opts)`
|
|
29
|
+
|
|
30
|
+
Sets `_jobTypeRuns.<key>` to `{ status: "in_progress", ... }`. Idempotent when already `in_progress` with the same `lastJobRunId`.
|
|
31
|
+
|
|
32
|
+
### `markJobTypeRunCompleted(ref, jobTypeId, opts)`
|
|
33
|
+
|
|
34
|
+
Sets `status: "done"` with optional `result` pointer. Use when completion does not go through `writeGraphRunResult`.
|
|
35
|
+
|
|
36
|
+
### `markJobTypeRunFailed(ref, jobTypeId, opts)`
|
|
37
|
+
|
|
38
|
+
Sets terminal `failed` status with `error` and `completedAt`.
|
|
39
|
+
|
|
40
|
+
### `writeGraphRunResult(ref, graphId, { ..., jobTypeId? })`
|
|
41
|
+
|
|
42
|
+
When `jobTypeId` is provided, stamps both `_graphRuns.<graphId>` and `_jobTypeRuns.<key>` in the same Mongo transaction.
|
|
43
|
+
|
|
44
|
+
### `ensureJobTypeRunIndexes(client, ref, jobTypeId)`
|
|
45
|
+
|
|
46
|
+
Opt-in compound indexes for reprocessing filters:
|
|
47
|
+
|
|
48
|
+
- `{ "_jobTypeRuns.<key>.status": 1, <idField>: 1 }`
|
|
49
|
+
- `{ "_jobTypeRuns.<key>.completedAt": -1 }`
|
|
50
|
+
- `{ "_jobTypeRuns.<key>.status": 1, "_jobTypeRuns.<key>.completedAt": -1 }` (reprocessing)
|
|
51
|
+
|
|
52
|
+
## Read helper (`@x12i/memorix-mongo`)
|
|
53
|
+
|
|
54
|
+
```typescript
|
|
55
|
+
import { getJobTypeRun } from "@x12i/memorix-mongo";
|
|
56
|
+
|
|
57
|
+
const entry = await getJobTypeRun(retrieval, "assets", recordId, jobTypeId, "core");
|
|
58
|
+
```
|
|
59
|
+
|
|
60
|
+
## Indexes and performance
|
|
61
|
+
|
|
62
|
+
Baseline sparse index (created by `ensureCoreCollection` / `initializeEntityCollections`):
|
|
63
|
+
|
|
64
|
+
```javascript
|
|
65
|
+
db.<canonicalCollection>.createIndex({ _jobTypeRuns: 1 }, { sparse: true, name: "idx_jobTypeRuns" });
|
|
66
|
+
```
|
|
67
|
+
|
|
68
|
+
Per-jobType compound indexes remain opt-in via `ensureJobTypeRunIndexes`.
|
|
69
|
+
|
|
70
|
+
## Error codes
|
|
71
|
+
|
|
72
|
+
Same semantics as `_graphRuns`: `RECORD_NOT_FOUND`, `SYSTEM_FIELD_NOT_WRITABLE`, etc.
|
|
73
|
+
|
|
74
|
+
Log correlation shape: `{ jobRunId, jobTypeId, recordRef, operation }`.
|
|
75
|
+
|
|
76
|
+
## References
|
|
77
|
+
|
|
78
|
+
- MRX-CR-003 change request
|
|
79
|
+
- [GRAPH-RUNS.md](./GRAPH-RUNS.md) — parallel `_graphRuns` contract (MRX-FRS-001)
|
package/package.json
CHANGED
|
@@ -1,6 +1,6 @@
|
|
|
1
1
|
{
|
|
2
2
|
"name": "@x12i/memorix-writer",
|
|
3
|
-
"version": "1.
|
|
3
|
+
"version": "1.4.0",
|
|
4
4
|
"description": "Descriptor-driven write layer for Memorix entity/event records and content objects",
|
|
5
5
|
"type": "module",
|
|
6
6
|
"main": "./dist/index.js",
|
|
@@ -26,9 +26,10 @@
|
|
|
26
26
|
"node": ">=18.0.0"
|
|
27
27
|
},
|
|
28
28
|
"dependencies": {
|
|
29
|
-
"@x12i/catalox": "^5.
|
|
30
|
-
"@x12i/memorix-descriptors": "
|
|
31
|
-
"@x12i/memorix-
|
|
29
|
+
"@x12i/catalox": "^5.9.8",
|
|
30
|
+
"@x12i/memorix-descriptors": "file:../memorix-descriptors",
|
|
31
|
+
"@x12i/memorix-mongo": "file:../memorix-mongo",
|
|
32
|
+
"@x12i/memorix-retrieval": "file:../memorix-retrieval",
|
|
32
33
|
"mongodb": "^6.21.0"
|
|
33
34
|
},
|
|
34
35
|
"devDependencies": {
|
|
@@ -44,5 +45,10 @@
|
|
|
44
45
|
},
|
|
45
46
|
"publishConfig": {
|
|
46
47
|
"access": "public"
|
|
48
|
+
},
|
|
49
|
+
"repository": {
|
|
50
|
+
"type": "git",
|
|
51
|
+
"url": "git+ssh://git@github.com/x12i/memorix-mono-repo.git",
|
|
52
|
+
"directory": "memorix-writer"
|
|
47
53
|
}
|
|
48
54
|
}
|