Update: Js 4 Log.html 80%
This commit is contained in:
@@ -87,6 +87,9 @@ func (h *ProxyHandler) HandleProxy(c *gin.Context) {
|
||||
return
|
||||
}
|
||||
|
||||
c.Request.Body = io.NopCloser(bytes.NewReader(requestBody))
|
||||
c.Request.ContentLength = int64(len(requestBody))
|
||||
|
||||
modelName := h.channel.ExtractModel(c, requestBody)
|
||||
groupName := c.Param("group_name")
|
||||
isPreciseRouting := groupName != ""
|
||||
|
||||
@@ -7,6 +7,7 @@ import (
|
||||
"gemini-balancer/internal/settings"
|
||||
|
||||
"github.com/gin-gonic/gin"
|
||||
"github.com/sirupsen/logrus"
|
||||
)
|
||||
|
||||
type SettingHandler struct {
|
||||
@@ -23,16 +24,35 @@ func (h *SettingHandler) GetSettings(c *gin.Context) {
|
||||
func (h *SettingHandler) UpdateSettings(c *gin.Context) {
|
||||
var newSettingsMap map[string]interface{}
|
||||
if err := c.ShouldBindJSON(&newSettingsMap); err != nil {
|
||||
response.Error(c, errors.NewAPIError(errors.ErrInvalidJSON, err.Error()))
|
||||
logrus.WithError(err).Error("Failed to bind JSON in UpdateSettings")
|
||||
response.Error(c, errors.NewAPIError(errors.ErrInvalidJSON, "Invalid JSON: "+err.Error()))
|
||||
return
|
||||
}
|
||||
if err := h.settingsManager.UpdateSettings(newSettingsMap); err != nil {
|
||||
// TODO 可以根据错误类型返回更具体的错误
|
||||
|
||||
logrus.Debugf("Received settings update: %+v", newSettingsMap)
|
||||
|
||||
validKeys := make(map[string]interface{})
|
||||
for key, value := range newSettingsMap {
|
||||
if _, exists := h.settingsManager.IsValidKey(key); exists {
|
||||
validKeys[key] = value
|
||||
} else {
|
||||
logrus.Warnf("Invalid key received: %s", key)
|
||||
}
|
||||
}
|
||||
|
||||
if len(validKeys) == 0 {
|
||||
response.Error(c, errors.NewAPIError(errors.ErrInvalidJSON, "No valid settings keys provided"))
|
||||
return
|
||||
}
|
||||
|
||||
logrus.Debugf("Valid keys to update: %+v", validKeys)
|
||||
|
||||
if err := h.settingsManager.UpdateSettings(validKeys); err != nil {
|
||||
logrus.WithError(err).Error("Failed to update settings")
|
||||
response.Error(c, errors.NewAPIError(errors.ErrInternalServer, err.Error()))
|
||||
return
|
||||
}
|
||||
response.Success(c, gin.H{"message": "Settings update request processed successfully."})
|
||||
|
||||
response.Success(c, gin.H{"message": "Settings updated successfully"})
|
||||
}
|
||||
|
||||
// ResetSettingsToDefaults resets all settings to their default values
|
||||
|
||||
Reference in New Issue
Block a user