2023-07-03 19:22:44 +00:00
|
|
|
package cmd
|
|
|
|
|
|
|
|
import (
|
|
|
|
"context"
|
|
|
|
"log"
|
|
|
|
"net"
|
|
|
|
"net/http"
|
|
|
|
"os"
|
|
|
|
"path"
|
|
|
|
"time"
|
|
|
|
|
2023-07-03 20:32:48 +00:00
|
|
|
"github.com/jmorganca/ollama/api"
|
|
|
|
"github.com/jmorganca/ollama/server"
|
2023-07-04 04:47:00 +00:00
|
|
|
"github.com/spf13/cobra"
|
2023-07-03 19:22:44 +00:00
|
|
|
)
|
|
|
|
|
2023-07-04 04:47:00 +00:00
|
|
|
func sockpath() string {
|
|
|
|
home, err := os.UserHomeDir()
|
|
|
|
if err != nil {
|
|
|
|
panic(err)
|
|
|
|
}
|
|
|
|
|
|
|
|
return path.Join(home, ".ollama", "ollama.sock")
|
|
|
|
}
|
|
|
|
|
|
|
|
func running() bool {
|
|
|
|
// Set a timeout duration
|
|
|
|
timeout := time.Second
|
|
|
|
// Dial the unix socket
|
|
|
|
conn, err := net.DialTimeout("unix", sockpath(), timeout)
|
|
|
|
if err != nil {
|
|
|
|
return false
|
|
|
|
}
|
|
|
|
|
|
|
|
if conn != nil {
|
|
|
|
defer conn.Close()
|
|
|
|
}
|
|
|
|
return true
|
|
|
|
}
|
|
|
|
|
|
|
|
func serve() error {
|
|
|
|
sp := sockpath()
|
|
|
|
|
|
|
|
if err := os.MkdirAll(path.Dir(sp), 0o700); err != nil {
|
|
|
|
return err
|
|
|
|
}
|
|
|
|
|
|
|
|
if err := os.RemoveAll(sp); err != nil {
|
|
|
|
return err
|
|
|
|
}
|
|
|
|
|
|
|
|
ln, err := net.Listen("unix", sp)
|
|
|
|
if err != nil {
|
|
|
|
return err
|
|
|
|
}
|
|
|
|
|
|
|
|
if err := os.Chmod(sp, 0o700); err != nil {
|
|
|
|
return err
|
|
|
|
}
|
|
|
|
|
|
|
|
return server.Serve(ln)
|
|
|
|
}
|
|
|
|
|
|
|
|
func NewAPIClient() (*api.Client, error) {
|
2023-07-03 19:22:44 +00:00
|
|
|
var err error
|
|
|
|
|
|
|
|
home, err := os.UserHomeDir()
|
|
|
|
if err != nil {
|
|
|
|
return nil, err
|
|
|
|
}
|
|
|
|
|
|
|
|
socket := path.Join(home, ".ollama", "ollama.sock")
|
|
|
|
|
|
|
|
dialer := &net.Dialer{
|
|
|
|
Timeout: 10 * time.Second,
|
|
|
|
}
|
|
|
|
|
|
|
|
return &api.Client{
|
|
|
|
URL: "http://localhost",
|
|
|
|
HTTP: http.Client{
|
|
|
|
Transport: &http.Transport{
|
|
|
|
DialContext: func(ctx context.Context, network, addr string) (net.Conn, error) {
|
|
|
|
return dialer.DialContext(ctx, "unix", socket)
|
|
|
|
},
|
|
|
|
},
|
|
|
|
},
|
|
|
|
}, nil
|
|
|
|
}
|
|
|
|
|
|
|
|
func NewCLI() *cobra.Command {
|
|
|
|
log.SetFlags(log.LstdFlags | log.Lshortfile)
|
|
|
|
|
|
|
|
rootCmd := &cobra.Command{
|
2023-07-03 20:32:48 +00:00
|
|
|
Use: "ollama",
|
2023-07-03 21:14:20 +00:00
|
|
|
Short: "Large language model runner",
|
2023-07-03 19:22:44 +00:00
|
|
|
CompletionOptions: cobra.CompletionOptions{
|
|
|
|
DisableDefaultCmd: true,
|
|
|
|
},
|
|
|
|
PersistentPreRun: func(cmd *cobra.Command, args []string) {
|
|
|
|
// Disable usage printing on errors
|
|
|
|
cmd.SilenceUsage = true
|
|
|
|
},
|
|
|
|
}
|
|
|
|
|
|
|
|
cobra.EnableCommandSorting = false
|
|
|
|
|
|
|
|
runCmd := &cobra.Command{
|
2023-07-04 04:47:00 +00:00
|
|
|
Use: "run MODEL",
|
|
|
|
Short: "Run a model",
|
|
|
|
Args: cobra.ExactArgs(1),
|
2023-07-03 21:14:20 +00:00
|
|
|
RunE: func(cmd *cobra.Command,args []string) error {
|
|
|
|
return nil
|
2023-07-03 19:22:44 +00:00
|
|
|
},
|
|
|
|
}
|
|
|
|
|
|
|
|
serveCmd := &cobra.Command{
|
|
|
|
Use: "serve",
|
|
|
|
Aliases: []string{"start"},
|
|
|
|
Short: "Start ollama",
|
|
|
|
RunE: func(cmd *cobra.Command, args []string) error {
|
2023-07-04 04:47:00 +00:00
|
|
|
return serve()
|
2023-07-03 19:22:44 +00:00
|
|
|
},
|
|
|
|
}
|
|
|
|
|
|
|
|
rootCmd.AddCommand(
|
|
|
|
serveCmd,
|
2023-07-03 21:14:20 +00:00
|
|
|
runCmd,
|
2023-07-03 19:22:44 +00:00
|
|
|
)
|
|
|
|
|
|
|
|
return rootCmd
|
|
|
|
}
|