|
package fiberContext |
|
|
|
import ( |
|
"fmt" |
|
"strings" |
|
|
|
"github.com/gofiber/fiber/v2" |
|
"github.com/mudler/LocalAI/core/config" |
|
"github.com/mudler/LocalAI/core/services" |
|
"github.com/mudler/LocalAI/pkg/model" |
|
"github.com/rs/zerolog/log" |
|
) |
|
|
|
|
|
|
|
|
|
|
|
func ModelFromContext(ctx *fiber.Ctx, cl *config.BackendConfigLoader, loader *model.ModelLoader, modelInput string, firstModel bool) (string, error) { |
|
if ctx.Params("model") != "" { |
|
modelInput = ctx.Params("model") |
|
} |
|
|
|
|
|
bearer := strings.TrimLeft(ctx.Get("authorization"), "Bearer ") |
|
bearerExists := bearer != "" && loader.ExistsInModelPath(bearer) |
|
|
|
|
|
if modelInput == "" && !bearerExists && firstModel { |
|
models, _ := services.ListModels(cl, loader, "", true) |
|
if len(models) > 0 { |
|
modelInput = models[0] |
|
log.Debug().Msgf("No model specified, using: %s", modelInput) |
|
} else { |
|
log.Debug().Msgf("No model specified, returning error") |
|
return "", fmt.Errorf("no model specified") |
|
} |
|
} |
|
|
|
|
|
if bearerExists { |
|
log.Debug().Msgf("Using model from bearer token: %s", bearer) |
|
modelInput = bearer |
|
} |
|
return modelInput, nil |
|
} |
|
|