forked from aurora-develop/aurora
-
Notifications
You must be signed in to change notification settings - Fork 0
/
Copy pathhandlers.go
128 lines (121 loc) · 3.22 KB
/
handlers.go
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
113
114
115
116
117
118
119
120
121
122
123
124
125
126
127
128
package main
import (
chatgpt_request_converter "aurora/conversion/requests/chatgpt"
chatgpt "aurora/internal/chatgpt"
official_types "aurora/typings/official"
"sync"
"github.com/gin-gonic/gin"
"github.com/google/uuid"
)
func optionsHandler(c *gin.Context) {
// Set headers for CORS
c.Header("Access-Control-Allow-Origin", "*")
c.Header("Access-Control-Allow-Methods", "POST")
c.Header("Access-Control-Allow-Headers", "*")
c.JSON(200, gin.H{
"message": "pong",
})
}
func simulateModel(c *gin.Context) {
c.JSON(200, gin.H{
"object": "list",
"data": []gin.H{
{
"id": "gpt-3.5-turbo",
"object": "model",
"created": 1688888888,
"owned_by": "chatgpt-to-api",
},
{
"id": "gpt-4",
"object": "model",
"created": 1688888888,
"owned_by": "chatgpt-to-api",
},
},
})
}
func nightmare(c *gin.Context) {
var original_request official_types.APIRequest
err := c.BindJSON(&original_request)
if err != nil {
c.JSON(400, gin.H{"error": gin.H{
"message": "Request must be proper JSON",
"type": "invalid_request_error",
"param": nil,
"code": err.Error(),
}})
return
}
token, puid := "", ""
var proxy_url = PROXY_URL
uid := uuid.NewString()
oidDid := uuid.NewString()
var chat_require *chatgpt.ChatRequire
var wg sync.WaitGroup
wg.Add(1)
//go func() {
// defer wg.Done()
// err = chatgpt.InitWSConn(token, uid, proxy_url)
//}()
go func() {
defer wg.Done()
chat_require = chatgpt.CheckRequire(token, puid, proxy_url, oidDid)
}()
wg.Wait()
//if err != nil {
// c.JSON(500, gin.H{"error": "unable to create ws tunnel"})
// return
//}
if chat_require == nil {
c.JSON(500, gin.H{"error": "unable to check chat requirement"})
return
}
// Convert the chat request to a ChatGPT request
translated_request := chatgpt_request_converter.ConvertAPIRequest(original_request, puid, chat_require.Arkose.Required, proxy_url)
response, err := chatgpt.POSTconversation(translated_request, token, puid, chat_require.Token, proxy_url, oidDid)
if err != nil {
c.JSON(500, gin.H{
"error": "error sending request",
})
return
}
defer response.Body.Close()
if chatgpt.Handle_request_error(c, response) {
return
}
var full_response string
for i := 3; i > 0; i-- {
var continue_info *chatgpt.ContinueInfo
var response_part string
response_part, continue_info = chatgpt.Handler(c, response, token, puid, uid, translated_request, original_request.Stream)
full_response += response_part
if continue_info == nil {
break
}
translated_request.Messages = nil
translated_request.Action = "continue"
translated_request.ConversationID = continue_info.ConversationID
translated_request.ParentMessageID = continue_info.ParentID
response, err = chatgpt.POSTconversation(translated_request, token, puid, chat_require.Token, proxy_url, oidDid)
if err != nil {
c.JSON(500, gin.H{
"error": "error sending request",
})
return
}
defer response.Body.Close()
if chatgpt.Handle_request_error(c, response) {
return
}
}
if c.Writer.Status() != 200 {
return
}
if !original_request.Stream {
c.JSON(200, official_types.NewChatCompletion(full_response))
} else {
c.String(200, "data: [DONE]\n\n")
}
chatgpt.UnlockSpecConn(token, uid)
}