Skip to main content

Unofficial CLI for Google Flow — drive Veo image-to-video generations from the terminal.

Project description

gflow-cli

Unofficial Python CLI for Google Flow. Drive Veo (image-to-video, text-to-video) and Imagen (text-to-image) generations from your terminal — scripted, batched, pipeline-friendly.

PyPI version CI Release Python versions License: MIT Status: alpha Code style: ruff Type checked: pyright Tests: TDD Quality Gate Status

⚠️ Unofficial. Reverse-engineered. Not affiliated with Google. Endpoints can change at any time. Full DISCLAIMER.

🌐 Headed-browser today. gflow drives Flow via a persistent Playwright Chromium profile — Google's auth + reCAPTCHA gates currently require it. See Architecture & current limitations for the contributor opportunity.

Why gflow-cli?

For Google AI Ultra / Pro subscribers with Veo credits and batch workloads:

  • Burn credits efficientlyfor p in $(cat prompts.txt); do gflow image t2i "$p"; done (image batching, plus gflow video t2v/i2v/r2v, all ship today)
  • Build pipelines — wire Veo into your content automation, AI video stack, or batch experiments
  • Stay in the terminal — no Chromium UI, no clicking through dialogs (after a one-time gflow auth login)

Same Veo + Imagen models, same quality, same Ultra/Pro billing — programmatic.

60-second quick start

# 1 · Install (uv recommended — also: pip install gflow-cli)
uv tool install gflow-cli
uv tool run --from gflow-cli playwright install chromium     # one-time, ~150 MB

# 2 · Authenticate (one-time, opens a real Chrome window)
gflow auth login --browser chrome

# 3 · Generate
gflow image t2i "a hot air balloon over Tokyo at sunrise"
# or:
gflow video t2v "Slow cinematic push-in on a sunlit forest clearing" --aspect 16:9

Outputs land under $GFLOW_CLI_OUTPUT_DIR unless GFLOW_CLI_STORAGE_URI sends generated assets to S3, MinIO, or Google Cloud Storage. First call is ~30–90 s while Chromium warms; subsequent calls reuse the warm session.

Why --browser chrome? Google rejects Playwright's bundled Chromium. The CLI fails fast with a friendly error (AuthBrowserRejectedError, exit code 14) if you pick anything else.

In-depth quick start

See USER_GUIDE — Journey 1: First-time setup for the 10-minute walkthrough with troubleshooting, multi-account setup, and the structured-log primer.

Demo

gflow image t2i — single 9:16 prompt, streaming structlog output, PNG on disk

A single gflow image t2i "..." --aspect 9:16 --model nano2 call against a logged-in Pro/Ultra profile. Terminal shows the streaming structlog JSON for the run, the final ls of the written PNG, and nothing else — Chromium drives the Flow editor silently in the background.

Reproduce the recording: scripts/record_demo.ps1 (Windows + OBS + ffmpeg + gifski).

▶ More demos — split-screen (terminal command + Flow generating, side-by-side) and other formats: docs/DEMOS.md.

Documentation

docs/INDEX.md is the master routing layer. Quick links:

Topic Read
🎯 Getting started User Guide · Usage · Configuration
Storage & catalog External Storage · Data Layer
🔐 Auth & sessions Authentication · Known issues
🏗️ Internals Architecture · Security · Debugging
📦 Releases Changelog · Roadmap · Release protocol · Project status
🤝 Contributing Contributing · Development · GitHub workflow

For AI agents & LLMs

gflow-cli ships three agent entry points — pick the one your tool reads first.

File Audience Tools
AGENTS.md Universal coding-agent spec Cursor · Codex · Aider · Gemini CLI · Jules · Devin · Windsurf · Zed · Warp · opencode · Copilot · 60k+ repos
CLAUDE.md Claude Code's auto-loaded memory Claude Code
llms.txt LLM-readable summary (llmstxt.org format) Paste into ChatGPT / Claude / Gemini to onboard the model
skills/gflow-cli/SKILL.md Claude Code Skill Symlink into ~/.claude/skills/

Onboarding any agent in one line: paste this into your agent of choice —

"Read AGENTS.md and docs/INDEX.md, then help me with my Flow batch."

Architecture & current limitations

gflow CLI  →  Provider (interchangeable)  →  Flow (ui_automation) / Mock (tests) / [planned: Official Veo]
                                              ↓
                                      Playwright Chromium (headed login, headless after)
                                              ↓
                              aisandbox-pa.googleapis.com  (Google's private Flow API)

Current transport: ui_automation — drives Flow via a persistent Playwright Chromium profile. Production-stable, end-to-end verified per release (see LIVE_VERIFICATION_* per-release evidence files).

What's blocked: A pure HTTP transport for video generation. The video upload endpoint returns HTTP 401 under non-Chrome browsers + a reCAPTCHA mint we cannot reproduce headlessly. Three earlier HTTP strategies (evaluate_fetch / bearer / sapisidhash) live under src/gflow_cli/api/transports/experimental/ — they are importable for research but not on the production critical path.

How you can help: If you have successfully driven aisandbox-pa.googleapis.com from outside a real Chrome session — or have insight into Google's anti-bot stack here — please open an issue. A working REST transport would unlock serverless deployments, true horizontal concurrency, and roughly 10× the project's reach. Details: docs/ARCHITECTURE.md § Headed-browser dependency.

Project status

v0.11.0 — alpha. Image (T2I / I2I / upload) + Video T2V / I2V / R2V live end-to-end on ui_automation, with a video --model picker (5 Veo models) + --duration / --count. v0.11.0 is a reliability release: it repairs gflow video i2v — on v0.10.0 every i2v run silently produced text-to-video output that ignored the start/end frames (issue #125) — fixes create-project generation when Flow's "Agent" composer mode is active, and hardens image-model selection for non-English Flow UIs (#94). New in v0.10.0: --json output across every generation command (image t2i/i2i, video t2v/i2v/r2v, auth list) plus a gflow models catalog so worker schedulers can drive the CLI machine-to-machine; per-model reference-image caps for i2i/r2v; profile Google-account identity persisted to disk (with auto-rename of the first-run default profile); external cloud storage (S3 / MinIO / GCS) via GFLOW_CLI_STORAGE_URI; and a gflow data prune maintenance command. Only video batch (manifest runner) is still queued for Phase B — use a shell for-loop until then (USAGE). Full milestone history → docs/PROJECT_STATUS.md. Changelog → CHANGELOG.md. Where the project is heading → ROADMAP.md.

License & legal

MIT License © 2026 Flavio Oliva (ffroliva). The MIT license covers gflow-cli's code only — it does not grant rights to Flow, Veo model output, or any Google service. Google's own terms (Labs Additional Terms, Ultra/Pro subscription terms) govern your generations. See DISCLAIMER.

Acknowledgements


Stats

GitHub stars GitHub forks GitHub watchers GitHub issues GitHub pull requests GitHub last commit GitHub repo size PyPI downloads

If gflow-cli saves you time, please ⭐ the repo — it is the cheapest way to support the project.

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

gflow_cli-0.11.0.tar.gz (3.3 MB view details)

Uploaded Source

Built Distribution

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

gflow_cli-0.11.0-py3-none-any.whl (207.3 kB view details)

Uploaded Python 3

File details

Details for the file gflow_cli-0.11.0.tar.gz.

File metadata

  • Download URL: gflow_cli-0.11.0.tar.gz
  • Upload date:
  • Size: 3.3 MB
  • Tags: Source
  • Uploaded using Trusted Publishing? Yes
  • Uploaded via: twine/6.1.0 CPython/3.13.12

File hashes

Hashes for gflow_cli-0.11.0.tar.gz
Algorithm Hash digest
SHA256 77484ada6e339e81d3db40760339e5a75211e662318efc9b4a22f3a1212b97b8
MD5 543ad96bf7a22f4f1086bfee12c6229e
BLAKE2b-256 4527402ae78a8878b730f0bde20c4b399e71c6af850e4474153f3c14a51a87e4

See more details on using hashes here.

Provenance

The following attestation bundles were made for gflow_cli-0.11.0.tar.gz:

Publisher: release.yml on ffroliva/gflow-cli

Attestations: Values shown here reflect the state when the release was signed and may no longer be current.

File details

Details for the file gflow_cli-0.11.0-py3-none-any.whl.

File metadata

  • Download URL: gflow_cli-0.11.0-py3-none-any.whl
  • Upload date:
  • Size: 207.3 kB
  • Tags: Python 3
  • Uploaded using Trusted Publishing? Yes
  • Uploaded via: twine/6.1.0 CPython/3.13.12

File hashes

Hashes for gflow_cli-0.11.0-py3-none-any.whl
Algorithm Hash digest
SHA256 b0ae8bc6d567021aef13be51fd642eb86555b2c0e7ca9fc41a4b7d190035f377
MD5 d6c4e1c3acf702ff6714f79b00d02b23
BLAKE2b-256 c06a55a3dc1390321863cf283cfc047ee03f5f9fe0d83d8e747a3ff3e876d2b3

See more details on using hashes here.

Provenance

The following attestation bundles were made for gflow_cli-0.11.0-py3-none-any.whl:

Publisher: release.yml on ffroliva/gflow-cli

Attestations: Values shown here reflect the state when the release was signed and may no longer be current.

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