| import express from 'express' |
| import type { RequestProps } from './types' |
| import type { ChatMessage } from './chatgpt' |
| import { chatConfig, chatReplyProcess, currentModel } from './chatgpt' |
| import { auth } from './middleware/auth' |
| import { limiter } from './middleware/limiter' |
| import { isNotEmptyString } from './utils/is' |
|
|
| const app = express() |
| const router = express.Router() |
|
|
| app.use(express.static('public')) |
| app.use(express.json()) |
|
|
| app.all('*', (_, res, next) => { |
| res.header('Access-Control-Allow-Origin', '*') |
| res.header('Access-Control-Allow-Headers', 'authorization, Content-Type') |
| res.header('Access-Control-Allow-Methods', '*') |
| next() |
| }) |
|
|
| router.post('/chat-process', [auth, limiter], async (req, res) => { |
| res.setHeader('Content-type', 'application/octet-stream') |
|
|
| try { |
| const { prompt, options = {}, systemMessage, temperature, top_p } = req.body as RequestProps |
| let firstChunk = true |
| await chatReplyProcess({ |
| message: prompt, |
| lastContext: options, |
| process: (chat: ChatMessage) => { |
| res.write(firstChunk ? JSON.stringify(chat) : `\n${JSON.stringify(chat)}`) |
| firstChunk = false |
| }, |
| systemMessage, |
| temperature, |
| top_p, |
| }) |
| } |
| catch (error) { |
| res.write(JSON.stringify(error)) |
| } |
| finally { |
| res.end() |
| } |
| }) |
|
|
| router.post('/config', auth, async (req, res) => { |
| try { |
| const response = await chatConfig() |
| res.send(response) |
| } |
| catch (error) { |
| res.send(error) |
| } |
| }) |
|
|
| router.post('/session', async (req, res) => { |
| try { |
| const AUTH_SECRET_KEY = process.env.AUTH_SECRET_KEY |
| const hasAuth = isNotEmptyString(AUTH_SECRET_KEY) |
| res.send({ status: 'Success', message: '', data: { auth: hasAuth, model: currentModel() } }) |
| } |
| catch (error) { |
| res.send({ status: 'Fail', message: error.message, data: null }) |
| } |
| }) |
|
|
| router.post('/verify', async (req, res) => { |
| try { |
| const { token } = req.body as { token: string } |
| if (!token) |
| throw new Error('Secret key is empty') |
|
|
| if (process.env.AUTH_SECRET_KEY !== token) |
| throw new Error('密钥无效 | Secret key is invalid') |
|
|
| res.send({ status: 'Success', message: 'Verify successfully', data: null }) |
| } |
| catch (error) { |
| res.send({ status: 'Fail', message: error.message, data: null }) |
| } |
| }) |
|
|
| app.use('', router) |
| app.use('/api', router) |
| app.set('trust proxy', 1) |
|
|
| app.listen(3002, () => globalThis.console.log('Server is running on port 3002')) |
|
|