Node.js SDK
Requirements
- Node.js 18 or higher
Installation
bash
npm install openaiQuick Start
Configure Client
javascript
import OpenAI from 'openai';
const client = new OpenAI({
baseURL: 'https://ai-tokenhub.com/v1',
apiKey: 'your_api_key_here'
});Basic Request
javascript
async function main() {
const response = await client.chat.completions.create({
model: 'gpt-4o',
messages: [
{ role: 'system', content: 'You are a helpful assistant' },
{ role: 'user', content: 'Hello, please introduce yourself' }
]
});
console.log(response.choices[0].message.content);
}
main();Streaming
javascript
async function main() {
const stream = await client.chat.completions.create({
model: 'gpt-4o',
messages: [
{ role: 'user', content: 'Tell me a joke about AI' }
],
stream: true
});
for await (const chunk of stream) {
if (chunk.choices[0].delta.content) {
process.stdout.write(chunk.choices[0].delta.content);
}
}
}
main();Using Claude Models
javascript
async function main() {
const response = await client.chat.completions.create({
model: 'claude-3-5-sonnet-20241022',
messages: [
{ role: 'user', content: 'Hello' }
]
});
console.log(response.choices[0].message.content);
}
main();Error Handling
javascript
import OpenAI from 'openai';
const client = new OpenAI({
baseURL: 'https://ai-tokenhub.com/v1',
apiKey: 'your_api_key_here'
});
async function main() {
try {
const response = await client.chat.completions.create({
model: 'gpt-4o',
messages: [{ role: 'user', content: 'Hello' }]
});
console.log(response.choices[0].message.content);
} catch (error) {
if (error.status === 401) {
console.error('Invalid API key');
} else if (error.status === 429) {
console.error('Rate limit exceeded, please try again later');
} else {
console.error('Error occurred:', error.message);
}
}
}
main();Next.js Integration Example
Environment Variables
env
# .env.local
OPENAI_API_KEY=your_api_key_here
OPENAI_BASE_URL=https://ai-tokenhub.com/v1API Route
javascript
// app/api/chat/route.js
import OpenAI from 'openai';
const client = new OpenAI({
apiKey: process.env.OPENAI_API_KEY,
baseURL: process.env.OPENAI_BASE_URL
});
export async function POST(request) {
const { messages } = await request.json();
const response = await client.chat.completions.create({
model: 'gpt-4o',
messages
});
return Response.json(response);
}