goldwarden-vaultwarden-bitw.../cli/cmd/root.go

64 lines
1.4 KiB
Go

package cmd
import (
"fmt"
"os"
"github.com/quexten/goldwarden/cli/agent/config"
"github.com/quexten/goldwarden/cli/client"
"github.com/quexten/goldwarden/cli/ipc/messages"
"github.com/spf13/cobra"
)
var commandClient client.UnixSocketClient
var runtimeConfig config.RuntimeConfig
var rootCmd = &cobra.Command{
Use: "goldwarden",
Short: "OS level integration for Bitwarden",
Long: `Goldwarden is a daemon that runs in the background and provides
OS level integration for Bitwarden, such as SSH agent integration,
biometric unlock, and more.`,
}
func Execute(cfg config.RuntimeConfig) {
runtimeConfig = cfg
commandClient = client.NewUnixSocketClient(&cfg)
err := rootCmd.Execute()
if err != nil {
os.Exit(1)
}
}
func init() {
rootCmd.Flags().BoolP("toggle", "t", false, "Help message for toggle")
}
func loginIfRequired() error {
var err error
if runtimeConfig.AuthMethod == "password" {
_, err = commandClient.SendToAgent(messages.DoLoginRequest{
Email: runtimeConfig.User,
Password: runtimeConfig.Password,
})
} else if runtimeConfig.AuthMethod == "passwordless" {
_, err = commandClient.SendToAgent(messages.DoLoginRequest{
Email: runtimeConfig.User,
Passwordless: true,
})
}
return err
}
func handleSendToAgentError(err error) {
if err != nil {
fmt.Println("Error: " + err.Error())
fmt.Println("Is the daemon running?")
return
}
}