summaryrefslogtreecommitdiff
path: root/internal/cli/cmd_create_client_key.go
diff options
context:
space:
mode:
authorPaul Buetow <paul@buetow.org>2026-04-14 11:31:39 +0300
committerPaul Buetow <paul@buetow.org>2026-04-14 11:31:39 +0300
commit0b090c2698607fcdef039fb703c8c6bac5fceca0 (patch)
tree77b3ba27e9f07d128115cd5a41ac6c2f6db8c01b /internal/cli/cmd_create_client_key.go
parent0165352a63cb2f78871c2e72d4f2fd4f111637c3 (diff)
refactor(cli): split run* handlers into files (ask 24)
Move runImport, runQuery, runReportFromFiles, runDaemon, runCreateClientKey, and runTests into dedicated cmd_*.go files. Keep Execute routing in cli.go. defaultListenFromEnv stays with daemon. Made-with: Cursor
Diffstat (limited to 'internal/cli/cmd_create_client_key.go')
-rw-r--r--internal/cli/cmd_create_client_key.go47
1 files changed, 47 insertions, 0 deletions
diff --git a/internal/cli/cmd_create_client_key.go b/internal/cli/cmd_create_client_key.go
new file mode 100644
index 0000000..d5caf28
--- /dev/null
+++ b/internal/cli/cmd_create_client_key.go
@@ -0,0 +1,47 @@
+package cli
+
+import (
+ "context"
+ "flag"
+ "fmt"
+ "os"
+
+ "codeberg.org/snonux/goprecords/internal/authkeys"
+)
+
+func runCreateClientKey(hostname string, args []string) error {
+ if hostname == "" {
+ return fmt.Errorf("create-client-key: hostname required")
+ }
+ fs := flag.NewFlagSet("create-client-key", flag.ExitOnError)
+ fs.SetOutput(os.Stderr)
+ statsDir := fs.String("stats-dir", "", "Uptimed stats directory (sets default auth-db path)")
+ authDB := fs.String("auth-db", "", "SQLite file for upload API keys (default: <stats-dir>/goprecords-auth.db)")
+ if err := fs.Parse(args); err != nil {
+ return err
+ }
+ authPath := *authDB
+ if authPath == "" {
+ if *statsDir == "" {
+ fmt.Fprintln(os.Stderr, "create-client-key: need -stats-dir or -auth-db")
+ fs.Usage()
+ return fmt.Errorf("missing -stats-dir or -auth-db")
+ }
+ authPath = authkeys.DefaultPath(*statsDir)
+ }
+ ctx := context.Background()
+ store, err := authkeys.OpenStore(ctx, authPath)
+ if err != nil {
+ return fmt.Errorf("open auth db: %w", err)
+ }
+ defer store.Close()
+ if err := store.EnsureSchema(ctx); err != nil {
+ return fmt.Errorf("schema: %w", err)
+ }
+ token, err := store.CreateKey(ctx, hostname)
+ if err != nil {
+ return fmt.Errorf("create key: %w", err)
+ }
+ fmt.Println(token)
+ return nil
+}