coai/manager/completions.go

63 lines
1.4 KiB
Go

package manager
import (
adaptercommon "chat/adapter/common"
"chat/addition/web"
"chat/admin"
"chat/auth"
"chat/channel"
"chat/globals"
"chat/utils"
"fmt"
"runtime/debug"
"github.com/gin-gonic/gin"
)
func NativeChatHandler(c *gin.Context, user *auth.User, model string, message []globals.Message, enableWeb bool) (string, float32) {
defer func() {
if err := recover(); err != nil {
stack := debug.Stack()
globals.Warn(fmt.Sprintf("caught panic from chat handler: %s (instance: %s, client: %s)\n%s",
err, model, c.ClientIP(), stack,
))
}
}()
segment := web.ToSearched(enableWeb, message)
db := utils.GetDBFromContext(c)
cache := utils.GetCacheFromContext(c)
check, plan := auth.CanEnableModelWithSubscription(db, cache, user, model, segment)
if check != nil {
return check.Error(), 0
}
buffer := utils.NewBuffer(model, segment, channel.ChargeInstance.GetCharge(model))
hit, err := channel.NewChatRequestWithCache(
cache, buffer,
auth.GetGroup(db, user),
adaptercommon.CreateChatProps(&adaptercommon.ChatProps{
Model: model,
Message: segment,
}, buffer),
func(resp *globals.Chunk) error {
buffer.WriteChunk(resp)
return nil
},
)
admin.AnalyseRequest(model, buffer, err)
if err != nil {
auth.RevertSubscriptionUsage(db, cache, user, model)
return err.Error(), 0
}
if !hit {
CollectQuota(c, user, buffer, plan, err)
}
return buffer.ReadWithDefault(defaultMessage), buffer.GetQuota()
}