Files

66 lines
1.8 KiB
Go

/*
Copyright © 2025 Hazem Krimi me@hazemkrimi.tech
*/
package cmd
import (
"log"
"log/slog"
"os"
"github.com/hazemKrimi/crimson-vault/internal/api"
"github.com/hazemKrimi/crimson-vault/internal/lib"
"github.com/spf13/cobra"
)
// rootCmd represents the base command when called without any subcommands
var rootCmd = &cobra.Command{
Use: "crimson-vault",
Short: "A brief description of your application",
Long: `A longer description that spans multiple lines and likely contains
examples and usage of using your application. For example:
Cobra is a CLI library for Go that empowers applications.
This application is a tool to generate the needed files
to quickly create a Cobra application.`,
// Uncomment the following line if your bare application
// has an action associated with it:
Run: func(cmd *cobra.Command, args []string) {
dir, err := lib.GetConfigDirectoryPath()
if err != nil {
log.Fatal(err)
}
if err := os.MkdirAll(dir, os.ModePerm); err != nil {
log.Fatal(err)
}
logger := slog.New(slog.NewTextHandler(os.Stdout, nil))
server := api.API{ConfigDirectory: dir, Logger: logger}
server.Initialize()
},
}
// Execute adds all child commands to the root command and sets flags appropriately.
// This is called by main.main(). It only needs to happen once to the rootCmd.
func Execute() {
err := rootCmd.Execute()
if err != nil {
os.Exit(1)
}
}
func init() {
// Here you will define your flags and configuration settings.
// Cobra supports persistent flags, which, if defined here,
// will be global for your application.
// rootCmd.PersistentFlags().StringVar(&cfgFile, "config", "", "config file (default is $HOME/.crimson-vault.yaml)")
// Cobra also supports local flags, which will only run
// when this action is called directly.
rootCmd.Flags().BoolP("toggle", "t", false, "Help message for toggle")
}