Skip to content

Node.js SDK

Requirements

  • Node.js 18 or higher

Installation

bash
npm install openai

Quick 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/v1

API 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);
}