|
|
@@ -13,6 +13,7 @@ import (
|
|
|
relaymodel "one-api/dto"
|
|
|
"one-api/relay/channel/claude"
|
|
|
relaycommon "one-api/relay/common"
|
|
|
+ "one-api/service"
|
|
|
"strings"
|
|
|
"time"
|
|
|
|
|
|
@@ -112,7 +113,7 @@ func awsHandler(c *gin.Context, info *relaycommon.RelayInfo, requestMode int) (*
|
|
|
return nil, &usage
|
|
|
}
|
|
|
|
|
|
-func awsStreamHandler(c *gin.Context, info *relaycommon.RelayInfo, requestMode int) (*relaymodel.OpenAIErrorWithStatusCode, *relaymodel.Usage) {
|
|
|
+func awsStreamHandler(c *gin.Context, resp *http.Response, info *relaycommon.RelayInfo, requestMode int) (*relaymodel.OpenAIErrorWithStatusCode, *relaymodel.Usage) {
|
|
|
awsCli, err := newAwsClient(c, info)
|
|
|
if err != nil {
|
|
|
return wrapErr(errors.Wrap(err, "newAwsClient")), nil
|
|
|
@@ -162,7 +163,6 @@ func awsStreamHandler(c *gin.Context, info *relaycommon.RelayInfo, requestMode i
|
|
|
c.Stream(func(w io.Writer) bool {
|
|
|
event, ok := <-stream.Events()
|
|
|
if !ok {
|
|
|
- c.Render(-1, common.CustomEvent{Data: "data: [DONE]"})
|
|
|
return false
|
|
|
}
|
|
|
|
|
|
@@ -214,6 +214,15 @@ func awsStreamHandler(c *gin.Context, info *relaycommon.RelayInfo, requestMode i
|
|
|
return false
|
|
|
}
|
|
|
})
|
|
|
-
|
|
|
+ response := service.GenerateFinalUsageResponse(id, createdTime, model, usage)
|
|
|
+ err = service.ObjectData(c, response)
|
|
|
+ if err != nil {
|
|
|
+ common.SysError("send final response failed: " + err.Error())
|
|
|
+ }
|
|
|
+ service.Done(c)
|
|
|
+ err = resp.Body.Close()
|
|
|
+ if err != nil {
|
|
|
+ return service.OpenAIErrorWrapperLocal(err, "close_response_body_failed", http.StatusInternalServerError), nil
|
|
|
+ }
|
|
|
return nil, &usage
|
|
|
}
|