-
Notifications
You must be signed in to change notification settings - Fork 0
/
Copy pathserver.js
112 lines (93 loc) · 2.32 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
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
const fs = require('fs')
const https = require('https')
const express = require('express')
const cors = require('cors')
const bodyParser = require('body-parser')
const axios = require('axios').default
require('dotenv').config()
const app = express()
const httpsAgent = new https.Agent({
rejectUnauthorized: false,
})
const openAIApi = axios.create({
baseURL: 'https://api.openai.com',
headers: {
Authorization: `Bearer ${process.env.OPENAI_API_KEY}`,
},
})
app.use(cors())
app.use(bodyParser.json())
const qbTokenValidation = async (token) => {
try {
if (!token) return false
const { data } = await axios.get('session.json', {
baseURL: process.env.QUICKBLOX_API_URL,
headers: {
'QB-Token': token,
},
httpsAgent,
})
return Boolean(data.session && data.session.user_id)
} catch (error) {
return false
}
}
app.use(async (req, res) => {
try {
const excludedHeaders = [
'qb-token',
'accept',
'host',
'user-agent',
'content-length',
]
const headers = { ...req.headers }
const isValidToken = await qbTokenValidation(headers['qb-token'])
if (!isValidToken) {
res.status(403).send({
error: {
message: 'Invalid QB-Token header',
},
})
return
}
excludedHeaders.forEach((header) => {
delete headers[header]
})
const options = {
method: req.method,
url: req.originalUrl,
headers,
data: req.body,
httpsAgent,
}
const { data } = await openAIApi.request(options)
res.send(data)
} catch (error) {
let status = 500
let errorData = {
error: {
message: error.message,
},
}
if ('response' in error) {
status = error.response.status
errorData = error.response.data
}
res.status(status).send(errorData)
}
})
const runServerListener = () => {
console.log(`Server is running at port ${process.env.PORT}`)
}
if (process.env.SSL_KEY_FILE && process.env.SSL_CERT_FILE) {
const certificates = {
key: fs.readFileSync(process.env.SSL_KEY_FILE),
cert: fs.readFileSync(process.env.SSL_CERT_FILE),
}
https
.createServer(certificates, app)
.listen(process.env.PORT, process.env.HOST, runServerListener)
} else {
app.listen(process.env.PORT, process.env.HOST, runServerListener)
}