96 lines
1.7 KiB
Go
Raw Normal View History

2025-08-23 13:28:48 +02:00
package main
import (
"context"
"fmt"
2025-08-23 13:28:48 +02:00
"log"
2025-08-23 19:14:16 +02:00
"log/slog"
2025-08-23 13:28:48 +02:00
"net/mail"
"os"
"os/exec"
"runtime/debug"
2025-08-23 13:28:48 +02:00
2025-08-23 19:14:16 +02:00
"gitea.kleinsense.nl/DariusKlein/kleinTodo/client/todo/clientCommon/config"
2025-08-23 13:28:48 +02:00
"github.com/urfave/cli/v3"
)
2025-08-23 19:14:16 +02:00
var cfg config.Config
2025-08-23 13:28:48 +02:00
func main() {
2025-08-23 19:14:16 +02:00
var err error
cfg, err = config.ReadConfig()
if err != nil {
slog.Error(err.Error())
}
2025-08-23 13:28:48 +02:00
app := &cli.Command{
Name: "Todo",
Usage: "kleinTodo client",
2025-08-23 19:14:16 +02:00
UsageText: "Todo [command] [arguments...]",
2026-01-12 21:20:59 +01:00
Version: "v0.9.0",
2025-08-23 13:28:48 +02:00
HideVersion: true,
Authors: []any{
mail.Address{
Name: "Darius",
Address: "darius.klein@dariusklein.nl",
},
},
2025-08-23 19:14:16 +02:00
DefaultCommand: "todo",
Commands: commands(),
2025-08-23 13:28:48 +02:00
}
if err := app.Run(context.Background(), os.Args); err != nil {
log.Fatal(err)
}
}
2025-08-23 19:14:16 +02:00
func commands() []*cli.Command {
return []*cli.Command{
config.Category(),
Login(),
Sync(),
2025-08-23 21:51:33 +02:00
Add(),
Todo(),
Register(),
{
Name: "update",
Usage: "Update the vennexCLI to a specific version",
Flags: []cli.Flag{
&cli.StringFlag{
Name: "version",
Usage: "The version label to install (e.g., v1.2.0, main, latest)",
Value: "latest",
},
},
Action: runUpdate,
},
}
}
func runUpdate(ctx context.Context, command *cli.Command) error {
var pkgPath = "unknown"
info, ok := debug.ReadBuildInfo()
if ok {
pkgPath = info.Main.Path
}
pkg := fmt.Sprintf("%s@%s", pkgPath, command.String("version"))
slog.Info(fmt.Sprintf("Updating to %s...\n", pkg))
cmd := exec.Command("go", "install", pkg)
cmd.Stdout = os.Stdout
cmd.Stderr = os.Stderr
err := cmd.Run()
if err != nil {
slog.Error("Update failed:", "error", err)
return err
2025-08-23 19:14:16 +02:00
}
slog.Info("Update successful!")
return nil
2025-08-23 19:14:16 +02:00
}