Skip to content

REST API Reference

Interactive API docs with request/response examples are available at http://localhost:1349/api/docs.

Machine-readable specs:

  • /api/v1/openapi.yaml - OpenAPI 3.1 spec
  • /llms.txt - LLM-friendly summary
  • /llms-full.txt - Complete LLM-friendly docs

Authentication

All endpoints require authentication unless AUTH_ENABLED=false.

Session Token

bash
# Login
curl -X POST http://localhost:1349/api/auth/login \
  -H "Content-Type: application/json" \
  -d '{"username":"admin","password":"admin"}'
# Returns: {"token":"<session-token>"}

# Use token
curl http://localhost:1349/api/v1/tools/resize \
  -H "Authorization: Bearer <session-token>"

Sessions expire after 7 days (configurable via SESSION_DURATION_HOURS).

API Keys

bash
# Create a key (returns key once - store it)
curl -X POST http://localhost:1349/api/v1/api-keys \
  -H "Authorization: Bearer <session-token>" \
  -H "Content-Type: application/json" \
  -d '{"name":"my-script"}'
# Returns: {"key":"si_<96 hex chars>","id":"...","name":"my-script"}

# Use the key
curl http://localhost:1349/api/v1/tools/resize \
  -H "Authorization: Bearer si_<your-key>"

Keys are prefixed si_ and stored as scrypt hashes - the raw key is shown once and never retrievable again.

Auth Endpoints

MethodPathAccessDescription
POST/api/auth/loginPublicLogin, get session token
POST/api/auth/logoutAuthDestroy current session
GET/api/auth/sessionAuthValidate current session
POST/api/auth/change-passwordAuthChange own password (invalidates all other sessions + API keys)
GET/api/auth/usersAdminList all users
POST/api/auth/registerAdminCreate a new user
PUT/api/auth/users/:idAdminUpdate user role or team
POST/api/auth/users/:id/reset-passwordAdminReset user's password
DELETE/api/auth/users/:idAdminDelete a user
GET/api/v1/config/authPublicCheck if authentication is enabled ({ authEnabled: bool })

Permissions

PermissionAdminUser
Use tools
Own files/pipelines/API keys
See all users' files/pipelines/keys-
Write settings-
Manage users & teams-
Manage branding-

Health Check

MethodPathAccessDescription
GET/api/v1/healthPublicBasic health check. Returns {"status":"healthy","version":"..."} with 200, or {"status":"unhealthy"} with 503 if the database is unreachable.
GET/api/v1/admin/healthAdmin (system:health)Detailed diagnostics including uptime, storage mode, database status, queue state, and GPU availability.

Using Tools

Every tool follows the same pattern:

bash
# Single file
curl -X POST http://localhost:1349/api/v1/tools/<toolId> \
  -H "Authorization: Bearer <token>" \
  -F "[email protected]" \
  -F 'settings={"width":800,"height":600}'

# Batch (returns ZIP)
curl -X POST http://localhost:1349/api/v1/tools/<toolId>/batch \
  -H "Authorization: Bearer <token>" \
  -F "[email protected]" \
  -F "[email protected]" \
  -F 'settings={...}'
  • Upload is multipart/form-data.
  • settings is a JSON string with tool-specific options.
  • Response is the processed file directly (or a ZIP for batch).
  • Progress is tracked via SSE (see Progress Tracking).

Tools Reference

Essentials

Tool IDNameKey settings
resizeResizewidth, height, fit (cover/contain/fill/inside/outside), percentage, withoutEnlargement, plus 23 social media presets
cropCropleft, top, width, height, unit (px/percent)
rotateRotate & Flipangle, horizontal (bool), vertical (bool)
convertConvertformat (jpg/png/webp/avif/tiff/gif/heic/heif), quality
compressCompressmode (quality/targetSize), quality (1–100), targetSizeKb

Optimization

Tool IDNameKey settings
optimize-for-webOptimize for Webformat (webp/jpeg/avif/png), quality, maxWidth, maxHeight, progressive, stripMetadata
strip-metadataStrip Metadata-
edit-metadataEdit Metadatatitle, description, author, copyright, keywords, gps (lat/lon), dateTime
bulk-renameBulk Renamepattern (supports {n}, {date}, {original}), startIndex, padding
image-to-pdfImage to PDFpageSize (A4/Letter/...), orientation, margin, targetSize ({value, unit})
faviconFavicon Generatorpadding, backgroundColor, borderRadius - generates all standard sizes

Adjustments

Tool IDNameKey settings
adjust-colorsAdjust Colorsbrightness, contrast, exposure, saturation, temperature, tint, hue, sharpness, red, green, blue, effect (none/grayscale/sepia/invert)
sharpeningSharpeningmethod (adaptive/unsharp-mask/high-pass), sigma, m1, m2, x1, y2, y3, amount, radius, threshold, strength, kernelSize (3/5), denoise (off/light/medium/strong)
replace-colorReplace ColorsourceColor, targetColor (replacement), makeTransparent, tolerance
color-blindnessColor Blindness SimulationsimulationType (protanopia/deuteranopia/tritanopia/protanomaly/deuteranomaly/tritanomaly/achromatopsia/blueConeMonochromacy, default "deuteranomaly")

AI Tools

All AI tools run on your hardware (CPU or NVIDIA GPU). No internet required.

Tool IDNameAI ModelKey settings
remove-backgroundRemove Backgroundrembg (BiRefNet / U2-Net)model, backgroundType (transparent/color/gradient/blur/image), backgroundColor, gradientColor1, gradientColor2, gradientAngle, blurEnabled, blurIntensity, shadowEnabled, shadowOpacity
upscaleImage UpscalingRealESRGANscale (2/4), model, faceEnhance, denoise, format, quality
erase-objectObject EraserLaMa (ONNX)Mask sent as second file part (fieldname mask), format, quality
ocrOCR / Text ExtractionPaddleOCR / Tesseractquality (fast/balanced/best), language, enhance
blur-facesFace / PII BlurMediaPipeblurRadius, sensitivity
smart-cropSmart CropMediaPipe + Sharpmode (subject/face/trim), strategy (attention/entropy), width, height, padding, facePreset (closeup/head-shoulders/upper-body/half-body), sensitivity, threshold, padToSquare, padColor, targetSize, quality
image-enhancementImage EnhancementAnalysis-basedmode (auto/exposure/contrast/color/sharpness), strength
enhance-facesFace EnhancementGFPGAN / CodeFormermodel (gfpgan/codeformer), strength, sensitivity, centerFace
colorizeAI ColorizationDDColorintensity, model
noise-removalNoise RemovalTiered denoisingtier (quick/balanced/quality/maximum), strength, detailPreservation, colorNoise, format, quality
red-eye-removalRed Eye RemovalFace landmark + color analysissensitivity, strength
restore-photoPhoto RestorationMulti-step pipelinemode (auto/light/heavy), scratchRemoval, faceEnhancement, fidelity, denoise, denoiseStrength, colorize
passport-photoPassport PhotoMediaPipe landmarkscountry (37 countries), printLayout (4x6/A4/none), backgroundColor
content-aware-resizeContent-Aware ResizeSeam carving (caire)width, height, protectFaces, blurRadius, sobelThreshold, square
transparency-fixerPNG Transparency FixerBiRefNet HR-mattingdefringe (0-100), outputFormat (png/webp)

Watermark & Overlay

Tool IDNameKey settings
watermark-textText Watermarktext, font, fontSize, color, opacity, position, rotation, tile
watermark-imageImage Watermarkopacity, position, scale - second file is the watermark
text-overlayText Overlaytext, font, fontSize, color, x, y, background, padding, borderRadius
composeImage Compositionx, y, opacity, blend - second file is layered on top
meme-generatorMeme GeneratortemplateId, textLayout (top-bottom/top-only/bottom-only/center/side-by-side), textBoxes ([{id, text}]), fontFamily (anton/arial-black/comic-sans/montserrat/bebas-neue/permanent-marker/roboto), fontSize, textColor, strokeColor, textAlign, allCaps. Supports template mode (JSON body with templateId) or custom image mode (multipart with file).

Utilities

Tool IDNameKey settings
infoImage Info- (returns width, height, format, size, channels, hasAlpha, DPI, EXIF)
compareImage Comparemode (side-by-side/overlay/diff), diffThreshold - second file is the comparison target
find-duplicatesFind Duplicatesthreshold (perceptual hash distance, default 8) - multi-file
color-paletteColor Palettecount (dominant color count), format (hex/rgb)
qr-generateQR Code Generatordata, size, margin, colorDark, colorLight, errorCorrectionLevel, dotStyle, cornerStyle, logo (optional file)
barcode-readBarcode Reader- (auto-detects QR, EAN, Code128, DataMatrix, etc.)
image-to-base64Image to Base64format (data-uri/plain), mimeType
html-to-imageHTML to Imageurl, format (png/jpg/webp), quality, fullPage, devicePreset (desktop/tablet/mobile/custom), viewportWidth, viewportHeight

Layout & Composition

Tool IDNameKey settings
collageCollage / Gridtemplate (25+ layouts), gap, backgroundColor, borderRadius - multi-file
stitchStitch / Combinedirection (horizontal/vertical/grid), gap, backgroundColor, alignment - multi-file
splitImage Splittingmode (grid/rows/cols), rows, cols, tileWidth, tileHeight
borderBorder & Framewidth, color, style (solid/gradient/pattern), borderRadius, padding, shadow
beautifyBeautify ScreenshotbackgroundType (solid/linear-gradient/radial-gradient/image/transparent), gradientStops, padding, borderRadius, shadowPreset, frame (none/macos-light/macos-dark/windows-light/windows-dark/browser-light/browser-dark/iphone/macbook/ipad/...), socialPreset (none/twitter/linkedin/instagram-square/instagram-story/facebook/producthunt), watermarkText, outputFormat

Format & Conversion

Tool IDNameKey settings
svg-to-rasterSVG to Rasterformat (png/jpeg/webp/avif/tiff/gif/heif), width, height, scale, dpi, background
vectorizeImage to SVGcolorMode (bw/color), threshold, colorPrecision, filterSpeckle, pathMode (none/polygon/spline)
gif-toolsGIF Toolsaction (resize/optimize/reverse/speed/extract-frames/rotate/add-text), action-specific params
pdf-to-imagePDF to Imagepages (all/range), format, dpi, quality

HTML to Image

Capture a webpage as an image. Unlike other tools, this endpoint accepts application/json instead of multipart form data (no file upload needed).

Endpoint: POST /api/v1/tools/html-to-image

Content-Type: application/json

ParameterTypeDefaultDescription
urlstring(required)URL to capture (http/https only)
formatstring"png"Output format: jpg, png, webp
qualitynumber90Quality 1-100 (JPG/WebP only)
fullPagebooleanfalseCapture full scrollable page
devicePresetstring"desktop"desktop, tablet, mobile, custom
viewportWidthnumber1280Custom viewport width 320-3840
viewportHeightnumber720Custom viewport height 320-2160

Example:

bash
curl -X POST http://localhost:1349/api/v1/tools/html-to-image \
  -H "Authorization: Bearer $TOKEN" \
  -H "Content-Type: application/json" \
  -d '{"url": "https://snapotter.com", "format": "png", "devicePreset": "desktop"}'

Response:

json
{
  "jobId": "uuid",
  "downloadUrl": "/api/v1/download/{jobId}/screenshot.png",
  "originalSize": 0,
  "processedSize": 54321
}

Tool Sub-Routes

Some tools expose additional endpoints beyond the standard POST /api/v1/tools/<toolId>:

MethodPathDescription
POST/api/v1/tools/remove-background/effectsApply background effects (color/gradient/blur/shadow) without re-running AI. Uses cached mask from initial removal.
POST/api/v1/tools/edit-metadata/inspectRead existing EXIF/IPTC/XMP metadata from an image
POST/api/v1/tools/strip-metadata/inspectInspect metadata fields before stripping
POST/api/v1/tools/passport-photo/analyzePhase 1: AI face detection + background removal. Returns face landmarks and cached data.
POST/api/v1/tools/passport-photo/generatePhase 2: Crop, resize, and tile using cached analysis. No AI re-run.
POST/api/v1/tools/gif-tools/infoGet GIF metadata (frame count, dimensions, duration)
POST/api/v1/tools/pdf-to-image/infoGet PDF metadata (page count, dimensions)
POST/api/v1/tools/pdf-to-image/previewGenerate a preview of a specific PDF page
POST/api/v1/tools/svg-to-raster/batchBatch convert multiple SVGs to raster
POST/api/v1/tools/image-enhancement/analyzeAnalyze image quality and return enhancement recommendations
POST/api/v1/tools/optimize-for-web/previewLightweight preview for live parameter tuning. Returns optimized image with size headers.

Batch Processing

Apply any tool to multiple files at once. Returns a ZIP archive.

bash
curl -X POST http://localhost:1349/api/v1/tools/compress/batch \
  -H "Authorization: Bearer <token>" \
  -F "[email protected]" \
  -F "[email protected]" \
  -F "[email protected]" \
  -F 'settings={"quality":80}'

Concurrency is controlled by CONCURRENT_JOBS (default: auto-detected from CPU cores). Set MAX_BATCH_SIZE to limit the number of files per batch (default: unlimited).

Pipelines

Execute a pipeline

bash
# Single file
curl -X POST http://localhost:1349/api/v1/pipeline/execute \
  -H "Authorization: Bearer <token>" \
  -F "[email protected]" \
  -F 'pipeline={"steps":[
    {"toolId":"resize","settings":{"width":1200}},
    {"toolId":"compress","settings":{"quality":80}},
    {"toolId":"watermark-text","settings":{"text":"© 2025"}}
  ]}'

# Batch (multiple files → ZIP)
curl -X POST http://localhost:1349/api/v1/pipeline/batch \
  -H "Authorization: Bearer <token>" \
  -F "[email protected]" \
  -F "[email protected]" \
  -F 'pipeline={"steps":[{"toolId":"resize","settings":{"width":800}}]}'

Each step's output is the next step's input. Unlimited steps per pipeline by default (configurable via MAX_PIPELINE_STEPS).

Save and manage pipelines

MethodPathDescription
POST/api/v1/pipeline/saveSave a named pipeline (name, description, steps[])
GET/api/v1/pipeline/listList saved pipelines (admins see all; users see own)
DELETE/api/v1/pipeline/:idDelete (owner or admin)
GET/api/v1/pipeline/toolsList tool IDs valid for pipeline steps

Progress Tracking

Long-running jobs (AI tools, batch, pipelines) emit real-time progress via Server-Sent Events:

bash
# Connect to the SSE stream (jobId returned in X-Job-Id response header)
curl -N http://localhost:1349/api/v1/jobs/<jobId>/progress \
  -H "Authorization: Bearer <token>"

Event format:

data: {"progress":42,"status":"processing","message":"Upscaling frame 2/5"}
data: {"progress":100,"status":"completed"}

File Library

Persistent file storage with version history.

MethodPathDescription
POST/api/v1/uploadUpload files to workspace (temp processing)
POST/api/v1/files/uploadUpload files to the persistent file library
POST/api/v1/files/save-resultSave a tool processing result as a new file version
GET/api/v1/filesList saved files (paginated, with search)
GET/api/v1/files/:idGet file metadata + version chain
GET/api/v1/files/:id/downloadDownload file
GET/api/v1/files/:id/thumbnailGet 300px JPEG thumbnail
DELETE/api/v1/filesBulk delete files and their version chains (body: { ids: [...] })
POST/api/v1/previewGenerate a browser-compatible WebP preview (for HEIC/HEIF/RAW formats)
GET/api/v1/download/:jobId/:filenameDownload a processed file from a workspace

To auto-save a tool result to the library, include fileId in the settings payload referencing an existing library file. The processed result will be saved as a new version.

API Key Management

MethodPathAccessDescription
POST/api/v1/api-keysAuthGenerate new key - shown once
GET/api/v1/api-keysAuthList keys (name, id, lastUsedAt - not raw key)
DELETE/api/v1/api-keys/:idAuthDelete key

Teams

MethodPathAccessDescription
GET/api/v1/teamsAdmin (teams:manage)List teams
POST/api/v1/teamsAdmin (teams:manage)Create team
PUT/api/v1/teams/:idAdmin (teams:manage)Rename team
DELETE/api/v1/teams/:idAdmin (teams:manage)Delete team (cannot delete default team or teams with members)

Settings

Runtime key-value configuration (read by any authenticated user, write by admin only).

MethodPathDescription
GET/api/v1/settingsGet all settings
PUT/api/v1/settingsBulk update settings (JSON body with key-value pairs)
GET/api/v1/settings/:keyGet a specific setting by key

Known keys: disabledTools (JSON array of tool IDs), enableExperimentalTools (bool string), loginAttemptLimit (number).

Roles

Custom role management with granular permissions.

MethodPathAccessDescription
GET/api/v1/rolesAdmin (audit:read)List all roles with user counts
POST/api/v1/rolesAdmin (users:manage)Create a custom role (name, description, permissions)
PUT/api/v1/roles/:idAdmin (users:manage)Update a custom role (cannot modify built-in roles)
DELETE/api/v1/roles/:idAdmin (users:manage)Delete a custom role (cannot delete built-in roles; affected users revert to user role)

Available permissions: tools:use, files:own, files:all, apikeys:own, apikeys:all, pipelines:own, pipelines:all, settings:read, settings:write, users:manage, teams:manage, features:manage, system:health, audit:read.

Audit Log

Admin-only endpoint for reviewing security-relevant actions.

MethodPathAccessDescription
GET/api/v1/audit-logAdmin (audit:read)Paginated audit log with optional filters

Query parameters:

ParameterDescription
pagePage number (default: 1)
limitEntries per page (default: 50, max: 100)
actionFilter by action type (e.g. ROLE_CREATED, ROLE_DELETED)
fromFilter entries after this ISO 8601 date
toFilter entries before this ISO 8601 date

Analytics

MethodPathAccessDescription
GET/api/v1/config/analyticsPublicGet analytics configuration (PostHog key, Sentry DSN, sample rate). Returns empty values if ANALYTICS_ENABLED=false.
PUT/api/v1/user/analyticsAuthSet the current user's analytics consent (enabled: true/false) or defer with remindLater: true.

Features / AI Bundles

Manage AI feature bundles (install/uninstall AI model packages in the Docker environment).

MethodPathAccessDescription
GET/api/v1/featuresAuthList all feature bundles and their install status
POST/api/v1/admin/features/:bundleId/installAdmin (features:manage)Install a feature bundle (async, returns jobId for progress tracking)
POST/api/v1/admin/features/:bundleId/uninstallAdmin (features:manage)Uninstall a feature bundle and clean up model files
GET/api/v1/admin/features/disk-usageAdmin (features:manage)Get total disk usage of AI models

Meme Templates

Supporting API for the meme generator tool.

MethodPathAccessDescription
GET/api/v1/meme-templatesAuthList all available meme templates with text box positions
GET/api/v1/meme-templates/full/:filenameAuthServe full-size template image
GET/api/v1/meme-templates/thumbs/:filenameAuthServe template thumbnail
GET/api/v1/meme-templates/fonts/:filenameAuthServe font file used for meme text rendering

Error Responses

All errors return JSON:

json
{
  "error": "Human-readable message",
  "code": "MACHINE_READABLE_CODE"
}
StatusMeaning
400Invalid request / validation failed
401Not authenticated
403Insufficient permissions
404Resource not found
413File too large (see MAX_UPLOAD_SIZE_MB)
429Rate limited (see RATE_LIMIT_PER_MIN)
500Internal server error