Comparisons / Flue vs OpenAI Agents SDK

Flue vs OpenAI Agents SDK: Which Agent Framework to Use?

Flue vs OpenAI Agents SDK, head to head

Flue and OpenAI Agents SDK both let you build an agent, but they sit in different parts of the stack and they assume different things about who's writing the code.

Flue is a declarative TypeScript agent framework from Fred K.

OpenAI's Agents SDK (evolved from Swarm) provides Agent, Runner, handoffs, and guardrails.

Underneath, both wrap the same thing: a model call, a tool dispatch, a loop. The decision is about which abstraction your team wants to think in day to day, and which ecosystem you're willing to inherit along with it. There's an honest, framework-free version of the same pattern in about 60 lines of Python in the lesson at the bottom of this page — useful as a baseline regardless of which framework wins.

Pick Flue if

Pick Flue if flue is the natural choice when the deploy target is Cloudflare and you want a TypeScript-first, declarative agent framework tuned for Durable Objects. Its cross-runtime story (Cloudflare + Node + CI) is genuinely useful if agents run in more than one place. For a single-agent loop that doesn't need persistence, plain TypeScript is simpler. The tradeoffs in its intro should match how your team already thinks about agents; OpenAI Agents SDK will feel like translation if they don't.

Full Fluecomparison →

Pick OpenAI Agents SDK if

Pick OpenAI Agents SDK if the Agents SDK is the thinnest framework on this list — it barely abstracts beyond what you'd write yourself. Use it when you want OpenAI's conventions and auto-schema generation. Skip it when you want full control or use non-OpenAI models. The tradeoffs in its intro should match how your team already thinks about agents; Flue will feel like translation if they don't.

Full OpenAI Agents SDKcomparison →

What both add

Whichever you pick, you're inheriting a dependency tree and a vocabulary your team has to learn before they ship anything. Flue has its own class hierarchy and tool registration conventions; OpenAI Agents SDK has its. Either way, when something misbehaves you'll be reading framework source before you reach the actual HTTP call.

If the real workload is one model and a handful of tools, both can feel like a workbench for driving a nail. The lesson below builds the same pattern in plain Python — useful as a comparison point even if you ultimately keep the framework.

By the numbers

By the numbers

Flue

GitHub Stars

2.4k

Forks

140

Language

TypeScript

License

MIT

Created

2026-05-01

Created by

Fred K. Schott + Astro team (at Cloudflare)

Backed by

Cloudflare

Cloud/SaaS

Cloudflare Durable Objects; also deploys to Node, GitHub Actions, GitLab CI

Production ready

Yes

github.com/withastro/flue

OpenAI Agents SDK

GitHub Stars

20.6k

Forks

3.4k

Language

Python

License

MIT

Created

2025-03-11

Created by

OpenAI

github.com/openai/openai-agents-python

GitHub stats as of April 2026. Stars indicate community interest, not necessarily quality or fit for your use case.

ConceptFlueOpenAI Agents SDK
Agent`createAgent({ model, instructions, tools })` — declarative config, framework runs the loop`Agent(name, instructions, model, tools)`
ToolsRegistered with valibot schemas: `{ name, description, schema, execute }`Python functions with type hints, auto-converted to schemas
StateDurable Streams — replayable, checkpointed event log stored in Cloudflare Durable Objects
DeploymentOne config controls deploys to Cloudflare, Node, GitHub Actions, or GitLab CI
RuntimeThe Pi harness — same runtime as OpenClaw, so agents share tooling with that ecosystem
Cloudflare-nativeDurable Objects give per-agent persistence and locking without an external DB
Agent Loop`Runner.run()` handles the loop internally
Handoffs`Handoff` between `Agent` objects for multi-agent routing
Guardrails`InputGuardrail` and `OutputGuardrail` with tripwire pattern
ContextTyped context object passed through the agent lifecycle

Or build your own in 60 lines

Both Flue and OpenAI Agents SDK implement the same 8 patterns. An agent is a function. Tools are a dict. The loop is a while loop. The whole thing composes in ~60 lines of Python.

No framework. No dependencies. No opinions. Just the code.

Build it from scratch →