ocr-provenance-mcp 1.0.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.

Potentially problematic release.


This version of ocr-provenance-mcp might be problematic. Click here for more details.

Files changed (578) hide show
  1. package/.env.example +55 -0
  2. package/LICENSE +78 -0
  3. package/README.md +1154 -0
  4. package/dist/bin-http.d.ts +24 -0
  5. package/dist/bin-http.d.ts.map +1 -0
  6. package/dist/bin-http.js +275 -0
  7. package/dist/bin-http.js.map +1 -0
  8. package/dist/bin-setup.d.ts +11 -0
  9. package/dist/bin-setup.d.ts.map +1 -0
  10. package/dist/bin-setup.js +610 -0
  11. package/dist/bin-setup.js.map +1 -0
  12. package/dist/bin.d.ts +16 -0
  13. package/dist/bin.d.ts.map +1 -0
  14. package/dist/bin.js +16 -0
  15. package/dist/bin.js.map +1 -0
  16. package/dist/index.d.ts +13 -0
  17. package/dist/index.d.ts.map +1 -0
  18. package/dist/index.js +90 -0
  19. package/dist/index.js.map +1 -0
  20. package/dist/models/chunk.d.ts +136 -0
  21. package/dist/models/chunk.d.ts.map +1 -0
  22. package/dist/models/chunk.js +27 -0
  23. package/dist/models/chunk.js.map +1 -0
  24. package/dist/models/cluster.d.ts +79 -0
  25. package/dist/models/cluster.d.ts.map +1 -0
  26. package/dist/models/cluster.js +10 -0
  27. package/dist/models/cluster.js.map +1 -0
  28. package/dist/models/comparison.d.ts +62 -0
  29. package/dist/models/comparison.d.ts.map +1 -0
  30. package/dist/models/comparison.js +8 -0
  31. package/dist/models/comparison.js.map +1 -0
  32. package/dist/models/document.d.ts +104 -0
  33. package/dist/models/document.d.ts.map +1 -0
  34. package/dist/models/document.js +15 -0
  35. package/dist/models/document.js.map +1 -0
  36. package/dist/models/embedding.d.ts +87 -0
  37. package/dist/models/embedding.d.ts.map +1 -0
  38. package/dist/models/embedding.js +23 -0
  39. package/dist/models/embedding.js.map +1 -0
  40. package/dist/models/extraction.d.ts +15 -0
  41. package/dist/models/extraction.d.ts.map +1 -0
  42. package/dist/models/extraction.js +2 -0
  43. package/dist/models/extraction.js.map +1 -0
  44. package/dist/models/form-fill.d.ts +23 -0
  45. package/dist/models/form-fill.d.ts.map +1 -0
  46. package/dist/models/form-fill.js +2 -0
  47. package/dist/models/form-fill.js.map +1 -0
  48. package/dist/models/image.d.ts +177 -0
  49. package/dist/models/image.d.ts.map +1 -0
  50. package/dist/models/image.js +8 -0
  51. package/dist/models/image.js.map +1 -0
  52. package/dist/models/index.d.ts +14 -0
  53. package/dist/models/index.d.ts.map +1 -0
  54. package/dist/models/index.js +22 -0
  55. package/dist/models/index.js.map +1 -0
  56. package/dist/models/provenance.d.ts +174 -0
  57. package/dist/models/provenance.d.ts.map +1 -0
  58. package/dist/models/provenance.js +53 -0
  59. package/dist/models/provenance.js.map +1 -0
  60. package/dist/models/uploaded-file.d.ts +20 -0
  61. package/dist/models/uploaded-file.d.ts.map +1 -0
  62. package/dist/models/uploaded-file.js +2 -0
  63. package/dist/models/uploaded-file.js.map +1 -0
  64. package/dist/server/errors.d.ts +93 -0
  65. package/dist/server/errors.d.ts.map +1 -0
  66. package/dist/server/errors.js +256 -0
  67. package/dist/server/errors.js.map +1 -0
  68. package/dist/server/events.d.ts +36 -0
  69. package/dist/server/events.d.ts.map +1 -0
  70. package/dist/server/events.js +48 -0
  71. package/dist/server/events.js.map +1 -0
  72. package/dist/server/permissions.d.ts +26 -0
  73. package/dist/server/permissions.d.ts.map +1 -0
  74. package/dist/server/permissions.js +194 -0
  75. package/dist/server/permissions.js.map +1 -0
  76. package/dist/server/register-tools.d.ts +25 -0
  77. package/dist/server/register-tools.d.ts.map +1 -0
  78. package/dist/server/register-tools.js +102 -0
  79. package/dist/server/register-tools.js.map +1 -0
  80. package/dist/server/startup.d.ts +16 -0
  81. package/dist/server/startup.d.ts.map +1 -0
  82. package/dist/server/startup.js +37 -0
  83. package/dist/server/startup.js.map +1 -0
  84. package/dist/server/state.d.ts +166 -0
  85. package/dist/server/state.d.ts.map +1 -0
  86. package/dist/server/state.js +424 -0
  87. package/dist/server/state.js.map +1 -0
  88. package/dist/server/transports/http-transport.d.ts +37 -0
  89. package/dist/server/transports/http-transport.d.ts.map +1 -0
  90. package/dist/server/transports/http-transport.js +204 -0
  91. package/dist/server/transports/http-transport.js.map +1 -0
  92. package/dist/server/transports/index.d.ts +9 -0
  93. package/dist/server/transports/index.d.ts.map +1 -0
  94. package/dist/server/transports/index.js +9 -0
  95. package/dist/server/transports/index.js.map +1 -0
  96. package/dist/server/transports/session-manager.d.ts +40 -0
  97. package/dist/server/transports/session-manager.d.ts.map +1 -0
  98. package/dist/server/transports/session-manager.js +74 -0
  99. package/dist/server/transports/session-manager.js.map +1 -0
  100. package/dist/server/types.d.ts +82 -0
  101. package/dist/server/types.d.ts.map +1 -0
  102. package/dist/server/types.js +14 -0
  103. package/dist/server/types.js.map +1 -0
  104. package/dist/services/audit.d.ts +26 -0
  105. package/dist/services/audit.d.ts.map +1 -0
  106. package/dist/services/audit.js +43 -0
  107. package/dist/services/audit.js.map +1 -0
  108. package/dist/services/chunking/chunk-deduplicator.d.ts +33 -0
  109. package/dist/services/chunking/chunk-deduplicator.d.ts.map +1 -0
  110. package/dist/services/chunking/chunk-deduplicator.js +46 -0
  111. package/dist/services/chunking/chunk-deduplicator.js.map +1 -0
  112. package/dist/services/chunking/chunk-merger.d.ts +26 -0
  113. package/dist/services/chunking/chunk-merger.d.ts.map +1 -0
  114. package/dist/services/chunking/chunk-merger.js +94 -0
  115. package/dist/services/chunking/chunk-merger.js.map +1 -0
  116. package/dist/services/chunking/chunker.d.ts +62 -0
  117. package/dist/services/chunking/chunker.d.ts.map +1 -0
  118. package/dist/services/chunking/chunker.js +566 -0
  119. package/dist/services/chunking/chunker.js.map +1 -0
  120. package/dist/services/chunking/heading-normalizer.d.ts +33 -0
  121. package/dist/services/chunking/heading-normalizer.d.ts.map +1 -0
  122. package/dist/services/chunking/heading-normalizer.js +101 -0
  123. package/dist/services/chunking/heading-normalizer.js.map +1 -0
  124. package/dist/services/chunking/json-block-analyzer.d.ts +163 -0
  125. package/dist/services/chunking/json-block-analyzer.d.ts.map +1 -0
  126. package/dist/services/chunking/json-block-analyzer.js +1033 -0
  127. package/dist/services/chunking/json-block-analyzer.js.map +1 -0
  128. package/dist/services/chunking/markdown-parser.d.ts +75 -0
  129. package/dist/services/chunking/markdown-parser.d.ts.map +1 -0
  130. package/dist/services/chunking/markdown-parser.js +428 -0
  131. package/dist/services/chunking/markdown-parser.js.map +1 -0
  132. package/dist/services/chunking/text-normalizer.d.ts +20 -0
  133. package/dist/services/chunking/text-normalizer.d.ts.map +1 -0
  134. package/dist/services/chunking/text-normalizer.js +36 -0
  135. package/dist/services/chunking/text-normalizer.js.map +1 -0
  136. package/dist/services/clm/contract-schemas.d.ts +36 -0
  137. package/dist/services/clm/contract-schemas.d.ts.map +1 -0
  138. package/dist/services/clm/contract-schemas.js +92 -0
  139. package/dist/services/clm/contract-schemas.js.map +1 -0
  140. package/dist/services/clm/summarization.d.ts +46 -0
  141. package/dist/services/clm/summarization.d.ts.map +1 -0
  142. package/dist/services/clm/summarization.js +61 -0
  143. package/dist/services/clm/summarization.js.map +1 -0
  144. package/dist/services/clustering/clustering-service.d.ts +58 -0
  145. package/dist/services/clustering/clustering-service.d.ts.map +1 -0
  146. package/dist/services/clustering/clustering-service.js +467 -0
  147. package/dist/services/clustering/clustering-service.js.map +1 -0
  148. package/dist/services/comparison/diff-service.d.ts +41 -0
  149. package/dist/services/comparison/diff-service.d.ts.map +1 -0
  150. package/dist/services/comparison/diff-service.js +120 -0
  151. package/dist/services/comparison/diff-service.js.map +1 -0
  152. package/dist/services/embedding/embedder.d.ts +55 -0
  153. package/dist/services/embedding/embedder.d.ts.map +1 -0
  154. package/dist/services/embedding/embedder.js +202 -0
  155. package/dist/services/embedding/embedder.js.map +1 -0
  156. package/dist/services/embedding/nomic.d.ts +67 -0
  157. package/dist/services/embedding/nomic.d.ts.map +1 -0
  158. package/dist/services/embedding/nomic.js +280 -0
  159. package/dist/services/embedding/nomic.js.map +1 -0
  160. package/dist/services/gemini/circuit-breaker.d.ts +106 -0
  161. package/dist/services/gemini/circuit-breaker.d.ts.map +1 -0
  162. package/dist/services/gemini/circuit-breaker.js +237 -0
  163. package/dist/services/gemini/circuit-breaker.js.map +1 -0
  164. package/dist/services/gemini/client.d.ts +173 -0
  165. package/dist/services/gemini/client.d.ts.map +1 -0
  166. package/dist/services/gemini/client.js +483 -0
  167. package/dist/services/gemini/client.js.map +1 -0
  168. package/dist/services/gemini/config.d.ts +116 -0
  169. package/dist/services/gemini/config.d.ts.map +1 -0
  170. package/dist/services/gemini/config.js +118 -0
  171. package/dist/services/gemini/config.js.map +1 -0
  172. package/dist/services/gemini/index.d.ts +9 -0
  173. package/dist/services/gemini/index.d.ts.map +1 -0
  174. package/dist/services/gemini/index.js +13 -0
  175. package/dist/services/gemini/index.js.map +1 -0
  176. package/dist/services/gemini/rate-limiter.d.ts +62 -0
  177. package/dist/services/gemini/rate-limiter.d.ts.map +1 -0
  178. package/dist/services/gemini/rate-limiter.js +120 -0
  179. package/dist/services/gemini/rate-limiter.js.map +1 -0
  180. package/dist/services/images/extractor.d.ts +88 -0
  181. package/dist/services/images/extractor.d.ts.map +1 -0
  182. package/dist/services/images/extractor.js +340 -0
  183. package/dist/services/images/extractor.js.map +1 -0
  184. package/dist/services/images/optimizer.d.ts +130 -0
  185. package/dist/services/images/optimizer.d.ts.map +1 -0
  186. package/dist/services/images/optimizer.js +228 -0
  187. package/dist/services/images/optimizer.js.map +1 -0
  188. package/dist/services/ocr/datalab.d.ts +64 -0
  189. package/dist/services/ocr/datalab.d.ts.map +1 -0
  190. package/dist/services/ocr/datalab.js +425 -0
  191. package/dist/services/ocr/datalab.js.map +1 -0
  192. package/dist/services/ocr/errors.d.ts +38 -0
  193. package/dist/services/ocr/errors.d.ts.map +1 -0
  194. package/dist/services/ocr/errors.js +83 -0
  195. package/dist/services/ocr/errors.js.map +1 -0
  196. package/dist/services/ocr/file-manager.d.ts +76 -0
  197. package/dist/services/ocr/file-manager.d.ts.map +1 -0
  198. package/dist/services/ocr/file-manager.js +238 -0
  199. package/dist/services/ocr/file-manager.js.map +1 -0
  200. package/dist/services/ocr/form-fill.d.ts +48 -0
  201. package/dist/services/ocr/form-fill.d.ts.map +1 -0
  202. package/dist/services/ocr/form-fill.js +213 -0
  203. package/dist/services/ocr/form-fill.js.map +1 -0
  204. package/dist/services/ocr/processor.d.ts +95 -0
  205. package/dist/services/ocr/processor.d.ts.map +1 -0
  206. package/dist/services/ocr/processor.js +259 -0
  207. package/dist/services/ocr/processor.js.map +1 -0
  208. package/dist/services/provenance/agent-metadata.d.ts +82 -0
  209. package/dist/services/provenance/agent-metadata.d.ts.map +1 -0
  210. package/dist/services/provenance/agent-metadata.js +106 -0
  211. package/dist/services/provenance/agent-metadata.js.map +1 -0
  212. package/dist/services/provenance/chain-hash.d.ts +57 -0
  213. package/dist/services/provenance/chain-hash.d.ts.map +1 -0
  214. package/dist/services/provenance/chain-hash.js +131 -0
  215. package/dist/services/provenance/chain-hash.js.map +1 -0
  216. package/dist/services/provenance/exporter.d.ts +202 -0
  217. package/dist/services/provenance/exporter.d.ts.map +1 -0
  218. package/dist/services/provenance/exporter.js +457 -0
  219. package/dist/services/provenance/exporter.js.map +1 -0
  220. package/dist/services/provenance/index.d.ts +15 -0
  221. package/dist/services/provenance/index.d.ts.map +1 -0
  222. package/dist/services/provenance/index.js +17 -0
  223. package/dist/services/provenance/index.js.map +1 -0
  224. package/dist/services/provenance/tracker.d.ts +138 -0
  225. package/dist/services/provenance/tracker.d.ts.map +1 -0
  226. package/dist/services/provenance/tracker.js +293 -0
  227. package/dist/services/provenance/tracker.js.map +1 -0
  228. package/dist/services/provenance/verifier.d.ts +153 -0
  229. package/dist/services/provenance/verifier.d.ts.map +1 -0
  230. package/dist/services/provenance/verifier.js +536 -0
  231. package/dist/services/provenance/verifier.js.map +1 -0
  232. package/dist/services/python-pool.d.ts +70 -0
  233. package/dist/services/python-pool.d.ts.map +1 -0
  234. package/dist/services/python-pool.js +265 -0
  235. package/dist/services/python-pool.js.map +1 -0
  236. package/dist/services/search/bm25.d.ts +180 -0
  237. package/dist/services/search/bm25.d.ts.map +1 -0
  238. package/dist/services/search/bm25.js +656 -0
  239. package/dist/services/search/bm25.js.map +1 -0
  240. package/dist/services/search/fusion.d.ts +103 -0
  241. package/dist/services/search/fusion.d.ts.map +1 -0
  242. package/dist/services/search/fusion.js +122 -0
  243. package/dist/services/search/fusion.js.map +1 -0
  244. package/dist/services/search/local-reranker.d.ts +30 -0
  245. package/dist/services/search/local-reranker.d.ts.map +1 -0
  246. package/dist/services/search/local-reranker.js +123 -0
  247. package/dist/services/search/local-reranker.js.map +1 -0
  248. package/dist/services/search/quality.d.ts +11 -0
  249. package/dist/services/search/quality.d.ts.map +1 -0
  250. package/dist/services/search/quality.js +17 -0
  251. package/dist/services/search/quality.js.map +1 -0
  252. package/dist/services/search/query-classifier.d.ts +34 -0
  253. package/dist/services/search/query-classifier.d.ts.map +1 -0
  254. package/dist/services/search/query-classifier.js +114 -0
  255. package/dist/services/search/query-classifier.js.map +1 -0
  256. package/dist/services/search/query-expander.d.ts +73 -0
  257. package/dist/services/search/query-expander.d.ts.map +1 -0
  258. package/dist/services/search/query-expander.js +281 -0
  259. package/dist/services/search/query-expander.js.map +1 -0
  260. package/dist/services/search/reranker.d.ts +44 -0
  261. package/dist/services/search/reranker.d.ts.map +1 -0
  262. package/dist/services/search/reranker.js +101 -0
  263. package/dist/services/search/reranker.js.map +1 -0
  264. package/dist/services/storage/database/annotation-operations.d.ts +113 -0
  265. package/dist/services/storage/database/annotation-operations.d.ts.map +1 -0
  266. package/dist/services/storage/database/annotation-operations.js +177 -0
  267. package/dist/services/storage/database/annotation-operations.js.map +1 -0
  268. package/dist/services/storage/database/approval-operations.d.ts +132 -0
  269. package/dist/services/storage/database/approval-operations.d.ts.map +1 -0
  270. package/dist/services/storage/database/approval-operations.js +206 -0
  271. package/dist/services/storage/database/approval-operations.js.map +1 -0
  272. package/dist/services/storage/database/chunk-operations.d.ts +132 -0
  273. package/dist/services/storage/database/chunk-operations.d.ts.map +1 -0
  274. package/dist/services/storage/database/chunk-operations.js +306 -0
  275. package/dist/services/storage/database/chunk-operations.js.map +1 -0
  276. package/dist/services/storage/database/cluster-operations.d.ts +97 -0
  277. package/dist/services/storage/database/cluster-operations.d.ts.map +1 -0
  278. package/dist/services/storage/database/cluster-operations.js +258 -0
  279. package/dist/services/storage/database/cluster-operations.js.map +1 -0
  280. package/dist/services/storage/database/comparison-operations.d.ts +41 -0
  281. package/dist/services/storage/database/comparison-operations.d.ts.map +1 -0
  282. package/dist/services/storage/database/comparison-operations.js +65 -0
  283. package/dist/services/storage/database/comparison-operations.js.map +1 -0
  284. package/dist/services/storage/database/converters.d.ts +36 -0
  285. package/dist/services/storage/database/converters.d.ts.map +1 -0
  286. package/dist/services/storage/database/converters.js +244 -0
  287. package/dist/services/storage/database/converters.js.map +1 -0
  288. package/dist/services/storage/database/document-operations.d.ts +145 -0
  289. package/dist/services/storage/database/document-operations.d.ts.map +1 -0
  290. package/dist/services/storage/database/document-operations.js +498 -0
  291. package/dist/services/storage/database/document-operations.js.map +1 -0
  292. package/dist/services/storage/database/embedding-operations.d.ts +130 -0
  293. package/dist/services/storage/database/embedding-operations.d.ts.map +1 -0
  294. package/dist/services/storage/database/embedding-operations.js +315 -0
  295. package/dist/services/storage/database/embedding-operations.js.map +1 -0
  296. package/dist/services/storage/database/extraction-operations.d.ts +47 -0
  297. package/dist/services/storage/database/extraction-operations.d.ts.map +1 -0
  298. package/dist/services/storage/database/extraction-operations.js +85 -0
  299. package/dist/services/storage/database/extraction-operations.js.map +1 -0
  300. package/dist/services/storage/database/form-fill-operations.d.ts +58 -0
  301. package/dist/services/storage/database/form-fill-operations.d.ts.map +1 -0
  302. package/dist/services/storage/database/form-fill-operations.js +116 -0
  303. package/dist/services/storage/database/form-fill-operations.js.map +1 -0
  304. package/dist/services/storage/database/helpers.d.ts +29 -0
  305. package/dist/services/storage/database/helpers.d.ts.map +1 -0
  306. package/dist/services/storage/database/helpers.js +55 -0
  307. package/dist/services/storage/database/helpers.js.map +1 -0
  308. package/dist/services/storage/database/image-operations.d.ts +202 -0
  309. package/dist/services/storage/database/image-operations.d.ts.map +1 -0
  310. package/dist/services/storage/database/image-operations.js +484 -0
  311. package/dist/services/storage/database/image-operations.js.map +1 -0
  312. package/dist/services/storage/database/index.d.ts +13 -0
  313. package/dist/services/storage/database/index.d.ts.map +1 -0
  314. package/dist/services/storage/database/index.js +16 -0
  315. package/dist/services/storage/database/index.js.map +1 -0
  316. package/dist/services/storage/database/lock-operations.d.ts +59 -0
  317. package/dist/services/storage/database/lock-operations.d.ts.map +1 -0
  318. package/dist/services/storage/database/lock-operations.js +89 -0
  319. package/dist/services/storage/database/lock-operations.js.map +1 -0
  320. package/dist/services/storage/database/obligation-operations.d.ts +88 -0
  321. package/dist/services/storage/database/obligation-operations.d.ts.map +1 -0
  322. package/dist/services/storage/database/obligation-operations.js +206 -0
  323. package/dist/services/storage/database/obligation-operations.js.map +1 -0
  324. package/dist/services/storage/database/ocr-operations.d.ts +33 -0
  325. package/dist/services/storage/database/ocr-operations.d.ts.map +1 -0
  326. package/dist/services/storage/database/ocr-operations.js +70 -0
  327. package/dist/services/storage/database/ocr-operations.js.map +1 -0
  328. package/dist/services/storage/database/playbook-operations.d.ts +72 -0
  329. package/dist/services/storage/database/playbook-operations.d.ts.map +1 -0
  330. package/dist/services/storage/database/playbook-operations.js +247 -0
  331. package/dist/services/storage/database/playbook-operations.js.map +1 -0
  332. package/dist/services/storage/database/provenance-operations.d.ts +112 -0
  333. package/dist/services/storage/database/provenance-operations.d.ts.map +1 -0
  334. package/dist/services/storage/database/provenance-operations.js +251 -0
  335. package/dist/services/storage/database/provenance-operations.js.map +1 -0
  336. package/dist/services/storage/database/service.d.ts +142 -0
  337. package/dist/services/storage/database/service.d.ts.map +1 -0
  338. package/dist/services/storage/database/service.js +310 -0
  339. package/dist/services/storage/database/service.js.map +1 -0
  340. package/dist/services/storage/database/static-operations.d.ts +30 -0
  341. package/dist/services/storage/database/static-operations.d.ts.map +1 -0
  342. package/dist/services/storage/database/static-operations.js +218 -0
  343. package/dist/services/storage/database/static-operations.js.map +1 -0
  344. package/dist/services/storage/database/stats-operations.d.ts +101 -0
  345. package/dist/services/storage/database/stats-operations.d.ts.map +1 -0
  346. package/dist/services/storage/database/stats-operations.js +394 -0
  347. package/dist/services/storage/database/stats-operations.js.map +1 -0
  348. package/dist/services/storage/database/tag-operations.d.ts +76 -0
  349. package/dist/services/storage/database/tag-operations.d.ts.map +1 -0
  350. package/dist/services/storage/database/tag-operations.js +178 -0
  351. package/dist/services/storage/database/tag-operations.js.map +1 -0
  352. package/dist/services/storage/database/types.d.ts +286 -0
  353. package/dist/services/storage/database/types.d.ts.map +1 -0
  354. package/dist/services/storage/database/types.js +39 -0
  355. package/dist/services/storage/database/types.js.map +1 -0
  356. package/dist/services/storage/database/upload-operations.d.ts +71 -0
  357. package/dist/services/storage/database/upload-operations.d.ts.map +1 -0
  358. package/dist/services/storage/database/upload-operations.js +124 -0
  359. package/dist/services/storage/database/upload-operations.js.map +1 -0
  360. package/dist/services/storage/database/user-operations.d.ts +102 -0
  361. package/dist/services/storage/database/user-operations.d.ts.map +1 -0
  362. package/dist/services/storage/database/user-operations.js +151 -0
  363. package/dist/services/storage/database/user-operations.js.map +1 -0
  364. package/dist/services/storage/database/workflow-operations.d.ts +98 -0
  365. package/dist/services/storage/database/workflow-operations.d.ts.map +1 -0
  366. package/dist/services/storage/database/workflow-operations.js +157 -0
  367. package/dist/services/storage/database/workflow-operations.js.map +1 -0
  368. package/dist/services/storage/database.d.ts +16 -0
  369. package/dist/services/storage/database.d.ts.map +1 -0
  370. package/dist/services/storage/database.js +15 -0
  371. package/dist/services/storage/database.js.map +1 -0
  372. package/dist/services/storage/index.d.ts +10 -0
  373. package/dist/services/storage/index.d.ts.map +1 -0
  374. package/dist/services/storage/index.js +10 -0
  375. package/dist/services/storage/index.js.map +1 -0
  376. package/dist/services/storage/migrations/index.d.ts +16 -0
  377. package/dist/services/storage/migrations/index.d.ts.map +1 -0
  378. package/dist/services/storage/migrations/index.js +20 -0
  379. package/dist/services/storage/migrations/index.js.map +1 -0
  380. package/dist/services/storage/migrations/operations.d.ts +40 -0
  381. package/dist/services/storage/migrations/operations.d.ts.map +1 -0
  382. package/dist/services/storage/migrations/operations.js +2910 -0
  383. package/dist/services/storage/migrations/operations.js.map +1 -0
  384. package/dist/services/storage/migrations/schema-definitions.d.ts +306 -0
  385. package/dist/services/storage/migrations/schema-definitions.d.ts.map +1 -0
  386. package/dist/services/storage/migrations/schema-definitions.js +1006 -0
  387. package/dist/services/storage/migrations/schema-definitions.js.map +1 -0
  388. package/dist/services/storage/migrations/schema-helpers.d.ts +50 -0
  389. package/dist/services/storage/migrations/schema-helpers.d.ts.map +1 -0
  390. package/dist/services/storage/migrations/schema-helpers.js +176 -0
  391. package/dist/services/storage/migrations/schema-helpers.js.map +1 -0
  392. package/dist/services/storage/migrations/types.d.ts +15 -0
  393. package/dist/services/storage/migrations/types.d.ts.map +1 -0
  394. package/dist/services/storage/migrations/types.js +21 -0
  395. package/dist/services/storage/migrations/types.js.map +1 -0
  396. package/dist/services/storage/migrations/verification.d.ts +20 -0
  397. package/dist/services/storage/migrations/verification.d.ts.map +1 -0
  398. package/dist/services/storage/migrations/verification.js +78 -0
  399. package/dist/services/storage/migrations/verification.js.map +1 -0
  400. package/dist/services/storage/migrations.d.ts +16 -0
  401. package/dist/services/storage/migrations.d.ts.map +1 -0
  402. package/dist/services/storage/migrations.js +17 -0
  403. package/dist/services/storage/migrations.js.map +1 -0
  404. package/dist/services/storage/types.d.ts +12 -0
  405. package/dist/services/storage/types.d.ts.map +1 -0
  406. package/dist/services/storage/types.js +5 -0
  407. package/dist/services/storage/types.js.map +1 -0
  408. package/dist/services/storage/vector.d.ts +208 -0
  409. package/dist/services/storage/vector.d.ts.map +1 -0
  410. package/dist/services/storage/vector.js +526 -0
  411. package/dist/services/storage/vector.js.map +1 -0
  412. package/dist/services/vlm/pipeline.d.ts +194 -0
  413. package/dist/services/vlm/pipeline.d.ts.map +1 -0
  414. package/dist/services/vlm/pipeline.js +800 -0
  415. package/dist/services/vlm/pipeline.js.map +1 -0
  416. package/dist/services/vlm/prompts.d.ts +171 -0
  417. package/dist/services/vlm/prompts.d.ts.map +1 -0
  418. package/dist/services/vlm/prompts.js +229 -0
  419. package/dist/services/vlm/prompts.js.map +1 -0
  420. package/dist/services/vlm/service.d.ts +174 -0
  421. package/dist/services/vlm/service.d.ts.map +1 -0
  422. package/dist/services/vlm/service.js +256 -0
  423. package/dist/services/vlm/service.js.map +1 -0
  424. package/dist/services/webhook-delivery.d.ts +4 -0
  425. package/dist/services/webhook-delivery.d.ts.map +1 -0
  426. package/dist/services/webhook-delivery.js +140 -0
  427. package/dist/services/webhook-delivery.js.map +1 -0
  428. package/dist/tools/chunks.d.ts +19 -0
  429. package/dist/tools/chunks.d.ts.map +1 -0
  430. package/dist/tools/chunks.js +392 -0
  431. package/dist/tools/chunks.js.map +1 -0
  432. package/dist/tools/clm.d.ts +16 -0
  433. package/dist/tools/clm.d.ts.map +1 -0
  434. package/dist/tools/clm.js +668 -0
  435. package/dist/tools/clm.js.map +1 -0
  436. package/dist/tools/clustering.d.ts +13 -0
  437. package/dist/tools/clustering.d.ts.map +1 -0
  438. package/dist/tools/clustering.js +498 -0
  439. package/dist/tools/clustering.js.map +1 -0
  440. package/dist/tools/collaboration.d.ts +15 -0
  441. package/dist/tools/collaboration.d.ts.map +1 -0
  442. package/dist/tools/collaboration.js +516 -0
  443. package/dist/tools/collaboration.js.map +1 -0
  444. package/dist/tools/comparison.d.ts +13 -0
  445. package/dist/tools/comparison.d.ts.map +1 -0
  446. package/dist/tools/comparison.js +735 -0
  447. package/dist/tools/comparison.js.map +1 -0
  448. package/dist/tools/compliance.d.ts +15 -0
  449. package/dist/tools/compliance.d.ts.map +1 -0
  450. package/dist/tools/compliance.js +640 -0
  451. package/dist/tools/compliance.js.map +1 -0
  452. package/dist/tools/config.d.ts +19 -0
  453. package/dist/tools/config.d.ts.map +1 -0
  454. package/dist/tools/config.js +213 -0
  455. package/dist/tools/config.js.map +1 -0
  456. package/dist/tools/database.d.ts +62 -0
  457. package/dist/tools/database.d.ts.map +1 -0
  458. package/dist/tools/database.js +288 -0
  459. package/dist/tools/database.js.map +1 -0
  460. package/dist/tools/documents.d.ts +61 -0
  461. package/dist/tools/documents.d.ts.map +1 -0
  462. package/dist/tools/documents.js +1624 -0
  463. package/dist/tools/documents.js.map +1 -0
  464. package/dist/tools/embeddings.d.ts +14 -0
  465. package/dist/tools/embeddings.d.ts.map +1 -0
  466. package/dist/tools/embeddings.js +626 -0
  467. package/dist/tools/embeddings.js.map +1 -0
  468. package/dist/tools/evaluation.d.ts +25 -0
  469. package/dist/tools/evaluation.d.ts.map +1 -0
  470. package/dist/tools/evaluation.js +523 -0
  471. package/dist/tools/evaluation.js.map +1 -0
  472. package/dist/tools/events.d.ts +16 -0
  473. package/dist/tools/events.d.ts.map +1 -0
  474. package/dist/tools/events.js +493 -0
  475. package/dist/tools/events.js.map +1 -0
  476. package/dist/tools/extraction-structured.d.ts +13 -0
  477. package/dist/tools/extraction-structured.d.ts.map +1 -0
  478. package/dist/tools/extraction-structured.js +390 -0
  479. package/dist/tools/extraction-structured.js.map +1 -0
  480. package/dist/tools/extraction.d.ts +24 -0
  481. package/dist/tools/extraction.d.ts.map +1 -0
  482. package/dist/tools/extraction.js +424 -0
  483. package/dist/tools/extraction.js.map +1 -0
  484. package/dist/tools/file-management.d.ts +14 -0
  485. package/dist/tools/file-management.d.ts.map +1 -0
  486. package/dist/tools/file-management.js +523 -0
  487. package/dist/tools/file-management.js.map +1 -0
  488. package/dist/tools/form-fill.d.ts +13 -0
  489. package/dist/tools/form-fill.d.ts.map +1 -0
  490. package/dist/tools/form-fill.js +250 -0
  491. package/dist/tools/form-fill.js.map +1 -0
  492. package/dist/tools/health.d.ts +19 -0
  493. package/dist/tools/health.d.ts.map +1 -0
  494. package/dist/tools/health.js +229 -0
  495. package/dist/tools/health.js.map +1 -0
  496. package/dist/tools/images.d.ts +54 -0
  497. package/dist/tools/images.d.ts.map +1 -0
  498. package/dist/tools/images.js +787 -0
  499. package/dist/tools/images.js.map +1 -0
  500. package/dist/tools/ingestion.d.ts +94 -0
  501. package/dist/tools/ingestion.d.ts.map +1 -0
  502. package/dist/tools/ingestion.js +1659 -0
  503. package/dist/tools/ingestion.js.map +1 -0
  504. package/dist/tools/intelligence.d.ts +18 -0
  505. package/dist/tools/intelligence.d.ts.map +1 -0
  506. package/dist/tools/intelligence.js +1039 -0
  507. package/dist/tools/intelligence.js.map +1 -0
  508. package/dist/tools/provenance.d.ts +51 -0
  509. package/dist/tools/provenance.d.ts.map +1 -0
  510. package/dist/tools/provenance.js +691 -0
  511. package/dist/tools/provenance.js.map +1 -0
  512. package/dist/tools/reports.d.ts +41 -0
  513. package/dist/tools/reports.d.ts.map +1 -0
  514. package/dist/tools/reports.js +1394 -0
  515. package/dist/tools/reports.js.map +1 -0
  516. package/dist/tools/search.d.ts +35 -0
  517. package/dist/tools/search.d.ts.map +1 -0
  518. package/dist/tools/search.js +2528 -0
  519. package/dist/tools/search.js.map +1 -0
  520. package/dist/tools/shared.d.ts +52 -0
  521. package/dist/tools/shared.d.ts.map +1 -0
  522. package/dist/tools/shared.js +54 -0
  523. package/dist/tools/shared.js.map +1 -0
  524. package/dist/tools/tags.d.ts +15 -0
  525. package/dist/tools/tags.d.ts.map +1 -0
  526. package/dist/tools/tags.js +287 -0
  527. package/dist/tools/tags.js.map +1 -0
  528. package/dist/tools/timeline.d.ts +15 -0
  529. package/dist/tools/timeline.d.ts.map +1 -0
  530. package/dist/tools/timeline.js +14 -0
  531. package/dist/tools/timeline.js.map +1 -0
  532. package/dist/tools/users.d.ts +14 -0
  533. package/dist/tools/users.d.ts.map +1 -0
  534. package/dist/tools/users.js +257 -0
  535. package/dist/tools/users.js.map +1 -0
  536. package/dist/tools/vlm.d.ts +40 -0
  537. package/dist/tools/vlm.d.ts.map +1 -0
  538. package/dist/tools/vlm.js +475 -0
  539. package/dist/tools/vlm.js.map +1 -0
  540. package/dist/tools/workflow.d.ts +16 -0
  541. package/dist/tools/workflow.d.ts.map +1 -0
  542. package/dist/tools/workflow.js +495 -0
  543. package/dist/tools/workflow.js.map +1 -0
  544. package/dist/utils/backoff.d.ts +53 -0
  545. package/dist/utils/backoff.d.ts.map +1 -0
  546. package/dist/utils/backoff.js +78 -0
  547. package/dist/utils/backoff.js.map +1 -0
  548. package/dist/utils/config-persistence.d.ts +33 -0
  549. package/dist/utils/config-persistence.d.ts.map +1 -0
  550. package/dist/utils/config-persistence.js +61 -0
  551. package/dist/utils/config-persistence.js.map +1 -0
  552. package/dist/utils/hash.d.ts +65 -0
  553. package/dist/utils/hash.d.ts.map +1 -0
  554. package/dist/utils/hash.js +146 -0
  555. package/dist/utils/hash.js.map +1 -0
  556. package/dist/utils/math.d.ts +21 -0
  557. package/dist/utils/math.d.ts.map +1 -0
  558. package/dist/utils/math.js +39 -0
  559. package/dist/utils/math.js.map +1 -0
  560. package/dist/utils/validation.d.ts +697 -0
  561. package/dist/utils/validation.d.ts.map +1 -0
  562. package/dist/utils/validation.js +529 -0
  563. package/dist/utils/validation.js.map +1 -0
  564. package/package.json +96 -0
  565. package/python/.gitkeep +0 -0
  566. package/python/__init__.py +104 -0
  567. package/python/clustering_worker.py +440 -0
  568. package/python/docx_image_extractor.py +524 -0
  569. package/python/embedding_worker.py +552 -0
  570. package/python/file_manager_worker.py +564 -0
  571. package/python/form_fill_worker.py +399 -0
  572. package/python/gpu_utils.py +582 -0
  573. package/python/image_extractor.py +317 -0
  574. package/python/image_optimizer.py +444 -0
  575. package/python/ocr_worker.py +712 -0
  576. package/python/pyproject.toml +76 -0
  577. package/python/requirements.txt +51 -0
  578. package/python/reranker_worker.py +87 -0
@@ -0,0 +1,444 @@
1
+ #!/usr/bin/env python3
2
+ """
3
+ Image Optimizer and Relevance Analyzer for VLM Pipeline.
4
+
5
+ Provides two key functions:
6
+ 1. Resize images for VLM (optimize token usage)
7
+ 2. Analyze image relevance to filter out logos, icons, and decorative elements
8
+
9
+ The relevance analysis uses a multi-layer heuristic approach:
10
+ - Layer 1: Size filtering (tiny images are likely icons)
11
+ - Layer 2: Aspect ratio analysis (extreme ratios = banners/logos)
12
+ - Layer 3: Color diversity (low color count = likely logo/icon)
13
+ - Layer 4: Optional VLM pre-classification for borderline cases
14
+
15
+ Usage:
16
+ # Resize for VLM
17
+ python image_optimizer.py --resize-for-vlm /path/to/image.png --output /tmp/resized.png
18
+
19
+ # Analyze image relevance (full analysis)
20
+ python image_optimizer.py --analyze /path/to/image.png
21
+
22
+ Output:
23
+ JSON to stdout with operation results.
24
+ """
25
+
26
+ import argparse
27
+ import json
28
+ import sys
29
+ from dataclasses import dataclass
30
+ from enum import Enum
31
+ from typing import Any
32
+
33
+ try:
34
+ from PIL import Image
35
+ except ImportError:
36
+ print(json.dumps({"success": False, "error": "Pillow not installed. Run: pip install Pillow"}))
37
+ sys.exit(1)
38
+
39
+
40
+ class ImageCategory(Enum):
41
+ """Classification of image types for VLM relevance filtering."""
42
+
43
+ PHOTO = "photo" # Photographs, screenshots - HIGH relevance
44
+ CHART = "chart" # Charts, graphs, diagrams - HIGH relevance
45
+ DOCUMENT = "document" # Scanned documents, forms - HIGH relevance
46
+ LOGO = "logo" # Company logos, branding - LOW relevance
47
+ ICON = "icon" # UI icons, small graphics - LOW relevance
48
+ DECORATIVE = "decorative" # Borders, lines, separators - LOW relevance
49
+ UNKNOWN = "unknown" # Cannot determine
50
+
51
+
52
+ @dataclass
53
+ class ImageAnalysis:
54
+ """Results of image relevance analysis."""
55
+
56
+ width: int
57
+ height: int
58
+ aspect_ratio: float
59
+ unique_colors: int
60
+ color_diversity_score: float # 0-1, higher = more diverse
61
+ size_score: float # 0-1, based on pixel count
62
+ aspect_score: float # 0-1, penalty for extreme ratios
63
+ overall_relevance: float # 0-1, combined score
64
+ predicted_category: ImageCategory
65
+ should_vlm: bool # Final recommendation
66
+ skip_reason: str | None # Why skipped, if applicable
67
+
68
+
69
+ # Thresholds for heuristic filtering
70
+ MIN_DIMENSION_VLM = 50 # Skip images smaller than this
71
+ MIN_RELEVANCE_SCORE = 0.35 # Below this = definitely skip VLM
72
+ LOGO_COLOR_THRESHOLD = 48 # Images with fewer colors likely logos
73
+ EXTREME_ASPECT_RATIO = 3.5 # Ratios > this are likely banners/decorative
74
+
75
+ # OCR and VLM size limits
76
+ VLM_MAX_DIMENSION = 2048 # Gemini optimal size
77
+
78
+
79
+ def get_color_diversity(img: Image.Image, sample_size: int = 10000) -> tuple[int, float]:
80
+ """
81
+ Analyze color diversity of an image.
82
+
83
+ Returns:
84
+ (unique_colors, diversity_score)
85
+ - unique_colors: Number of distinct colors in sample
86
+ - diversity_score: 0-1 normalized score (1 = very diverse)
87
+ """
88
+ # M-8: track intermediates for cleanup
89
+ rgb_img = None
90
+ sample_img = None
91
+ try:
92
+ # Convert to RGB if needed
93
+ if img.mode != "RGB":
94
+ rgb_img = img.convert("RGB")
95
+ work_img = rgb_img
96
+ else:
97
+ work_img = img
98
+
99
+ # Sample pixels for large images
100
+ width, height = work_img.size
101
+ total_pixels = width * height
102
+
103
+ if total_pixels > sample_size:
104
+ # Resize to get a representative sample
105
+ scale = (sample_size / total_pixels) ** 0.5
106
+ sample_img = work_img.resize(
107
+ (max(1, int(width * scale)), max(1, int(height * scale))), Image.Resampling.NEAREST
108
+ )
109
+ else:
110
+ sample_img = work_img
111
+
112
+ # Count unique colors
113
+ colors = sample_img.getcolors(maxcolors=65536)
114
+ if colors is None:
115
+ # More than 65536 colors = very diverse
116
+ return 65536, 1.0
117
+
118
+ unique_colors = len(colors)
119
+
120
+ # Normalize to 0-1 score
121
+ # Scale: 1 color = 0, 256+ colors = 1.0
122
+ if unique_colors <= 1:
123
+ diversity_score = 0.0
124
+ elif unique_colors >= 256:
125
+ diversity_score = 1.0
126
+ else:
127
+ # Log scale for smooth transition
128
+ import math
129
+
130
+ diversity_score = math.log2(unique_colors) / 8.0 # log2(256) = 8
131
+
132
+ return unique_colors, diversity_score
133
+ finally:
134
+ # M-8: close intermediate images (only if they are distinct objects)
135
+ if sample_img is not None and sample_img is not work_img:
136
+ sample_img.close()
137
+ if rgb_img is not None:
138
+ rgb_img.close()
139
+
140
+
141
+ def calculate_aspect_score(width: int, height: int) -> float:
142
+ """
143
+ Calculate aspect ratio score. Normal ratios score 1.0, extreme ratios score lower.
144
+
145
+ Common document/photo ratios (score ~1.0):
146
+ - 4:3, 16:9, 3:2, 1:1, A4 (1:1.41)
147
+
148
+ Suspicious ratios (score < 0.5):
149
+ - Very wide banners (10:1)
150
+ - Very tall sidebars (1:10)
151
+ """
152
+ if width == 0 or height == 0:
153
+ return 0.0
154
+
155
+ ratio = max(width, height) / min(width, height)
156
+
157
+ if ratio <= 2.0:
158
+ return 1.0 # Normal ratio
159
+ elif ratio <= EXTREME_ASPECT_RATIO:
160
+ # Linear decay from 1.0 to 0.5
161
+ return 1.0 - 0.5 * (ratio - 2.0) / (EXTREME_ASPECT_RATIO - 2.0)
162
+ else:
163
+ # Extreme ratio - likely banner/decorative
164
+ return max(0.1, 0.5 - 0.1 * (ratio - EXTREME_ASPECT_RATIO))
165
+
166
+
167
+ def calculate_size_score(width: int, height: int) -> float:
168
+ """
169
+ Calculate size score based on pixel count.
170
+
171
+ Larger images are more likely to contain meaningful content.
172
+ Very small images (<100px) are likely icons.
173
+ """
174
+ pixels = width * height
175
+
176
+ if pixels < 50 * 50:
177
+ return 0.0 # Tiny - definitely skip
178
+ elif pixels < 100 * 100:
179
+ return 0.2 # Very small - likely icon
180
+ elif pixels < 200 * 200:
181
+ return 0.4 # Small - possibly icon
182
+ elif pixels < 400 * 400:
183
+ return 0.7 # Medium - likely meaningful
184
+ else:
185
+ return 1.0 # Large - definitely meaningful
186
+
187
+
188
+ def predict_category(
189
+ width: int, height: int, unique_colors: int, color_diversity: float
190
+ ) -> ImageCategory:
191
+ """
192
+ Predict image category based on heuristics.
193
+ """
194
+ max_dim = max(width, height)
195
+ min_dim = min(width, height)
196
+ pixels = width * height
197
+ aspect_ratio = max_dim / min_dim if min_dim > 0 else 999
198
+
199
+ # Tiny images are icons
200
+ if max_dim < 64:
201
+ return ImageCategory.ICON
202
+
203
+ # Very few colors with small size = likely logo/icon
204
+ if unique_colors < 8 and max_dim < 200:
205
+ return ImageCategory.ICON
206
+
207
+ if unique_colors < LOGO_COLOR_THRESHOLD and max_dim < 400:
208
+ return ImageCategory.LOGO
209
+
210
+ # Extreme aspect ratio = decorative banner/separator
211
+ if aspect_ratio > 6:
212
+ return ImageCategory.DECORATIVE
213
+
214
+ # Medium-high color diversity with reasonable size = content
215
+ if color_diversity > 0.7 and pixels > 200 * 200:
216
+ return ImageCategory.PHOTO
217
+
218
+ # Moderate colors, could be chart or document
219
+ if LOGO_COLOR_THRESHOLD <= unique_colors < 256:
220
+ if aspect_ratio < 2:
221
+ return ImageCategory.CHART
222
+ else:
223
+ return ImageCategory.DOCUMENT
224
+
225
+ # High color diversity = likely photo
226
+ if unique_colors >= 256:
227
+ return ImageCategory.PHOTO
228
+
229
+ return ImageCategory.UNKNOWN
230
+
231
+
232
+ def analyze_image(image_path: str) -> ImageAnalysis:
233
+ """
234
+ Analyze an image to determine if it's worth VLM processing.
235
+
236
+ Args:
237
+ image_path: Path to the image file
238
+
239
+ Returns:
240
+ ImageAnalysis with relevance scores and recommendation
241
+ """
242
+ with Image.open(image_path) as img:
243
+ width, height = img.size
244
+
245
+ # Calculate metrics
246
+ aspect_ratio = max(width, height) / min(width, height) if min(width, height) > 0 else 999
247
+ unique_colors, color_diversity = get_color_diversity(img)
248
+ size_score = calculate_size_score(width, height)
249
+ aspect_score = calculate_aspect_score(width, height)
250
+
251
+ # Predict category
252
+ category = predict_category(width, height, unique_colors, color_diversity)
253
+
254
+ # Calculate overall relevance score
255
+ # Weights: size (30%), aspect (20%), color diversity (30%), category bonus (20%)
256
+ category_bonus = {
257
+ ImageCategory.PHOTO: 1.0,
258
+ ImageCategory.CHART: 1.0,
259
+ ImageCategory.DOCUMENT: 0.9,
260
+ ImageCategory.UNKNOWN: 0.5,
261
+ ImageCategory.LOGO: 0.2,
262
+ ImageCategory.ICON: 0.1,
263
+ ImageCategory.DECORATIVE: 0.1,
264
+ }
265
+
266
+ overall_relevance = (
267
+ 0.30 * size_score
268
+ + 0.20 * aspect_score
269
+ + 0.30 * color_diversity
270
+ + 0.20 * category_bonus[category]
271
+ )
272
+
273
+ # Determine if we should VLM process
274
+ skip_reason = None
275
+
276
+ if max(width, height) < MIN_DIMENSION_VLM:
277
+ should_vlm = False
278
+ skip_reason = f"Too small: {width}x{height} < {MIN_DIMENSION_VLM}px"
279
+ elif category in (ImageCategory.ICON, ImageCategory.DECORATIVE):
280
+ should_vlm = False
281
+ skip_reason = f"Predicted category: {category.value}"
282
+ elif category == ImageCategory.LOGO and overall_relevance < 0.4:
283
+ should_vlm = False
284
+ skip_reason = f"Likely logo with low relevance: {overall_relevance:.2f}"
285
+ elif overall_relevance < MIN_RELEVANCE_SCORE:
286
+ should_vlm = False
287
+ skip_reason = f"Low relevance score: {overall_relevance:.2f} < {MIN_RELEVANCE_SCORE}"
288
+ else:
289
+ should_vlm = True
290
+
291
+ return ImageAnalysis(
292
+ width=width,
293
+ height=height,
294
+ aspect_ratio=round(aspect_ratio, 2),
295
+ unique_colors=unique_colors,
296
+ color_diversity_score=round(color_diversity, 3),
297
+ size_score=round(size_score, 3),
298
+ aspect_score=round(aspect_score, 3),
299
+ overall_relevance=round(overall_relevance, 3),
300
+ predicted_category=category,
301
+ should_vlm=should_vlm,
302
+ skip_reason=skip_reason,
303
+ )
304
+
305
+
306
+ def resize_for_vlm(
307
+ input_path: str,
308
+ output_path: str,
309
+ max_dimension: int = VLM_MAX_DIMENSION,
310
+ skip_below: int = MIN_DIMENSION_VLM,
311
+ ) -> dict[str, Any]:
312
+ """
313
+ Resize an image for VLM processing, optimizing for token usage.
314
+
315
+ Args:
316
+ input_path: Path to input image
317
+ output_path: Path to save resized image
318
+ max_dimension: Maximum dimension (width or height)
319
+ skip_below: Skip images smaller than this
320
+
321
+ Returns:
322
+ Dict with resize results or skip indication
323
+ """
324
+ with Image.open(input_path) as img:
325
+ original_width, original_height = img.size
326
+ max_dim = max(original_width, original_height)
327
+
328
+ # Check if too small
329
+ if max_dim < skip_below:
330
+ return {
331
+ "success": True,
332
+ "skipped": True,
333
+ "skip_reason": f"Image too small: {original_width}x{original_height}",
334
+ "original_width": original_width,
335
+ "original_height": original_height,
336
+ }
337
+
338
+ # Check if resize needed
339
+ if max_dim <= max_dimension:
340
+ if input_path != output_path:
341
+ img.save(output_path, quality=95)
342
+ return {
343
+ "success": True,
344
+ "resized": False,
345
+ "original_width": original_width,
346
+ "original_height": original_height,
347
+ "output_width": original_width,
348
+ "output_height": original_height,
349
+ "output_path": output_path,
350
+ }
351
+
352
+ # Calculate new dimensions preserving aspect ratio
353
+ scale = max_dimension / max_dim
354
+ new_width = int(original_width * scale)
355
+ new_height = int(original_height * scale)
356
+
357
+ # Resize with high quality (L-10: close resized image after save)
358
+ resized = img.resize((new_width, new_height), Image.Resampling.LANCZOS)
359
+ try:
360
+ resized.save(output_path, quality=95)
361
+ finally:
362
+ resized.close()
363
+
364
+ return {
365
+ "success": True,
366
+ "resized": True,
367
+ "original_width": original_width,
368
+ "original_height": original_height,
369
+ "output_width": new_width,
370
+ "output_height": new_height,
371
+ "scale_factor": round(scale, 4),
372
+ "output_path": output_path,
373
+ }
374
+
375
+
376
+ def main():
377
+ """CLI entry point."""
378
+ parser = argparse.ArgumentParser(
379
+ description="Image optimization and relevance analysis for OCR/VLM pipeline"
380
+ )
381
+
382
+ # Mode selection
383
+ mode_group = parser.add_mutually_exclusive_group(required=True)
384
+ mode_group.add_argument(
385
+ "--resize-for-vlm", metavar="IMAGE", help="Resize image for VLM (max 2048px)"
386
+ )
387
+ mode_group.add_argument(
388
+ "--analyze", metavar="IMAGE", help="Analyze single image for VLM relevance"
389
+ )
390
+
391
+ # Options
392
+ parser.add_argument("--output", "-o", help="Output path for resized image")
393
+ parser.add_argument(
394
+ "--max-dimension",
395
+ type=int,
396
+ default=VLM_MAX_DIMENSION,
397
+ help=f"Max dimension for VLM resize (default: {VLM_MAX_DIMENSION})",
398
+ )
399
+
400
+ args = parser.parse_args()
401
+
402
+ try:
403
+ if args.resize_for_vlm:
404
+ if not args.output:
405
+ print(
406
+ json.dumps(
407
+ {"success": False, "error": "--output required for resize operations"}
408
+ )
409
+ )
410
+ sys.exit(1)
411
+ result = resize_for_vlm(args.resize_for_vlm, args.output, args.max_dimension)
412
+
413
+ elif args.analyze:
414
+ analysis = analyze_image(args.analyze)
415
+ result = {
416
+ "success": True,
417
+ "path": args.analyze,
418
+ "width": analysis.width,
419
+ "height": analysis.height,
420
+ "aspect_ratio": analysis.aspect_ratio,
421
+ "unique_colors": analysis.unique_colors,
422
+ "color_diversity_score": analysis.color_diversity_score,
423
+ "size_score": analysis.size_score,
424
+ "aspect_score": analysis.aspect_score,
425
+ "overall_relevance": analysis.overall_relevance,
426
+ "predicted_category": analysis.predicted_category.value,
427
+ "should_vlm": analysis.should_vlm,
428
+ }
429
+ if analysis.skip_reason:
430
+ result["skip_reason"] = analysis.skip_reason
431
+
432
+ print(json.dumps(result))
433
+ sys.exit(0)
434
+
435
+ except FileNotFoundError as e:
436
+ print(json.dumps({"success": False, "error": f"File not found: {e}"}))
437
+ sys.exit(1)
438
+ except Exception as e:
439
+ print(json.dumps({"success": False, "error": f"{type(e).__name__}: {e}"}))
440
+ sys.exit(1)
441
+
442
+
443
+ if __name__ == "__main__":
444
+ main()