feat(ocr): add a Mistral-based OCR adapter for KVM frames

This commit is contained in:
2026-05-18 00:16:58 +00:00
parent 8588c6c70d
commit 91d9be3fe7
7 changed files with 841 additions and 23 deletions
+46
View File
@@ -0,0 +1,46 @@
import { createMistralOcrEngine } from '@push.rocks/smartai/ocr';
import type {
ISmartAiMistralOcrTransport,
TSmartAiMistralOcrConfidenceScoresGranularity,
TSmartAiMistralOcrTableFormat,
} from '@push.rocks/smartai/ocr';
import type { IOcrEngine, IOcrResult } from './smartkvm.interfaces.js';
export interface ISmartKvmMistralOcrEngineOptions {
apiKey?: string;
model?: string;
endpointUrl?: string;
transport?: ISmartAiMistralOcrTransport;
includeImageBase64?: boolean;
tableFormat?: TSmartAiMistralOcrTableFormat;
extractHeader?: boolean;
extractFooter?: boolean;
confidenceScoresGranularity?: TSmartAiMistralOcrConfidenceScoresGranularity;
}
export const createMistralKvmOcrEngine = (
options: ISmartKvmMistralOcrEngineOptions = {}
): IOcrEngine => {
const smartAiOcrEngine = createMistralOcrEngine({
...options,
confidenceScoresGranularity: options.confidenceScoresGranularity ?? 'page',
});
return {
recognize: async (frame, recognizeOptions = {}): Promise<IOcrResult> => {
if (recognizeOptions.crop) {
throw new Error('Mistral KVM OCR does not support crop options yet.');
}
const result = await smartAiOcrEngine.recognizeImage({
dataBase64: frame.dataBase64,
mimeType: frame.mimeType,
});
return {
text: result.text,
confidence: result.confidence,
};
},
};
};