mirror of
				https://github.com/songquanpeng/one-api.git
				synced 2025-11-04 15:53:42 +08:00 
			
		
		
		
	feat: vertexai support proxy url(example: cloudflare ai gateway) and fix some vertexai bug (#1642)
* feat: vertexai support proxy url(example: cloudflare ai gateway) * fix: do resp model mapping * fix: missing system * fix: stream need query alt=sse
This commit is contained in:
		@@ -19,7 +19,7 @@ var _ adaptor.Adaptor = new(Adaptor)
 | 
			
		||||
 | 
			
		||||
const channelName = "vertexai"
 | 
			
		||||
 | 
			
		||||
type Adaptor struct {}
 | 
			
		||||
type Adaptor struct{}
 | 
			
		||||
 | 
			
		||||
func (a *Adaptor) Init(meta *meta.Meta) {
 | 
			
		||||
}
 | 
			
		||||
@@ -38,7 +38,7 @@ func (a *Adaptor) ConvertRequest(c *gin.Context, relayMode int, request *model.G
 | 
			
		||||
}
 | 
			
		||||
 | 
			
		||||
func (a *Adaptor) DoResponse(c *gin.Context, resp *http.Response, meta *meta.Meta) (usage *model.Usage, err *model.ErrorWithStatusCode) {
 | 
			
		||||
	adaptor := GetAdaptor(meta.OriginModelName)
 | 
			
		||||
	adaptor := GetAdaptor(meta.ActualModelName)
 | 
			
		||||
	if adaptor == nil {
 | 
			
		||||
		return nil, &relaymodel.ErrorWithStatusCode{
 | 
			
		||||
			StatusCode: http.StatusInternalServerError,
 | 
			
		||||
@@ -63,20 +63,36 @@ func (a *Adaptor) GetRequestURL(meta *meta.Meta) (string, error) {
 | 
			
		||||
	suffix := ""
 | 
			
		||||
	if strings.HasPrefix(meta.ActualModelName, "gemini") {
 | 
			
		||||
		if meta.IsStream {
 | 
			
		||||
			suffix = "streamGenerateContent"
 | 
			
		||||
			suffix = "streamGenerateContent?alt=sse"
 | 
			
		||||
		} else {
 | 
			
		||||
			suffix = "generateContent"
 | 
			
		||||
		}
 | 
			
		||||
	} else {
 | 
			
		||||
		if meta.IsStream {
 | 
			
		||||
			suffix = "streamRawPredict"
 | 
			
		||||
			suffix = "streamRawPredict?alt=sse"
 | 
			
		||||
		} else {
 | 
			
		||||
			suffix = "rawPredict"
 | 
			
		||||
		}
 | 
			
		||||
	}
 | 
			
		||||
 | 
			
		||||
	baseUrl := fmt.Sprintf("https://%s-aiplatform.googleapis.com/v1/projects/%s/locations/%s/publishers/google/models/%s:%s", meta.Config.Region, meta.Config.VertexAIProjectID, meta.Config.Region, meta.ActualModelName, suffix)
 | 
			
		||||
	return baseUrl, nil
 | 
			
		||||
	if meta.BaseURL != "" {
 | 
			
		||||
		return fmt.Sprintf(
 | 
			
		||||
			"%s/v1/projects/%s/locations/%s/publishers/google/models/%s:%s",
 | 
			
		||||
			meta.BaseURL,
 | 
			
		||||
			meta.Config.VertexAIProjectID,
 | 
			
		||||
			meta.Config.Region,
 | 
			
		||||
			meta.ActualModelName,
 | 
			
		||||
			suffix,
 | 
			
		||||
		), nil
 | 
			
		||||
	}
 | 
			
		||||
	return fmt.Sprintf(
 | 
			
		||||
		"https://%s-aiplatform.googleapis.com/v1/projects/%s/locations/%s/publishers/google/models/%s:%s",
 | 
			
		||||
		meta.Config.Region,
 | 
			
		||||
		meta.Config.VertexAIProjectID,
 | 
			
		||||
		meta.Config.Region,
 | 
			
		||||
		meta.ActualModelName,
 | 
			
		||||
		suffix,
 | 
			
		||||
	), nil
 | 
			
		||||
}
 | 
			
		||||
 | 
			
		||||
func (a *Adaptor) SetupRequestHeader(c *gin.Context, req *http.Request, meta *meta.Meta) error {
 | 
			
		||||
 
 | 
			
		||||
@@ -30,13 +30,14 @@ func (a *Adaptor) ConvertRequest(c *gin.Context, relayMode int, request *model.G
 | 
			
		||||
	req := Request{
 | 
			
		||||
		AnthropicVersion: anthropicVersion,
 | 
			
		||||
		// Model:            claudeReq.Model,
 | 
			
		||||
		Messages:         claudeReq.Messages,
 | 
			
		||||
		MaxTokens:        claudeReq.MaxTokens,
 | 
			
		||||
		Temperature:      claudeReq.Temperature,
 | 
			
		||||
		TopP:             claudeReq.TopP,
 | 
			
		||||
		TopK:             claudeReq.TopK,
 | 
			
		||||
		Stream:           claudeReq.Stream,
 | 
			
		||||
		Tools:            claudeReq.Tools,
 | 
			
		||||
		Messages:    claudeReq.Messages,
 | 
			
		||||
		System:      claudeReq.System,
 | 
			
		||||
		MaxTokens:   claudeReq.MaxTokens,
 | 
			
		||||
		Temperature: claudeReq.Temperature,
 | 
			
		||||
		TopP:        claudeReq.TopP,
 | 
			
		||||
		TopK:        claudeReq.TopK,
 | 
			
		||||
		Stream:      claudeReq.Stream,
 | 
			
		||||
		Tools:       claudeReq.Tools,
 | 
			
		||||
	}
 | 
			
		||||
 | 
			
		||||
	c.Set(ctxkey.RequestModel, request.Model)
 | 
			
		||||
 
 | 
			
		||||
		Reference in New Issue
	
	Block a user