-
Notifications
You must be signed in to change notification settings - Fork 0
/
Copy pathserver.js
76 lines (64 loc) · 1.9 KB
/
server.js
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
const express = require('express');
const { WebSocket, WebSocketServer } = require('ws');
const http = require('http');
require('dotenv').config();
const app = express();
const server = http.createServer(app);
const wss = new WebSocketServer({ server });
app.use((req, res, next) => {
res.header('Access-Control-Allow-Origin', '*');
next();
});
wss.on('connection', (ws) => {
console.log('Client connected');
let openAiWs = null;
const connectToOpenAI = () => {
const url = "wss://api.openai.com/v1/realtime?model=gpt-4o-realtime-preview-2024-10-01";
openAiWs = new WebSocket(url, {
headers: {
'Authorization': `Bearer ${process.env.REACT_APP_OPENAI_API_KEY}`,
'OpenAI-Beta': 'realtime=v1'
}
});
openAiWs.on('open', () => {
console.log('Connected to OpenAI Realtime API');
openAiWs.send(JSON.stringify({
type: 'session.update',
session: {
model: 'gpt-4o-realtime-preview-2024-10-01',
voice: 'alloy',
input_audio_format: 'pcm16',
output_audio_format: 'pcm16',
sample_rate: 24000,
turn_detection: null // Disable VAD for manual mode
}
}));
});
openAiWs.on('error', (error) => {
console.error('OpenAI WebSocket error:', error);
ws.send(JSON.stringify({ type: 'error', error: error.message }));
});
openAiWs.on('message', (data) => {
ws.send(data.toString());
});
openAiWs.on('close', () => {
console.log('OpenAI connection closed');
});
};
connectToOpenAI();
ws.on('message', (message) => {
if (openAiWs?.readyState === WebSocket.OPEN) {
openAiWs.send(message.toString());
}
});
ws.on('close', () => {
if (openAiWs) {
openAiWs.close();
}
console.log('Client disconnected');
});
});
const PORT = 3005;
server.listen(PORT, () => {
console.log(`Proxy server running on port ${PORT}`);
});