Show HN: AgentKit – JavaScript Alternative to OpenAI Agents SDK with Native MCP
Hi HN! I’m Tony, co-founder of Inngest. I wanted to share AgentKit, our Typescript multi-agent library we’ve been cooking and testing with some early users in prod for months.Although OpenAI’s Agents SDK has been launched since, we think an Agent framework should offer more deterministic and flexible routing, work with multiple model providers, embrace MCP (for rich tooling), and support the unstoppable and growing community of TypeScript AI developers by enabling a smooth transition to production use cases.This is why we are building AgentKit, and we’re really excited about it for a few reasons:Firstly, it’s simple. We embrace KISS principles brought by Anthropic and HuggingFace by allowing you to gradually add autonomy to your AgentKit program using primitives:- Agents: LLM calls that can be combined with prompts, tools, and MCP native support.- Networks: a simple way to get Agents to collaborate with a shared State, including handoff.- State: combines conversation history with a fully typed state machine, used in routing.- Routers: where the autonomy lives, from code-based to LLM-based (ex: ReAct) orchestrationThe routers are where the magic happens, and allow you to build deterministic, reliable, testable agents.AgentKit routing works as follows: the network calls itself in a loop, inspecting the State to determine which agents to call next using a router. The returned agent runs, then optionally updates state data using its tools. On the next loop, the network inspects state data and conversation history, and determines which new agent to run.This fully typed state machine routing allows you to deterministically build agents using any of the effective agent patterns — which means your code is easy to read, edit, understand, and debug.This also makes handoff incredibly easy: you define when agents should hand off to each other using regular code and state (or by calling an LLM in the router for AI-based routing). This is similar to the OpenAI Agents SDK but easier to manage, plan, and build.Then comes the local development and moving to production capabilities.AgentKit is compatible with Inngest’s tooling, meaning that you can test agents using Inngest’s local DevServer, which provides traces, inputs, outputs, replay, tool, and MCP inputs and outputs, and (soon) a step-over debugger so that you can easily understand and visually see what's happening in the agent loop.In production, you can also optionally combine AgentKit with Inngest for fault-tolerant execution. Each agent’s LLM call is wrapped in a step, and tools can use multiple steps to incorporate things like human-in-the-loop. This gives you native orchestration, observability, and out-of-the-box scale.You will find the documentation as an example of an AgentKit SWE-bench and multiple Coding Agent examples.It’s fully open-source under the Apache 2 license.If you want to get started:- npm: npm i @inngest/agent-kit- GitHub: https://github.com/inngest/agent-kit- Docs: https://agentkit.inngest.com/overviewWe’re excited to finally launch AgentKit; let us know what you think! Comments URL: https://news.ycombinator.com/item?id=43426164 Points: 49 # Comments: 11
Hi HN! I’m Tony, co-founder of Inngest. I wanted to share AgentKit, our Typescript multi-agent library we’ve been cooking and testing with some early users in prod for months.
Although OpenAI’s Agents SDK has been launched since, we think an Agent framework should offer more deterministic and flexible routing, work with multiple model providers, embrace MCP (for rich tooling), and support the unstoppable and growing community of TypeScript AI developers by enabling a smooth transition to production use cases.
This is why we are building AgentKit, and we’re really excited about it for a few reasons:
Firstly, it’s simple. We embrace KISS principles brought by Anthropic and HuggingFace by allowing you to gradually add autonomy to your AgentKit program using primitives:
- Agents: LLM calls that can be combined with prompts, tools, and MCP native support.
- Networks: a simple way to get Agents to collaborate with a shared State, including handoff.
- State: combines conversation history with a fully typed state machine, used in routing.
- Routers: where the autonomy lives, from code-based to LLM-based (ex: ReAct) orchestration
The routers are where the magic happens, and allow you to build deterministic, reliable, testable agents.
AgentKit routing works as follows: the network calls itself in a loop, inspecting the State to determine which agents to call next using a router. The returned agent runs, then optionally updates state data using its tools. On the next loop, the network inspects state data and conversation history, and determines which new agent to run.
This fully typed state machine routing allows you to deterministically build agents using any of the effective agent patterns — which means your code is easy to read, edit, understand, and debug.
This also makes handoff incredibly easy: you define when agents should hand off to each other using regular code and state (or by calling an LLM in the router for AI-based routing). This is similar to the OpenAI Agents SDK but easier to manage, plan, and build.
Then comes the local development and moving to production capabilities.
AgentKit is compatible with Inngest’s tooling, meaning that you can test agents using Inngest’s local DevServer, which provides traces, inputs, outputs, replay, tool, and MCP inputs and outputs, and (soon) a step-over debugger so that you can easily understand and visually see what's happening in the agent loop.
In production, you can also optionally combine AgentKit with Inngest for fault-tolerant execution. Each agent’s LLM call is wrapped in a step, and tools can use multiple steps to incorporate things like human-in-the-loop. This gives you native orchestration, observability, and out-of-the-box scale.
You will find the documentation as an example of an AgentKit SWE-bench and multiple Coding Agent examples.
It’s fully open-source under the Apache 2 license.
If you want to get started:
- npm: npm i @inngest/agent-kit
- GitHub: https://github.com/inngest/agent-kit
- Docs: https://agentkit.inngest.com/overview
We’re excited to finally launch AgentKit; let us know what you think!
Comments URL: https://news.ycombinator.com/item?id=43426164
Points: 49
# Comments: 11