Use this skill for Mindee V2 integrations with the official Java SDK.
- Use the official
com.mindee.sdkJava SDK. - Focus on SDK-based integration patterns only.
- Do not suggest direct HTTP calls, cURL, or non-SDK integrations.
- Do not use undocumented SDK internals.
- Use: https://docs.mindee.com/extraction-models/sdk-integration/extraction-result.md
- Use this page for accessing dynamic fields from
response.getInference().getResult().getFields(). - Use this page for examples of
SimpleField,ObjectField,ListField, confidence, and locations.
- Use: https://docs.mindee.com/split-models/sdk-integration/split-result.md
- Use this page for iterating over
response.getInference().getResult().getSplits(). - Use this page for examples of
getDocumentType(),getPageRange(), and optional chained extraction results.
- Use: https://docs.mindee.com/crop-models/sdk-integration/crop-result.md
- Use this page for iterating over
response.getInference().getResult().getCrops(). - Use this page for examples of
getObjectType(),getLocation(), and optional chained extraction results.
- Use: https://docs.mindee.com/classification-models/sdk-integration/classification-result.md
- Use this page for accessing
response.getInference().getResult().getClassification(). - Use this page for examples of
getDocumentType(), and optional chained extraction results.
- Use: https://docs.mindee.com/raw-text-ocr-models/sdk-integration/ocr-result.md
- Use this page for iterating over
response.getInference().getResult().getPages(). - Use this page for page text, words, and word polygon data.
When answering questions, follow this order:
- Initialize the SDK client.
- Configure
modelIdand other inference parameters. - Load the input source.
- Optionally adjust the file before upload.
- Send with polling or webhooks.
- Process the response.
- Handle errors and retries.
- Base answers on the documentation above.
- Prefer documented SDK methods and patterns.
- Use environment variable
MINDEE_V2_API_KEYfor API keys in production. - Reuse a client instance when possible.
- Prefer polling (
enqueueAndGetResult()) for simple examples. - Prefer webhooks for production or high-volume workflows.
- Declare
throws IOException, InterruptedExceptionon methods that call polling. - If a feature is not documented, say it is not officially supported.
- If a user asks for code, keep examples minimal and working.
- This SDK has two API versions: V2 (
com.mindee.v2) and V1 (com.mindee.v1). Default to V2 unless the user asks for V1.
- Use Java examples only.
- Use the official Maven artifact
com.mindee.sdk:mindee-api-java. - Show imports explicitly.
- Include the exact documented class and method names.
- Use placeholders like
MY_API_KEY,MY_MODEL_ID, and/path/to/file.pdf. - Keep samples focused on one task.
- Use Java 11+ syntax.
Use:
new MindeeClient("MY_API_KEY")— explicit key (com.mindee.v2.MindeeClient)new MindeeClient()— reads fromMINDEE_V2_API_KEYenvironment variable
Use (com.mindee.input):
new LocalInputSource("path/to/file.pdf")— from file pathnew LocalInputSource(new File(...))— from File objectnew LocalInputSource(inputStream, "filename.pdf")— from InputStreamnew LocalInputSource(byteArray, "filename.pdf")— from byte arraynew LocalInputSource(base64String, "filename.pdf")— from Base64 stringURLInputSource.builder("https://...").build()— from URL
Use (com.mindee.v2.MindeeClient):
enqueueAndGetResult(ResponseClass.class, inputSource, parameters)— pollingenqueue(inputSource, parameters)— for webhooks
Use:
response.getInference()— access the typed inference objectresponse.getInference().getResult()— access the result fieldsresponse.getRawResponse()— raw JSON stringnew LocalResponse(file).deserialize(ResponseClass.class)— for webhook payloads
Use (com.mindee.input.LocalInputSource):
source.getPageCount()— count pagessource.compress()— compress before uploadsource.applyPageOptions(pageOptions)— trim or remove pages
Use:
MindeeException— base exception (com.mindee.MindeeException)MindeeHttpExceptionV2— HTTP errors withgetStatus()andgetDetail()(com.mindee.v2.http)
- Direct REST examples
- cURL examples
- Manual authentication header construction
- Bearer token examples for API keys
- Non-Java examples
- V1 examples unless the user explicitly asks for V1
Ask for only what is needed:
- input type: local file or URL
- delivery pattern: polling or webhook
- model ID
- model type: extraction, split, crop, classification, or OCR
- Be concise.
- Answer with runnable examples when code is requested.
- Link to the most relevant doc section.
- Do not overwhelm the user with every option.
- Start with the documented default path.
If you need additional information that is not directly available in this page, you can query the documentation dynamically by asking a question.
Perform an HTTP GET request on the documentation URL with the ask query parameter.
Include java+sdk+-+ at the beginning of the question to get answers specific to this library:
GET https://docs.mindee.com/integrations.md?ask=java+sdk+-+<question>
The question should be specific, self-contained, and written in natural language. The response will contain a direct answer to the question and relevant excerpts and sources from the documentation.
Use this mechanism when the answer is not explicitly present in the current page, you need clarification or additional context, or you want to retrieve related documentation sections.