Ecosyste.ms: Awesome
An open API service indexing awesome lists of open source software.
https://github.com/samestrin/claude-to-chatgpt-netlify
A Node.js Netlify Function based port of jtsang4/claude-to-chatgpt; it adapts Anthropic's Claude API to match OpenAI's Chat API format.
https://github.com/samestrin/claude-to-chatgpt-netlify
ai anthropic api chatgpt claude javascript llm node nodejs openai port rest
Last synced: 12 days ago
JSON representation
A Node.js Netlify Function based port of jtsang4/claude-to-chatgpt; it adapts Anthropic's Claude API to match OpenAI's Chat API format.
- Host: GitHub
- URL: https://github.com/samestrin/claude-to-chatgpt-netlify
- Owner: samestrin
- License: mit
- Created: 2024-04-17T18:01:14.000Z (9 months ago)
- Default Branch: main
- Last Pushed: 2024-05-09T00:11:45.000Z (9 months ago)
- Last Synced: 2024-11-22T04:13:09.759Z (2 months ago)
- Topics: ai, anthropic, api, chatgpt, claude, javascript, llm, node, nodejs, openai, port, rest
- Language: JavaScript
- Homepage:
- Size: 41 KB
- Stars: 0
- Watchers: 1
- Forks: 1
- Open Issues: 0
-
Metadata Files:
- Readme: README.md
- License: LICENSE
Awesome Lists containing this project
README
# claude-to-chatgpt-netlify
[![Star on GitHub](https://img.shields.io/github/stars/samestrin/claude-to-chatgpt-netlify?style=social)](https://github.com/samestrin/claude-to-chatgpt-netlify/stargazers) [![Fork on GitHub](https://img.shields.io/github/forks/samestrin/claude-to-chatgpt-netlify?style=social)](https://github.com/samestrin/claude-to-chatgpt-netlify/network/members) [![Watch on GitHub](https://img.shields.io/github/watchers/samestrin/claude-to-chatgpt-netlify?style=social)](https://github.com/samestrin/claude-to-chatgpt-netlify/watchers)
![Version 0.0.1](https://img.shields.io/badge/Version-0.0.1-blue) [![License: MIT](https://img.shields.io/badge/License-MIT-yellow.svg)](https://opensource.org/licenses/MIT) [![Built with Node.js](https://img.shields.io/badge/Built%20with-Node.js-green)](https://nodejs.org/)
A Node.js Netlify Function based port of [jtsang4/claude-to-chatgpt](https://github.com/jtsang4/claude-to-chatgpt)'s cloudflare-worker.js. This project converts the API of Anthropic's Claude model to the OpenAI Chat API format.
Netlify Function calls offer _slightly_ more resources than Cloudflare Workers and may be more performant in some use cases. _However, Netlify Functions do not support streaming._
A PHP port, designed to deploy on DigitalOcean App Platform, is available [samestrin/claude-to-chatgpt-digitalocean](https://github.com/samestrin/claude-to-chatgpt-digitalocean) here.
## Dependencies
- **Node.js**: The script runs in a Node.js environment.
- **node-fetch**: A Node.js module used for making HTTP requests to external APIs.## Features
- **API Compatibility**: Enables Claude model integration by mimicking the OpenAI ChatGPT API structure.
- **Model Flexibility**: Supports various configurations of Claude models including claude-instant-1 and claude-2.
- **Performance Optimization**: Utilizes the enhanced capabilities of Netlify Functions for improved performance over alternatives like Cloudflare Workers.## Deploy to Netlify
Click this button to deploy the project to your Netlify account:
[![Deploy to Netlify](https://www.netlify.com/img/deploy/button.svg)](https://app.netlify.com/start/deploy?repository=https://github.com/samestrin/claude-to-chatgpt-netlify)
## **Endpoints**
### **Chat Completion**
**Endpoint:** `/v1/chat/completions`
**Method:** POSTSimulate ChatGPT-like interaction by sending a message to the Claude model.
#### **Parameters**
- `model`: The OpenAI model (e.g., 'gpt-3.5-turbo') or Claude model (e.g.,'claude-instant-1') to use. (OpenAI models are automatically mapped to Claude models.)
- `messages`: An array of message objects where each message has a `role` ('user' or 'assistant') and `content`.#### **Example Usage**
Use a tool like Postman or curl to make a request:
```bash
curl -X POST http://localhost:[PORT]/v1/chat/completions \
-H "Content-Type: application/json" \
-d '{
"model": "claude-instant-1",
"messages": [
{"role": "user", "content": "Hello, how are you?"}
]
}'
```The server will process the request and return the model's response in JSON format.
### **Model Information**
**Endpoint:** `/v1/models`
**Method:** GETRetrieve information about the available models.
#### **Example Usage**
Use curl to make a request:
```bash
curl http://localhost:[PORT]/v1/models
```The server will return a list of available models and their details in JSON format.
### **CORS Pre-flight Request**
**Endpoint:** `/`
**Method:** OPTIONSHandle pre-flight requests for CORS (Cross-Origin Resource Sharing). This endpoint provides necessary headers in response to pre-flight checks performed by browsers to ensure that the server accepts requests from allowed origins.
#### **Example Usage**
This is typically used by browsers automatically before sending actual requests, but you can manually test CORS settings using curl:
```bash
curl -X OPTIONS http://localhost:[PORT]/ \
-H "Access-Control-Request-Method: POST" \
-H "Origin: http://example.com"
```The server responds with appropriate CORS headers such as Access-Control-Allow-Origin.
## Testing Your Netlify Deployment Locally
Start your Netlify dev server using the command:
```
netlify dev
```then use the following curl command to test your deployment:
```
curl -X POST http://localhost:8888/v1/chat/completions \
-H "Content-Type: application/json" \
-H "Authorization: YOUR_CLAUDE_API_KEY" \
-d '{"model": "gpt-3.5-turbo", "messages": [{"role": "user", "content": "Hello, how are you?"}]}'
```## Options
This application can be configured with various options through environment variables:
- **CLAUDE_API_KEY**: API key for accessing the Claude API.
- **CLAUDE_BASE_URL**: URL endpoint for the Claude API; defaults to "https://api.anthropic.com" if not set.
- **CLAUDE_MAX_TOKENS**: Maximum tokens that can be processed in a request; defaults to 100000 if not set.
- **CLAUDE_MAX_REQUEST_SIZE_BYTES**: Maximum size of the request payload in bytes; defaults to 1048576 (1MB) if not set.## Contribute
Contributions to this project are welcome. Please fork the repository and submit a pull request with your changes or improvements.
## License
This project is licensed under the MIT License - see the LICENSE file for details.
## Share
[![Twitter](https://img.shields.io/badge/X-Tweet-blue)](https://twitter.com/intent/tweet?text=Check%20out%20this%20awesome%20project!&url=https://github.com/samestrin/claude-to-chatgpt-netlify) [![Facebook](https://img.shields.io/badge/Facebook-Share-blue)](https://www.facebook.com/sharer/sharer.php?u=https://github.com/samestrin/claude-to-chatgpt-netlify) [![LinkedIn](https://img.shields.io/badge/LinkedIn-Share-blue)](https://www.linkedin.com/sharing/share-offsite/?url=https://github.com/samestrin/claude-to-chatgpt-netlify)