mirror of
https://github.com/edgelesssys/constellation.git
synced 2025-01-12 16:09:39 -05:00
cli: adopt Cobra cli reference style (#997)
* adapt to Cobra CLI ref style
* linting
* change multi-line reference style
* lowercase short descriptions
* Revert "lowercase short descriptions"
This reverts commit 499dc3577a
.
* use 2 newlines on long description and add dots
* mark required flags
* Update cli/internal/cmd/iamcreateaws.go
Co-authored-by: Paul Meyer <49727155+katexochen@users.noreply.github.com>
* Update cli/internal/cmd/upgradeexecute.go
Co-authored-by: Paul Meyer <49727155+katexochen@users.noreply.github.com>
* Update cli/internal/cmd/upgradeexecute.go
Co-authored-by: Paul Meyer <49727155+katexochen@users.noreply.github.com>
Co-authored-by: Paul Meyer <49727155+katexochen@users.noreply.github.com>
This commit is contained in:
parent
8f88129cac
commit
e844ceb2b1
@ -30,7 +30,8 @@ func newConfigFetchMeasurementsCmd() *cobra.Command {
|
|||||||
cmd := &cobra.Command{
|
cmd := &cobra.Command{
|
||||||
Use: "fetch-measurements",
|
Use: "fetch-measurements",
|
||||||
Short: "Fetch measurements for configured cloud provider and image",
|
Short: "Fetch measurements for configured cloud provider and image",
|
||||||
Long: "Fetch measurements for configured cloud provider and image. A config needs to be generated first!",
|
Long: "Fetch measurements for configured cloud provider and image.\n\n" +
|
||||||
|
"A config needs to be generated first.",
|
||||||
Args: cobra.ExactArgs(0),
|
Args: cobra.ExactArgs(0),
|
||||||
RunE: runConfigFetchMeasurements,
|
RunE: runConfigFetchMeasurements,
|
||||||
}
|
}
|
||||||
|
@ -32,7 +32,7 @@ func newIAMCreateCmd() *cobra.Command {
|
|||||||
Args: cobra.ExactArgs(0),
|
Args: cobra.ExactArgs(0),
|
||||||
}
|
}
|
||||||
|
|
||||||
cmd.PersistentFlags().Bool("generate-config", false, "Automatically generate a config file and fill in the required fields")
|
cmd.PersistentFlags().Bool("generate-config", false, "automatically generate a configuration file and fill in the required fields")
|
||||||
|
|
||||||
cmd.AddCommand(newIAMCreateAWSCmd())
|
cmd.AddCommand(newIAMCreateAWSCmd())
|
||||||
cmd.AddCommand(newIAMCreateAzureCmd())
|
cmd.AddCommand(newIAMCreateAzureCmd())
|
||||||
|
@ -26,11 +26,13 @@ func newIAMCreateAWSCmd() *cobra.Command {
|
|||||||
RunE: runIAMCreateAWS,
|
RunE: runIAMCreateAWS,
|
||||||
}
|
}
|
||||||
|
|
||||||
cmd.Flags().String("prefix", "", "Name prefix for all resources.")
|
cmd.Flags().String("prefix", "", "name prefix for all resources (required)")
|
||||||
must(cobra.MarkFlagRequired(cmd.Flags(), "prefix"))
|
must(cobra.MarkFlagRequired(cmd.Flags(), "prefix"))
|
||||||
cmd.Flags().String("zone", "", "AWS availability zone the resources will be created in (e.g. us-east-2a). Find available zones here: https://docs.aws.amazon.com/AWSEC2/latest/UserGuide/using-regions-availability-zones.html#concepts-availability-zones. Note that we do not support every zone / region. You can find a list of all supported regions in our docs.")
|
cmd.Flags().String("zone", "", "AWS availability zone the resources will be created in, e.g. us-east-2a (required)\n"+
|
||||||
|
"Find available zones here: https://docs.aws.amazon.com/AWSEC2/latest/UserGuide/using-regions-availability-zones.html#concepts-availability-zones. "+
|
||||||
|
"Note that we do not support every zone / region. You can find a list of all supported regions in our docs.")
|
||||||
must(cobra.MarkFlagRequired(cmd.Flags(), "zone"))
|
must(cobra.MarkFlagRequired(cmd.Flags(), "zone"))
|
||||||
cmd.Flags().Bool("yes", false, "Create the IAM configuration without further confirmation.")
|
cmd.Flags().Bool("yes", false, "create the IAM configuration without further confirmation")
|
||||||
|
|
||||||
return cmd
|
return cmd
|
||||||
}
|
}
|
||||||
|
@ -25,13 +25,13 @@ func newIAMCreateAzureCmd() *cobra.Command {
|
|||||||
RunE: runIAMCreateAzure,
|
RunE: runIAMCreateAzure,
|
||||||
}
|
}
|
||||||
|
|
||||||
cmd.Flags().String("resourceGroup", "", "Name prefix of the two resource groups your cluster / IAM resources will be created in.")
|
cmd.Flags().String("resourceGroup", "", "name prefix of the two resource groups your cluster / IAM resources will be created in (required)")
|
||||||
must(cobra.MarkFlagRequired(cmd.Flags(), "resourceGroup"))
|
must(cobra.MarkFlagRequired(cmd.Flags(), "resourceGroup"))
|
||||||
cmd.Flags().String("region", "", "Region the resources will be created in. (e.g. westus)")
|
cmd.Flags().String("region", "", "region the resources will be created in, e.g. westus (required)")
|
||||||
must(cobra.MarkFlagRequired(cmd.Flags(), "region"))
|
must(cobra.MarkFlagRequired(cmd.Flags(), "region"))
|
||||||
cmd.Flags().String("servicePrincipal", "", "Name of the service principal that will be created.")
|
cmd.Flags().String("servicePrincipal", "", "name of the service principal that will be created (required)")
|
||||||
must(cobra.MarkFlagRequired(cmd.Flags(), "servicePrincipal"))
|
must(cobra.MarkFlagRequired(cmd.Flags(), "servicePrincipal"))
|
||||||
cmd.Flags().Bool("yes", false, "Create the IAM configuration without further confirmation.")
|
cmd.Flags().Bool("yes", false, "create the IAM configuration without further confirmation")
|
||||||
|
|
||||||
return cmd
|
return cmd
|
||||||
}
|
}
|
||||||
|
@ -37,13 +37,16 @@ func newIAMCreateGCPCmd() *cobra.Command {
|
|||||||
RunE: runIAMCreateGCP,
|
RunE: runIAMCreateGCP,
|
||||||
}
|
}
|
||||||
|
|
||||||
cmd.Flags().String("zone", "", "GCP zone the cluster will be deployed in. Find a list of available zones here: https://cloud.google.com/compute/docs/regions-zones#available")
|
cmd.Flags().String("zone", "", "GCP zone the cluster will be deployed in (required)\n"+
|
||||||
|
"Find a list of available zones here: https://cloud.google.com/compute/docs/regions-zones#available.")
|
||||||
must(cobra.MarkFlagRequired(cmd.Flags(), "zone"))
|
must(cobra.MarkFlagRequired(cmd.Flags(), "zone"))
|
||||||
cmd.Flags().String("serviceAccountID", "", "ID for the service account that will be created. Must match ^[a-z](?:[-a-z0-9]{4,28}[a-z0-9])$")
|
cmd.Flags().String("serviceAccountID", "", "ID for the service account that will be created (required)\n"+
|
||||||
|
"Must match ^[a-z](?:[-a-z0-9]{4,28}[a-z0-9])$.")
|
||||||
must(cobra.MarkFlagRequired(cmd.Flags(), "serviceAccountID"))
|
must(cobra.MarkFlagRequired(cmd.Flags(), "serviceAccountID"))
|
||||||
cmd.Flags().String("projectID", "", "ID of the GCP project the configuration will be created in. Find it on the welcome screen of your project: https://console.cloud.google.com/welcome")
|
cmd.Flags().String("projectID", "", "ID of the GCP project the configuration will be created in (required)\n"+
|
||||||
|
"Find it on the welcome screen of your project: https://console.cloud.google.com/welcome.")
|
||||||
must(cobra.MarkFlagRequired(cmd.Flags(), "projectID"))
|
must(cobra.MarkFlagRequired(cmd.Flags(), "projectID"))
|
||||||
cmd.Flags().Bool("yes", false, "Create the IAM configuration without further confirmation.")
|
cmd.Flags().Bool("yes", false, "create the IAM configuration without further confirmation")
|
||||||
|
|
||||||
return cmd
|
return cmd
|
||||||
}
|
}
|
||||||
|
@ -44,7 +44,8 @@ func NewInitCmd() *cobra.Command {
|
|||||||
cmd := &cobra.Command{
|
cmd := &cobra.Command{
|
||||||
Use: "init",
|
Use: "init",
|
||||||
Short: "Initialize the Constellation cluster",
|
Short: "Initialize the Constellation cluster",
|
||||||
Long: "Initialize the Constellation cluster. Start your confidential Kubernetes.",
|
Long: "Initialize the Constellation cluster.\n\n" +
|
||||||
|
"Start your confidential Kubernetes.",
|
||||||
Args: cobra.ExactArgs(0),
|
Args: cobra.ExactArgs(0),
|
||||||
RunE: runInitialize,
|
RunE: runInitialize,
|
||||||
}
|
}
|
||||||
|
@ -34,14 +34,14 @@ func newMiniUpCmd() *cobra.Command {
|
|||||||
cmd := &cobra.Command{
|
cmd := &cobra.Command{
|
||||||
Use: "up",
|
Use: "up",
|
||||||
Short: "Create and initialize a new MiniConstellation cluster",
|
Short: "Create and initialize a new MiniConstellation cluster",
|
||||||
Long: "Create and initialize a new MiniConstellation cluster.\n" +
|
Long: "Create and initialize a new MiniConstellation cluster.\n\n" +
|
||||||
"A mini cluster consists of a single control-plane and worker node, hosted using QEMU/KVM.\n",
|
"A mini cluster consists of a single control-plane and worker node, hosted using QEMU/KVM.",
|
||||||
Args: cobra.ExactArgs(0),
|
Args: cobra.ExactArgs(0),
|
||||||
RunE: runUp,
|
RunE: runUp,
|
||||||
}
|
}
|
||||||
|
|
||||||
// override global flag so we don't have a default value for the config
|
// override global flag so we don't have a default value for the config
|
||||||
cmd.Flags().String("config", "", "path to the config file to use for the cluster")
|
cmd.Flags().String("config", "", "path to the configuration file to use for the cluster")
|
||||||
|
|
||||||
return cmd
|
return cmd
|
||||||
}
|
}
|
||||||
|
@ -35,8 +35,8 @@ func NewRecoverCmd() *cobra.Command {
|
|||||||
cmd := &cobra.Command{
|
cmd := &cobra.Command{
|
||||||
Use: "recover",
|
Use: "recover",
|
||||||
Short: "Recover a completely stopped Constellation cluster",
|
Short: "Recover a completely stopped Constellation cluster",
|
||||||
Long: "Recover a Constellation cluster by sending a recovery key to an instance in the boot stage." +
|
Long: "Recover a Constellation cluster by sending a recovery key to an instance in the boot stage.\n\n" +
|
||||||
"\nThis is only required if instances restart without other instances available for bootstrapping.",
|
"This is only required if instances restart without other instances available for bootstrapping.",
|
||||||
Args: cobra.ExactArgs(0),
|
Args: cobra.ExactArgs(0),
|
||||||
RunE: runRecover,
|
RunE: runRecover,
|
||||||
}
|
}
|
||||||
|
@ -25,7 +25,8 @@ func NewTerminateCmd() *cobra.Command {
|
|||||||
cmd := &cobra.Command{
|
cmd := &cobra.Command{
|
||||||
Use: "terminate",
|
Use: "terminate",
|
||||||
Short: "Terminate a Constellation cluster",
|
Short: "Terminate a Constellation cluster",
|
||||||
Long: "Terminate a Constellation cluster. The cluster can't be started again, and all persistent storage will be lost.",
|
Long: "Terminate a Constellation cluster.\n\n" +
|
||||||
|
"The cluster can't be started again, and all persistent storage will be lost.",
|
||||||
Args: cobra.NoArgs,
|
Args: cobra.NoArgs,
|
||||||
RunE: runTerminate,
|
RunE: runTerminate,
|
||||||
}
|
}
|
||||||
|
@ -31,9 +31,12 @@ func newUpgradeExecuteCmd() *cobra.Command {
|
|||||||
RunE: runUpgradeExecute,
|
RunE: runUpgradeExecute,
|
||||||
}
|
}
|
||||||
|
|
||||||
cmd.Flags().Bool("helm", false, "Execute helm upgrade. This feature is still in development an may change without anounncement. Upgrades all helm charts deployed during constellation-init.")
|
cmd.Flags().Bool("helm", false, "execute helm upgrade\n"+
|
||||||
cmd.Flags().BoolP("yes", "y", false, "Run upgrades without further confirmation. WARNING: might delete your resources in case you are using cert-manager in your cluster. Please read the docs.")
|
"This feature is still in development an may change without announcement. Upgrades all helm charts deployed during constellation-init.")
|
||||||
cmd.Flags().Duration("timeout", 3*time.Minute, "Change helm upgrade timeout. This feature is still in development an may change without anounncement. Might be useful for slow connections or big clusters.")
|
cmd.Flags().BoolP("yes", "y", false, "run upgrades without further confirmation\n"+
|
||||||
|
"WARNING: might delete your resources in case you are using cert-manager in your cluster. Please read the docs.")
|
||||||
|
cmd.Flags().Duration("timeout", 3*time.Minute, "change helm upgrade timeout\n"+
|
||||||
|
"This feature is still in development an may change without announcement. Might be useful for slow connections or big clusters.")
|
||||||
if err := cmd.Flags().MarkHidden("helm"); err != nil {
|
if err := cmd.Flags().MarkHidden("helm"); err != nil {
|
||||||
panic(err)
|
panic(err)
|
||||||
}
|
}
|
||||||
|
@ -169,6 +169,16 @@ In case the scope of your PR is too wide, use the alternative format.
|
|||||||
|
|
||||||
and `<Title>` starts with a capital letter.
|
and `<Title>` starts with a capital letter.
|
||||||
|
|
||||||
|
## CLI reference
|
||||||
|
|
||||||
|
The command reference within the CLI should follow the following conventions:
|
||||||
|
|
||||||
|
- Short description: Starts with a capital letter, beginnings of sentences, names and acronyms are capitalized, ends without a period. It should be a single sentence.
|
||||||
|
- Long description: Starts with a capital letter, beginnings of sentences, names and acronyms are capitalized, ends with a period.
|
||||||
|
- If the long description contains multiple sentences, the first sentence is formatted as a long description, followed by 2 newlines and the rest of the sentences. The rest of the sentences start with a capital letter, beginnings of sentences, names and acronyms are capitalized and each sentence ends with a period.
|
||||||
|
- Flag: Starts with a lowercase letter, beginnings of sentences, names and acronyms are capitalized, ends without a period.
|
||||||
|
- If a flag contains multiple sentences, the first sentence is formatted as a normal flag, followed by a newline and the rest of the sentences. The rest of the sentences start with a capital letter, beginnings of sentences, names and acronyms are capitalized and each sentence ends with a period.
|
||||||
|
|
||||||
## Naming convention
|
## Naming convention
|
||||||
|
|
||||||
### Network
|
### Network
|
||||||
|
Loading…
Reference in New Issue
Block a user