| <div align="center"> | |
|  | |
| # New API | |
| 🍥 **Next-Generation Large Model Gateway and AI Asset Management System** | |
| <p align="center"> | |
| <a href="./README.md">中文</a> | | |
| <strong>English</strong> | | |
| <a href="./README.fr.md">Français</a> | | |
| <a href="./README.ja.md">日本語</a> | |
| </p> | |
| <p align="center"> | |
| <a href="https://raw.githubusercontent.com/Calcium-Ion/new-api/main/LICENSE"> | |
| <img src="https://img.shields.io/github/license/Calcium-Ion/new-api?color=brightgreen" alt="license"> | |
| </a> | |
| <a href="https://github.com/Calcium-Ion/new-api/releases/latest"> | |
| <img src="https://img.shields.io/github/v/release/Calcium-Ion/new-api?color=brightgreen&include_prereleases" alt="release"> | |
| </a> | |
| <a href="https://github.com/users/Calcium-Ion/packages/container/package/new-api"> | |
| <img src="https://img.shields.io/badge/docker-ghcr.io-blue" alt="docker"> | |
| </a> | |
| <a href="https://hub.docker.com/r/CalciumIon/new-api"> | |
| <img src="https://img.shields.io/badge/docker-dockerHub-blue" alt="docker"> | |
| </a> | |
| <a href="https://goreportcard.com/report/github.com/Calcium-Ion/new-api"> | |
| <img src="https://goreportcard.com/badge/github.com/Calcium-Ion/new-api" alt="GoReportCard"> | |
| </a> | |
| </p> | |
| <p align="center"> | |
| <a href="https://trendshift.io/repositories/8227" target="_blank"> | |
| <img src="https://trendshift.io/api/badge/repositories/8227" alt="Calcium-Ion%2Fnew-api | Trendshift" style="width: 250px; height: 55px;" width="250" height="55"/> | |
| </a> | |
| </p> | |
| <p align="center"> | |
| <a href="#-quick-start">Quick Start</a> • | |
| <a href="#-key-features">Key Features</a> • | |
| <a href="#-deployment">Deployment</a> • | |
| <a href="#-documentation">Documentation</a> • | |
| <a href="#-help-support">Help</a> | |
| </p> | |
| </div> | |
| ## 📝 Project Description | |
| > [!NOTE] | |
| > This is an open-source project developed based on [One API](https://github.com/songquanpeng/one-api) | |
| > [!IMPORTANT] | |
| > - This project is for personal learning purposes only, with no guarantee of stability or technical support | |
| > - Users must comply with OpenAI's [Terms of Use](https://openai.com/policies/terms-of-use) and **applicable laws and regulations**, and must not use it for illegal purposes | |
| > - According to the [《Interim Measures for the Management of Generative Artificial Intelligence Services》](http://www.cac.gov.cn/2023-07/13/c_1690898327029107.htm), please do not provide any unregistered generative AI services to the public in China. | |
| --- | |
| ## 🤝 Trusted Partners | |
| <p align="center"> | |
| <em>No particular order</em> | |
| </p> | |
| <p align="center"> | |
| <a href="https://www.cherry-ai.com/" target="_blank"> | |
| <img src="./docs/images/cherry-studio.png" alt="Cherry Studio" height="80" /> | |
| </a> | |
| <a href="https://bda.pku.edu.cn/" target="_blank"> | |
| <img src="./docs/images/pku.png" alt="Peking University" height="80" /> | |
| </a> | |
| <a href="https://www.compshare.cn/?ytag=GPU_yy_gh_newapi" target="_blank"> | |
| <img src="./docs/images/ucloud.png" alt="UCloud" height="80" /> | |
| </a> | |
| <a href="https://www.aliyun.com/" target="_blank"> | |
| <img src="./docs/images/aliyun.png" alt="Alibaba Cloud" height="80" /> | |
| </a> | |
| <a href="https://io.net/" target="_blank"> | |
| <img src="./docs/images/io-net.png" alt="IO.NET" height="80" /> | |
| </a> | |
| </p> | |
| --- | |
| ## 🙏 Special Thanks | |
| <p align="center"> | |
| <a href="https://www.jetbrains.com/?from=new-api" target="_blank"> | |
| <img src="https://resources.jetbrains.com/storage/products/company/brand/logos/jb_beam.png" alt="JetBrains Logo" width="120" /> | |
| </a> | |
| </p> | |
| <p align="center"> | |
| <strong>Thanks to <a href="https://www.jetbrains.com/?from=new-api">JetBrains</a> for providing free open-source development license for this project</strong> | |
| </p> | |
| --- | |
| ## 🚀 Quick Start | |
| ### Using Docker Compose (Recommended) | |
| ```bash | |
| # Clone the project | |
| git clone https://github.com/QuantumNous/new-api.git | |
| cd new-api | |
| # Edit docker-compose.yml configuration | |
| nano docker-compose.yml | |
| # Start the service | |
| docker-compose up -d | |
| ``` | |
| <details> | |
| <summary><strong>Using Docker Commands</strong></summary> | |
| ```bash | |
| # Pull the latest image | |
| docker pull calciumion/new-api:latest | |
| # Using SQLite (default) | |
| docker run --name new-api -d --restart always \ | |
| -p 3000:3000 \ | |
| -e TZ=Asia/Shanghai \ | |
| -v ./data:/data \ | |
| calciumion/new-api:latest | |
| # Using MySQL | |
| docker run --name new-api -d --restart always \ | |
| -p 3000:3000 \ | |
| -e SQL_DSN="root:123456@tcp(localhost:3306)/oneapi" \ | |
| -e TZ=Asia/Shanghai \ | |
| -v ./data:/data \ | |
| calciumion/new-api:latest | |
| ``` | |
| > **💡 Tip:** `-v ./data:/data` will save data in the `data` folder of the current directory, you can also change it to an absolute path like `-v /your/custom/path:/data` | |
| </details> | |
| --- | |
| 🎉 After deployment is complete, visit `http://localhost:3000` to start using! | |
| 📖 For more deployment methods, please refer to [Deployment Guide](https://docs.newapi.pro/installation) | |
| --- | |
| ## 📚 Documentation | |
| <div align="center"> | |
| ### 📖 [Official Documentation](https://docs.newapi.pro/) | [](https://deepwiki.com/QuantumNous/new-api) | |
| </div> | |
| **Quick Navigation:** | |
| | Category | Link | | |
| |------|------| | |
| | 🚀 Deployment Guide | [Installation Documentation](https://docs.newapi.pro/installation) | | |
| | ⚙️ Environment Configuration | [Environment Variables](https://docs.newapi.pro/installation/environment-variables) | | |
| | 📡 API Documentation | [API Documentation](https://docs.newapi.pro/api) | | |
| | ❓ FAQ | [FAQ](https://docs.newapi.pro/support/faq) | | |
| | 💬 Community Interaction | [Communication Channels](https://docs.newapi.pro/support/community-interaction) | | |
| --- | |
| ## ✨ Key Features | |
| > For detailed features, please refer to [Features Introduction](https://docs.newapi.pro/wiki/features-introduction) | |
| ### 🎨 Core Functions | |
| | Feature | Description | | |
| |------|------| | |
| | 🎨 New UI | Modern user interface design | | |
| | 🌍 Multi-language | Supports Chinese, English, French, Japanese | | |
| | 🔄 Data Compatibility | Fully compatible with the original One API database | | |
| | 📈 Data Dashboard | Visual console and statistical analysis | | |
| | 🔒 Permission Management | Token grouping, model restrictions, user management | | |
| ### 💰 Payment and Billing | |
| - ✅ Online recharge (EPay, Stripe) | |
| - ✅ Pay-per-use model pricing | |
| - ✅ Cache billing support (OpenAI, Azure, DeepSeek, Claude, Qwen and all supported models) | |
| - ✅ Flexible billing policy configuration | |
| ### 🔐 Authorization and Security | |
| - 😈 Discord authorization login | |
| - 🤖 LinuxDO authorization login | |
| - 📱 Telegram authorization login | |
| - 🔑 OIDC unified authentication | |
| ### 🚀 Advanced Features | |
| **API Format Support:** | |
| - ⚡ [OpenAI Responses](https://docs.newapi.pro/api/openai-responses) | |
| - ⚡ [OpenAI Realtime API](https://docs.newapi.pro/api/openai-realtime) (including Azure) | |
| - ⚡ [Claude Messages](https://docs.newapi.pro/api/anthropic-chat) | |
| - ⚡ [Google Gemini](https://docs.newapi.pro/api/google-gemini-chat/) | |
| - 🔄 [Rerank Models](https://docs.newapi.pro/api/jinaai-rerank) (Cohere, Jina) | |
| **Intelligent Routing:** | |
| - ⚖️ Channel weighted random | |
| - 🔄 Automatic retry on failure | |
| - 🚦 User-level model rate limiting | |
| **Format Conversion:** | |
| - 🔄 OpenAI ⇄ Claude Messages | |
| - 🔄 OpenAI ⇄ Gemini Chat | |
| - 🔄 Thinking-to-content functionality | |
| **Reasoning Effort Support:** | |
| <details> | |
| <summary>View detailed configuration</summary> | |
| **OpenAI series models:** | |
| - `o3-mini-high` - High reasoning effort | |
| - `o3-mini-medium` - Medium reasoning effort | |
| - `o3-mini-low` - Low reasoning effort | |
| - `gpt-5-high` - High reasoning effort | |
| - `gpt-5-medium` - Medium reasoning effort | |
| - `gpt-5-low` - Low reasoning effort | |
| **Claude thinking models:** | |
| - `claude-3-7-sonnet-20250219-thinking` - Enable thinking mode | |
| **Google Gemini series models:** | |
| - `gemini-2.5-flash-thinking` - Enable thinking mode | |
| - `gemini-2.5-flash-nothinking` - Disable thinking mode | |
| - `gemini-2.5-pro-thinking` - Enable thinking mode | |
| - `gemini-2.5-pro-thinking-128` - Enable thinking mode with thinking budget of 128 tokens | |
| </details> | |
| --- | |
| ## 🤖 Model Support | |
| > For details, please refer to [API Documentation - Relay Interface](https://docs.newapi.pro/api) | |
| | Model Type | Description | Documentation | | |
| |---------|------|------| | |
| | 🤖 OpenAI GPTs | gpt-4-gizmo-* series | - | | |
| | 🎨 Midjourney-Proxy | [Midjourney-Proxy(Plus)](https://github.com/novicezk/midjourney-proxy) | [Documentation](https://docs.newapi.pro/api/midjourney-proxy-image) | | |
| | 🎵 Suno-API | [Suno API](https://github.com/Suno-API/Suno-API) | [Documentation](https://docs.newapi.pro/api/suno-music) | | |
| | 🔄 Rerank | Cohere, Jina | [Documentation](https://docs.newapi.pro/api/jinaai-rerank) | | |
| | 💬 Claude | Messages format | [Documentation](https://docs.newapi.pro/api/anthropic-chat) | | |
| | 🌐 Gemini | Google Gemini format | [Documentation](https://docs.newapi.pro/api/google-gemini-chat/) | | |
| | 🔧 Dify | ChatFlow mode | - | | |
| | 🎯 Custom | Supports complete call address | - | | |
| ### 📡 Supported Interfaces | |
| <details> | |
| <summary>View complete interface list</summary> | |
| - [Chat Interface (Chat Completions)](https://docs.newapi.pro/api/openai-chat) | |
| - [Response Interface (Responses)](https://docs.newapi.pro/api/openai-responses) | |
| - [Image Interface (Image)](https://docs.newapi.pro/api/openai-image) | |
| - [Audio Interface (Audio)](https://docs.newapi.pro/api/openai-audio) | |
| - [Video Interface (Video)](https://docs.newapi.pro/api/openai-video) | |
| - [Embedding Interface (Embeddings)](https://docs.newapi.pro/api/openai-embeddings) | |
| - [Rerank Interface (Rerank)](https://docs.newapi.pro/api/jinaai-rerank) | |
| - [Realtime Conversation (Realtime)](https://docs.newapi.pro/api/openai-realtime) | |
| - [Claude Chat](https://docs.newapi.pro/api/anthropic-chat) | |
| - [Google Gemini Chat](https://docs.newapi.pro/api/google-gemini-chat/) | |
| </details> | |
| --- | |
| ## 🚢 Deployment | |
| > [!TIP] | |
| > **Latest Docker image:** `calciumion/new-api:latest` | |
| ### 📋 Deployment Requirements | |
| | Component | Requirement | | |
| |------|------| | |
| | **Local database** | SQLite (Docker must mount `/data` directory)| | |
| | **Remote database** | MySQL ≥ 5.7.8 or PostgreSQL ≥ 9.6 | | |
| | **Container engine** | Docker / Docker Compose | | |
| ### ⚙️ Environment Variable Configuration | |
| <details> | |
| <summary>Common environment variable configuration</summary> | |
| | Variable Name | Description | Default Value | | |
| |--------|------|--------| | |
| | `SESSION_SECRET` | Session secret (required for multi-machine deployment) | - | | |
| | `CRYPTO_SECRET` | Encryption secret (required for Redis) | - | | |
| | `SQL_DSN` | Database connection string | - | | |
| | `REDIS_CONN_STRING` | Redis connection string | - | | |
| | `STREAMING_TIMEOUT` | Streaming timeout (seconds) | `300` | | |
| | `AZURE_DEFAULT_API_VERSION` | Azure API version | `2025-04-01-preview` | | |
| | `ERROR_LOG_ENABLED` | Error log switch | `false` | | |
| 📖 **Complete configuration:** [Environment Variables Documentation](https://docs.newapi.pro/installation/environment-variables) | |
| </details> | |
| ### 🔧 Deployment Methods | |
| <details> | |
| <summary><strong>Method 1: Docker Compose (Recommended)</strong></summary> | |
| ```bash | |
| # Clone the project | |
| git clone https://github.com/QuantumNous/new-api.git | |
| cd new-api | |
| # Edit configuration | |
| nano docker-compose.yml | |
| # Start service | |
| docker-compose up -d | |
| ``` | |
| </details> | |
| <details> | |
| <summary><strong>Method 2: Docker Commands</strong></summary> | |
| **Using SQLite:** | |
| ```bash | |
| docker run --name new-api -d --restart always \ | |
| -p 3000:3000 \ | |
| -e TZ=Asia/Shanghai \ | |
| -v ./data:/data \ | |
| calciumion/new-api:latest | |
| ``` | |
| **Using MySQL:** | |
| ```bash | |
| docker run --name new-api -d --restart always \ | |
| -p 3000:3000 \ | |
| -e SQL_DSN="root:123456@tcp(localhost:3306)/oneapi" \ | |
| -e TZ=Asia/Shanghai \ | |
| -v ./data:/data \ | |
| calciumion/new-api:latest | |
| ``` | |
| > **💡 Path explanation:** | |
| > - `./data:/data` - Relative path, data saved in the data folder of the current directory | |
| > - You can also use absolute path, e.g.: `/your/custom/path:/data` | |
| </details> | |
| <details> | |
| <summary><strong>Method 3: BaoTa Panel</strong></summary> | |
| 1. Install BaoTa Panel (≥ 9.2.0 version) | |
| 2. Search for **New-API** in the application store | |
| 3. One-click installation | |
| 📖 [Tutorial with images](./docs/BT.md) | |
| </details> | |
| ### ⚠️ Multi-machine Deployment Considerations | |
| > [!WARNING] | |
| > - **Must set** `SESSION_SECRET` - Otherwise login status inconsistent | |
| > - **Shared Redis must set** `CRYPTO_SECRET` - Otherwise data cannot be decrypted | |
| ### 🔄 Channel Retry and Cache | |
| **Retry configuration:** `Settings → Operation Settings → General Settings → Failure Retry Count` | |
| **Cache configuration:** | |
| - `REDIS_CONN_STRING`: Redis cache (recommended) | |
| - `MEMORY_CACHE_ENABLED`: Memory cache | |
| --- | |
| ## 🔗 Related Projects | |
| ### Upstream Projects | |
| | Project | Description | | |
| |------|------| | |
| | [One API](https://github.com/songquanpeng/one-api) | Original project base | | |
| | [Midjourney-Proxy](https://github.com/novicezk/midjourney-proxy) | Midjourney interface support | | |
| ### Supporting Tools | |
| | Project | Description | | |
| |------|------| | |
| | [neko-api-key-tool](https://github.com/Calcium-Ion/neko-api-key-tool) | Key quota query tool | | |
| | [new-api-horizon](https://github.com/Calcium-Ion/new-api-horizon) | New API high-performance optimized version | | |
| --- | |
| ## 💬 Help Support | |
| ### 📖 Documentation Resources | |
| | Resource | Link | | |
| |------|------| | |
| | 📘 FAQ | [FAQ](https://docs.newapi.pro/support/faq) | | |
| | 💬 Community Interaction | [Communication Channels](https://docs.newapi.pro/support/community-interaction) | | |
| | 🐛 Issue Feedback | [Issue Feedback](https://docs.newapi.pro/support/feedback-issues) | | |
| | 📚 Complete Documentation | [Official Documentation](https://docs.newapi.pro/support) | | |
| ### 🤝 Contribution Guide | |
| Welcome all forms of contribution! | |
| - 🐛 Report Bugs | |
| - 💡 Propose New Features | |
| - 📝 Improve Documentation | |
| - 🔧 Submit Code | |
| --- | |
| ## 🌟 Star History | |
| <div align="center"> | |
| [](https://star-history.com/#Calcium-Ion/new-api&Date) | |
| </div> | |
| --- | |
| <div align="center"> | |
| ### 💖 Thank you for using New API | |
| If this project is helpful to you, welcome to give us a ⭐️ Star! | |
| **[Official Documentation](https://docs.newapi.pro/)** • **[Issue Feedback](https://github.com/Calcium-Ion/new-api/issues)** • **[Latest Release](https://github.com/Calcium-Ion/new-api/releases)** | |
| <sub>Built with ❤️ by QuantumNous</sub> | |
| </div> | |