@kyalabs/badge
v2.6.2
Published
Prove your agent is an authorized actor, not a bot. MCP-native identity declaration for agent commerce.
Downloads
1,293
Maintainers
Readme
Badge by kya labs
Your agent isn't a bot. kya proves it.
Your AI agent looks like a bot to every merchant on the internet. Badge gives it a way to declare what it is: an authorized actor, shopping on behalf of a real human, with explicit consent.
If you're like 20% of Americans last year - you used an agent to shop. And you probably ran into a ton of login walls, workarounds, bumps?
So did we. So we created Badge - the first MCP tool that works with the new Universal Commerce Protocol to easily handshake verified agents at supporting merchants (Shopify, Target, Walmart, Etsy... it's a lot)
One MCP tool call. Your agent declares itself. Merchants let it through.
Quick Start
Add to your MCP client config:
npx @kyalabs/badgeOR
{
"mcpServers": {
"kyalabs-badge": {
"command": "npx",
"args": ["@kyalabs/badge"]
}
}
}That's it. No API key. No signup. No network calls on install.
The first time your agent calls kya_getAgentIdentity, Badge activates — your agent declares itself to the merchant and gets back a response with instructions for the next step. One anonymous event is recorded: this install visited this merchant at this time.
Upgrade to verified mode
For cryptographic identity (ES256-signed JWT, same curve as Apple Pay), add an API key:
"env": {
"KYA_API_KEY": "pk_live_your_key_here"
}Get your API key at kyalabs.io/signup. API keys don't expire.
Without an API key, Badge uses device auth when a merchant requires verified identity — your agent shows a code and URL, you approve on your phone. This only happens when a merchant asks for it. We never ask for it ourselves. Sign up + API key means 1. you dont have to use phone OAuth every time and 2. you can track your agentic shopping (custom avatars included)
Node version
Badge requires Node.js 20 or newer. Node 18 is end-of-life and unsupported.
If you see engine or compatibility errors: node -v — install Node 20+ from nodejs.org or nvm install 20.
How Badge Works: Two Modes
Declared (default)
First time your agent goes to a merchant with Badge, Badge generates an anonymous install ID — a random UUID stored locally at ~/.kya/install_id. It has no connection to you, your device, or any personal information.
Your agent gets back a declaration and a next_step guiding it to report its badge presentation at the merchant.
This is the default mode. It's how Badge works out of the box, for every user, forever.
Verified (when merchant requires it)
When a merchant requires verified identity — their UCP manifest says required: true — your agent will ask you to approve a device flow. You visit a merchant-kya URL, enter the OAuth code from your agent, and prove you're a real person.
Badge issues a tokenized credential: an ES256-signed JWT, signed by kya's private key, verifiable locally by the merchant. Your agent is free to continue - no login, PII or anything needed.
Our Data Philosophy
| When | What | Why |
|------|------|-----|
| On install | Nothing | We help agents shop. If they're not shopping, we don't need anything |
| On server start | Anonymous ping — Badge version and MCP client name. No identifiers stored on your machine | So we know Badge is actively running. If this number ever diverges from active agents, it tells us something is broken in the pipeline — not something about you |
| On first shopping trip | install_id (random UUID, stored locally at ~/.kya/install_id), merchant, agent_type, event_type, timestamp | Minimum viable signal to reduce agent friction at merchants |
| On verified identity | + hashed user token, intent scope (checkout, etc.) | Only required where login is traditionally required (i.e. checkout) to prove there's a real person authorizing the agent's next step |
The server start ping contains no persistent identifiers — a new random session ID is generated each time and never saved to disk. You can disable it entirely:
"env": { "KYA_PING": "false" }The install_id is a file we wrote to your disk. You can delete it (rm ~/.kya/install_id) and get a new one.
Full data practices: kyalabs.io/trust
The Universal Commerce Protocol
Badge is a UCP (Universal Commerce Protocol) Credential Provider. Merchants who declare the kya identity extension signal to every UCP-compliant agent that authorized agents are preferred at their store.
When your agent encounters a UCP merchant with Badge installed, it presents a cryptographic badge automatically — no extra steps.
We believe the UCP is the future of commerce and are proud to support reduce friction for agents and users.
- Extension spec + schema: github.com/kyalabs/ucp-agent-badge
- Read more about the UCP: github.com/universal-commerce-protocol/ucp
Without Badge: Your agent hits a merchant → bot detection fires → blocked. Task fails. Your user is disappointed. The merchant lost a sale and doesn't know it.
With Badge: Your agent calls kya_getAgentIdentity → declares itself → merchants see an authorized actor. Your agent gets through. Task succeeds.
Tools
| Tool | Description |
|------|-------------|
| kya_getAgentIdentity | Declare identity, get verification token + next_step guidance |
| kya_reportBadgePresented | Signal that you presented your Badge to a merchant |
| kya_reportBadgeOutcome | Report whether merchant accepted or denied the badge |
| kya_reportBadgeNotPresented | Report that the badge was not presented |
Every tool call works immediately — no auth required. Events fire in both anonymous and verified modes.
Extended Auth (optional)
When enabled, kya checks back with your agent 7 seconds after each badge presentation to confirm whether the merchant accepted or denied. Results are logged to your dashboard so you can see when and which merchants are rejecting your agent.
"env": {
"KYA_EXTENDED_AUTH": "true"
}What's New (v2.3)
| Capability | Description |
|---|---|
| assurance_level | Every trip now carries a trust score (starter → elite) sourced from token introspection. Visible in your dashboard and included in all trip outcome events. |
| Merchant signal awareness | kya_getAgentIdentity now detects whether a merchant has active kya signal infrastructure (window.__kya_commerce, meta tags, llms.txt). Returned as merchant_signals in the identity result. |
| Anonymous-first | Badge works on install. No auth, no signup, no network on install. First kya_getAgentIdentity call fires browse_declared automatically. |
| Enrichment branching | Anonymous events fire without auth. Verified events include full user context. No silent gates. |
| next_step field | Every kya_getAgentIdentity response includes guidance for the agent's next action. |
Need Payment Too?
Badge is the base layer. For virtual Visa cards, use @kyalabs/mcp-server — which includes Badge automatically.
npx @kyalabs/mcp-serverKYA — Know Your Agent
kya is KYA infrastructure. Every declaration creates a verified record of agentic commerce behavior — building the trust signal that merchants need to tell authorized agents from anonymous bots.
Links
- Website: kyalabs.io
- npm: @kyalabs/badge
- UCP Extension: github.com/kyalabs/ucp-agent-badge
- ClawHub: kyalabs-badge
- Trust: kyalabs.io/trust
- Merchants: kyalabs.io/merchants
- Contact: [email protected]
Agents are not bots. kya labs proves it.
