Merge pull request #1517 from RedwindA/fix/gemini-fetch-models
Fix/gemini-fetch-models
This commit is contained in:
@@ -36,30 +36,11 @@ type OpenAIModel struct {
|
|||||||
Parent string `json:"parent"`
|
Parent string `json:"parent"`
|
||||||
}
|
}
|
||||||
|
|
||||||
type GoogleOpenAICompatibleModels []struct {
|
|
||||||
Name string `json:"name"`
|
|
||||||
Version string `json:"version"`
|
|
||||||
DisplayName string `json:"displayName"`
|
|
||||||
Description string `json:"description,omitempty"`
|
|
||||||
InputTokenLimit int `json:"inputTokenLimit"`
|
|
||||||
OutputTokenLimit int `json:"outputTokenLimit"`
|
|
||||||
SupportedGenerationMethods []string `json:"supportedGenerationMethods"`
|
|
||||||
Temperature float64 `json:"temperature,omitempty"`
|
|
||||||
TopP float64 `json:"topP,omitempty"`
|
|
||||||
TopK int `json:"topK,omitempty"`
|
|
||||||
MaxTemperature int `json:"maxTemperature,omitempty"`
|
|
||||||
}
|
|
||||||
|
|
||||||
type OpenAIModelsResponse struct {
|
type OpenAIModelsResponse struct {
|
||||||
Data []OpenAIModel `json:"data"`
|
Data []OpenAIModel `json:"data"`
|
||||||
Success bool `json:"success"`
|
Success bool `json:"success"`
|
||||||
}
|
}
|
||||||
|
|
||||||
type GoogleOpenAICompatibleResponse struct {
|
|
||||||
Models []GoogleOpenAICompatibleModels `json:"models"`
|
|
||||||
NextPageToken string `json:"nextPageToken"`
|
|
||||||
}
|
|
||||||
|
|
||||||
func parseStatusFilter(statusParam string) int {
|
func parseStatusFilter(statusParam string) int {
|
||||||
switch strings.ToLower(statusParam) {
|
switch strings.ToLower(statusParam) {
|
||||||
case "enabled", "1":
|
case "enabled", "1":
|
||||||
@@ -203,7 +184,7 @@ func FetchUpstreamModels(c *gin.Context) {
|
|||||||
switch channel.Type {
|
switch channel.Type {
|
||||||
case constant.ChannelTypeGemini:
|
case constant.ChannelTypeGemini:
|
||||||
// curl https://example.com/v1beta/models?key=$GEMINI_API_KEY
|
// curl https://example.com/v1beta/models?key=$GEMINI_API_KEY
|
||||||
url = fmt.Sprintf("%s/v1beta/openai/models?key=%s", baseURL, channel.Key)
|
url = fmt.Sprintf("%s/v1beta/openai/models", baseURL) // Remove key in url since we need to use AuthHeader
|
||||||
case constant.ChannelTypeAli:
|
case constant.ChannelTypeAli:
|
||||||
url = fmt.Sprintf("%s/compatible-mode/v1/models", baseURL)
|
url = fmt.Sprintf("%s/compatible-mode/v1/models", baseURL)
|
||||||
default:
|
default:
|
||||||
@@ -212,10 +193,11 @@ func FetchUpstreamModels(c *gin.Context) {
|
|||||||
|
|
||||||
// 获取响应体 - 根据渠道类型决定是否添加 AuthHeader
|
// 获取响应体 - 根据渠道类型决定是否添加 AuthHeader
|
||||||
var body []byte
|
var body []byte
|
||||||
|
key := strings.Split(channel.Key, "\n")[0]
|
||||||
if channel.Type == constant.ChannelTypeGemini {
|
if channel.Type == constant.ChannelTypeGemini {
|
||||||
body, err = GetResponseBody("GET", url, channel, nil) // I don't know why, but Gemini requires no AuthHeader
|
body, err = GetResponseBody("GET", url, channel, GetAuthHeader(key)) // Use AuthHeader since Gemini now forces it
|
||||||
} else {
|
} else {
|
||||||
body, err = GetResponseBody("GET", url, channel, GetAuthHeader(channel.Key))
|
body, err = GetResponseBody("GET", url, channel, GetAuthHeader(key))
|
||||||
}
|
}
|
||||||
if err != nil {
|
if err != nil {
|
||||||
common.ApiError(c, err)
|
common.ApiError(c, err)
|
||||||
@@ -223,27 +205,6 @@ func FetchUpstreamModels(c *gin.Context) {
|
|||||||
}
|
}
|
||||||
|
|
||||||
var result OpenAIModelsResponse
|
var result OpenAIModelsResponse
|
||||||
var parseSuccess bool
|
|
||||||
|
|
||||||
// 适配特殊格式
|
|
||||||
switch channel.Type {
|
|
||||||
case constant.ChannelTypeGemini:
|
|
||||||
var googleResult GoogleOpenAICompatibleResponse
|
|
||||||
if err = json.Unmarshal(body, &googleResult); err == nil {
|
|
||||||
// 转换Google格式到OpenAI格式
|
|
||||||
for _, model := range googleResult.Models {
|
|
||||||
for _, gModel := range model {
|
|
||||||
result.Data = append(result.Data, OpenAIModel{
|
|
||||||
ID: gModel.Name,
|
|
||||||
})
|
|
||||||
}
|
|
||||||
}
|
|
||||||
parseSuccess = true
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
// 如果解析失败,尝试OpenAI格式
|
|
||||||
if !parseSuccess {
|
|
||||||
if err = json.Unmarshal(body, &result); err != nil {
|
if err = json.Unmarshal(body, &result); err != nil {
|
||||||
c.JSON(http.StatusOK, gin.H{
|
c.JSON(http.StatusOK, gin.H{
|
||||||
"success": false,
|
"success": false,
|
||||||
@@ -251,7 +212,6 @@ func FetchUpstreamModels(c *gin.Context) {
|
|||||||
})
|
})
|
||||||
return
|
return
|
||||||
}
|
}
|
||||||
}
|
|
||||||
|
|
||||||
var ids []string
|
var ids []string
|
||||||
for _, model := range result.Data {
|
for _, model := range result.Data {
|
||||||
|
|||||||
Reference in New Issue
Block a user