mirror of
https://github.com/zitadel/zitadel.git
synced 2024-12-15 12:27:59 +00:00
fe4f6a963e
* feat: enable specifying custom acme authority for subdomains * test: none authority * chore: use latest ORBOS * chore: use latest ORBOS * test: host tls secret is unmanaged if not provided * chore: use latest ORBOS * chore: use latest ORBOS * fix: default acme authority to "none" * chore: use latest ORBOS * chore: compile with latest ORBOS
62 lines
1.4 KiB
Go
62 lines
1.4 KiB
Go
package cmds
|
|
|
|
import (
|
|
"os"
|
|
|
|
"github.com/caos/orbos/pkg/kubernetes/cli"
|
|
|
|
"github.com/caos/zitadel/operator/secrets"
|
|
|
|
"github.com/caos/orbos/pkg/secret"
|
|
"github.com/spf13/cobra"
|
|
)
|
|
|
|
func ReadSecretCommand(getRv GetRootValues) *cobra.Command {
|
|
return &cobra.Command{
|
|
Use: "readsecret [path]",
|
|
Short: "Print a secrets decrypted value to stdout",
|
|
Long: "Print a secrets decrypted value to stdout.\nIf no path is provided, a secret can interactively be chosen from a list of all possible secrets",
|
|
Args: cobra.MaximumNArgs(1),
|
|
Example: `zitadelctl readsecret database.bucket.serviceaccountjson.encrypted > ~/googlecloudstoragesa.json`,
|
|
RunE: func(cmd *cobra.Command, args []string) error {
|
|
rv, err := getRv()
|
|
if err != nil {
|
|
return err
|
|
}
|
|
defer func() {
|
|
err = rv.ErrFunc(err)
|
|
}()
|
|
|
|
monitor := rv.Monitor
|
|
orbConfig := rv.OrbConfig
|
|
gitClient := rv.GitClient
|
|
|
|
path := ""
|
|
if len(args) > 0 {
|
|
path = args[0]
|
|
}
|
|
|
|
k8sClient, err := cli.Client(monitor, orbConfig, gitClient, rv.Kubeconfig, rv.Gitops, true)
|
|
if err != nil && !rv.Gitops {
|
|
return err
|
|
}
|
|
|
|
value, err := secret.Read(
|
|
k8sClient,
|
|
path,
|
|
secrets.GetAllSecretsFunc(monitor, path == "", rv.Gitops, gitClient, k8sClient, orbConfig),
|
|
)
|
|
if err != nil {
|
|
monitor.Error(err)
|
|
return nil
|
|
}
|
|
|
|
if _, err := os.Stdout.Write([]byte(value)); err != nil {
|
|
monitor.Error(err)
|
|
return nil
|
|
}
|
|
return nil
|
|
},
|
|
}
|
|
}
|