mirror of
https://github.com/zitadel/zitadel.git
synced 2024-12-13 19:44:21 +00:00
ce29a78d1b
# Which Problems Are Solved
The v2beta services are stable but not GA.
# How the Problems Are Solved
The v2beta services are copied to v2. The corresponding v1 and v2beta
services are deprecated.
# Additional Context
Closes #7236
---------
Co-authored-by: Elio Bischof <elio@zitadel.com>
(cherry picked from commit 7d2d85f57c
)
67 lines
1.7 KiB
Go
67 lines
1.7 KiB
Go
package key
|
|
|
|
import (
|
|
"errors"
|
|
"os"
|
|
|
|
"github.com/spf13/cobra"
|
|
)
|
|
|
|
const (
|
|
flagMasterKey = "masterkeyFile"
|
|
flagMasterKeyShort = "m"
|
|
flagMasterKeyArg = "masterkey"
|
|
flagMasterKeyEnv = "masterkeyFromEnv"
|
|
envMasterKey = "ZITADEL_MASTERKEY"
|
|
)
|
|
|
|
var (
|
|
ErrNotSingleFlag = errors.New("masterkey must either be provided by file path, value or environment variable")
|
|
)
|
|
|
|
func AddMasterKeyFlag(cmd *cobra.Command) {
|
|
if cmd.PersistentFlags().Lookup(flagMasterKey) != nil {
|
|
return
|
|
}
|
|
cmd.PersistentFlags().StringP(flagMasterKey, flagMasterKeyShort, "", "path to the masterkey for en/decryption keys")
|
|
cmd.PersistentFlags().String(flagMasterKeyArg, "", "masterkey as argument for en/decryption keys")
|
|
cmd.PersistentFlags().Bool(flagMasterKeyEnv, false, "read masterkey for en/decryption keys from environment variable (ZITADEL_MASTERKEY)")
|
|
}
|
|
|
|
func MasterKey(cmd *cobra.Command) (string, error) {
|
|
masterKeyFile, _ := cmd.Flags().GetString(flagMasterKey)
|
|
masterKeyFromArg, _ := cmd.Flags().GetString(flagMasterKeyArg)
|
|
masterKeyFromEnv, _ := cmd.Flags().GetBool(flagMasterKeyEnv)
|
|
if err := checkSingleFlag(masterKeyFile, masterKeyFromArg, masterKeyFromEnv); err != nil {
|
|
return "", err
|
|
}
|
|
if masterKeyFromArg != "" {
|
|
return masterKeyFromArg, nil
|
|
}
|
|
if masterKeyFromEnv {
|
|
return os.Getenv(envMasterKey), nil
|
|
}
|
|
data, err := os.ReadFile(masterKeyFile)
|
|
if err != nil {
|
|
return "", err
|
|
}
|
|
return string(data), nil
|
|
}
|
|
|
|
func checkSingleFlag(masterKeyFile, masterKeyFromArg string, masterKeyFromEnv bool) error {
|
|
var flags int
|
|
if masterKeyFile != "" {
|
|
flags++
|
|
}
|
|
if masterKeyFromArg != "" {
|
|
flags++
|
|
}
|
|
if masterKeyFromEnv {
|
|
flags++
|
|
}
|
|
if flags != 1 {
|
|
return ErrNotSingleFlag
|
|
}
|
|
return nil
|
|
}
|