Ir al contenido

OpenRouter

OpenRouter proporciona una API unificada que enruta las solicitudes a muchos modelos detrás de un único punto de conexión y clave de API. Es compatible con OpenAI, por lo que la mayoría de los SDK de OpenAI funcionan simplemente cambiando la URL base.

  1. Obtén tu clave de API

    Crea una clave de API en openrouter.ai/keys.

  2. Ejecuta la incorporación

    Ventana de terminal
    openclaw onboard --auth-choice openrouter-api-key
  3. (Opcional) Cambia a un modelo específico

    La incorporación usa por defecto openrouter/auto. Elige un modelo concreto más tarde:

    Ventana de terminal
    openclaw models set openrouter/

    /

{
env: { OPENROUTER_API_KEY: "sk-or-..." },
agents: {
defaults: {
model: { primary: "openrouter/auto" },
},
},
}

Ejemplos de reserva agrupados:

Referencia de modeloNotas
openrouter/autoEnrutamiento automático de OpenRouter
openrouter/moonshotai/kimi-k2.6Kimi K2.6 vía MoonshotAI
openrouter/moonshotai/kimi-k2.5Kimi K2.5 vía MoonshotAI

OpenRouter también puede respaldar la herramienta image_generate. Usa un modelo de imagen de OpenRouter en agents.defaults.imageGenerationModel:

{
env: { OPENROUTER_API_KEY: "sk-or-..." },
agents: {
defaults: {
imageGenerationModel: {
primary: "openrouter/google/gemini-3.1-flash-image-preview",
timeoutMs: 180_000,
},
},
},
}

OpenClaw envía solicitudes de imagen a la API de imagen de finalizaciones de chat de OpenRouter con modalities: ["image", "text"]. Los modelos de imagen de Gemini reciben sugerencias compatibles de aspectRatio y resolution a través de image_config de OpenRouter. Usa agents.defaults.imageGenerationModel.timeoutMs para modelos de imagen de OpenRouter más lentos; el parámetro timeoutMs por llamada de la herramienta image_generate sigue teniendo prioridad.

OpenRouter también puede respaldar la herramienta video_generate a través de su API asíncrona /videos. Usa un modelo de video de OpenRouter en agents.defaults.videoGenerationModel:

{
env: { OPENROUTER_API_KEY: "sk-or-..." },
agents: {
defaults: {
videoGenerationModel: {
primary: "openrouter/google/veo-3.1-fast",
},
},
},
}

OpenClaw envía trabajos de texto a vídeo e imagen a vídeo a OpenRouter, sondea el polling_url devuelto y descarga el vídeo completado desde el unsigned_urls de OpenRouter o el punto de conexión de contenido del trabajo documentado. Las imágenes de referencia se envían como imágenes del primer/último fotograma de forma predeterminada; las imágenes etiquetadas con reference_image se envían como referencias de entrada de OpenRouter. El google/veo-3.1-fast predeterminado incluido anuncia las duraciones de 4/6/8 segundos actualmente compatibles, las resoluciones 720P/1080P y las relaciones de aspecto 16:9/9:16. Video-to-video no está registrado para OpenRouter porque la API de generación de vídeo ascendente actualmente acepta referencias de texto e imagen.

OpenRouter también puede respaldar la herramienta music_generate a través de la salida de audio de completaciones de chat. Utilice un modelo de audio de OpenRouter en agents.defaults.musicGenerationModel:

{
env: { OPENROUTER_API_KEY: "sk-or-..." },
agents: {
defaults: {
musicGenerationModel: {
primary: "openrouter/google/lyria-3-pro-preview",
timeoutMs: 180_000,
},
},
},
}

El proveedor de música OpenRouter incluido se predetermina a google/lyria-3-pro-preview y también expone google/lyria-3-clip-preview. OpenClaw envía modalities: ["text", "audio"], habilita el streaming, recopila los fragmentos de audio transmitidos y guarda el resultado como medio generado para la entrega del canal. Las imágenes de referencia se aceptan para los modelos Lyria a través del parámetro compartido music_generate image=....

OpenRouter también se puede utilizar como proveedor de TTS a través de su punto de conexión /audio/speech compatible con OpenAI.

{
messages: {
tts: {
auto: "always",
provider: "openrouter",
providers: {
openrouter: {
model: "hexgrad/kokoro-82m",
voice: "af_alloy",
responseFormat: "mp3",
},
},
},
},
}

Si se omite messages.tts.providers.openrouter.apiKey, TTS reutiliza models.providers.openrouter.apiKey y luego OPENROUTER_API_KEY.

OpenRouter puede transcribir archivos adjuntos de voz/audio entrantes a través de la ruta compartida tools.media.audio utilizando su punto de conexión STT (/audio/transcriptions). Esto se aplica a cualquier complemento de canal que reenvíe voz/audio entrante al preflight de comprensión de medios.

{
tools: {
media: {
audio: {
enabled: true,
models: [{ provider: "openrouter", model: "openai/whisper-large-v3-turbo" }],
},
},
},
}

OpenClaw envía solicitudes STT de OpenRouter como JSON con audio en base64 bajo input_audio (contrato STT de OpenRouter), no como cargas de formulario multiparte de OpenAI.

OpenRouter utiliza un token Bearer con su clave de API en segundo plano.

En las solicitudes reales de OpenRouter (https://openrouter.ai/api/v1), OpenClaw también añade los encabezados de atribución de la aplicación documentados de OpenRouter:

EncabezadoValor
HTTP-Refererhttps://openclaw.ai
X-OpenRouter-TitleOpenClaw
X-OpenRouter-Categoriescli-agent,cloud-agent,programming-app,creative-writing,writing-assistant,general-chat,personal-agent

Response caching

El almacenamiento en caché de respuestas de OpenRouter es opcional. Actívelo para cada modelo de OpenRouter con parámetros del modelo:

{
agents: {
defaults: {
models: {
"openrouter/auto": {
params: {
responseCache: true,
responseCacheTtlSeconds: 300,
},
},
},
},
},
}

OpenClaw envía X-OpenRouter-Cache: true y, cuando está configurado, X-OpenRouter-Cache-TTL. responseCacheClear: true fuerza una actualización para la solicitud actual y almacena la respuesta de reemplazo. Los alias en snake_case (response_cache, response_cache_ttl_seconds y response_cache_clear) también se aceptan.

Esto es independiente del almacenamiento en caché de avisos del proveedor y de los marcadores Anthropic cache_control de OpenRouter. Solo se aplica en rutas openrouter.ai verificadas, no en URLs base de proxy personalizadas.

Anthropic cache markers

En las rutas verificadas de OpenRouter, las referencias de modelos de Anthropic mantienen los marcadores Anthropic cache_control específicos de OpenRouter que OpenClaw utiliza para un mejor reúso del caché de avisos en los bloques de avisos del sistema/desarrollador.

Anthropic reasoning prefill

En las rutas verificadas de OpenRouter, las referencias de modelos de Anthropic con el razonamiento habilitado eliminan los turnos de prefill del asistente finales antes de que la solicitud llegue a OpenRouter, cumpliendo con el requisito de Anthropic de que las conversaciones de razonamiento terminen con un turno de usuario.

Inyección de pensamiento / razonamiento

En las rutas compatibles que no son de auto, OpenClaw asigna el nivel de pensamiento seleccionado a las cargas útiles de razonamiento del proxy de OpenRouter. Las sugerencias de modelo no compatibles y openrouter/auto omiten esa inyección de razonamiento. Hunter Alpha también omite el razonamiento del proxy para las referencias de modelo configuradas obsoletas porque OpenRouter podría devolver el texto de la respuesta final en los campos de razonamiento para esa ruta retirada.

Reproducción de razonamiento de DeepSeek V4

En las rutas verificadas de OpenRouter, openrouter/deepseek/deepseek-v4-flash y openrouter/deepseek/deepseek-v4-pro completan los reasoning_content que faltan en los turnos del asistente reproducidos para que las conversaciones de pensamiento/herramientas mantengan la forma de seguimiento requerida por DeepSeek V4. OpenClaw envía valores reasoning_effort compatibles con OpenRouter para estas rutas; xhigh es el nivel más alto anunciado y las anulaciones obsoletas max se asignan a xhigh.

Conformación de solicitudes solo de OpenAI

OpenRouter aún se ejecuta a través de la ruta compatible con OpenAI de estilo proxy, por lo que la conformación de solicitudes nativa solo de OpenAI, como serviceTier, Responses store, las cargas útiles de compatibilidad de razonamiento de OpenAI y las sugerencias de caché de indicaciones no se reenvían.

Rutas respaldadas por Gemini

Las referencias de OpenRouter respaldadas por Gemini permanecen en la ruta proxy-Gemini: OpenClaw mantiene allí la saneamiento de firmas de pensamiento de Gemini, pero no habilita la validación de reproducción nativa de Gemini ni las reescrituras de arranque.

Metadatos de enrutamiento del proveedor

Si pasa el enrutamiento del proveedor de OpenRouter bajo los parámetros del modelo, OpenClaw lo reenvía como metadatos de enrutamiento de OpenRouter antes de que se ejecuten los contenedores de flujo compartidos.

Selección de modelo

Elección de proveedores, referencias de modelos y comportamiento de conmutación por error.

Referencia de configuración

Referencia completa de configuración para agentes, modelos y proveedores.