Skip to main content

Lightweight async Python SDK for the Fotor OpenAPI

Project description

fotor-sdk

Lightweight, async-first Python SDK for the Fotor OpenAPI. Generate images and videos with a single API key -- no MCP server, no S3, no internal services required.

Installation

pip install fotor-sdk

Or install from GitHub:

pip install git+https://github.com/zeng121/fotor-sdk.git

For local development:

git clone https://github.com/zeng121/fotor-sdk.git
cd fotor-sdk
pip install -e .

Quick Start

Single Task

import asyncio
import os
from fotor_sdk import FotorClient, text2image

async def main():
    client = FotorClient(api_key=os.environ["FOTOR_OPENAPI_KEY"])
    result = await text2image(
        client,
        prompt="A diamond kitten on velvet, studio lighting",
        model_id="seedream-4-5-251128",
        resolution="2k",
        aspect_ratio="1:1",
    )
    print(result.result_url)

asyncio.run(main())

Parallel Batch with Progress

import asyncio
import os
from fotor_sdk import FotorClient, TaskRunner, TaskSpec

async def main():
    client = FotorClient(api_key=os.environ["FOTOR_OPENAPI_KEY"])
    runner = TaskRunner(client, max_concurrent=5)

    specs = [
        TaskSpec("text2image", {"prompt": "A cat", "model_id": "seedream-4-5-251128"}, tag="cat"),
        TaskSpec("text2image", {"prompt": "A dog", "model_id": "seedream-4-5-251128"}, tag="dog"),
        TaskSpec("text2video", {"prompt": "Sunset", "model_id": "kling-v3", "duration": 5}, tag="sunset"),
    ]

    def on_progress(total, completed, failed, in_progress, latest):
        print(f"  {completed + failed}/{total} done, latest: {latest.metadata.get('tag')}")

    results = await runner.run(specs, on_progress=on_progress)
    for r in results:
        print(f"{r.metadata.get('tag')}: {r.status.name} -> {r.result_url}")

asyncio.run(main())

Configuration

Environment Variable Required Default Description
FOTOR_OPENAPI_KEY Yes -- Your Fotor OpenAPI key
FOTOR_OPENAPI_ENDPOINT No https://api.fotor.com API base URL

Available Task Functions

Function Description
text2image() Generate image from text
image2image() Edit / multi-reference generation
image_upscale() 2x or 4x upscale
background_remove() Remove background
text2video() Generate video from text
single_image2video() Animate a single image
start_end_frame2video() Interpolate between two frames
multiple_image2video() Video from multiple images

Core Classes

FotorClient

FotorClient(
    api_key: str,
    endpoint: str = "https://api.fotor.com",
    poll_interval: float = 2.0,
    max_poll_seconds: float = 1200,
)

Methods:

  • await create_task(path, payload) -> task_id
  • await get_task_status(task_id) -> TaskResult
  • await get_credits() -> dict
  • await wait_for_task(task_id) -> TaskResult
  • await submit_and_wait(path, payload) -> TaskResult
  • submit_and_wait_sync(path, payload) -> TaskResult
  • get_credits_sync() -> dict

TaskRunner

TaskRunner(client: FotorClient, max_concurrent: int = 5)
  • await run(specs, on_progress=None) -> list[TaskResult]
  • run_sync(specs, on_progress=None) -> list[TaskResult]

TaskResult

TaskResult(task_id, status, result_url, error, elapsed_seconds, metadata)
result.success  # True when COMPLETED with a result_url

TaskSpec

TaskSpec(task_type: str, params: dict, tag: str = "")

Error Handling

from fotor_sdk import FotorAPIError

try:
    result = await text2image(client, prompt="...", model_id="bad-model")
except FotorAPIError as e:
    print(f"API error: {e}  code={e.code}")

For batch runs, failed tasks appear in results with status=FAILED and the error field populated. The runner never raises on individual task failures.

License

MIT

Project details


Download files

Download the file for your platform. If you're not sure which to choose, learn more about installing packages.

Source Distribution

fotor_sdk-0.1.5.tar.gz (15.2 kB view details)

Uploaded Source

Built Distribution

If you're not sure about the file name format, learn more about wheel file names.

fotor_sdk-0.1.5-py3-none-any.whl (12.8 kB view details)

Uploaded Python 3

File details

Details for the file fotor_sdk-0.1.5.tar.gz.

File metadata

  • Download URL: fotor_sdk-0.1.5.tar.gz
  • Upload date:
  • Size: 15.2 kB
  • Tags: Source
  • Uploaded using Trusted Publishing? No
  • Uploaded via: twine/6.2.0 CPython/3.13.9

File hashes

Hashes for fotor_sdk-0.1.5.tar.gz
Algorithm Hash digest
SHA256 07259dbbd49b26cf547da3b8ef2c4352211ee21cc8a6c89adaf06d9cb1627818
MD5 6ce4300f40a714720e257978d07c7442
BLAKE2b-256 a3df620cf2783b75a04089005df9c9f5d76c8a13c1ce12885fe5e15edab6e3a6

See more details on using hashes here.

File details

Details for the file fotor_sdk-0.1.5-py3-none-any.whl.

File metadata

  • Download URL: fotor_sdk-0.1.5-py3-none-any.whl
  • Upload date:
  • Size: 12.8 kB
  • Tags: Python 3
  • Uploaded using Trusted Publishing? No
  • Uploaded via: twine/6.2.0 CPython/3.13.9

File hashes

Hashes for fotor_sdk-0.1.5-py3-none-any.whl
Algorithm Hash digest
SHA256 f2f407aedbba2ae57cffc19e5af449a331793b36f7ed9a3665ebb18e8df02e7b
MD5 f38c8bd935d5ec848045951ab4e4f056
BLAKE2b-256 a0ae45c2e8d0a9ee2dc5440a70da4a5700a8b65162e79af8868f3f2ef9e8d1c5

See more details on using hashes here.

Supported by

AWS Cloud computing and Security Sponsor Datadog Monitoring Depot Continuous Integration Fastly CDN Google Download Analytics Pingdom Monitoring Sentry Error logging StatusPage Status page