@docmana/sdk 0.2.2 → 0.3.1
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/CHANGELOG.md +19 -8
- package/dist/cli.mjs +368 -64
- package/dist/cli.mjs.map +1 -1
- package/dist/index.d.cts +237 -12
- package/dist/index.d.ts +237 -12
- package/dist/index.js +165 -10
- package/dist/index.js.map +1 -1
- package/dist/index.mjs +165 -10
- package/dist/index.mjs.map +1 -1
- package/package.json +1 -1
package/dist/index.d.ts
CHANGED
|
@@ -1,3 +1,59 @@
|
|
|
1
|
+
interface DocmanaDocumentMapping {
|
|
2
|
+
name: string;
|
|
3
|
+
reference: string;
|
|
4
|
+
}
|
|
5
|
+
|
|
6
|
+
interface DocmanaNodeResult {
|
|
7
|
+
status: string;
|
|
8
|
+
errors?: string[];
|
|
9
|
+
data?: Record<string, unknown>;
|
|
10
|
+
}
|
|
11
|
+
|
|
12
|
+
interface DocmanaScoreNodeResult extends DocmanaNodeResult {
|
|
13
|
+
score?: number;
|
|
14
|
+
feedback?: string;
|
|
15
|
+
}
|
|
16
|
+
|
|
17
|
+
interface DocmanaClassificationResult extends DocmanaScoreNodeResult {
|
|
18
|
+
}
|
|
19
|
+
|
|
20
|
+
interface DocmanaMetadataExtractionResult extends DocmanaNodeResult {
|
|
21
|
+
}
|
|
22
|
+
|
|
23
|
+
interface DocmanaExtractionResult extends DocmanaNodeResult {
|
|
24
|
+
}
|
|
25
|
+
|
|
26
|
+
interface DocmanaValidationResult extends DocmanaScoreNodeResult {
|
|
27
|
+
}
|
|
28
|
+
|
|
29
|
+
interface DocmanaDocumentResult {
|
|
30
|
+
status: string;
|
|
31
|
+
classifications?: Record<string, DocmanaClassificationResult>;
|
|
32
|
+
metadataExtraction?: DocmanaMetadataExtractionResult;
|
|
33
|
+
extractions?: Record<string, DocmanaExtractionResult>;
|
|
34
|
+
validations?: Record<string, DocmanaValidationResult>;
|
|
35
|
+
}
|
|
36
|
+
|
|
37
|
+
interface DocmanaCrossValidationResult extends DocmanaScoreNodeResult {
|
|
38
|
+
}
|
|
39
|
+
|
|
40
|
+
interface DocmanaConclusionResult extends DocmanaScoreNodeResult {
|
|
41
|
+
}
|
|
42
|
+
|
|
43
|
+
interface DocmanaExecutionResult {
|
|
44
|
+
status: string;
|
|
45
|
+
executionId: string;
|
|
46
|
+
errors?: string[];
|
|
47
|
+
documents: {
|
|
48
|
+
mappings: DocmanaDocumentMapping[];
|
|
49
|
+
[docKey: string]: DocmanaDocumentResult | DocmanaDocumentMapping[];
|
|
50
|
+
};
|
|
51
|
+
crossValidations?: Record<string, DocmanaCrossValidationResult>;
|
|
52
|
+
conclusions?: Record<string, DocmanaConclusionResult>;
|
|
53
|
+
}
|
|
54
|
+
|
|
55
|
+
type ExecutionStatus = "Pending" | "Running" | "Incompleted" | "Completed" | "Failed";
|
|
56
|
+
|
|
1
57
|
interface DocmanaConfig {
|
|
2
58
|
clientId: string;
|
|
3
59
|
clientSecret: string;
|
|
@@ -34,14 +90,7 @@ interface RunFlowInput {
|
|
|
34
90
|
timeoutMs?: number;
|
|
35
91
|
pollIntervalMs?: number;
|
|
36
92
|
once?: boolean;
|
|
37
|
-
|
|
38
|
-
type ExecutionStatus = "Pending" | "Running" | "Incompleted" | "Completed" | "Failed";
|
|
39
|
-
interface ExecutionResult {
|
|
40
|
-
status: ExecutionStatus | string;
|
|
41
|
-
execution_id?: string;
|
|
42
|
-
results?: unknown[];
|
|
43
|
-
errors?: unknown[];
|
|
44
|
-
[key: string]: unknown;
|
|
93
|
+
language?: string;
|
|
45
94
|
}
|
|
46
95
|
|
|
47
96
|
declare class Docmana {
|
|
@@ -55,8 +104,8 @@ declare class Docmana {
|
|
|
55
104
|
getStatus(executionResultId: string, signal?: AbortSignal): Promise<{
|
|
56
105
|
status: ExecutionStatus | string;
|
|
57
106
|
}>;
|
|
58
|
-
getResult(executionResultId: string, signal?: AbortSignal): Promise<
|
|
59
|
-
runFlow(flowId: string, input: RunFlowInput): Promise<
|
|
107
|
+
getResult(executionResultId: string, signal?: AbortSignal, language?: string): Promise<DocmanaExecutionResult>;
|
|
108
|
+
runFlow(flowId: string, input: RunFlowInput): Promise<DocmanaExecutionResult>;
|
|
60
109
|
}
|
|
61
110
|
|
|
62
111
|
declare class DocmanaError extends Error {
|
|
@@ -95,7 +144,8 @@ declare class DocmanaRequestError extends DocmanaError {
|
|
|
95
144
|
}
|
|
96
145
|
declare class DocmanaExecutionError extends DocmanaError {
|
|
97
146
|
readonly errors: unknown[];
|
|
98
|
-
|
|
147
|
+
readonly result?: DocmanaExecutionResult;
|
|
148
|
+
constructor(message: string, errors?: unknown[], result?: DocmanaExecutionResult);
|
|
99
149
|
}
|
|
100
150
|
declare class DocmanaTimeoutError extends DocmanaError {
|
|
101
151
|
constructor(message: string);
|
|
@@ -104,4 +154,179 @@ declare class DocmanaAbortError extends DocmanaError {
|
|
|
104
154
|
constructor(message: string);
|
|
105
155
|
}
|
|
106
156
|
|
|
107
|
-
|
|
157
|
+
interface PhysicalDocument {
|
|
158
|
+
physical_document_name: string;
|
|
159
|
+
physical_document_id: string;
|
|
160
|
+
physical_document_path?: string;
|
|
161
|
+
page_from: number;
|
|
162
|
+
page_to: number;
|
|
163
|
+
physical_document_url?: string;
|
|
164
|
+
metadata?: Record<string, unknown>;
|
|
165
|
+
}
|
|
166
|
+
|
|
167
|
+
interface DocumentContent {
|
|
168
|
+
coordinates_unit?: string;
|
|
169
|
+
pages?: Array<Array<Record<string, unknown>>>;
|
|
170
|
+
}
|
|
171
|
+
|
|
172
|
+
interface VirtualDocument {
|
|
173
|
+
source: PhysicalDocument;
|
|
174
|
+
virtual_document_name: string;
|
|
175
|
+
virtual_document_id: string;
|
|
176
|
+
is_translated: boolean;
|
|
177
|
+
document_types?: string[];
|
|
178
|
+
content?: DocumentContent;
|
|
179
|
+
}
|
|
180
|
+
|
|
181
|
+
type FlowNodeType = "Start" | "Finish" | "DataMapping" | "Classification" | "Extraction" | "Validation" | "CrossValidation" | "MetadataExtraction";
|
|
182
|
+
|
|
183
|
+
interface FlowConfigs {
|
|
184
|
+
description?: string | null;
|
|
185
|
+
useIntelligentSplitting: boolean;
|
|
186
|
+
useSplittingAsContextOnly: boolean;
|
|
187
|
+
useDetectAndClassifyPII: boolean;
|
|
188
|
+
enableChatFeature: boolean;
|
|
189
|
+
defaultLanguage?: string | null;
|
|
190
|
+
additionalLanguages?: string[] | null;
|
|
191
|
+
enableDocumentPersistenceForViewing: boolean;
|
|
192
|
+
preClassificationAggregatorPrompt?: string | null;
|
|
193
|
+
preClassificationSummarizerPrompt?: string | null;
|
|
194
|
+
enforceSingleClassificationPerDocument?: boolean | null;
|
|
195
|
+
useFraudDetection: boolean;
|
|
196
|
+
fraudDetectionThreshold: number;
|
|
197
|
+
useMetadataExtraction: boolean;
|
|
198
|
+
}
|
|
199
|
+
|
|
200
|
+
interface FlowNodePromptMessage {
|
|
201
|
+
role: string;
|
|
202
|
+
content: string;
|
|
203
|
+
type?: string | null;
|
|
204
|
+
}
|
|
205
|
+
interface FlowNodePromptOutputStructure {
|
|
206
|
+
output_structure: Record<string, {
|
|
207
|
+
type: string;
|
|
208
|
+
description?: string | null;
|
|
209
|
+
items?: Record<string, unknown> | null;
|
|
210
|
+
properties?: Record<string, unknown> | null;
|
|
211
|
+
context?: string | null;
|
|
212
|
+
}>;
|
|
213
|
+
}
|
|
214
|
+
interface FlowNode {
|
|
215
|
+
node_id: string;
|
|
216
|
+
label: string;
|
|
217
|
+
unique_name?: string | null;
|
|
218
|
+
type: FlowNodeType;
|
|
219
|
+
has_single_document_type: boolean;
|
|
220
|
+
prompt_id?: string | null;
|
|
221
|
+
commit?: string | null;
|
|
222
|
+
target_language?: string | null;
|
|
223
|
+
mock_results?: Record<string, unknown> | null;
|
|
224
|
+
enabled?: boolean;
|
|
225
|
+
model?: string | null;
|
|
226
|
+
classification_priority?: number;
|
|
227
|
+
prompt_messages?: {
|
|
228
|
+
messages: FlowNodePromptMessage[];
|
|
229
|
+
} | null;
|
|
230
|
+
prompt_output_structure?: FlowNodePromptOutputStructure | null;
|
|
231
|
+
}
|
|
232
|
+
|
|
233
|
+
interface FlowEdge {
|
|
234
|
+
source: string;
|
|
235
|
+
target: string;
|
|
236
|
+
}
|
|
237
|
+
|
|
238
|
+
interface Flow {
|
|
239
|
+
flow_id: string;
|
|
240
|
+
name: string;
|
|
241
|
+
version: number;
|
|
242
|
+
configs: FlowConfigs;
|
|
243
|
+
nodes: FlowNode[];
|
|
244
|
+
edges: FlowEdge[];
|
|
245
|
+
}
|
|
246
|
+
|
|
247
|
+
interface NodeTranslationResult {
|
|
248
|
+
status?: string;
|
|
249
|
+
running_time?: number | null;
|
|
250
|
+
feedback?: string | null;
|
|
251
|
+
score?: number | null;
|
|
252
|
+
[key: string]: unknown;
|
|
253
|
+
}
|
|
254
|
+
|
|
255
|
+
interface ExecutionProgress {
|
|
256
|
+
status: string;
|
|
257
|
+
errors?: string[];
|
|
258
|
+
}
|
|
259
|
+
|
|
260
|
+
interface DocmanaApiDocumentRequest {
|
|
261
|
+
name: string;
|
|
262
|
+
file_extension: string;
|
|
263
|
+
sas_url: string;
|
|
264
|
+
blob_name: string;
|
|
265
|
+
uuid_file: string;
|
|
266
|
+
physical_document_id?: string | null;
|
|
267
|
+
doc_key: string | null;
|
|
268
|
+
status?: string | null;
|
|
269
|
+
error_message?: string | null;
|
|
270
|
+
message?: string | null;
|
|
271
|
+
message_code?: string | null;
|
|
272
|
+
metadata?: Record<string, unknown> | null;
|
|
273
|
+
is_temporary_upload?: boolean;
|
|
274
|
+
}
|
|
275
|
+
|
|
276
|
+
interface DocmanaApiNodeResult {
|
|
277
|
+
node_id?: string;
|
|
278
|
+
node_name?: string | null;
|
|
279
|
+
node_type?: string | null;
|
|
280
|
+
feature_name?: string | null;
|
|
281
|
+
running_time?: number | null;
|
|
282
|
+
status?: string;
|
|
283
|
+
score?: number | null;
|
|
284
|
+
feedback?: string | null;
|
|
285
|
+
translations?: Record<string, NodeTranslationResult> | null;
|
|
286
|
+
tokens?: number | null;
|
|
287
|
+
input_tokens?: number | null;
|
|
288
|
+
output_tokens?: number | null;
|
|
289
|
+
errors?: string[];
|
|
290
|
+
mana?: number | null;
|
|
291
|
+
model?: string | null;
|
|
292
|
+
tool_calls?: Record<string, unknown>[] | null;
|
|
293
|
+
prompt_id?: string | null;
|
|
294
|
+
prompt?: string | null;
|
|
295
|
+
prompt_name?: string | null;
|
|
296
|
+
label?: string | null;
|
|
297
|
+
scoreDescription?: string | null;
|
|
298
|
+
score_description?: string | null;
|
|
299
|
+
result?: unknown;
|
|
300
|
+
documentType?: string | null;
|
|
301
|
+
[key: string]: unknown;
|
|
302
|
+
}
|
|
303
|
+
|
|
304
|
+
interface DocmanaApiDocumentExecutionResult {
|
|
305
|
+
document?: DocmanaApiDocumentRequest;
|
|
306
|
+
node_results?: DocmanaApiNodeResult[];
|
|
307
|
+
status?: string;
|
|
308
|
+
error?: string | null;
|
|
309
|
+
[key: string]: unknown;
|
|
310
|
+
}
|
|
311
|
+
|
|
312
|
+
interface DocmanaApiExecutionResult {
|
|
313
|
+
status: ExecutionStatus | string;
|
|
314
|
+
error?: string;
|
|
315
|
+
errors?: string[];
|
|
316
|
+
document_requests?: DocmanaApiDocumentRequest[];
|
|
317
|
+
flow?: Flow | null;
|
|
318
|
+
results?: DocmanaApiDocumentExecutionResult[];
|
|
319
|
+
restructured_documents?: VirtualDocument[];
|
|
320
|
+
execution_id?: string;
|
|
321
|
+
total_running_time?: number;
|
|
322
|
+
total_running_time_node?: number;
|
|
323
|
+
total_tokens?: number;
|
|
324
|
+
total_input_tokens?: number;
|
|
325
|
+
total_output_tokens?: number;
|
|
326
|
+
total_documents?: number;
|
|
327
|
+
total_pages?: number;
|
|
328
|
+
event_timestamp?: string;
|
|
329
|
+
[key: string]: unknown;
|
|
330
|
+
}
|
|
331
|
+
|
|
332
|
+
export { Docmana, DocmanaAbortError, type DocmanaApiDocumentExecutionResult, type DocmanaApiDocumentRequest, type DocmanaApiExecutionResult, type DocmanaApiNodeResult, DocmanaAuthError, type DocmanaClassificationResult, type DocmanaConclusionResult, type DocmanaConfig, type DocmanaCrossValidationResult, type DocmanaDocumentMapping, type DocmanaDocumentResult, DocmanaError, DocmanaExecutionError, type DocmanaExecutionResult, type DocmanaExtractionResult, type DocmanaMetadataExtractionResult, type DocmanaNodeResult, DocmanaNotFoundError, DocmanaPermissionError, DocmanaRequestError, type DocmanaScoreNodeResult, DocmanaTimeoutError, type DocmanaValidationResult, type DocumentContent, type ExecutionProgress, type ExecutionStatus, type FileInput, type Flow, type FlowConfigs, type FlowEdge, type FlowNode, type FlowNodeType, type NodeTranslationResult, type PhysicalDocument, type RunFlowInput, type VirtualDocument };
|
package/dist/index.js
CHANGED
|
@@ -94,9 +94,11 @@ var DocmanaRequestError = class extends DocmanaError {
|
|
|
94
94
|
};
|
|
95
95
|
var DocmanaExecutionError = class extends DocmanaError {
|
|
96
96
|
errors;
|
|
97
|
-
|
|
97
|
+
result;
|
|
98
|
+
constructor(message, errors = [], result) {
|
|
98
99
|
super(message, { code: "execution_failed" });
|
|
99
100
|
this.errors = errors;
|
|
101
|
+
this.result = result;
|
|
100
102
|
}
|
|
101
103
|
};
|
|
102
104
|
var DocmanaTimeoutError = class extends DocmanaError {
|
|
@@ -330,14 +332,12 @@ async function resolveInputs(input) {
|
|
|
330
332
|
|
|
331
333
|
// src/api/upload.ts
|
|
332
334
|
async function uploadFiles(http, parts, signal) {
|
|
333
|
-
const
|
|
335
|
+
const form = new FormData();
|
|
334
336
|
for (const part of parts) {
|
|
335
|
-
const form = new FormData();
|
|
336
337
|
form.append("files", new File([part.data], part.filename, { type: part.contentType }));
|
|
337
|
-
const res = await http.requestJson("POST", "/upload", { body: form, signal });
|
|
338
|
-
ids.push(res.id);
|
|
339
338
|
}
|
|
340
|
-
|
|
339
|
+
const res = await http.requestJson("POST", "/upload", { body: form, signal });
|
|
340
|
+
return [res.id];
|
|
341
341
|
}
|
|
342
342
|
|
|
343
343
|
// src/api/run-flow.ts
|
|
@@ -380,6 +380,156 @@ async function pollUntilTerminal(opts) {
|
|
|
380
380
|
}
|
|
381
381
|
}
|
|
382
382
|
|
|
383
|
+
// src/mappers/mapper.ts
|
|
384
|
+
function extractNodeFields(rawNode, targetLanguage) {
|
|
385
|
+
const metadataFields = /* @__PURE__ */ new Set([
|
|
386
|
+
"node_id",
|
|
387
|
+
"node_name",
|
|
388
|
+
"node_type",
|
|
389
|
+
"feature_name",
|
|
390
|
+
"running_time",
|
|
391
|
+
"status",
|
|
392
|
+
"score",
|
|
393
|
+
"feedback",
|
|
394
|
+
"translations",
|
|
395
|
+
"tokens",
|
|
396
|
+
"input_tokens",
|
|
397
|
+
"output_tokens",
|
|
398
|
+
"errors",
|
|
399
|
+
"mana",
|
|
400
|
+
"model",
|
|
401
|
+
"tool_calls",
|
|
402
|
+
"prompt_id",
|
|
403
|
+
"prompt",
|
|
404
|
+
"prompt_name",
|
|
405
|
+
"label",
|
|
406
|
+
"scoreDescription",
|
|
407
|
+
"score_description",
|
|
408
|
+
"result",
|
|
409
|
+
"documentType"
|
|
410
|
+
]);
|
|
411
|
+
let sourceObj = rawNode;
|
|
412
|
+
if (targetLanguage) {
|
|
413
|
+
const translations = rawNode.translations;
|
|
414
|
+
if (!translations || !translations[targetLanguage]) {
|
|
415
|
+
throw new DocmanaError(
|
|
416
|
+
`Translation for language '${targetLanguage}' is missing on node '${rawNode.node_name || rawNode.node_id}'`,
|
|
417
|
+
{ code: "translation_missing", status: 400 }
|
|
418
|
+
);
|
|
419
|
+
}
|
|
420
|
+
sourceObj = translations[targetLanguage];
|
|
421
|
+
}
|
|
422
|
+
const dynamicFields = {};
|
|
423
|
+
for (const [key, value] of Object.entries(sourceObj)) {
|
|
424
|
+
if (!metadataFields.has(key)) {
|
|
425
|
+
dynamicFields[key] = value;
|
|
426
|
+
}
|
|
427
|
+
}
|
|
428
|
+
const sdkNode = {
|
|
429
|
+
status: rawNode.status || "Unknown"
|
|
430
|
+
};
|
|
431
|
+
if (rawNode.errors && rawNode.errors.length > 0) {
|
|
432
|
+
sdkNode.errors = rawNode.errors;
|
|
433
|
+
}
|
|
434
|
+
const nodeType = rawNode.node_type || "";
|
|
435
|
+
const isScoreNode = /^(Validation|Classification|CrossValidation|Conclusion)$/i.test(nodeType);
|
|
436
|
+
if (isScoreNode) {
|
|
437
|
+
if (rawNode.score !== void 0 && rawNode.score !== null) {
|
|
438
|
+
sdkNode.score = rawNode.score;
|
|
439
|
+
}
|
|
440
|
+
if (rawNode.feedback !== void 0 && rawNode.feedback !== null) {
|
|
441
|
+
sdkNode.feedback = rawNode.feedback;
|
|
442
|
+
}
|
|
443
|
+
}
|
|
444
|
+
if (Object.keys(dynamicFields).length > 0) {
|
|
445
|
+
sdkNode.data = dynamicFields;
|
|
446
|
+
}
|
|
447
|
+
return sdkNode;
|
|
448
|
+
}
|
|
449
|
+
function mapExecutionResult(raw, targetLanguage) {
|
|
450
|
+
const sdkResult = {
|
|
451
|
+
status: raw.status || "Unknown",
|
|
452
|
+
executionId: String(raw.execution_id || raw.executionResultId || raw.execution_result_id || ""),
|
|
453
|
+
documents: {
|
|
454
|
+
mappings: []
|
|
455
|
+
}
|
|
456
|
+
};
|
|
457
|
+
if (raw.errors && raw.errors.length > 0) {
|
|
458
|
+
sdkResult.errors = raw.errors;
|
|
459
|
+
}
|
|
460
|
+
const results = raw.results || [];
|
|
461
|
+
for (const item of results) {
|
|
462
|
+
const isDocSpecific = !!item.document;
|
|
463
|
+
if (isDocSpecific && item.document) {
|
|
464
|
+
const docReq = item.document;
|
|
465
|
+
const docKey = docReq.doc_key || "unknown_doc";
|
|
466
|
+
const docName = docReq.name || "";
|
|
467
|
+
sdkResult.documents.mappings.push({
|
|
468
|
+
name: docName,
|
|
469
|
+
reference: docKey
|
|
470
|
+
});
|
|
471
|
+
const docResult = {
|
|
472
|
+
status: item.status || docReq.status || "Unknown",
|
|
473
|
+
extractions: {},
|
|
474
|
+
validations: {}
|
|
475
|
+
};
|
|
476
|
+
const nodeResults = item.node_results || [];
|
|
477
|
+
for (const node of nodeResults) {
|
|
478
|
+
const nodeType = node.node_type || "";
|
|
479
|
+
const nodeName = node.node_name || node.node_id || "unknown_node";
|
|
480
|
+
if (/^Classification$/i.test(nodeType)) {
|
|
481
|
+
const mappedNode = extractNodeFields(node, targetLanguage);
|
|
482
|
+
if (!docResult.classifications) {
|
|
483
|
+
docResult.classifications = {};
|
|
484
|
+
}
|
|
485
|
+
docResult.classifications[nodeName] = mappedNode;
|
|
486
|
+
} else if (/^MetadataExtraction$/i.test(nodeType)) {
|
|
487
|
+
docResult.metadataExtraction = extractNodeFields(node, targetLanguage);
|
|
488
|
+
} else if (/^Extraction$/i.test(nodeType)) {
|
|
489
|
+
if (docResult.extractions) {
|
|
490
|
+
docResult.extractions[nodeName] = extractNodeFields(node, targetLanguage);
|
|
491
|
+
}
|
|
492
|
+
} else if (/^Validation$/i.test(nodeType)) {
|
|
493
|
+
if (docResult.validations) {
|
|
494
|
+
docResult.validations[nodeName] = extractNodeFields(node, targetLanguage);
|
|
495
|
+
}
|
|
496
|
+
}
|
|
497
|
+
}
|
|
498
|
+
if (docResult.extractions && Object.keys(docResult.extractions).length === 0) {
|
|
499
|
+
delete docResult.extractions;
|
|
500
|
+
}
|
|
501
|
+
if (docResult.validations && Object.keys(docResult.validations).length === 0) {
|
|
502
|
+
delete docResult.validations;
|
|
503
|
+
}
|
|
504
|
+
sdkResult.documents[docKey] = docResult;
|
|
505
|
+
} else {
|
|
506
|
+
const nodeResults = item.node_results || [];
|
|
507
|
+
for (const node of nodeResults) {
|
|
508
|
+
const nodeType = node.node_type || "";
|
|
509
|
+
const nodeName = node.node_name || node.node_id || "unknown_node";
|
|
510
|
+
if (/^CrossValidation$/i.test(nodeType)) {
|
|
511
|
+
if (!sdkResult.crossValidations) {
|
|
512
|
+
sdkResult.crossValidations = {};
|
|
513
|
+
}
|
|
514
|
+
sdkResult.crossValidations[nodeName] = extractNodeFields(
|
|
515
|
+
node,
|
|
516
|
+
targetLanguage
|
|
517
|
+
);
|
|
518
|
+
} else if (/^(Conclusion|Finish)$/i.test(nodeType)) {
|
|
519
|
+
if (!sdkResult.conclusions) {
|
|
520
|
+
sdkResult.conclusions = {};
|
|
521
|
+
}
|
|
522
|
+
sdkResult.conclusions[nodeName] = extractNodeFields(
|
|
523
|
+
node,
|
|
524
|
+
targetLanguage
|
|
525
|
+
);
|
|
526
|
+
}
|
|
527
|
+
}
|
|
528
|
+
}
|
|
529
|
+
}
|
|
530
|
+
return sdkResult;
|
|
531
|
+
}
|
|
532
|
+
|
|
383
533
|
// src/client.ts
|
|
384
534
|
var Docmana = class {
|
|
385
535
|
config;
|
|
@@ -416,8 +566,9 @@ var Docmana = class {
|
|
|
416
566
|
async getStatus(executionResultId, signal) {
|
|
417
567
|
return getStatus(this.http, executionResultId, signal);
|
|
418
568
|
}
|
|
419
|
-
async getResult(executionResultId, signal) {
|
|
420
|
-
|
|
569
|
+
async getResult(executionResultId, signal, language) {
|
|
570
|
+
const rawResult = await getResult(this.http, executionResultId, signal);
|
|
571
|
+
return mapExecutionResult(rawResult, language);
|
|
421
572
|
}
|
|
422
573
|
async runFlow(flowId, input) {
|
|
423
574
|
const { executionResultId } = await this.runFlowAsync(flowId, input);
|
|
@@ -427,9 +578,13 @@ var Docmana = class {
|
|
|
427
578
|
timeoutMs: input.timeoutMs ?? this.config.timeoutMs,
|
|
428
579
|
signal: input.signal
|
|
429
580
|
});
|
|
430
|
-
const result = await this.getResult(executionResultId, input.signal);
|
|
581
|
+
const result = await this.getResult(executionResultId, input.signal, input.language);
|
|
431
582
|
if (result.status === "Failed") {
|
|
432
|
-
throw new DocmanaExecutionError(
|
|
583
|
+
throw new DocmanaExecutionError(
|
|
584
|
+
`Flow ${flowId} execution failed`,
|
|
585
|
+
result.errors ?? [],
|
|
586
|
+
result
|
|
587
|
+
);
|
|
433
588
|
}
|
|
434
589
|
return result;
|
|
435
590
|
}
|
package/dist/index.js.map
CHANGED
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"sources":["../src/index.ts","../src/config.ts","../src/errors.ts","../src/auth/token-manager.ts","../src/http/http-client.ts","../src/files/resolve-input.ts","../src/api/upload.ts","../src/api/run-flow.ts","../src/api/execution-status.ts","../src/api/execution-result.ts","../src/polling/poll.ts","../src/client.ts"],"sourcesContent":["export { Docmana } from \"./client.js\";\nexport {\n DocmanaError,\n DocmanaAuthError,\n DocmanaRequestError,\n DocmanaPermissionError,\n DocmanaNotFoundError,\n DocmanaExecutionError,\n DocmanaTimeoutError,\n DocmanaAbortError,\n} from \"./errors.js\";\nexport type {\n DocmanaConfig,\n RunFlowInput,\n FileInput,\n ExecutionResult,\n ExecutionStatus,\n} from \"./types.js\";\n","import type { DocmanaConfig } from \"./types.js\";\nimport type { TokenCache } from \"./types.js\";\n\nexport const DEFAULTS = {\n apiBaseUrl: \"https://api.docmana.ai\",\n tokenEndpoint:\n \"https://4fe70f5b-e013-4f65-9fa7-3109a33beba5.ciamlogin.com/4fe70f5b-e013-4f65-9fa7-3109a33beba5/oauth2/v2.0/token\",\n scope: \"api://d781e6ba-cc08-4618-8099-ad968abd2b9e/.default\",\n timeoutMs: 300_000,\n pollIntervalMs: 2_000,\n} as const;\n\nexport interface ResolvedConfig {\n clientId: string;\n clientSecret: string;\n apiBaseUrl: string;\n tokenEndpoint: string;\n scope: string;\n timeoutMs: number;\n pollIntervalMs: number;\n fetchImpl: typeof fetch;\n headers: Record<string, string>;\n tokenCache?: TokenCache;\n}\n\nexport function resolveConfig(config: DocmanaConfig): ResolvedConfig {\n if (!config.clientId) throw new Error(\"DocmanaConfig.clientId is required\");\n if (!config.clientSecret) throw new Error(\"DocmanaConfig.clientSecret is required\");\n const apiBaseUrl = (config.apiBaseUrl ?? DEFAULTS.apiBaseUrl).replace(/\\/+$/, \"\");\n return {\n clientId: config.clientId,\n clientSecret: config.clientSecret,\n apiBaseUrl,\n tokenEndpoint: config.tokenEndpoint ?? DEFAULTS.tokenEndpoint,\n scope: config.scope ?? DEFAULTS.scope,\n timeoutMs: config.timeoutMs ?? DEFAULTS.timeoutMs,\n pollIntervalMs: config.pollIntervalMs ?? DEFAULTS.pollIntervalMs,\n fetchImpl: config.fetch ?? fetch,\n headers: config.headers ?? {},\n tokenCache: config.tokenCache,\n };\n}\n","export class DocmanaError extends Error {\n readonly status?: number;\n readonly requestId?: string;\n readonly code: string;\n constructor(message: string, opts: { status?: number; requestId?: string; code?: string } = {}) {\n super(message);\n this.name = new.target.name;\n this.status = opts.status;\n this.requestId = opts.requestId;\n this.code = opts.code ?? \"docmana_error\";\n Object.setPrototypeOf(this, new.target.prototype);\n }\n}\n\nexport class DocmanaAuthError extends DocmanaError {\n constructor(message: string, opts: { status?: number; requestId?: string } = {}) {\n super(message, { ...opts, code: \"auth_error\" });\n }\n}\n\nexport class DocmanaPermissionError extends DocmanaError {\n constructor(message: string, opts: { status?: number; requestId?: string } = {}) {\n super(message, { ...opts, code: \"permission_error\" });\n }\n}\n\nexport class DocmanaNotFoundError extends DocmanaError {\n constructor(message: string, opts: { status?: number; requestId?: string } = {}) {\n super(message, { ...opts, code: \"not_found\" });\n }\n}\n\nexport class DocmanaRequestError extends DocmanaError {\n constructor(message: string, opts: { status?: number; requestId?: string } = {}) {\n super(message, { ...opts, code: \"bad_request\" });\n }\n}\n\nexport class DocmanaExecutionError extends DocmanaError {\n readonly errors: unknown[];\n constructor(message: string, errors: unknown[] = []) {\n super(message, { code: \"execution_failed\" });\n this.errors = errors;\n }\n}\n\nexport class DocmanaTimeoutError extends DocmanaError {\n constructor(message: string) {\n super(message, { code: \"timeout\" });\n }\n}\n\nexport class DocmanaAbortError extends DocmanaError {\n constructor(message: string) {\n super(message, { code: \"aborted\" });\n }\n}\n\nexport function errorFromResponse(\n status: number,\n message: string,\n requestId?: string,\n): DocmanaError {\n const opts = { status, requestId };\n switch (status) {\n case 400:\n return new DocmanaRequestError(message, opts);\n case 401:\n return new DocmanaAuthError(message, opts);\n case 403:\n return new DocmanaPermissionError(message, opts);\n case 404:\n return new DocmanaNotFoundError(message, opts);\n default:\n return new DocmanaError(message, opts);\n }\n}\n","import { DocmanaAuthError } from \"../errors.js\";\nimport type { TokenCache, TokenCacheEntry } from \"../types.js\";\n\nconst SAFETY_MARGIN_MS = 60_000;\n\nexport interface TokenManagerOptions {\n clientId: string;\n clientSecret: string;\n tokenEndpoint: string;\n scope: string;\n fetchImpl: typeof fetch;\n tokenCache?: TokenCache;\n}\n\nexport class TokenManager {\n private token: string | null = null;\n private expiresAt = 0;\n private inflight: Promise<string> | null = null;\n\n constructor(private readonly opts: TokenManagerOptions) {}\n\n invalidate(): void {\n this.token = null;\n this.expiresAt = 0;\n void this.opts.tokenCache?.clear().catch(() => undefined);\n }\n\n async getToken(): Promise<string> {\n if (this.token && Date.now() < this.expiresAt) return this.token;\n const cached = await this.readCachedToken();\n if (cached) return cached;\n if (this.inflight) return this.inflight;\n this.inflight = this.acquire().finally(() => {\n this.inflight = null;\n });\n return this.inflight;\n }\n\n private async acquire(): Promise<string> {\n const body = new URLSearchParams({\n grant_type: \"client_credentials\",\n client_id: this.opts.clientId,\n client_secret: this.opts.clientSecret,\n scope: this.opts.scope,\n });\n const res = await this.opts.fetchImpl(this.opts.tokenEndpoint, {\n method: \"POST\",\n headers: { \"content-type\": \"application/x-www-form-urlencoded\" },\n body: body.toString(),\n });\n if (!res.ok) {\n // Do NOT include the response body verbatim — avoid leaking secrets/echoes.\n throw new DocmanaAuthError(\"Failed to acquire Docmana access token\", { status: res.status });\n }\n const json = (await res.json()) as Partial<{ access_token: string; expires_in: number }>;\n if (\n typeof json.access_token !== \"string\" ||\n json.access_token.length === 0 ||\n typeof json.expires_in !== \"number\" ||\n !Number.isFinite(json.expires_in)\n ) {\n throw new DocmanaAuthError(\"Malformed token response from Docmana CIAM\", {\n status: res.status,\n });\n }\n this.token = json.access_token;\n this.expiresAt = Date.now() + json.expires_in * 1000 - SAFETY_MARGIN_MS;\n await this.writeCachedToken().catch(() => undefined);\n return this.token;\n }\n\n private async readCachedToken(): Promise<string | null> {\n if (!this.opts.tokenCache) return null;\n let entry: TokenCacheEntry | null;\n try {\n entry = await this.opts.tokenCache.read();\n } catch {\n return null;\n }\n if (!entry) return null;\n if (\n entry.clientId !== this.opts.clientId ||\n entry.tokenEndpoint !== this.opts.tokenEndpoint ||\n entry.scope !== this.opts.scope ||\n Date.now() >= entry.expiresAt\n ) {\n await this.opts.tokenCache.clear().catch(() => undefined);\n return null;\n }\n this.token = entry.accessToken;\n this.expiresAt = entry.expiresAt;\n return this.token;\n }\n\n private async writeCachedToken(): Promise<void> {\n if (!this.opts.tokenCache || !this.token) return;\n await this.opts.tokenCache.write({\n accessToken: this.token,\n expiresAt: this.expiresAt,\n clientId: this.opts.clientId,\n tokenEndpoint: this.opts.tokenEndpoint,\n scope: this.opts.scope,\n });\n }\n}\n","import type { TokenManager } from \"../auth/token-manager.js\";\nimport { DocmanaError, DocmanaAbortError, errorFromResponse } from \"../errors.js\";\n\nexport interface HttpClientOptions {\n apiBaseUrl: string;\n fetchImpl: typeof fetch;\n tokenManager: TokenManager;\n headers?: Record<string, string>;\n}\n\ntype FetchBody = NonNullable<Parameters<typeof fetch>[1]>[\"body\"];\n\nexport interface RequestOptions {\n query?: Record<string, string>;\n body?: FetchBody;\n headers?: Record<string, string>;\n signal?: AbortSignal;\n}\n\nexport class HttpClient {\n constructor(private readonly opts: HttpClientOptions) {}\n\n async requestJson<T>(method: string, path: string, options: RequestOptions = {}): Promise<T> {\n const res = await this.requestRaw(method, path, options);\n const text = await res.text();\n if (!text) return {} as T;\n try {\n return JSON.parse(text) as T;\n } catch {\n throw new DocmanaError(\"Invalid JSON response from Docmana\", { status: res.status });\n }\n }\n\n async requestRaw(method: string, path: string, options: RequestOptions = {}): Promise<Response> {\n let res = await this.send(method, path, options);\n if (res.status === 401) {\n this.opts.tokenManager.invalidate();\n res = await this.send(method, path, options);\n }\n if (!res.ok) {\n const requestId = res.headers.get(\"x-request-id\") ?? undefined;\n const message = await this.extractMessage(res);\n throw errorFromResponse(res.status, message, requestId);\n }\n return res;\n }\n\n private async send(method: string, path: string, options: RequestOptions): Promise<Response> {\n const token = await this.opts.tokenManager.getToken();\n const url = new URL(this.opts.apiBaseUrl + path);\n for (const [k, v] of Object.entries(options.query ?? {})) url.searchParams.set(k, v);\n const headers: Record<string, string> = {\n ...(this.opts.headers ?? {}),\n authorization: `Bearer ${token}`,\n ...(options.headers ?? {}),\n };\n try {\n return await this.opts.fetchImpl(url, {\n method,\n headers,\n body: options.body,\n signal: options.signal,\n });\n } catch (err) {\n if (options.signal?.aborted || (err instanceof Error && err.name === \"AbortError\")) {\n throw new DocmanaAbortError(\"Request aborted\");\n }\n throw err;\n }\n }\n\n private async extractMessage(res: Response): Promise<string> {\n try {\n const data = (await res.clone().json()) as { message?: string; error?: string };\n return data.message ?? data.error ?? res.statusText ?? `HTTP ${res.status}`;\n } catch {\n return res.statusText ?? `HTTP ${res.status}`;\n }\n }\n}\n","import { readFile } from \"node:fs/promises\";\nimport { basename } from \"node:path\";\nimport type { Readable } from \"node:stream\";\nimport type { FileInput, RunFlowInput } from \"../types.js\";\n\nexport interface ResolvedPart {\n data: Blob;\n filename: string;\n contentType: string;\n}\n\nconst CONTENT_TYPES: Record<string, string> = {\n \".pdf\": \"application/pdf\",\n \".png\": \"image/png\",\n \".jpg\": \"image/jpeg\",\n \".jpeg\": \"image/jpeg\",\n \".tif\": \"image/tiff\",\n \".tiff\": \"image/tiff\",\n \".txt\": \"text/plain\",\n \".json\": \"application/json\",\n};\n\nfunction contentTypeFor(name: string): string {\n const dot = name.lastIndexOf(\".\");\n if (dot < 0) return \"application/octet-stream\";\n const ext = name.slice(dot).toLowerCase();\n return CONTENT_TYPES[ext] ?? \"application/octet-stream\";\n}\n\nfunction isReadable(x: unknown): x is Readable {\n return typeof x === \"object\" && x !== null && typeof (x as Readable).pipe === \"function\";\n}\n\nfunction isPathInput(x: unknown): x is { path: string } {\n return typeof x === \"object\" && x !== null && typeof (x as { path?: unknown }).path === \"string\";\n}\n\nasync function streamToBuffer(stream: Readable): Promise<Buffer> {\n const chunks: Buffer[] = [];\n for await (const chunk of stream) chunks.push(Buffer.from(chunk));\n return Buffer.concat(chunks);\n}\n\nasync function resolveOne(input: FileInput, fallbackName: string): Promise<ResolvedPart> {\n if (typeof input === \"string\" || isPathInput(input)) {\n const path = typeof input === \"string\" ? input : input.path;\n const data = await readFile(path);\n const filename = basename(path);\n return { data: new Blob([data]), filename, contentType: contentTypeFor(filename) };\n }\n if (input instanceof Uint8Array) {\n return {\n data: new Blob([input]),\n filename: fallbackName,\n contentType: contentTypeFor(fallbackName),\n };\n }\n if (isReadable(input)) {\n const buf = await streamToBuffer(input);\n return {\n data: new Blob([buf]),\n filename: fallbackName,\n contentType: contentTypeFor(fallbackName),\n };\n }\n throw new Error(\"Unsupported file input type\");\n}\n\nexport async function resolveInputs(input: RunFlowInput): Promise<ResolvedPart[]> {\n const list: FileInput[] = input.files ?? (input.file !== undefined ? [input.file] : []);\n if (list.length === 0) throw new Error(\"runFlow requires `file` or `files`\");\n const fallback = input.fileName ?? \"upload.bin\";\n return Promise.all(list.map((item) => resolveOne(item, fallback)));\n}\n","import type { HttpClient } from \"../http/http-client.js\";\nimport type { ResolvedPart } from \"../files/resolve-input.js\";\n\nexport async function uploadFiles(\n http: HttpClient,\n parts: ResolvedPart[],\n signal?: AbortSignal,\n): Promise<string[]> {\n const ids: string[] = [];\n for (const part of parts) {\n const form = new FormData();\n form.append(\"files\", new File([part.data], part.filename, { type: part.contentType }));\n const res = await http.requestJson<{ id: string }>(\"POST\", \"/upload\", { body: form, signal });\n ids.push(res.id);\n }\n return ids;\n}\n","import type { HttpClient } from \"../http/http-client.js\";\n\nexport async function runFlow(\n http: HttpClient,\n flowId: string,\n uuidFiles: string[],\n signal?: AbortSignal,\n once = false,\n): Promise<string> {\n const path = once ? `/flows/run_once_flow/${flowId}` : `/flows/run_flow/${flowId}`;\n const res = await http.requestJson<{ execution_result_id: string }>(\"POST\", path, {\n query: { async_mode: \"true\" },\n headers: { \"content-type\": \"application/json\" },\n body: JSON.stringify({ uuid_files: uuidFiles }),\n signal,\n });\n return res.execution_result_id;\n}\n","import type { HttpClient } from \"../http/http-client.js\";\nimport type { ExecutionStatus } from \"../types.js\";\n\nexport async function getStatus(\n http: HttpClient,\n executionResultId: string,\n signal?: AbortSignal,\n): Promise<{ status: ExecutionStatus | string }> {\n return http.requestJson(\"GET\", `/flows/execution-status/${executionResultId}`, { signal });\n}\n","import type { HttpClient } from \"../http/http-client.js\";\nimport type { ExecutionResult } from \"../types.js\";\n\nexport async function getResult(\n http: HttpClient,\n executionResultId: string,\n signal?: AbortSignal,\n): Promise<ExecutionResult> {\n return http.requestJson(\"GET\", `/flows/execution-result/${executionResultId}`, { signal });\n}\n","import { DocmanaTimeoutError, DocmanaAbortError } from \"../errors.js\";\n\nconst TERMINAL = new Set([\"Completed\", \"Failed\"]);\n\nexport interface PollOptions {\n check: () => Promise<string>;\n intervalMs: number;\n timeoutMs: number;\n sleep?: (ms: number) => Promise<void>;\n elapsed?: () => number;\n signal?: AbortSignal;\n}\n\nconst defaultSleep = (ms: number) => new Promise<void>((r) => setTimeout(r, ms));\n\nexport async function pollUntilTerminal(opts: PollOptions): Promise<string> {\n const sleep = opts.sleep ?? defaultSleep;\n const start = Date.now();\n const elapsed = opts.elapsed ?? (() => Date.now() - start);\n for (;;) {\n if (opts.signal?.aborted) throw new DocmanaAbortError(\"Polling aborted\");\n const status = await opts.check();\n if (TERMINAL.has(status)) return status;\n if (elapsed() >= opts.timeoutMs) {\n throw new DocmanaTimeoutError(`Execution did not finish within ${opts.timeoutMs}ms`);\n }\n await sleep(opts.intervalMs);\n }\n}\n","import { resolveConfig } from \"./config.js\";\nimport type { ResolvedConfig } from \"./config.js\";\nimport type { DocmanaConfig, ExecutionResult, ExecutionStatus, RunFlowInput } from \"./types.js\";\nimport { TokenManager } from \"./auth/token-manager.js\";\nimport { HttpClient } from \"./http/http-client.js\";\nimport { resolveInputs } from \"./files/resolve-input.js\";\nimport { uploadFiles } from \"./api/upload.js\";\nimport { runFlow as runFlowApi } from \"./api/run-flow.js\";\nimport { getStatus as getStatusApi } from \"./api/execution-status.js\";\nimport { getResult as getResultApi } from \"./api/execution-result.js\";\nimport { pollUntilTerminal } from \"./polling/poll.js\";\nimport { DocmanaExecutionError } from \"./errors.js\";\n\nexport class Docmana {\n private readonly config: ResolvedConfig;\n private readonly http: HttpClient;\n\n constructor(config: DocmanaConfig) {\n this.config = resolveConfig(config);\n const tokenManager = new TokenManager({\n clientId: this.config.clientId,\n clientSecret: this.config.clientSecret,\n tokenEndpoint: this.config.tokenEndpoint,\n scope: this.config.scope,\n fetchImpl: this.config.fetchImpl,\n tokenCache: this.config.tokenCache,\n });\n this.http = new HttpClient({\n apiBaseUrl: this.config.apiBaseUrl,\n fetchImpl: this.config.fetchImpl,\n tokenManager,\n headers: this.config.headers,\n });\n }\n\n async runFlowAsync(\n flowId: string,\n input: RunFlowInput,\n ): Promise<{ executionResultId: string; fileIds: string[] }> {\n const parts = await resolveInputs(input);\n const fileIds = await uploadFiles(this.http, parts, input.signal);\n const executionResultId = await runFlowApi(\n this.http,\n flowId,\n fileIds,\n input.signal,\n input.once ?? false,\n );\n return { executionResultId, fileIds };\n }\n\n async getStatus(\n executionResultId: string,\n signal?: AbortSignal,\n ): Promise<{ status: ExecutionStatus | string }> {\n return getStatusApi(this.http, executionResultId, signal);\n }\n\n async getResult(executionResultId: string, signal?: AbortSignal): Promise<ExecutionResult> {\n return getResultApi(this.http, executionResultId, signal);\n }\n\n async runFlow(flowId: string, input: RunFlowInput): Promise<ExecutionResult> {\n const { executionResultId } = await this.runFlowAsync(flowId, input);\n await pollUntilTerminal({\n check: async () => (await this.getStatus(executionResultId, input.signal)).status,\n intervalMs: input.pollIntervalMs ?? this.config.pollIntervalMs,\n timeoutMs: input.timeoutMs ?? this.config.timeoutMs,\n signal: input.signal,\n });\n const result = await this.getResult(executionResultId, input.signal);\n if (result.status === \"Failed\") {\n throw new DocmanaExecutionError(`Flow ${flowId} execution failed`, result.errors ?? []);\n }\n return result;\n }\n}\n"],"mappings":"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","names":[]}
|
|
1
|
+
{"version":3,"sources":["../src/index.ts","../src/config.ts","../src/errors.ts","../src/auth/token-manager.ts","../src/http/http-client.ts","../src/files/resolve-input.ts","../src/api/upload.ts","../src/api/run-flow.ts","../src/api/execution-status.ts","../src/api/execution-result.ts","../src/polling/poll.ts","../src/mappers/mapper.ts","../src/client.ts"],"sourcesContent":["export { Docmana } from \"./client.js\";\nexport {\n DocmanaError,\n DocmanaAuthError,\n DocmanaRequestError,\n DocmanaPermissionError,\n DocmanaNotFoundError,\n DocmanaExecutionError,\n DocmanaTimeoutError,\n DocmanaAbortError,\n} from \"./errors.js\";\nexport type {\n DocmanaConfig,\n RunFlowInput,\n FileInput,\n DocmanaExecutionResult,\n ExecutionStatus,\n DocmanaDocumentMapping,\n DocmanaDocumentResult,\n DocmanaNodeResult,\n DocmanaScoreNodeResult,\n DocmanaCrossValidationResult,\n DocmanaConclusionResult,\n DocmanaClassificationResult,\n DocmanaMetadataExtractionResult,\n DocmanaExtractionResult,\n DocmanaValidationResult,\n} from \"./types.js\";\nexport type {\n ExecutionProgress,\n VirtualDocument,\n PhysicalDocument,\n DocumentContent,\n FlowNodeType,\n FlowConfigs,\n FlowNode,\n FlowEdge,\n Flow,\n NodeTranslationResult,\n DocmanaApiExecutionResult,\n DocmanaApiNodeResult,\n DocmanaApiDocumentExecutionResult,\n DocmanaApiDocumentRequest,\n} from \"./models/index.js\";\n","import type { DocmanaConfig } from \"./types.js\";\nimport type { TokenCache } from \"./types.js\";\n\nexport const DEFAULTS = {\n apiBaseUrl: \"https://api.docmana.ai\",\n tokenEndpoint:\n \"https://4fe70f5b-e013-4f65-9fa7-3109a33beba5.ciamlogin.com/4fe70f5b-e013-4f65-9fa7-3109a33beba5/oauth2/v2.0/token\",\n scope: \"api://d781e6ba-cc08-4618-8099-ad968abd2b9e/.default\",\n timeoutMs: 300_000,\n pollIntervalMs: 2_000,\n} as const;\n\nexport interface ResolvedConfig {\n clientId: string;\n clientSecret: string;\n apiBaseUrl: string;\n tokenEndpoint: string;\n scope: string;\n timeoutMs: number;\n pollIntervalMs: number;\n fetchImpl: typeof fetch;\n headers: Record<string, string>;\n tokenCache?: TokenCache;\n}\n\nexport function resolveConfig(config: DocmanaConfig): ResolvedConfig {\n if (!config.clientId) throw new Error(\"DocmanaConfig.clientId is required\");\n if (!config.clientSecret) throw new Error(\"DocmanaConfig.clientSecret is required\");\n const apiBaseUrl = (config.apiBaseUrl ?? DEFAULTS.apiBaseUrl).replace(/\\/+$/, \"\");\n return {\n clientId: config.clientId,\n clientSecret: config.clientSecret,\n apiBaseUrl,\n tokenEndpoint: config.tokenEndpoint ?? DEFAULTS.tokenEndpoint,\n scope: config.scope ?? DEFAULTS.scope,\n timeoutMs: config.timeoutMs ?? DEFAULTS.timeoutMs,\n pollIntervalMs: config.pollIntervalMs ?? DEFAULTS.pollIntervalMs,\n fetchImpl: config.fetch ?? fetch,\n headers: config.headers ?? {},\n tokenCache: config.tokenCache,\n };\n}\n","import type { DocmanaExecutionResult } from \"./models/docmana-execution-result.model.js\";\n\nexport class DocmanaError extends Error {\n readonly status?: number;\n readonly requestId?: string;\n readonly code: string;\n constructor(message: string, opts: { status?: number; requestId?: string; code?: string } = {}) {\n super(message);\n this.name = new.target.name;\n this.status = opts.status;\n this.requestId = opts.requestId;\n this.code = opts.code ?? \"docmana_error\";\n Object.setPrototypeOf(this, new.target.prototype);\n }\n}\n\nexport class DocmanaAuthError extends DocmanaError {\n constructor(message: string, opts: { status?: number; requestId?: string } = {}) {\n super(message, { ...opts, code: \"auth_error\" });\n }\n}\n\nexport class DocmanaPermissionError extends DocmanaError {\n constructor(message: string, opts: { status?: number; requestId?: string } = {}) {\n super(message, { ...opts, code: \"permission_error\" });\n }\n}\n\nexport class DocmanaNotFoundError extends DocmanaError {\n constructor(message: string, opts: { status?: number; requestId?: string } = {}) {\n super(message, { ...opts, code: \"not_found\" });\n }\n}\n\nexport class DocmanaRequestError extends DocmanaError {\n constructor(message: string, opts: { status?: number; requestId?: string } = {}) {\n super(message, { ...opts, code: \"bad_request\" });\n }\n}\n\nexport class DocmanaExecutionError extends DocmanaError {\n readonly errors: unknown[];\n readonly result?: DocmanaExecutionResult;\n constructor(message: string, errors: unknown[] = [], result?: DocmanaExecutionResult) {\n super(message, { code: \"execution_failed\" });\n this.errors = errors;\n this.result = result;\n }\n}\n\nexport class DocmanaTimeoutError extends DocmanaError {\n constructor(message: string) {\n super(message, { code: \"timeout\" });\n }\n}\n\nexport class DocmanaAbortError extends DocmanaError {\n constructor(message: string) {\n super(message, { code: \"aborted\" });\n }\n}\n\nexport function errorFromResponse(\n status: number,\n message: string,\n requestId?: string,\n): DocmanaError {\n const opts = { status, requestId };\n switch (status) {\n case 400:\n return new DocmanaRequestError(message, opts);\n case 401:\n return new DocmanaAuthError(message, opts);\n case 403:\n return new DocmanaPermissionError(message, opts);\n case 404:\n return new DocmanaNotFoundError(message, opts);\n default:\n return new DocmanaError(message, opts);\n }\n}\n","import { DocmanaAuthError } from \"../errors.js\";\nimport type { TokenCache, TokenCacheEntry } from \"../types.js\";\n\nconst SAFETY_MARGIN_MS = 60_000;\n\nexport interface TokenManagerOptions {\n clientId: string;\n clientSecret: string;\n tokenEndpoint: string;\n scope: string;\n fetchImpl: typeof fetch;\n tokenCache?: TokenCache;\n}\n\nexport class TokenManager {\n private token: string | null = null;\n private expiresAt = 0;\n private inflight: Promise<string> | null = null;\n\n constructor(private readonly opts: TokenManagerOptions) {}\n\n invalidate(): void {\n this.token = null;\n this.expiresAt = 0;\n void this.opts.tokenCache?.clear().catch(() => undefined);\n }\n\n async getToken(): Promise<string> {\n if (this.token && Date.now() < this.expiresAt) return this.token;\n const cached = await this.readCachedToken();\n if (cached) return cached;\n if (this.inflight) return this.inflight;\n this.inflight = this.acquire().finally(() => {\n this.inflight = null;\n });\n return this.inflight;\n }\n\n private async acquire(): Promise<string> {\n const body = new URLSearchParams({\n grant_type: \"client_credentials\",\n client_id: this.opts.clientId,\n client_secret: this.opts.clientSecret,\n scope: this.opts.scope,\n });\n const res = await this.opts.fetchImpl(this.opts.tokenEndpoint, {\n method: \"POST\",\n headers: { \"content-type\": \"application/x-www-form-urlencoded\" },\n body: body.toString(),\n });\n if (!res.ok) {\n // Do NOT include the response body verbatim — avoid leaking secrets/echoes.\n throw new DocmanaAuthError(\"Failed to acquire Docmana access token\", { status: res.status });\n }\n const json = (await res.json()) as Partial<{ access_token: string; expires_in: number }>;\n if (\n typeof json.access_token !== \"string\" ||\n json.access_token.length === 0 ||\n typeof json.expires_in !== \"number\" ||\n !Number.isFinite(json.expires_in)\n ) {\n throw new DocmanaAuthError(\"Malformed token response from Docmana CIAM\", {\n status: res.status,\n });\n }\n this.token = json.access_token;\n this.expiresAt = Date.now() + json.expires_in * 1000 - SAFETY_MARGIN_MS;\n await this.writeCachedToken().catch(() => undefined);\n return this.token;\n }\n\n private async readCachedToken(): Promise<string | null> {\n if (!this.opts.tokenCache) return null;\n let entry: TokenCacheEntry | null;\n try {\n entry = await this.opts.tokenCache.read();\n } catch {\n return null;\n }\n if (!entry) return null;\n if (\n entry.clientId !== this.opts.clientId ||\n entry.tokenEndpoint !== this.opts.tokenEndpoint ||\n entry.scope !== this.opts.scope ||\n Date.now() >= entry.expiresAt\n ) {\n await this.opts.tokenCache.clear().catch(() => undefined);\n return null;\n }\n this.token = entry.accessToken;\n this.expiresAt = entry.expiresAt;\n return this.token;\n }\n\n private async writeCachedToken(): Promise<void> {\n if (!this.opts.tokenCache || !this.token) return;\n await this.opts.tokenCache.write({\n accessToken: this.token,\n expiresAt: this.expiresAt,\n clientId: this.opts.clientId,\n tokenEndpoint: this.opts.tokenEndpoint,\n scope: this.opts.scope,\n });\n }\n}\n","import type { TokenManager } from \"../auth/token-manager.js\";\nimport { DocmanaError, DocmanaAbortError, errorFromResponse } from \"../errors.js\";\n\nexport interface HttpClientOptions {\n apiBaseUrl: string;\n fetchImpl: typeof fetch;\n tokenManager: TokenManager;\n headers?: Record<string, string>;\n}\n\ntype FetchBody = NonNullable<Parameters<typeof fetch>[1]>[\"body\"];\n\nexport interface RequestOptions {\n query?: Record<string, string>;\n body?: FetchBody;\n headers?: Record<string, string>;\n signal?: AbortSignal;\n}\n\nexport class HttpClient {\n constructor(private readonly opts: HttpClientOptions) {}\n\n async requestJson<T>(method: string, path: string, options: RequestOptions = {}): Promise<T> {\n const res = await this.requestRaw(method, path, options);\n const text = await res.text();\n if (!text) return {} as T;\n try {\n return JSON.parse(text) as T;\n } catch {\n throw new DocmanaError(\"Invalid JSON response from Docmana\", { status: res.status });\n }\n }\n\n async requestRaw(method: string, path: string, options: RequestOptions = {}): Promise<Response> {\n let res = await this.send(method, path, options);\n if (res.status === 401) {\n this.opts.tokenManager.invalidate();\n res = await this.send(method, path, options);\n }\n if (!res.ok) {\n const requestId = res.headers.get(\"x-request-id\") ?? undefined;\n const message = await this.extractMessage(res);\n throw errorFromResponse(res.status, message, requestId);\n }\n return res;\n }\n\n private async send(method: string, path: string, options: RequestOptions): Promise<Response> {\n const token = await this.opts.tokenManager.getToken();\n const url = new URL(this.opts.apiBaseUrl + path);\n for (const [k, v] of Object.entries(options.query ?? {})) url.searchParams.set(k, v);\n const headers: Record<string, string> = {\n ...(this.opts.headers ?? {}),\n authorization: `Bearer ${token}`,\n ...(options.headers ?? {}),\n };\n try {\n return await this.opts.fetchImpl(url, {\n method,\n headers,\n body: options.body,\n signal: options.signal,\n });\n } catch (err) {\n if (options.signal?.aborted || (err instanceof Error && err.name === \"AbortError\")) {\n throw new DocmanaAbortError(\"Request aborted\");\n }\n throw err;\n }\n }\n\n private async extractMessage(res: Response): Promise<string> {\n try {\n const data = (await res.clone().json()) as { message?: string; error?: string };\n return data.message ?? data.error ?? res.statusText ?? `HTTP ${res.status}`;\n } catch {\n return res.statusText ?? `HTTP ${res.status}`;\n }\n }\n}\n","import { readFile } from \"node:fs/promises\";\nimport { basename } from \"node:path\";\nimport type { Readable } from \"node:stream\";\nimport type { FileInput, RunFlowInput } from \"../types.js\";\n\nexport interface ResolvedPart {\n data: Blob;\n filename: string;\n contentType: string;\n}\n\nconst CONTENT_TYPES: Record<string, string> = {\n \".pdf\": \"application/pdf\",\n \".png\": \"image/png\",\n \".jpg\": \"image/jpeg\",\n \".jpeg\": \"image/jpeg\",\n \".tif\": \"image/tiff\",\n \".tiff\": \"image/tiff\",\n \".txt\": \"text/plain\",\n \".json\": \"application/json\",\n};\n\nfunction contentTypeFor(name: string): string {\n const dot = name.lastIndexOf(\".\");\n if (dot < 0) return \"application/octet-stream\";\n const ext = name.slice(dot).toLowerCase();\n return CONTENT_TYPES[ext] ?? \"application/octet-stream\";\n}\n\nfunction isReadable(x: unknown): x is Readable {\n return typeof x === \"object\" && x !== null && typeof (x as Readable).pipe === \"function\";\n}\n\nfunction isPathInput(x: unknown): x is { path: string } {\n return typeof x === \"object\" && x !== null && typeof (x as { path?: unknown }).path === \"string\";\n}\n\nasync function streamToBuffer(stream: Readable): Promise<Buffer> {\n const chunks: Buffer[] = [];\n for await (const chunk of stream) chunks.push(Buffer.from(chunk));\n return Buffer.concat(chunks);\n}\n\nasync function resolveOne(input: FileInput, fallbackName: string): Promise<ResolvedPart> {\n if (typeof input === \"string\" || isPathInput(input)) {\n const path = typeof input === \"string\" ? input : input.path;\n const data = await readFile(path);\n const filename = basename(path);\n return { data: new Blob([data]), filename, contentType: contentTypeFor(filename) };\n }\n if (input instanceof Uint8Array) {\n return {\n data: new Blob([input]),\n filename: fallbackName,\n contentType: contentTypeFor(fallbackName),\n };\n }\n if (isReadable(input)) {\n const buf = await streamToBuffer(input);\n return {\n data: new Blob([buf]),\n filename: fallbackName,\n contentType: contentTypeFor(fallbackName),\n };\n }\n throw new Error(\"Unsupported file input type\");\n}\n\nexport async function resolveInputs(input: RunFlowInput): Promise<ResolvedPart[]> {\n const list: FileInput[] = input.files ?? (input.file !== undefined ? [input.file] : []);\n if (list.length === 0) throw new Error(\"runFlow requires `file` or `files`\");\n const fallback = input.fileName ?? \"upload.bin\";\n return Promise.all(list.map((item) => resolveOne(item, fallback)));\n}\n","import type { HttpClient } from \"../http/http-client.js\";\nimport type { ResolvedPart } from \"../files/resolve-input.js\";\n\nexport async function uploadFiles(\n http: HttpClient,\n parts: ResolvedPart[],\n signal?: AbortSignal,\n): Promise<string[]> {\n // The /upload endpoint accepts multiple files in a SINGLE call and returns one\n // folder UUID holding all of them. Uploading every file in its own call would\n // make Docmana treat each file as a separate document, which breaks flows that\n // process several documents together (the graph builder reuses the same node per\n // document -> \"Node already present\"). So we send every part in one request.\n const form = new FormData();\n for (const part of parts) {\n form.append(\"files\", new File([part.data], part.filename, { type: part.contentType }));\n }\n const res = await http.requestJson<{ id: string }>(\"POST\", \"/upload\", { body: form, signal });\n return [res.id];\n}\n","import type { HttpClient } from \"../http/http-client.js\";\n\nexport async function runFlow(\n http: HttpClient,\n flowId: string,\n uuidFiles: string[],\n signal?: AbortSignal,\n once = false,\n): Promise<string> {\n const path = once ? `/flows/run_once_flow/${flowId}` : `/flows/run_flow/${flowId}`;\n const res = await http.requestJson<{ execution_result_id: string }>(\"POST\", path, {\n query: { async_mode: \"true\" },\n headers: { \"content-type\": \"application/json\" },\n body: JSON.stringify({ uuid_files: uuidFiles }),\n signal,\n });\n return res.execution_result_id;\n}\n","import type { HttpClient } from \"../http/http-client.js\";\nimport type { ExecutionStatus } from \"../types.js\";\n\nexport async function getStatus(\n http: HttpClient,\n executionResultId: string,\n signal?: AbortSignal,\n): Promise<{ status: ExecutionStatus | string }> {\n return http.requestJson(\"GET\", `/flows/execution-status/${executionResultId}`, { signal });\n}\n","import type { HttpClient } from \"../http/http-client.js\";\nimport type { DocmanaApiExecutionResult } from \"../models/docmana-api-execution-result.model.js\";\n\nexport async function getResult(\n http: HttpClient,\n executionResultId: string,\n signal?: AbortSignal,\n): Promise<DocmanaApiExecutionResult> {\n return http.requestJson(\"GET\", `/flows/execution-result/${executionResultId}`, { signal });\n}\n","import { DocmanaTimeoutError, DocmanaAbortError } from \"../errors.js\";\n\nconst TERMINAL = new Set([\"Completed\", \"Failed\"]);\n\nexport interface PollOptions {\n check: () => Promise<string>;\n intervalMs: number;\n timeoutMs: number;\n sleep?: (ms: number) => Promise<void>;\n elapsed?: () => number;\n signal?: AbortSignal;\n}\n\nconst defaultSleep = (ms: number) => new Promise<void>((r) => setTimeout(r, ms));\n\nexport async function pollUntilTerminal(opts: PollOptions): Promise<string> {\n const sleep = opts.sleep ?? defaultSleep;\n const start = Date.now();\n const elapsed = opts.elapsed ?? (() => Date.now() - start);\n for (;;) {\n if (opts.signal?.aborted) throw new DocmanaAbortError(\"Polling aborted\");\n const status = await opts.check();\n if (TERMINAL.has(status)) return status;\n if (elapsed() >= opts.timeoutMs) {\n throw new DocmanaTimeoutError(`Execution did not finish within ${opts.timeoutMs}ms`);\n }\n await sleep(opts.intervalMs);\n }\n}\n","import { DocmanaError } from \"../errors.js\";\nimport type { DocmanaApiExecutionResult } from \"../models/docmana-api-execution-result.model.js\";\nimport type { DocmanaApiNodeResult } from \"../models/docmana-api-node-result.model.js\";\nimport type { DocmanaExecutionResult } from \"../models/docmana-execution-result.model.js\";\nimport type { DocmanaDocumentResult } from \"../models/docmana-document-result.model.js\";\nimport type { DocmanaNodeResult } from \"../models/docmana-node-result.model.js\";\nimport type { DocmanaScoreNodeResult } from \"../models/docmana-score-node-result.model.js\";\nimport type { DocmanaCrossValidationResult } from \"../models/docmana-cross-validation-result.model.js\";\nimport type { DocmanaConclusionResult } from \"../models/docmana-conclusion-result.model.js\";\n\nfunction extractNodeFields(\n rawNode: DocmanaApiNodeResult,\n targetLanguage?: string,\n): DocmanaNodeResult {\n const metadataFields = new Set([\n \"node_id\",\n \"node_name\",\n \"node_type\",\n \"feature_name\",\n \"running_time\",\n \"status\",\n \"score\",\n \"feedback\",\n \"translations\",\n \"tokens\",\n \"input_tokens\",\n \"output_tokens\",\n \"errors\",\n \"mana\",\n \"model\",\n \"tool_calls\",\n \"prompt_id\",\n \"prompt\",\n \"prompt_name\",\n \"label\",\n \"scoreDescription\",\n \"score_description\",\n \"result\",\n \"documentType\",\n ]);\n\n let sourceObj: Record<string, unknown> = rawNode;\n if (targetLanguage) {\n const translations = rawNode.translations;\n if (!translations || !translations[targetLanguage]) {\n throw new DocmanaError(\n `Translation for language '${targetLanguage}' is missing on node '${rawNode.node_name || rawNode.node_id}'`,\n { code: \"translation_missing\", status: 400 },\n );\n }\n sourceObj = translations[targetLanguage] as Record<string, unknown>;\n }\n\n const dynamicFields: Record<string, unknown> = {};\n for (const [key, value] of Object.entries(sourceObj)) {\n if (!metadataFields.has(key)) {\n dynamicFields[key] = value;\n }\n }\n\n const sdkNode: DocmanaScoreNodeResult = {\n status: rawNode.status || \"Unknown\",\n };\n\n if (rawNode.errors && rawNode.errors.length > 0) {\n sdkNode.errors = rawNode.errors;\n }\n\n const nodeType = rawNode.node_type || \"\";\n const isScoreNode = /^(Validation|Classification|CrossValidation|Conclusion)$/i.test(nodeType);\n if (isScoreNode) {\n if (rawNode.score !== undefined && rawNode.score !== null) {\n sdkNode.score = rawNode.score;\n }\n if (rawNode.feedback !== undefined && rawNode.feedback !== null) {\n sdkNode.feedback = rawNode.feedback;\n }\n }\n\n if (Object.keys(dynamicFields).length > 0) {\n sdkNode.data = dynamicFields;\n }\n\n return sdkNode;\n}\n\nexport function mapExecutionResult(\n raw: DocmanaApiExecutionResult,\n targetLanguage?: string,\n): DocmanaExecutionResult {\n const sdkResult: DocmanaExecutionResult = {\n status: raw.status || \"Unknown\",\n executionId: String(raw.execution_id || raw.executionResultId || raw.execution_result_id || \"\"),\n documents: {\n mappings: [],\n },\n };\n\n if (raw.errors && raw.errors.length > 0) {\n sdkResult.errors = raw.errors;\n }\n\n const results = raw.results || [];\n\n for (const item of results) {\n const isDocSpecific = !!item.document;\n\n if (isDocSpecific && item.document) {\n const docReq = item.document;\n const docKey = docReq.doc_key || \"unknown_doc\";\n const docName = docReq.name || \"\";\n\n sdkResult.documents.mappings.push({\n name: docName,\n reference: docKey,\n });\n\n const docResult: DocmanaDocumentResult = {\n status: item.status || docReq.status || \"Unknown\",\n extractions: {},\n validations: {},\n };\n\n const nodeResults = item.node_results || [];\n\n for (const node of nodeResults) {\n const nodeType = node.node_type || \"\";\n const nodeName = node.node_name || node.node_id || \"unknown_node\";\n\n if (/^Classification$/i.test(nodeType)) {\n const mappedNode = extractNodeFields(node, targetLanguage);\n if (!docResult.classifications) {\n docResult.classifications = {};\n }\n docResult.classifications[nodeName] = mappedNode;\n } else if (/^MetadataExtraction$/i.test(nodeType)) {\n docResult.metadataExtraction = extractNodeFields(node, targetLanguage);\n } else if (/^Extraction$/i.test(nodeType)) {\n if (docResult.extractions) {\n docResult.extractions[nodeName] = extractNodeFields(node, targetLanguage);\n }\n } else if (/^Validation$/i.test(nodeType)) {\n if (docResult.validations) {\n docResult.validations[nodeName] = extractNodeFields(node, targetLanguage);\n }\n }\n }\n\n if (docResult.extractions && Object.keys(docResult.extractions).length === 0) {\n delete docResult.extractions;\n }\n if (docResult.validations && Object.keys(docResult.validations).length === 0) {\n delete docResult.validations;\n }\n\n sdkResult.documents[docKey] = docResult;\n } else {\n const nodeResults = item.node_results || [];\n for (const node of nodeResults) {\n const nodeType = node.node_type || \"\";\n const nodeName = node.node_name || node.node_id || \"unknown_node\";\n\n if (/^CrossValidation$/i.test(nodeType)) {\n if (!sdkResult.crossValidations) {\n sdkResult.crossValidations = {};\n }\n sdkResult.crossValidations[nodeName] = extractNodeFields(\n node,\n targetLanguage,\n ) as DocmanaCrossValidationResult;\n } else if (/^(Conclusion|Finish)$/i.test(nodeType)) {\n if (!sdkResult.conclusions) {\n sdkResult.conclusions = {};\n }\n sdkResult.conclusions[nodeName] = extractNodeFields(\n node,\n targetLanguage,\n ) as DocmanaConclusionResult;\n }\n }\n }\n }\n\n return sdkResult;\n}\n","import { resolveConfig } from \"./config.js\";\nimport type { ResolvedConfig } from \"./config.js\";\nimport type {\n DocmanaConfig,\n DocmanaExecutionResult,\n ExecutionStatus,\n RunFlowInput,\n} from \"./types.js\";\nimport { TokenManager } from \"./auth/token-manager.js\";\nimport { HttpClient } from \"./http/http-client.js\";\nimport { resolveInputs } from \"./files/resolve-input.js\";\nimport { uploadFiles } from \"./api/upload.js\";\nimport { runFlow as runFlowApi } from \"./api/run-flow.js\";\nimport { getStatus as getStatusApi } from \"./api/execution-status.js\";\nimport { getResult as getResultApi } from \"./api/execution-result.js\";\nimport { pollUntilTerminal } from \"./polling/poll.js\";\nimport { DocmanaExecutionError } from \"./errors.js\";\nimport { mapExecutionResult } from \"./mappers/index.js\";\n\nexport class Docmana {\n private readonly config: ResolvedConfig;\n private readonly http: HttpClient;\n\n constructor(config: DocmanaConfig) {\n this.config = resolveConfig(config);\n const tokenManager = new TokenManager({\n clientId: this.config.clientId,\n clientSecret: this.config.clientSecret,\n tokenEndpoint: this.config.tokenEndpoint,\n scope: this.config.scope,\n fetchImpl: this.config.fetchImpl,\n tokenCache: this.config.tokenCache,\n });\n this.http = new HttpClient({\n apiBaseUrl: this.config.apiBaseUrl,\n fetchImpl: this.config.fetchImpl,\n tokenManager,\n headers: this.config.headers,\n });\n }\n\n async runFlowAsync(\n flowId: string,\n input: RunFlowInput,\n ): Promise<{ executionResultId: string; fileIds: string[] }> {\n const parts = await resolveInputs(input);\n const fileIds = await uploadFiles(this.http, parts, input.signal);\n const executionResultId = await runFlowApi(\n this.http,\n flowId,\n fileIds,\n input.signal,\n input.once ?? false,\n );\n return { executionResultId, fileIds };\n }\n\n async getStatus(\n executionResultId: string,\n signal?: AbortSignal,\n ): Promise<{ status: ExecutionStatus | string }> {\n return getStatusApi(this.http, executionResultId, signal);\n }\n\n async getResult(\n executionResultId: string,\n signal?: AbortSignal,\n language?: string,\n ): Promise<DocmanaExecutionResult> {\n const rawResult = await getResultApi(this.http, executionResultId, signal);\n return mapExecutionResult(rawResult, language);\n }\n\n async runFlow(flowId: string, input: RunFlowInput): Promise<DocmanaExecutionResult> {\n const { executionResultId } = await this.runFlowAsync(flowId, input);\n await pollUntilTerminal({\n check: async () => (await this.getStatus(executionResultId, input.signal)).status,\n intervalMs: input.pollIntervalMs ?? this.config.pollIntervalMs,\n timeoutMs: input.timeoutMs ?? this.config.timeoutMs,\n signal: input.signal,\n });\n const result = await this.getResult(executionResultId, input.signal, input.language);\n if (result.status === \"Failed\") {\n throw new DocmanaExecutionError(\n `Flow ${flowId} execution failed`,\n result.errors ?? [],\n result,\n );\n }\n return result;\n }\n}\n"],"mappings":";;;;;;;;;;;;;;;;;;;;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;;;ACGO,IAAM,WAAW;AAAA,EACtB,YAAY;AAAA,EACZ,eACE;AAAA,EACF,OAAO;AAAA,EACP,WAAW;AAAA,EACX,gBAAgB;AAClB;AAeO,SAAS,cAAc,QAAuC;AACnE,MAAI,CAAC,OAAO,SAAU,OAAM,IAAI,MAAM,oCAAoC;AAC1E,MAAI,CAAC,OAAO,aAAc,OAAM,IAAI,MAAM,wCAAwC;AAClF,QAAM,cAAc,OAAO,cAAc,SAAS,YAAY,QAAQ,QAAQ,EAAE;AAChF,SAAO;AAAA,IACL,UAAU,OAAO;AAAA,IACjB,cAAc,OAAO;AAAA,IACrB;AAAA,IACA,eAAe,OAAO,iBAAiB,SAAS;AAAA,IAChD,OAAO,OAAO,SAAS,SAAS;AAAA,IAChC,WAAW,OAAO,aAAa,SAAS;AAAA,IACxC,gBAAgB,OAAO,kBAAkB,SAAS;AAAA,IAClD,WAAW,OAAO,SAAS;AAAA,IAC3B,SAAS,OAAO,WAAW,CAAC;AAAA,IAC5B,YAAY,OAAO;AAAA,EACrB;AACF;;;ACvCO,IAAM,eAAN,cAA2B,MAAM;AAAA,EAC7B;AAAA,EACA;AAAA,EACA;AAAA,EACT,YAAY,SAAiB,OAA+D,CAAC,GAAG;AAC9F,UAAM,OAAO;AACb,SAAK,OAAO,WAAW;AACvB,SAAK,SAAS,KAAK;AACnB,SAAK,YAAY,KAAK;AACtB,SAAK,OAAO,KAAK,QAAQ;AACzB,WAAO,eAAe,MAAM,WAAW,SAAS;AAAA,EAClD;AACF;AAEO,IAAM,mBAAN,cAA+B,aAAa;AAAA,EACjD,YAAY,SAAiB,OAAgD,CAAC,GAAG;AAC/E,UAAM,SAAS,EAAE,GAAG,MAAM,MAAM,aAAa,CAAC;AAAA,EAChD;AACF;AAEO,IAAM,yBAAN,cAAqC,aAAa;AAAA,EACvD,YAAY,SAAiB,OAAgD,CAAC,GAAG;AAC/E,UAAM,SAAS,EAAE,GAAG,MAAM,MAAM,mBAAmB,CAAC;AAAA,EACtD;AACF;AAEO,IAAM,uBAAN,cAAmC,aAAa;AAAA,EACrD,YAAY,SAAiB,OAAgD,CAAC,GAAG;AAC/E,UAAM,SAAS,EAAE,GAAG,MAAM,MAAM,YAAY,CAAC;AAAA,EAC/C;AACF;AAEO,IAAM,sBAAN,cAAkC,aAAa;AAAA,EACpD,YAAY,SAAiB,OAAgD,CAAC,GAAG;AAC/E,UAAM,SAAS,EAAE,GAAG,MAAM,MAAM,cAAc,CAAC;AAAA,EACjD;AACF;AAEO,IAAM,wBAAN,cAAoC,aAAa;AAAA,EAC7C;AAAA,EACA;AAAA,EACT,YAAY,SAAiB,SAAoB,CAAC,GAAG,QAAiC;AACpF,UAAM,SAAS,EAAE,MAAM,mBAAmB,CAAC;AAC3C,SAAK,SAAS;AACd,SAAK,SAAS;AAAA,EAChB;AACF;AAEO,IAAM,sBAAN,cAAkC,aAAa;AAAA,EACpD,YAAY,SAAiB;AAC3B,UAAM,SAAS,EAAE,MAAM,UAAU,CAAC;AAAA,EACpC;AACF;AAEO,IAAM,oBAAN,cAAgC,aAAa;AAAA,EAClD,YAAY,SAAiB;AAC3B,UAAM,SAAS,EAAE,MAAM,UAAU,CAAC;AAAA,EACpC;AACF;AAEO,SAAS,kBACd,QACA,SACA,WACc;AACd,QAAM,OAAO,EAAE,QAAQ,UAAU;AACjC,UAAQ,QAAQ;AAAA,IACd,KAAK;AACH,aAAO,IAAI,oBAAoB,SAAS,IAAI;AAAA,IAC9C,KAAK;AACH,aAAO,IAAI,iBAAiB,SAAS,IAAI;AAAA,IAC3C,KAAK;AACH,aAAO,IAAI,uBAAuB,SAAS,IAAI;AAAA,IACjD,KAAK;AACH,aAAO,IAAI,qBAAqB,SAAS,IAAI;AAAA,IAC/C;AACE,aAAO,IAAI,aAAa,SAAS,IAAI;AAAA,EACzC;AACF;;;AC7EA,IAAM,mBAAmB;AAWlB,IAAM,eAAN,MAAmB;AAAA,EAKxB,YAA6B,MAA2B;AAA3B;AAAA,EAA4B;AAAA,EAA5B;AAAA,EAJrB,QAAuB;AAAA,EACvB,YAAY;AAAA,EACZ,WAAmC;AAAA,EAI3C,aAAmB;AACjB,SAAK,QAAQ;AACb,SAAK,YAAY;AACjB,SAAK,KAAK,KAAK,YAAY,MAAM,EAAE,MAAM,MAAM,MAAS;AAAA,EAC1D;AAAA,EAEA,MAAM,WAA4B;AAChC,QAAI,KAAK,SAAS,KAAK,IAAI,IAAI,KAAK,UAAW,QAAO,KAAK;AAC3D,UAAM,SAAS,MAAM,KAAK,gBAAgB;AAC1C,QAAI,OAAQ,QAAO;AACnB,QAAI,KAAK,SAAU,QAAO,KAAK;AAC/B,SAAK,WAAW,KAAK,QAAQ,EAAE,QAAQ,MAAM;AAC3C,WAAK,WAAW;AAAA,IAClB,CAAC;AACD,WAAO,KAAK;AAAA,EACd;AAAA,EAEA,MAAc,UAA2B;AACvC,UAAM,OAAO,IAAI,gBAAgB;AAAA,MAC/B,YAAY;AAAA,MACZ,WAAW,KAAK,KAAK;AAAA,MACrB,eAAe,KAAK,KAAK;AAAA,MACzB,OAAO,KAAK,KAAK;AAAA,IACnB,CAAC;AACD,UAAM,MAAM,MAAM,KAAK,KAAK,UAAU,KAAK,KAAK,eAAe;AAAA,MAC7D,QAAQ;AAAA,MACR,SAAS,EAAE,gBAAgB,oCAAoC;AAAA,MAC/D,MAAM,KAAK,SAAS;AAAA,IACtB,CAAC;AACD,QAAI,CAAC,IAAI,IAAI;AAEX,YAAM,IAAI,iBAAiB,0CAA0C,EAAE,QAAQ,IAAI,OAAO,CAAC;AAAA,IAC7F;AACA,UAAM,OAAQ,MAAM,IAAI,KAAK;AAC7B,QACE,OAAO,KAAK,iBAAiB,YAC7B,KAAK,aAAa,WAAW,KAC7B,OAAO,KAAK,eAAe,YAC3B,CAAC,OAAO,SAAS,KAAK,UAAU,GAChC;AACA,YAAM,IAAI,iBAAiB,8CAA8C;AAAA,QACvE,QAAQ,IAAI;AAAA,MACd,CAAC;AAAA,IACH;AACA,SAAK,QAAQ,KAAK;AAClB,SAAK,YAAY,KAAK,IAAI,IAAI,KAAK,aAAa,MAAO;AACvD,UAAM,KAAK,iBAAiB,EAAE,MAAM,MAAM,MAAS;AACnD,WAAO,KAAK;AAAA,EACd;AAAA,EAEA,MAAc,kBAA0C;AACtD,QAAI,CAAC,KAAK,KAAK,WAAY,QAAO;AAClC,QAAI;AACJ,QAAI;AACF,cAAQ,MAAM,KAAK,KAAK,WAAW,KAAK;AAAA,IAC1C,QAAQ;AACN,aAAO;AAAA,IACT;AACA,QAAI,CAAC,MAAO,QAAO;AACnB,QACE,MAAM,aAAa,KAAK,KAAK,YAC7B,MAAM,kBAAkB,KAAK,KAAK,iBAClC,MAAM,UAAU,KAAK,KAAK,SAC1B,KAAK,IAAI,KAAK,MAAM,WACpB;AACA,YAAM,KAAK,KAAK,WAAW,MAAM,EAAE,MAAM,MAAM,MAAS;AACxD,aAAO;AAAA,IACT;AACA,SAAK,QAAQ,MAAM;AACnB,SAAK,YAAY,MAAM;AACvB,WAAO,KAAK;AAAA,EACd;AAAA,EAEA,MAAc,mBAAkC;AAC9C,QAAI,CAAC,KAAK,KAAK,cAAc,CAAC,KAAK,MAAO;AAC1C,UAAM,KAAK,KAAK,WAAW,MAAM;AAAA,MAC/B,aAAa,KAAK;AAAA,MAClB,WAAW,KAAK;AAAA,MAChB,UAAU,KAAK,KAAK;AAAA,MACpB,eAAe,KAAK,KAAK;AAAA,MACzB,OAAO,KAAK,KAAK;AAAA,IACnB,CAAC;AAAA,EACH;AACF;;;ACrFO,IAAM,aAAN,MAAiB;AAAA,EACtB,YAA6B,MAAyB;AAAzB;AAAA,EAA0B;AAAA,EAA1B;AAAA,EAE7B,MAAM,YAAe,QAAgB,MAAc,UAA0B,CAAC,GAAe;AAC3F,UAAM,MAAM,MAAM,KAAK,WAAW,QAAQ,MAAM,OAAO;AACvD,UAAM,OAAO,MAAM,IAAI,KAAK;AAC5B,QAAI,CAAC,KAAM,QAAO,CAAC;AACnB,QAAI;AACF,aAAO,KAAK,MAAM,IAAI;AAAA,IACxB,QAAQ;AACN,YAAM,IAAI,aAAa,sCAAsC,EAAE,QAAQ,IAAI,OAAO,CAAC;AAAA,IACrF;AAAA,EACF;AAAA,EAEA,MAAM,WAAW,QAAgB,MAAc,UAA0B,CAAC,GAAsB;AAC9F,QAAI,MAAM,MAAM,KAAK,KAAK,QAAQ,MAAM,OAAO;AAC/C,QAAI,IAAI,WAAW,KAAK;AACtB,WAAK,KAAK,aAAa,WAAW;AAClC,YAAM,MAAM,KAAK,KAAK,QAAQ,MAAM,OAAO;AAAA,IAC7C;AACA,QAAI,CAAC,IAAI,IAAI;AACX,YAAM,YAAY,IAAI,QAAQ,IAAI,cAAc,KAAK;AACrD,YAAM,UAAU,MAAM,KAAK,eAAe,GAAG;AAC7C,YAAM,kBAAkB,IAAI,QAAQ,SAAS,SAAS;AAAA,IACxD;AACA,WAAO;AAAA,EACT;AAAA,EAEA,MAAc,KAAK,QAAgB,MAAc,SAA4C;AAC3F,UAAM,QAAQ,MAAM,KAAK,KAAK,aAAa,SAAS;AACpD,UAAM,MAAM,IAAI,IAAI,KAAK,KAAK,aAAa,IAAI;AAC/C,eAAW,CAAC,GAAG,CAAC,KAAK,OAAO,QAAQ,QAAQ,SAAS,CAAC,CAAC,EAAG,KAAI,aAAa,IAAI,GAAG,CAAC;AACnF,UAAM,UAAkC;AAAA,MACtC,GAAI,KAAK,KAAK,WAAW,CAAC;AAAA,MAC1B,eAAe,UAAU,KAAK;AAAA,MAC9B,GAAI,QAAQ,WAAW,CAAC;AAAA,IAC1B;AACA,QAAI;AACF,aAAO,MAAM,KAAK,KAAK,UAAU,KAAK;AAAA,QACpC;AAAA,QACA;AAAA,QACA,MAAM,QAAQ;AAAA,QACd,QAAQ,QAAQ;AAAA,MAClB,CAAC;AAAA,IACH,SAAS,KAAK;AACZ,UAAI,QAAQ,QAAQ,WAAY,eAAe,SAAS,IAAI,SAAS,cAAe;AAClF,cAAM,IAAI,kBAAkB,iBAAiB;AAAA,MAC/C;AACA,YAAM;AAAA,IACR;AAAA,EACF;AAAA,EAEA,MAAc,eAAe,KAAgC;AAC3D,QAAI;AACF,YAAM,OAAQ,MAAM,IAAI,MAAM,EAAE,KAAK;AACrC,aAAO,KAAK,WAAW,KAAK,SAAS,IAAI,cAAc,QAAQ,IAAI,MAAM;AAAA,IAC3E,QAAQ;AACN,aAAO,IAAI,cAAc,QAAQ,IAAI,MAAM;AAAA,IAC7C;AAAA,EACF;AACF;;;AC/EA,sBAAyB;AACzB,uBAAyB;AAUzB,IAAM,gBAAwC;AAAA,EAC5C,QAAQ;AAAA,EACR,QAAQ;AAAA,EACR,QAAQ;AAAA,EACR,SAAS;AAAA,EACT,QAAQ;AAAA,EACR,SAAS;AAAA,EACT,QAAQ;AAAA,EACR,SAAS;AACX;AAEA,SAAS,eAAe,MAAsB;AAC5C,QAAM,MAAM,KAAK,YAAY,GAAG;AAChC,MAAI,MAAM,EAAG,QAAO;AACpB,QAAM,MAAM,KAAK,MAAM,GAAG,EAAE,YAAY;AACxC,SAAO,cAAc,GAAG,KAAK;AAC/B;AAEA,SAAS,WAAW,GAA2B;AAC7C,SAAO,OAAO,MAAM,YAAY,MAAM,QAAQ,OAAQ,EAAe,SAAS;AAChF;AAEA,SAAS,YAAY,GAAmC;AACtD,SAAO,OAAO,MAAM,YAAY,MAAM,QAAQ,OAAQ,EAAyB,SAAS;AAC1F;AAEA,eAAe,eAAe,QAAmC;AAC/D,QAAM,SAAmB,CAAC;AAC1B,mBAAiB,SAAS,OAAQ,QAAO,KAAK,OAAO,KAAK,KAAK,CAAC;AAChE,SAAO,OAAO,OAAO,MAAM;AAC7B;AAEA,eAAe,WAAW,OAAkB,cAA6C;AACvF,MAAI,OAAO,UAAU,YAAY,YAAY,KAAK,GAAG;AACnD,UAAM,OAAO,OAAO,UAAU,WAAW,QAAQ,MAAM;AACvD,UAAM,OAAO,UAAM,0BAAS,IAAI;AAChC,UAAM,eAAW,2BAAS,IAAI;AAC9B,WAAO,EAAE,MAAM,IAAI,KAAK,CAAC,IAAI,CAAC,GAAG,UAAU,aAAa,eAAe,QAAQ,EAAE;AAAA,EACnF;AACA,MAAI,iBAAiB,YAAY;AAC/B,WAAO;AAAA,MACL,MAAM,IAAI,KAAK,CAAC,KAAK,CAAC;AAAA,MACtB,UAAU;AAAA,MACV,aAAa,eAAe,YAAY;AAAA,IAC1C;AAAA,EACF;AACA,MAAI,WAAW,KAAK,GAAG;AACrB,UAAM,MAAM,MAAM,eAAe,KAAK;AACtC,WAAO;AAAA,MACL,MAAM,IAAI,KAAK,CAAC,GAAG,CAAC;AAAA,MACpB,UAAU;AAAA,MACV,aAAa,eAAe,YAAY;AAAA,IAC1C;AAAA,EACF;AACA,QAAM,IAAI,MAAM,6BAA6B;AAC/C;AAEA,eAAsB,cAAc,OAA8C;AAChF,QAAM,OAAoB,MAAM,UAAU,MAAM,SAAS,SAAY,CAAC,MAAM,IAAI,IAAI,CAAC;AACrF,MAAI,KAAK,WAAW,EAAG,OAAM,IAAI,MAAM,oCAAoC;AAC3E,QAAM,WAAW,MAAM,YAAY;AACnC,SAAO,QAAQ,IAAI,KAAK,IAAI,CAAC,SAAS,WAAW,MAAM,QAAQ,CAAC,CAAC;AACnE;;;ACtEA,eAAsB,YACpB,MACA,OACA,QACmB;AAMnB,QAAM,OAAO,IAAI,SAAS;AAC1B,aAAW,QAAQ,OAAO;AACxB,SAAK,OAAO,SAAS,IAAI,KAAK,CAAC,KAAK,IAAI,GAAG,KAAK,UAAU,EAAE,MAAM,KAAK,YAAY,CAAC,CAAC;AAAA,EACvF;AACA,QAAM,MAAM,MAAM,KAAK,YAA4B,QAAQ,WAAW,EAAE,MAAM,MAAM,OAAO,CAAC;AAC5F,SAAO,CAAC,IAAI,EAAE;AAChB;;;ACjBA,eAAsB,QACpB,MACA,QACA,WACA,QACA,OAAO,OACU;AACjB,QAAM,OAAO,OAAO,wBAAwB,MAAM,KAAK,mBAAmB,MAAM;AAChF,QAAM,MAAM,MAAM,KAAK,YAA6C,QAAQ,MAAM;AAAA,IAChF,OAAO,EAAE,YAAY,OAAO;AAAA,IAC5B,SAAS,EAAE,gBAAgB,mBAAmB;AAAA,IAC9C,MAAM,KAAK,UAAU,EAAE,YAAY,UAAU,CAAC;AAAA,IAC9C;AAAA,EACF,CAAC;AACD,SAAO,IAAI;AACb;;;ACdA,eAAsB,UACpB,MACA,mBACA,QAC+C;AAC/C,SAAO,KAAK,YAAY,OAAO,2BAA2B,iBAAiB,IAAI,EAAE,OAAO,CAAC;AAC3F;;;ACNA,eAAsB,UACpB,MACA,mBACA,QACoC;AACpC,SAAO,KAAK,YAAY,OAAO,2BAA2B,iBAAiB,IAAI,EAAE,OAAO,CAAC;AAC3F;;;ACPA,IAAM,WAAW,oBAAI,IAAI,CAAC,aAAa,QAAQ,CAAC;AAWhD,IAAM,eAAe,CAAC,OAAe,IAAI,QAAc,CAAC,MAAM,WAAW,GAAG,EAAE,CAAC;AAE/E,eAAsB,kBAAkB,MAAoC;AAC1E,QAAM,QAAQ,KAAK,SAAS;AAC5B,QAAM,QAAQ,KAAK,IAAI;AACvB,QAAM,UAAU,KAAK,YAAY,MAAM,KAAK,IAAI,IAAI;AACpD,aAAS;AACP,QAAI,KAAK,QAAQ,QAAS,OAAM,IAAI,kBAAkB,iBAAiB;AACvE,UAAM,SAAS,MAAM,KAAK,MAAM;AAChC,QAAI,SAAS,IAAI,MAAM,EAAG,QAAO;AACjC,QAAI,QAAQ,KAAK,KAAK,WAAW;AAC/B,YAAM,IAAI,oBAAoB,mCAAmC,KAAK,SAAS,IAAI;AAAA,IACrF;AACA,UAAM,MAAM,KAAK,UAAU;AAAA,EAC7B;AACF;;;AClBA,SAAS,kBACP,SACA,gBACmB;AACnB,QAAM,iBAAiB,oBAAI,IAAI;AAAA,IAC7B;AAAA,IACA;AAAA,IACA;AAAA,IACA;AAAA,IACA;AAAA,IACA;AAAA,IACA;AAAA,IACA;AAAA,IACA;AAAA,IACA;AAAA,IACA;AAAA,IACA;AAAA,IACA;AAAA,IACA;AAAA,IACA;AAAA,IACA;AAAA,IACA;AAAA,IACA;AAAA,IACA;AAAA,IACA;AAAA,IACA;AAAA,IACA;AAAA,IACA;AAAA,IACA;AAAA,EACF,CAAC;AAED,MAAI,YAAqC;AACzC,MAAI,gBAAgB;AAClB,UAAM,eAAe,QAAQ;AAC7B,QAAI,CAAC,gBAAgB,CAAC,aAAa,cAAc,GAAG;AAClD,YAAM,IAAI;AAAA,QACR,6BAA6B,cAAc,yBAAyB,QAAQ,aAAa,QAAQ,OAAO;AAAA,QACxG,EAAE,MAAM,uBAAuB,QAAQ,IAAI;AAAA,MAC7C;AAAA,IACF;AACA,gBAAY,aAAa,cAAc;AAAA,EACzC;AAEA,QAAM,gBAAyC,CAAC;AAChD,aAAW,CAAC,KAAK,KAAK,KAAK,OAAO,QAAQ,SAAS,GAAG;AACpD,QAAI,CAAC,eAAe,IAAI,GAAG,GAAG;AAC5B,oBAAc,GAAG,IAAI;AAAA,IACvB;AAAA,EACF;AAEA,QAAM,UAAkC;AAAA,IACtC,QAAQ,QAAQ,UAAU;AAAA,EAC5B;AAEA,MAAI,QAAQ,UAAU,QAAQ,OAAO,SAAS,GAAG;AAC/C,YAAQ,SAAS,QAAQ;AAAA,EAC3B;AAEA,QAAM,WAAW,QAAQ,aAAa;AACtC,QAAM,cAAc,4DAA4D,KAAK,QAAQ;AAC7F,MAAI,aAAa;AACf,QAAI,QAAQ,UAAU,UAAa,QAAQ,UAAU,MAAM;AACzD,cAAQ,QAAQ,QAAQ;AAAA,IAC1B;AACA,QAAI,QAAQ,aAAa,UAAa,QAAQ,aAAa,MAAM;AAC/D,cAAQ,WAAW,QAAQ;AAAA,IAC7B;AAAA,EACF;AAEA,MAAI,OAAO,KAAK,aAAa,EAAE,SAAS,GAAG;AACzC,YAAQ,OAAO;AAAA,EACjB;AAEA,SAAO;AACT;AAEO,SAAS,mBACd,KACA,gBACwB;AACxB,QAAM,YAAoC;AAAA,IACxC,QAAQ,IAAI,UAAU;AAAA,IACtB,aAAa,OAAO,IAAI,gBAAgB,IAAI,qBAAqB,IAAI,uBAAuB,EAAE;AAAA,IAC9F,WAAW;AAAA,MACT,UAAU,CAAC;AAAA,IACb;AAAA,EACF;AAEA,MAAI,IAAI,UAAU,IAAI,OAAO,SAAS,GAAG;AACvC,cAAU,SAAS,IAAI;AAAA,EACzB;AAEA,QAAM,UAAU,IAAI,WAAW,CAAC;AAEhC,aAAW,QAAQ,SAAS;AAC1B,UAAM,gBAAgB,CAAC,CAAC,KAAK;AAE7B,QAAI,iBAAiB,KAAK,UAAU;AAClC,YAAM,SAAS,KAAK;AACpB,YAAM,SAAS,OAAO,WAAW;AACjC,YAAM,UAAU,OAAO,QAAQ;AAE/B,gBAAU,UAAU,SAAS,KAAK;AAAA,QAChC,MAAM;AAAA,QACN,WAAW;AAAA,MACb,CAAC;AAED,YAAM,YAAmC;AAAA,QACvC,QAAQ,KAAK,UAAU,OAAO,UAAU;AAAA,QACxC,aAAa,CAAC;AAAA,QACd,aAAa,CAAC;AAAA,MAChB;AAEA,YAAM,cAAc,KAAK,gBAAgB,CAAC;AAE1C,iBAAW,QAAQ,aAAa;AAC9B,cAAM,WAAW,KAAK,aAAa;AACnC,cAAM,WAAW,KAAK,aAAa,KAAK,WAAW;AAEnD,YAAI,oBAAoB,KAAK,QAAQ,GAAG;AACtC,gBAAM,aAAa,kBAAkB,MAAM,cAAc;AACzD,cAAI,CAAC,UAAU,iBAAiB;AAC9B,sBAAU,kBAAkB,CAAC;AAAA,UAC/B;AACA,oBAAU,gBAAgB,QAAQ,IAAI;AAAA,QACxC,WAAW,wBAAwB,KAAK,QAAQ,GAAG;AACjD,oBAAU,qBAAqB,kBAAkB,MAAM,cAAc;AAAA,QACvE,WAAW,gBAAgB,KAAK,QAAQ,GAAG;AACzC,cAAI,UAAU,aAAa;AACzB,sBAAU,YAAY,QAAQ,IAAI,kBAAkB,MAAM,cAAc;AAAA,UAC1E;AAAA,QACF,WAAW,gBAAgB,KAAK,QAAQ,GAAG;AACzC,cAAI,UAAU,aAAa;AACzB,sBAAU,YAAY,QAAQ,IAAI,kBAAkB,MAAM,cAAc;AAAA,UAC1E;AAAA,QACF;AAAA,MACF;AAEA,UAAI,UAAU,eAAe,OAAO,KAAK,UAAU,WAAW,EAAE,WAAW,GAAG;AAC5E,eAAO,UAAU;AAAA,MACnB;AACA,UAAI,UAAU,eAAe,OAAO,KAAK,UAAU,WAAW,EAAE,WAAW,GAAG;AAC5E,eAAO,UAAU;AAAA,MACnB;AAEA,gBAAU,UAAU,MAAM,IAAI;AAAA,IAChC,OAAO;AACL,YAAM,cAAc,KAAK,gBAAgB,CAAC;AAC1C,iBAAW,QAAQ,aAAa;AAC9B,cAAM,WAAW,KAAK,aAAa;AACnC,cAAM,WAAW,KAAK,aAAa,KAAK,WAAW;AAEnD,YAAI,qBAAqB,KAAK,QAAQ,GAAG;AACvC,cAAI,CAAC,UAAU,kBAAkB;AAC/B,sBAAU,mBAAmB,CAAC;AAAA,UAChC;AACA,oBAAU,iBAAiB,QAAQ,IAAI;AAAA,YACrC;AAAA,YACA;AAAA,UACF;AAAA,QACF,WAAW,yBAAyB,KAAK,QAAQ,GAAG;AAClD,cAAI,CAAC,UAAU,aAAa;AAC1B,sBAAU,cAAc,CAAC;AAAA,UAC3B;AACA,oBAAU,YAAY,QAAQ,IAAI;AAAA,YAChC;AAAA,YACA;AAAA,UACF;AAAA,QACF;AAAA,MACF;AAAA,IACF;AAAA,EACF;AAEA,SAAO;AACT;;;ACrKO,IAAM,UAAN,MAAc;AAAA,EACF;AAAA,EACA;AAAA,EAEjB,YAAY,QAAuB;AACjC,SAAK,SAAS,cAAc,MAAM;AAClC,UAAM,eAAe,IAAI,aAAa;AAAA,MACpC,UAAU,KAAK,OAAO;AAAA,MACtB,cAAc,KAAK,OAAO;AAAA,MAC1B,eAAe,KAAK,OAAO;AAAA,MAC3B,OAAO,KAAK,OAAO;AAAA,MACnB,WAAW,KAAK,OAAO;AAAA,MACvB,YAAY,KAAK,OAAO;AAAA,IAC1B,CAAC;AACD,SAAK,OAAO,IAAI,WAAW;AAAA,MACzB,YAAY,KAAK,OAAO;AAAA,MACxB,WAAW,KAAK,OAAO;AAAA,MACvB;AAAA,MACA,SAAS,KAAK,OAAO;AAAA,IACvB,CAAC;AAAA,EACH;AAAA,EAEA,MAAM,aACJ,QACA,OAC2D;AAC3D,UAAM,QAAQ,MAAM,cAAc,KAAK;AACvC,UAAM,UAAU,MAAM,YAAY,KAAK,MAAM,OAAO,MAAM,MAAM;AAChE,UAAM,oBAAoB,MAAM;AAAA,MAC9B,KAAK;AAAA,MACL;AAAA,MACA;AAAA,MACA,MAAM;AAAA,MACN,MAAM,QAAQ;AAAA,IAChB;AACA,WAAO,EAAE,mBAAmB,QAAQ;AAAA,EACtC;AAAA,EAEA,MAAM,UACJ,mBACA,QAC+C;AAC/C,WAAO,UAAa,KAAK,MAAM,mBAAmB,MAAM;AAAA,EAC1D;AAAA,EAEA,MAAM,UACJ,mBACA,QACA,UACiC;AACjC,UAAM,YAAY,MAAM,UAAa,KAAK,MAAM,mBAAmB,MAAM;AACzE,WAAO,mBAAmB,WAAW,QAAQ;AAAA,EAC/C;AAAA,EAEA,MAAM,QAAQ,QAAgB,OAAsD;AAClF,UAAM,EAAE,kBAAkB,IAAI,MAAM,KAAK,aAAa,QAAQ,KAAK;AACnE,UAAM,kBAAkB;AAAA,MACtB,OAAO,aAAa,MAAM,KAAK,UAAU,mBAAmB,MAAM,MAAM,GAAG;AAAA,MAC3E,YAAY,MAAM,kBAAkB,KAAK,OAAO;AAAA,MAChD,WAAW,MAAM,aAAa,KAAK,OAAO;AAAA,MAC1C,QAAQ,MAAM;AAAA,IAChB,CAAC;AACD,UAAM,SAAS,MAAM,KAAK,UAAU,mBAAmB,MAAM,QAAQ,MAAM,QAAQ;AACnF,QAAI,OAAO,WAAW,UAAU;AAC9B,YAAM,IAAI;AAAA,QACR,QAAQ,MAAM;AAAA,QACd,OAAO,UAAU,CAAC;AAAA,QAClB;AAAA,MACF;AAAA,IACF;AACA,WAAO;AAAA,EACT;AACF;","names":[]}
|