mirror of
https://github.com/mudler/LocalAI.git
synced 2026-04-01 13:42:20 -04:00
* feat(gallery): Switch to expandable box instead of pop-over and display model files Signed-off-by: Richard Palethorpe <io@richiejp.com> * feat(ui, backends): Add individual backend logging Signed-off-by: Richard Palethorpe <io@richiejp.com> * fix(ui): Set the context settings from the model config Signed-off-by: Richard Palethorpe <io@richiejp.com> --------- Signed-off-by: Richard Palethorpe <io@richiejp.com>
138 lines
3.4 KiB
Go
138 lines
3.4 KiB
Go
package main
|
|
|
|
import (
|
|
"context"
|
|
"flag"
|
|
"fmt"
|
|
"net/http"
|
|
"os"
|
|
"os/signal"
|
|
"path/filepath"
|
|
"syscall"
|
|
|
|
"github.com/mudler/LocalAI/core/application"
|
|
"github.com/mudler/LocalAI/core/config"
|
|
httpapi "github.com/mudler/LocalAI/core/http"
|
|
"github.com/mudler/LocalAI/pkg/system"
|
|
"github.com/mudler/xlog"
|
|
"gopkg.in/yaml.v3"
|
|
)
|
|
|
|
func main() {
|
|
mockBackend := flag.String("mock-backend", "", "path to mock-backend binary")
|
|
port := flag.Int("port", 8089, "port to listen on")
|
|
flag.Parse()
|
|
|
|
if *mockBackend == "" {
|
|
fmt.Fprintln(os.Stderr, "error: --mock-backend is required")
|
|
os.Exit(1)
|
|
}
|
|
|
|
// Resolve to absolute path
|
|
absBackend, err := filepath.Abs(*mockBackend)
|
|
if err != nil {
|
|
fmt.Fprintf(os.Stderr, "error resolving mock-backend path: %v\n", err)
|
|
os.Exit(1)
|
|
}
|
|
if _, err := os.Stat(absBackend); err != nil {
|
|
fmt.Fprintf(os.Stderr, "mock-backend not found at %s: %v\n", absBackend, err)
|
|
os.Exit(1)
|
|
}
|
|
|
|
// Create temp dirs
|
|
tmpDir, err := os.MkdirTemp("", "ui-e2e-*")
|
|
if err != nil {
|
|
fmt.Fprintf(os.Stderr, "error creating temp dir: %v\n", err)
|
|
os.Exit(1)
|
|
}
|
|
defer os.RemoveAll(tmpDir)
|
|
|
|
modelsPath := filepath.Join(tmpDir, "models")
|
|
backendsPath := filepath.Join(tmpDir, "backends")
|
|
generatedDir := filepath.Join(tmpDir, "generated")
|
|
dataDir := filepath.Join(tmpDir, "data")
|
|
for _, d := range []string{modelsPath, backendsPath, generatedDir, dataDir} {
|
|
if err := os.MkdirAll(d, 0755); err != nil {
|
|
fmt.Fprintf(os.Stderr, "error creating dir %s: %v\n", d, err)
|
|
os.Exit(1)
|
|
}
|
|
}
|
|
|
|
// Write mock-model config
|
|
modelConfig := map[string]any{
|
|
"name": "mock-model",
|
|
"backend": "mock-backend",
|
|
"parameters": map[string]any{
|
|
"model": "mock-model.bin",
|
|
},
|
|
}
|
|
configYAML, err := yaml.Marshal(modelConfig)
|
|
if err != nil {
|
|
fmt.Fprintf(os.Stderr, "error marshaling config: %v\n", err)
|
|
os.Exit(1)
|
|
}
|
|
if err := os.WriteFile(filepath.Join(modelsPath, "mock-model.yaml"), configYAML, 0644); err != nil {
|
|
fmt.Fprintf(os.Stderr, "error writing config: %v\n", err)
|
|
os.Exit(1)
|
|
}
|
|
|
|
// Set up system state
|
|
systemState, err := system.GetSystemState(
|
|
system.WithModelPath(modelsPath),
|
|
system.WithBackendPath(backendsPath),
|
|
)
|
|
if err != nil {
|
|
fmt.Fprintf(os.Stderr, "error getting system state: %v\n", err)
|
|
os.Exit(1)
|
|
}
|
|
|
|
// Create application
|
|
ctx, cancel := context.WithCancel(context.Background())
|
|
defer cancel()
|
|
|
|
app, err := application.New(
|
|
config.WithContext(ctx),
|
|
config.WithSystemState(systemState),
|
|
config.WithDebug(true),
|
|
config.WithDataPath(dataDir),
|
|
config.WithDynamicConfigDir(dataDir),
|
|
config.WithGeneratedContentDir(generatedDir),
|
|
config.EnableTracing,
|
|
config.EnableBackendLogging,
|
|
)
|
|
if err != nil {
|
|
fmt.Fprintf(os.Stderr, "error creating application: %v\n", err)
|
|
os.Exit(1)
|
|
}
|
|
|
|
// Register mock backend
|
|
app.ModelLoader().SetExternalBackend("mock-backend", absBackend)
|
|
|
|
// Create HTTP server
|
|
e, err := httpapi.API(app)
|
|
if err != nil {
|
|
fmt.Fprintf(os.Stderr, "error creating HTTP API: %v\n", err)
|
|
os.Exit(1)
|
|
}
|
|
|
|
// Start server
|
|
addr := fmt.Sprintf("127.0.0.1:%d", *port)
|
|
go func() {
|
|
if err := e.Start(addr); err != nil && err != http.ErrServerClosed {
|
|
xlog.Error("server error", "error", err)
|
|
os.Exit(1)
|
|
}
|
|
}()
|
|
|
|
fmt.Printf("UI test server listening on http://%s\n", addr)
|
|
|
|
// Wait for signal
|
|
sigCh := make(chan os.Signal, 1)
|
|
signal.Notify(sigCh, syscall.SIGINT, syscall.SIGTERM)
|
|
<-sigCh
|
|
|
|
fmt.Println("\nShutting down...")
|
|
cancel()
|
|
e.Close()
|
|
}
|