JS / TS SDK & CLI
Last updated: 2026-05-15
Suparse JavaScript SDK and CLI
Official JavaScript/TypeScript SDK and CLI for the Suparse Document Processing API.
Suparse is an AI-powered document processing API for extracting structured data from any document type, including invoices, receipts, bank statements, purchase orders and many more. This repository contains:
@suparse/sdk: TypeScript SDK for browser, edge, and Node.js runtimessuparse: command-line interface for processing documents from your terminal
Requirements
- Node.js 20+
- Package manager: npm, pnpm, yarn, or bun
Installation
Install the SDK:
npm install @suparse/sdkInstall the CLI globally:
npm install -g suparseOr run the CLI without a global install:
npx suparse process invoice.pdf -o results.jsonAuthentication
You'll need an API key to use the SDK or CLI. To obtain one:
- Sign in at suparse.com
- Go to the API Keys tab
- Enter a key name and click Generate New Key
- Copy the key value. It will be shown only once.
Set it as an environment variable:
export SUPARSE_API_KEY="your_api_key_here"Or pass it directly to the SDK constructor:
import { SuparseNodeClient } from "@suparse/sdk/node";
const client = new SuparseNodeClient({ apiKey: "your_api_key_here" });Quick Start
# CLI
suparse process invoice.pdf -o results.json// Node.js SDK, with SUPARSE_API_KEY set
import { SuparseNodeClient } from "@suparse/sdk/node";
const client = new SuparseNodeClient();
try {
const result = await client.extract("invoice.pdf");
for (const item of result.succeeded) {
console.log(item.original_file);
console.log(item.documents.map((doc) => doc.extracted_data));
}
} finally {
await client.close();
}// Browser or edge runtime
import { SuparseClient } from "@suparse/sdk";
const client = new SuparseClient({ apiKey: "your_api_key_here" });
const file = new File([fileBytes], "invoice.pdf", { type: "application/pdf" });
const result = await client.extract(file);
console.log(result.succeeded);CLI Usage
Run suparse --help or suparse process --help for full usage information.
Set your API key and process a file directly from the terminal. The CLI will auto-upload, poll, and download the resulting JSON.
Process a Document
export SUPARSE_API_KEY="your_api_key_here"
# Auto-detect template
suparse process path/to/invoice.pdf -o results.json
# Use a specific template without auto-splitting
suparse process path/to/invoice.pdf --template-id 276a0aa8-84bc-4491-a2e7-1ea13381790c
# Auto-split a multi-page PDF containing mixed document types
suparse process path/to/merged.pdf --with-split
# Use a specific template with auto-splitting
suparse process path/to/invoice.pdf --template-id 276a0aa8-84bc-4491-a2e7-1ea13381790c --with-split
# Process and auto-delete documents from the server after download
suparse process path/to/invoice.pdf --cleanupProcess a Folder
Process all supported files (.pdf, .jpg, .jpeg, .png, .heic, .heif) in a folder. Files are uploaded and polled individually, then results are exported to a single JSON file.
# Process all supported files in a folder
suparse process --folder path/to/receipts/
# Output to a specific file (default: {folder_name}_results.json)
suparse process --folder path/to/receipts/ -o all_results.json
# Process a folder with a specific template
suparse process --folder path/to/receipts/ --template-id 276a0aa8-84bc-4491-a2e7-1ea13381790c
# Process a folder with auto-splitting enabled
suparse process --folder path/to/receipts/ --with-split
# Process a folder and auto-delete documents from the server after download
suparse process --folder path/to/receipts/ --cleanupDelete Documents
# Delete one or more documents by ID (prompts for confirmation)
suparse delete <document_id>
suparse delete <id1> <id2> <id3>
# Skip confirmation prompt
suparse delete <id1> <id2> -yDeleting a parent document automatically deletes all its child documents server-side.
List Available Templates
Templates define how a document type (invoice, receipt, bank statement, etc.) is parsed. Before processing a document, check which templates are already assigned to your account:
# List templates assigned to your account (table format)
suparse templates
# List templates in JSON format
suparse templates --format json
# Include all system templates
suparse templates --include-systemThe recommended way to process documents is with auto-split enabled (--with-split), which handles both single-type and mixed document types automatically:
suparse process path/to/documents.pdf --with-split -o results.jsonIf you consistently process one document type, look up the template ID and pass it directly:
-
Run
suparse templatesto see templates assigned to your account. -
Use the matching template ID:
suparse process invoice.pdf --template-id <id> -o results.json -
If no template matches, run
suparse templates --include-systemto browse all system templates. Assign one to your account via the Suparse UI. -
If no system template fits, create a custom template using the template creator in the Suparse UI.
Configuration
The CLI reads settings from environment variables and global flags.
| Variable | Default | Description |
|---|---|---|
SUPARSE_API_URL | https://api.suparse.com/api/v1 | API base URL |
SUPARSE_API_KEY | - | Your API key (required) |
Priority: CLI flags > environment variables > defaults.
Global Options
These options apply to all subcommands.
| Option | Description |
|---|---|
--api-url | API URL (default: from SUPARSE_API_URL env var) |
--api-key | API key (default: from SUPARSE_API_KEY env var) |
-v, --verbose | Enable verbose output |
CLI Options
| Command | Option | Description |
|---|---|---|
process | --folder | Process all supported files in a folder |
process | -o, --output | Output JSON file path (default: {file_stem}_results.json, folder mode: {folder_name}_results.json) |
process | --template-id | Template ID to use (default: auto-detect) |
process | --with-split | Auto-split multi-page documents containing mixed document types |
process | --cleanup | Delete documents from server after download |
templates | --format | Output format: table or json (default: table) |
templates | --include-system | Include system templates |
delete | -y, --yes | Skip confirmation prompt |
SDK Usage
The SDK exports two clients:
SuparseClientfrom@suparse/sdk: browser/edge-compatible client forBlob,File, andURLinputsSuparseNodeClientfrom@suparse/sdk/node: Node.js client with file paths, folder processing, and disk output helpers
Both clients handle uploads, polling, exports, retries, rate limits, and parallel batch processing. Batch extraction runs up to 10 files concurrently.
Node.js
Use @suparse/sdk/node for local files and server-side applications.
import { SuparseNodeClient } from "@suparse/sdk/node";
const client = new SuparseNodeClient();
try {
const result = await client.extract(["invoice1.pdf", "invoice2.pdf"]);
for (const item of result.succeeded) {
console.log(item.original_file);
console.log(item.documents.map((doc) => doc.extracted_data));
}
for (const failed of result.failed) {
console.error(failed.file, failed.error);
}
} finally {
await client.close();
}The Node client reads SUPARSE_API_KEY and SUPARSE_API_URL from environment variables by default, so you can use new SuparseNodeClient() if those are set. Pass apiKey and baseUrl directly when you do not want to use environment variables.
Browser and Edge
Use @suparse/sdk for runtimes without Node.js file-system APIs.
import { SuparseClient } from "@suparse/sdk";
const client = new SuparseClient({ apiKey: "your_api_key_here" });
const result = await client.extract(fileInput.files![0], {
split: true,
});
for (const item of result.succeeded) {
console.log(item.documents.map((doc) => doc.extracted_data));
}You can also pass a URL; the SDK fetches it and uploads the response body:
const result = await client.extract(new URL("https://example.com/invoice.pdf"));Extract One or More Documents
extract() is the primary SDK API.
Node.js File Paths
import { SuparseNodeClient } from "@suparse/sdk/node";
const client = new SuparseNodeClient();
const result = await client.extract("invoice.pdf", {
template_id: "276a0aa8-84bc-4491-a2e7-1ea13381790c",
split: true,
cleanup: true,
onProgress: (item) => {
if ("file" in item) {
console.error(`Failed: ${item.file} - ${item.error}`);
} else {
console.log(`Done: ${item.original_file}`);
}
},
});SuparseNodeClient accepts a single file path, an array of file paths, Blob/File objects, URL objects, or an array mixing those input types.
Batch Processing
const result = await client.extract(["receipts/jan.pdf", "receipts/feb.pdf"]);
for (const item of result.succeeded) {
console.log(item.original_file, item.documents);
}
for (const failed of result.failed) {
console.error(failed.file, failed.error);
}
console.log(`Total: ${result.total}`);Browser Files
import { SuparseClient } from "@suparse/sdk";
const client = new SuparseClient({ apiKey: "your_api_key_here" });
const files = Array.from(fileInput.files ?? []);
const result = await client.extract(files, {
split: false,
auto_approve: true,
});SuparseClient accepts Blob, File, and URL inputs. Use SuparseNodeClient when you need local file paths or disk output helpers.
Extract a Folder
extractFolder() is available from SuparseNodeClient. It scans a directory for supported files and delegates to extract().
import { SuparseNodeClient } from "@suparse/sdk/node";
const client = new SuparseNodeClient();
const result = await client.extractFolder("./receipts/", {
template_id: "276a0aa8-84bc-4491-a2e7-1ea13381790c",
split: true,
cleanup: true,
});
for (const item of result.succeeded) {
console.log(item.original_file, item.documents);
}extractFolder() scans the immediate directory only, filters to supported extensions, sorts the files by name, and returns an empty BatchResult when no supported files are found.
Result Data
Each successful item is a TaskExport. Its documents array contains the extracted document records and parsed fields:
for (const item of result.succeeded) {
console.log(item.task_id);
console.log(item.original_file);
for (const document of item.documents) {
console.log(document.document_id);
console.log(document.template_id);
console.log(document.page_start, document.page_end);
console.log(document.credits_used);
console.log(document.extracted_data);
}
}For single-page documents, documents usually has one entry. When split is enabled, a single uploaded PDF can produce multiple document entries with their own page ranges and template IDs.
Low-Level API
Use the low-level methods when you need direct control over upload, polling, export, and deletion.
import { SuparseNodeClient } from "@suparse/sdk/node";
const client = new SuparseNodeClient();
// Upload a file and get back a task ID
const taskId = await client.uploadFile("invoice.pdf", {
template_id: "276a0aa8-84bc-4491-a2e7-1ea13381790c",
split: false,
auto_approve: true,
});
// Poll until processing completes
const { status, documentIds } = await client.pollTaskStatus(taskId);
// Fetch results in memory
const exportsJson = await client.fetchResults(documentIds);
// Or write results to disk
await client.downloadResults(documentIds, "output.json");
// Delete documents by ID
await client.deleteDocuments(["550e8400-e29b-41d4-a716-446655440000"]);
// List available templates
const templates = await client.listTemplates();
for (const template of templates) {
console.log(`${template.name} (${template.template_language})`);
}
// Include system templates too
const allTemplates = await client.listTemplates({ includeSystem: true });Browser and edge runtimes can use uploadFromSource() instead of uploadFile():
import { SuparseClient } from "@suparse/sdk";
const client = new SuparseClient({ apiKey: "your_api_key_here" });
const taskId = await client.uploadFromSource(fileInput.files![0], {
split: true,
auto_approve: true,
});
const { documentIds } = await client.pollTaskStatus(taskId);
const exportsJson = await client.fetchResults(documentIds);Node Convenience Methods
SuparseNodeClient also exposes convenience methods for file-based workflows:
import { SuparseNodeClient } from "@suparse/sdk/node";
const client = new SuparseNodeClient();
// Process one document and write the JSON export to disk.
await client.processDocument("invoice.pdf", "results.json", {
template_id: "276a0aa8-84bc-4491-a2e7-1ea13381790c",
split: false,
cleanup: true,
});
// Process multiple files and receive raw task/document IDs.
const { succeeded, failed } = await client.processBatch(["a.pdf", "b.pdf"], {
template_id: "276a0aa8-84bc-4491-a2e7-1ea13381790c",
split: true,
});
for (const item of succeeded) {
console.log(item.filePath, item.taskId, item.documentIds);
}
for (const item of failed) {
console.error(item.filePath, item.taskId, item.error);
}Error Handling
All SDK exceptions inherit from SuparseError.
import {
SuparseNodeClient,
SuparseError,
SuparseAuthError,
SuparseNetworkError,
SuparsePollingTimeoutError,
} from "@suparse/sdk/node";
const client = new SuparseNodeClient({ apiKey: "your_api_key_here" });
try {
const result = await client.extract("invoice.pdf");
console.log(result.succeeded);
} catch (error) {
if (error instanceof SuparseAuthError) {
console.error("Invalid API key");
} else if (error instanceof SuparseNetworkError) {
console.error("Connection failed");
} else if (error instanceof SuparsePollingTimeoutError) {
console.error("Processing timed out");
} else if (error instanceof SuparseError) {
console.error(`Unexpected Suparse error: ${error.message}`);
} else {
throw error;
}
}For batch operations, check result.failed to handle per-file errors without catching exceptions:
const result = await client.extract(["a.pdf", "b.pdf", "c.pdf"]);
for (const item of result.succeeded) {
console.log(`OK: ${item.original_file} -> ${item.documents.map((doc) => doc.document_id)}`);
}
for (const failed of result.failed) {
console.error(`FAIL: ${failed.file} -> ${failed.error}`);
}Reference
Constructor Parameters
SuparseClient requires apiKey directly. SuparseNodeClient can read apiKey and baseUrl from environment variables.
| Parameter | Type | Default | Description |
|---|---|---|---|
apiKey | string | SUPARSE_API_KEY in SuparseNodeClient only | Your API key |
baseUrl | string | SUPARSE_API_URL env var or https://api.suparse.com/api/v1 | API base URL |
timeoutMs | number | 60000 | Request timeout in milliseconds |
maxRetries | number | 3 | Max retry attempts for retryable network/API errors |
pollInterval | number | 5 | Initial seconds between polling attempts |
maxPollAttempts | number | 300 | Max polling attempts before timeout |
Polling uses exponential backoff starting from pollInterval seconds and caps the delay at 15 seconds. maxPollAttempts limits the total number of poll attempts before SuparsePollingTimeoutError is thrown.
Result Objects
| Object | Properties | Description |
|---|---|---|
TaskExport | task_id, original_file, total_documents_extracted, documents | Successfully extracted file |
DocumentExport | document_id, file_name, page_start, page_end, template_id, credits_used, extracted_data | Extracted document and parsed fields |
FailedResult | file, error | File that failed during extraction |
BatchResult | succeeded, failed, total | Container for batch results |
Exceptions
All exceptions inherit from SuparseError.
| Exception | Raised When |
|---|---|
SuparseError | Base exception for all SDK errors |
SuparseNetworkError | Network connection fails or times out |
SuparsePollingTimeoutError | Polling exceeds maxPollAttempts |
SuparseProcessingError | Document fails to process on the server |
SuparseAPIError | Base for HTTP error responses; has statusCode and responseBody |
SuparseAuthError | 401/403 authentication or authorization error |
SuparseNotFoundError | 404 resource not found |
SuparseRateLimitError | 429 too many requests |
SuparseServerError | 5xx server error |
SuparseSDKError | SDK fails to parse or handle the expected API response |
extract() Parameters
| Parameter | Type | Default | Description |
|---|---|---|---|
files | Node: string, Blob, File, URL, or array; browser/edge: Blob, File, URL, or array | required | One or more files to process |
template_id | string | undefined | Template ID (auto-detect if omitted) |
split | boolean | false | Auto-split multi-page documents |
auto_approve | boolean | true | Set to false to require human review in the Suparse UI |
cleanup | boolean | false | Delete documents from server after extraction |
onProgress | (result) => void | undefined | Called with each TaskExport or FailedResult as it completes |
cleanup deletes the uploaded parent task documents after results have been fetched. Deleting a parent document also deletes its child documents server-side.
extractFolder() Parameters
extractFolder() is available only in @suparse/sdk/node.
| Parameter | Type | Default | Description |
|---|---|---|---|
folder | string | required | Directory to scan |
pattern | string | currently reserved | Present in the options type; current implementation scans supported files in the directory |
template_id | string | undefined | Template ID (auto-detect if omitted) |
split | boolean | false | Auto-split multi-page documents |
auto_approve | boolean | true | Set to false to require human review in the Suparse UI |
cleanup | boolean | false | Delete documents from server after extraction |
onProgress | (result) => void | undefined | Called with each result as it completes |
Supported Files
| Extension | MIME Type |
|---|---|
.pdf | application/pdf |
.jpg, .jpeg | image/jpeg |
.png | image/png |
.heic | image/heic |
.heif | image/heif |