package main import ( "flag" "fmt" "fuj-management/go/internal/config" "fuj-management/go/internal/logging" "fuj-management/go/internal/web" "os" ) // Injected at build time via -ldflags "-X main.version=... -X main.commit=... -X main.buildDate=..." var ( version = "dev" commit = "unknown" buildDate = "unknown" ) func main() { if len(os.Args) < 2 { usage() os.Exit(2) } cmd, args := os.Args[1], os.Args[2:] switch cmd { case "server": serverCmd(args) case "version": versionCmd() case "fees", "reconcile", "sync", "infer": fmt.Fprintf(os.Stderr, "fuj %s: not implemented yet (lands in M2/M4)\n", cmd) os.Exit(2) case "-h", "--help", "help": usage() default: fmt.Fprintf(os.Stderr, "fuj: unknown command %q\n\n", cmd) usage() os.Exit(2) } } func serverCmd(args []string) { fs := flag.NewFlagSet("server", flag.ExitOnError) addr := fs.String("addr", "", "listen address (default from SERVER_ADDR env or :8080)") fs.Usage = func() { fmt.Fprintln(os.Stderr, "usage: fuj server [--addr :8080]") fs.PrintDefaults() } if err := fs.Parse(args); err != nil { fmt.Fprintln(os.Stderr, err) os.Exit(2) } cfg := config.Load() if *addr != "" { cfg.ServerAddr = *addr } logger := logging.New(cfg.LogLevel) build := web.BuildInfo{Version: version, Commit: commit, BuildDate: buildDate} if err := web.Run(logger, cfg.ServerAddr, build); err != nil { fmt.Fprintln(os.Stderr, err) os.Exit(1) } } func versionCmd() { fmt.Printf("fuj %s (%s) built %s\n", version, commit, buildDate) } func usage() { fmt.Fprintln(os.Stderr, `usage: fuj [flags] Commands: server Start HTTP server (default :8080) version Print version information fees Calculate monthly fees [M2] reconcile Show balance report [M2] sync Sync Fio transactions [M4] infer Infer payment details [M4]`) }