vet/cmd/cloud/key.go
Oleksandr Redko 4e39cebe61
chore: add formatters to golangci-lint config (#643)
Signed-off-by: Oleksandr Redko <oleksandr.red+github@gmail.com>
2025-11-27 14:58:24 +05:30

192 lines
4.1 KiB
Go

package cloud
import (
"time"
"github.com/spf13/cobra"
"github.com/safedep/vet/internal/auth"
"github.com/safedep/vet/internal/ui"
"github.com/safedep/vet/pkg/cloud"
"github.com/safedep/vet/pkg/common/logger"
)
var (
keyName string
keyDescription string
keyExpiresIn int
listKeysName string
listKeysIncludeExpired bool
listKeysOnlyMine bool
deleteKeyId string
)
func newKeyCommand() *cobra.Command {
cmd := &cobra.Command{
Use: "key",
Short: "Manage API keys",
RunE: func(cmd *cobra.Command, args []string) error {
return cmd.Help()
},
}
cmd.AddCommand(newKeyCreateCommand())
cmd.AddCommand(newListKeyCommand())
cmd.AddCommand(newDeleteKeyCommand())
return cmd
}
func newDeleteKeyCommand() *cobra.Command {
cmd := &cobra.Command{
Use: "delete",
Short: "Delete an API key",
RunE: func(cmd *cobra.Command, args []string) error {
err := executeDeleteKey()
if err != nil {
logger.Errorf("Failed to delete API key: %v", err)
}
return nil
},
}
cmd.Flags().StringVar(&deleteKeyId, "id", "", "ID of the API key to delete")
_ = cmd.MarkFlagRequired("id")
return cmd
}
func executeDeleteKey() error {
client, err := auth.ControlPlaneClientConnection("vet-cloud-key-delete")
if err != nil {
return err
}
keyService, err := cloud.NewApiKeyService(client)
if err != nil {
return err
}
err = keyService.DeleteKey(deleteKeyId)
if err != nil {
return err
}
ui.PrintSuccess("API key deleted successfully.")
return nil
}
func newListKeyCommand() *cobra.Command {
cmd := &cobra.Command{
Use: "list",
Short: "List API keys",
RunE: func(cmd *cobra.Command, args []string) error {
err := executeListKeys()
if err != nil {
logger.Errorf("Failed to list API keys: %v", err)
}
return nil
},
}
cmd.Flags().StringVar(&listKeysName, "name", "",
"List keys with partial match on the name")
cmd.Flags().BoolVar(&listKeysIncludeExpired, "include-expired", false,
"Include expired keys in the list")
cmd.Flags().BoolVar(&listKeysOnlyMine, "only-mine", false,
"List only keys created by the current user")
return cmd
}
func executeListKeys() error {
client, err := auth.ControlPlaneClientConnection("vet-cloud-key-list")
if err != nil {
return err
}
keyService, err := cloud.NewApiKeyService(client)
if err != nil {
return err
}
keys, err := keyService.ListKeys(&cloud.ListApiKeyRequest{
Name: listKeysName,
IncludeExpired: listKeysIncludeExpired,
OnlyMine: listKeysOnlyMine,
})
if err != nil {
return err
}
if len(keys.Keys) == 0 {
ui.PrintSuccess("No API keys found.")
return nil
}
tbl := ui.NewTabler(ui.TablerConfig{})
tbl.AddHeader("ID", "Name", "Expires At", "Description")
for _, key := range keys.Keys {
expiresAt := key.ExpiresAt.In(time.Local).Format(time.RFC822)
tbl.AddRow(key.ID, key.Name, expiresAt, key.Desc)
}
return tbl.Finish()
}
func newKeyCreateCommand() *cobra.Command {
cmd := &cobra.Command{
Use: "create",
Short: "Create a new API key",
RunE: func(cmd *cobra.Command, args []string) error {
err := executeCreateKey()
if err != nil {
logger.Errorf("Failed to create API key: %v", err)
}
return nil
},
}
cmd.Flags().StringVar(&keyName, "name", "", "Name of the API key")
cmd.Flags().StringVar(&keyDescription, "description", "", "Description of the API key")
cmd.Flags().IntVar(&keyExpiresIn, "expires-in", 30,
"Number of days after which the API key will expire")
_ = cmd.MarkFlagRequired("name")
return cmd
}
func executeCreateKey() error {
client, err := auth.ControlPlaneClientConnection("vet-cloud-key-create")
if err != nil {
return err
}
keyService, err := cloud.NewApiKeyService(client)
if err != nil {
return err
}
key, err := keyService.CreateApiKey(&cloud.CreateApiKeyRequest{
Name: keyName,
Desc: keyDescription,
ExpiryInDays: keyExpiresIn,
})
if err != nil {
return err
}
ui.PrintSuccess("API key created successfully.")
ui.PrintSuccess("Key: %s", key.Key)
ui.PrintSuccess("Expires at: %s", key.ExpiresAt.Format(time.RFC3339))
return nil
}