From 5c1a193f4dc1895b5f092b85c34470d0f783fd2d Mon Sep 17 00:00:00 2001 From: =?UTF-8?q?Fredrik=20Br=C3=A4nstr=C3=B6m?= Date: Mon, 11 Aug 2025 21:44:14 +0200 Subject: [PATCH] docs: add environment variable interpolation documentation - Document and syntax in README - Add example usage in config.json - Explain security benefits and recursive interpolation support --- README.md | 21 +++++++++++++++++++++ 1 file changed, 21 insertions(+) diff --git a/README.md b/README.md index e4198ab..e10265b 100644 --- a/README.md +++ b/README.md @@ -47,6 +47,27 @@ The `config.json` file has several key sections: - **`Router`**: Used to set up routing rules. `default` specifies the default model, which will be used for all requests if no other route is configured. - **`API_TIMEOUT_MS`**: Specifies the timeout for API calls in milliseconds. +#### Environment Variable Interpolation + +Claude Code Router supports environment variable interpolation for secure API key management. You can reference environment variables in your `config.json` using either `$VAR_NAME` or `${VAR_NAME}` syntax: + +```json +{ + "OPENAI_API_KEY": "$OPENAI_API_KEY", + "GEMINI_API_KEY": "${GEMINI_API_KEY}", + "Providers": [ + { + "name": "openai", + "api_base_url": "https://api.openai.com/v1/chat/completions", + "api_key": "$OPENAI_API_KEY", + "models": ["gpt-5", "gpt-5-mini"] + } + ] +} +``` + +This allows you to keep sensitive API keys in environment variables instead of hardcoding them in configuration files. The interpolation works recursively through nested objects and arrays. + Here is a comprehensive example: ```json