Authentication

The Kilo AI Gateway supports multiple authentication methods depending on your use case.

API key authentication

The primary authentication method is a Bearer token passed in the Authorization header:

Authorization: Bearer <your_api_key>

API keys are JWT tokens tied to your Kilo account. You can generate them from the Kilo dashboard.

Using your API key

import { createOpenAI } from "@ai-sdk/openai"

const kilo = createOpenAI({
	baseURL: "https://api.kilo.ai/api/gateway",
	apiKey: process.env.KILO_API_KEY,
})

Organization tokens

When making requests on behalf of an organization, include the organization ID in the request header:

X-KiloCode-OrganizationId: your_org_id

Organization tokens are scoped with a 15-minute expiry and enforce the organization's policies, including model allow lists, provider restrictions, and per-user spending limits.

Anonymous access

The gateway allows unauthenticated access for free models only. Anonymous requests are identified by IP address and are subject to rate limiting (200 requests per hour per IP).

Free models include models tagged with :free in their model ID, such as minimax/minimax-m2.1:free and z-ai/glm-5:free.

Bring Your Own Key (BYOK)

BYOK lets you use your own provider API keys with the Kilo AI Gateway. When a BYOK key is configured, the gateway routes requests through Vercel AI Gateway using your key. You are billed directly by the provider -- Kilo does not add any markup.

Supported BYOK providers

ProviderBYOK Key ID
Anthropicanthropic
OpenAIopenai
Google AI Studiogoogle
Mistralmistral
MiniMaxminimax
xAIxai
Z.AIzai
Codestral (FIM)codestral

How BYOK works

  1. Add your provider API key in the Kilo dashboard or through your Kilo Code extension settings
  2. Keys are encrypted at rest using AES encryption
  3. When you make a request for a model from that provider, the gateway automatically uses your key
  4. Usage is tracked but not billed to your Kilo balance (cost is set to $0)
  5. If your BYOK key fails, the request will not automatically fall back to Kilo's keys

BYOK routing

When a BYOK key is detected, the request is routed through Vercel AI Gateway with your credentials:

Client → Kilo Gateway → Vercel AI Gateway (with your key) → Provider

This provides the benefit of Vercel's reliability infrastructure while using your own billing relationship with the provider.

Request headers

The gateway accepts the following headers:

HeaderRequiredDescription
AuthorizationYes (unless free model)Bearer <api_key>
Content-TypeYesapplication/json
X-KiloCode-OrganizationIdNoOrganization context for org-scoped requests
X-KiloCode-TaskIdNoTask identifier for prompt cache keying
X-KiloCode-VersionNoClient version string
x-kilocode-modeNoMode hint for kilo/auto model routing