优化stream #8 (#9)

This commit is contained in:
Sakurasan
2023-05-25 20:03:24 +08:00
committed by GitHub
parent 01f4e90c2b
commit 6bdc38aa5a
7 changed files with 83 additions and 14 deletions

View File

@@ -7,9 +7,6 @@ on:
- dev - dev
tags: tags:
- 'v*' - 'v*'
pull_request:
branches: [ "main" ]
#项目任务,任务之间可以并行调度 #项目任务,任务之间可以并行调度
jobs: jobs:

View File

@@ -1,10 +1,14 @@
# opencatd-open # opencatd-open
<a title="Docker Image CI" target="_blank" href="https://github.com/mirrors2/opencatd-open/actions"><img alt="GitHub Workflow Status" src="https://img.shields.io/github/actions/workflow/status/mirrors2/opencatd-open/ci.yaml?label=Actions&logo=github&style=flat-square"></a> <a title="Docker Image CI" target="_blank" href="https://github.com/mirrors2/opencatd-open/actions"><img alt="GitHub Workflow Status" src="https://img.shields.io/github/actions/workflow/status/mirrors2/opencatd-open/ci.yaml?label=Actions&logo=github&style=flat-square"></a>
<a title="Docker Pulls" target="_blank" href="https://hub.docker.com/r/mirrors2/opencatd-open"><img src="https://img.shields.io/docker/pulls/mirrors2/opencatd-open.svg?logo=docker&label=docker&style=flat-square"></a> <a title="Docker Pulls" target="_blank" href="https://hub.docker.com/r/mirrors2/opencatd-open"><img src="https://img.shields.io/docker/pulls/mirrors2/opencatd-open.svg?logo=docker&label=docker&style=flat-square"></a>
opencatd-open is an open-source, team-shared service for ChatGPT API that can be safely shared with others for API usage.
---
OpenCat for Team的开源实现 OpenCat for Team的开源实现
基本实现了opencatd的全部功能 ~~基本~~实现了opencatd的全部功能
## 快速上手 ## 快速上手
``` ```

4
doc/azure.md Normal file
View File

@@ -0,0 +1,4 @@
# Azure OpenAI
需要获取 api-key和endpoint
![](./azure_key%26endpoint.png)

BIN
doc/azure_key&endpoint.png Normal file

Binary file not shown.

After

Width:  |  Height:  |  Size: 42 KiB

View File

@@ -0,0 +1,58 @@
/*
https://learn.microsoft.com/zh-cn/azure/cognitive-services/openai/chatgpt-quickstart
curl $AZURE_OPENAI_ENDPOINT/openai/deployments/gpt-35-turbo/chat/completions?api-version=2023-03-15-preview \
-H "Content-Type: application/json" \
-H "api-key: $AZURE_OPENAI_KEY" \
-d '{
"model": "gpt-3.5-turbo",
"messages": [{"role": "user", "content": "你好"}]
}'
*/
package azureopenai
import (
"encoding/json"
"net/http"
)
var (
ENDPOINT string
API_KEY string
DEPLOYMENT_NAME string
)
type ModelsList struct {
Data []struct {
ScaleSettings struct {
ScaleType string `json:"scale_type"`
} `json:"scale_settings"`
Model string `json:"model"`
Owner string `json:"owner"`
ID string `json:"id"`
Status string `json:"status"`
CreatedAt int `json:"created_at"`
UpdatedAt int `json:"updated_at"`
Object string `json:"object"`
} `json:"data"`
Object string `json:"object"`
}
func Models(endpoint, apikey string) (*ModelsList, error) {
var modelsl ModelsList
req, _ := http.NewRequest(http.MethodGet, endpoint+"/openai/deployments?api-version=2022-12-01", nil)
req.Header.Set("api-key", apikey)
resp, err := http.DefaultClient.Do(req)
if err != nil {
return nil, err
}
defer resp.Body.Close()
err = json.NewDecoder(resp.Body).Decode(&modelsl)
if err != nil {
return nil, err
}
return &modelsl, nil
}

View File

@@ -413,7 +413,7 @@ func HandleProy(c *gin.Context) {
if resp.StatusCode == 200 && localuser { if resp.StatusCode == 200 && localuser {
if isStream { if isStream {
contentCh := fetchResponseContent(writer, reader) contentCh := fetchResponseContent(c, reader)
var buffer bytes.Buffer var buffer bytes.Buffer
for content := range contentCh { for content := range contentCh {
buffer.WriteString(content) buffer.WriteString(content)
@@ -536,15 +536,18 @@ func HandleUsage(c *gin.Context) {
c.JSON(200, usage) c.JSON(200, usage)
} }
func fetchResponseContent(w *bufio.Writer, responseBody *bufio.Reader) <-chan string { func fetchResponseContent(ctx *gin.Context, responseBody *bufio.Reader) <-chan string {
contentCh := make(chan string) contentCh := make(chan string)
go func() { go func() {
defer close(contentCh) defer close(contentCh)
for { for {
line, err := responseBody.ReadString('\n') line, err := responseBody.ReadString('\n')
if err == nil { if err == nil {
w.WriteString(line) lines := strings.Split(line, "")
w.Flush() for _, word := range lines {
ctx.Writer.WriteString(word)
ctx.Writer.Flush()
}
if line == "\n" { if line == "\n" {
continue continue
} }

View File

@@ -7,6 +7,9 @@ type Key struct {
Key string `gorm:"unique;not null" json:"key,omitempty"` Key string `gorm:"unique;not null" json:"key,omitempty"`
Name string `gorm:"unique;not null" json:"name,omitempty"` Name string `gorm:"unique;not null" json:"name,omitempty"`
UserId string `json:"-,omitempty"` UserId string `json:"-,omitempty"`
KeyType string
EndPoint string
DeploymentName string
CreatedAt time.Time `json:"createdAt,omitempty"` CreatedAt time.Time `json:"createdAt,omitempty"`
UpdatedAt time.Time `json:"updatedAt,omitempty"` UpdatedAt time.Time `json:"updatedAt,omitempty"`
} }