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 wait_for_task(task_id) -> TaskResult
  • await submit_and_wait(path, payload) -> TaskResult
  • submit_and_wait_sync(path, payload) -> TaskResult

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.3.tar.gz (14.9 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.3-py3-none-any.whl (12.4 kB view details)

Uploaded Python 3

File details

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

File metadata

  • Download URL: fotor_sdk-0.1.3.tar.gz
  • Upload date:
  • Size: 14.9 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.3.tar.gz
Algorithm Hash digest
SHA256 eb4f3eba1e5a3dff6ce2f7fe10e40b7743ae41b3fee5965c8c8aa4788a27d3c5
MD5 8eec28a53e7cf6e1ae9d97c440181f81
BLAKE2b-256 0ce46f667630329707491fc55ccb1dacf6eb7a1c85c80b6585dbb1a4176515ef

See more details on using hashes here.

File details

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

File metadata

  • Download URL: fotor_sdk-0.1.3-py3-none-any.whl
  • Upload date:
  • Size: 12.4 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.3-py3-none-any.whl
Algorithm Hash digest
SHA256 f8c6553f066c202ea5ece20f30aca9b27e125b9adbf60b1ece67ab68b801cd98
MD5 13ea2918ccb7033158cd3d5813445729
BLAKE2b-256 0265a4e75d53ff75c917a5096ea31dba030ec05b21a00f97746691e25b440045

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