Quick Start
One API key. All models. OpenAI & Anthropic compatible.
curl https://api.luno.codes/v1/chat/completions \
-H "Authorization: Bearer YOUR_API_KEY" \
-H "Content-Type: application/json" \
-d '{
"model": "claude-sonnet-4-6",
"messages": [{"role": "user", "content": "Hello"}],
"max_tokens": 1024
}'Get API Key
Dashboard → API Keys → Create
Set Base URL
https://api.luno.codes/v1
Use any model
claude-sonnet-4-6, gpt-4o, gemini-3.1-pro...
Authentication
Pass your API key via the Authorization header or x-api-key.
Authorization: Bearer YOUR_API_KEY
# or
x-api-key: YOUR_API_KEYIntegrations
Drop-in replacement for any tool that supports OpenAI or Anthropic API.
Claude Code
Copy-paste ready. Replace your settings file and you're live.
{
"env": {
"ANTHROPIC_BASE_URL": "https://api.luno.codes",
"ANTHROPIC_AUTH_TOKEN": "YOUR_API_KEY",
"ANTHROPIC_DEFAULT_OPUS_MODEL": "claude-opus-4-8",
"ANTHROPIC_DEFAULT_SONNET_MODEL": "claude-sonnet-4-6",
"ANTHROPIC_DEFAULT_HAIKU_MODEL": "claude-haiku-4-5"
}
}ANTHROPIC_BASE_URL — без /v1 (Claude Code добавляет сам)
Задай все 3 DEFAULT_*_MODEL — иначе фоновые задачи упадут с "model may not exist"
Codex CLI
export OPENAI_BASE_URL=https://api.luno.codes/v1
export OPENAI_API_KEY=YOUR_API_KEY
codex
OpenCode
{
"$schema": "https://opencode.ai/config.json",
"provider": {
"luno": {
"npm": "@ai-sdk/openai-compatible",
"name": "Luno",
"options": {
"baseURL": "https://api.luno.codes/v1",
"apiKey": "YOUR_API_KEY"
},
"models": {
"claude-opus-4-8": { "name": "Claude Opus 4.8" },
"claude-sonnet-4-6": { "name": "Claude Sonnet 4.6" },
"gpt-4o": { "name": "GPT-4o" }
}
}
}
}
Cursor
Settings → Models → OpenAI API Key:
Base URL: https://api.luno.codes/v1
API Key: YOUR_API_KEY
OpenAI Python SDK
from openai import OpenAI
client = OpenAI(
base_url="https://api.luno.codes/v1",
api_key="YOUR_API_KEY"
)
response = client.chat.completions.create(
model="claude-sonnet-4-6",
messages=[{"role": "user", "content": "Hello"}]
)
print(response.choices[0].message.content)
Anthropic Python SDK
import anthropic
client = anthropic.Anthropic(
base_url="https://api.luno.codes/v1",
api_key="YOUR_API_KEY"
)
message = client.messages.create(
model="claude-opus-4-8",
max_tokens=1024,
messages=[{"role": "user", "content": "Hello"}]
)
print(message.content[0].text)https://api.luno.codes/v1Models
All models available through a single endpoint. Click any model ID to copy.
curl https://api.luno.codes/v1/models \
-H "Authorization: Bearer YOUR_API_KEY"
Claude
claude-opus-4-8Most capable, complex tasks
claude-opus-4-7Previous flagship
claude-opus-4-6Strong reasoning
claude-opus-4-5Balanced Opus
claude-sonnet-4-6Best speed/quality balance
claude-sonnet-4-5Fast generation
claude-sonnet-4Lightweight Sonnet
claude-haiku-4-5Ultra-fast
Claude Fable
claude-fable-5Latest Fable series, creative & fast
GPT
gpt-5.5Latest flagship
gpt-5.4Previous flagship
gpt-5.3-codexAgentic coding
gpt-5.2-codexLong-horizon coding
gpt-5.1Adaptive reasoning
gpt-4oMultimodal
gpt-4o-miniFast & cheap
Gemini
gemini-3.5-flashFastest, best value
gemini-3.1-proMost capable Gemini
gemini-3.1-flashLightweight & fast
Endpoints
/v1/chat/completionsOpenAI format — works with all models
/v1/messagesAnthropic format — Claude models (Claude Code, SDK)
Streaming
Add "stream": true for real-time Server-Sent Events output.
curl https://api.luno.codes/v1/chat/completions \
-H "Authorization: Bearer YOUR_API_KEY" \
-H "Content-Type: application/json" \
-d '{
"model": "claude-sonnet-4-6",
"stream": true,
"messages": [{"role": "user", "content": "Explain SSE briefly"}]
}'const res = await fetch("https://api.luno.codes/v1/chat/completions", {
method: "POST",
headers: {
"Authorization": "Bearer YOUR_API_KEY",
"Content-Type": "application/json"
},
body: JSON.stringify({
model: "claude-sonnet-4-6",
stream: true,
messages: [{ role: "user", content: "Hello" }]
})
});
const reader = res.body.getReader();
const decoder = new TextDecoder();
while (true) {
const { done, value } = await reader.read();
if (done) break;
process.stdout.write(decoder.decode(value));
}Errors
Standard HTTP status codes with JSON error bodies.
auth_errorInvalid or missing API key
insufficient_fundsToken budget exhausted for this period
rate_limit_exceededToo many requests — slow down
upstream_errorModel provider temporarily unavailable
{
"error": {
"message": "Invalid API key provided.",
"type": "auth_error",
"code": 401
}
}