From 21dfc5b76367a9fd50755b68e7c7c661388d6f7d Mon Sep 17 00:00:00 2001 From: Kian Parvin <46668016+kian99@users.noreply.github.com> Date: Thu, 5 Dec 2024 11:06:06 +0200 Subject: [PATCH] chore: update jimmctl command info (#1477) * chore: update jimmctl command info 1. Populate the `Examples` field of all commands for correct documentation generation. 2. Changed examples that contained to an actual string like mycontroller. I copied Juju's help text e.g. `juju add-cloud -h` uses mycontroller and mycloud in their examples. 3. Populate the `Args` field of all commands for correct documentation generation. 4. Removed indentation from the command's doc string to match Juju's output. 5. Nested commands like auth should have the `UsagePrefix` field set. * chore: fix typo * chore: reword auth doc --- cmd/jimmctl/cmd/addcloudtocontroller.go | 28 ++--- cmd/jimmctl/cmd/addcontroller.go | 18 +-- cmd/jimmctl/cmd/auth.go | 11 +- cmd/jimmctl/cmd/controllerinfo.go | 34 +++--- cmd/jimmctl/cmd/crossmodelquery.go | 22 ++-- cmd/jimmctl/cmd/grantauditlogaccess.go | 19 ++-- cmd/jimmctl/cmd/group.go | 76 +++++++------ cmd/jimmctl/cmd/importcloudcredentials.go | 44 ++++---- cmd/jimmctl/cmd/importmodel.go | 33 +++--- cmd/jimmctl/cmd/listauditevents.go | 28 +++-- cmd/jimmctl/cmd/listcontrollers.go | 25 ++-- cmd/jimmctl/cmd/migratemodel.go | 28 +++-- cmd/jimmctl/cmd/modelstatus.go | 22 ++-- cmd/jimmctl/cmd/purge_logs.go | 25 ++-- cmd/jimmctl/cmd/relation.go | 113 ++++++++++--------- cmd/jimmctl/cmd/removecloudfromcontroller.go | 19 ++-- cmd/jimmctl/cmd/removecontroller.go | 19 ++-- cmd/jimmctl/cmd/revokeauditlogaccess.go | 20 ++-- cmd/jimmctl/cmd/role.go | 70 +++++++----- cmd/jimmctl/cmd/setcontrollerdeprecated.go | 20 ++-- cmd/jimmctl/cmd/updatemigratedmodel.go | 23 ++-- 21 files changed, 384 insertions(+), 313 deletions(-) diff --git a/cmd/jimmctl/cmd/addcloudtocontroller.go b/cmd/jimmctl/cmd/addcloudtocontroller.go index aa4b88c62..1308fcde3 100644 --- a/cmd/jimmctl/cmd/addcloudtocontroller.go +++ b/cmd/jimmctl/cmd/addcloudtocontroller.go @@ -25,18 +25,18 @@ import ( apiparams "github.com/canonical/jimm/v3/pkg/api/params" ) -var ( +const ( addCloudToControllerCommandDoc = ` - add-cloud-to-controller command adds the specified cloud to a specific - controller on jimm. +The add-cloud-to-controller command adds the specified cloud to a specific +controller on jimm. - One can specify a cloud definition via a yaml file passed with the --cloud - flag. If the flag is missing, the command will assume the cloud definition - is already known and will error otherwise. - - Example: - jimmctl add-cloud-to-controller - jimmctl add-cloud-to-controller --cloud= +One can specify a cloud definition via a yaml file passed with the --cloud +flag. If the flag is missing, the command will assume the cloud definition +is already known and will error otherwise. +` + addCloudToControllerExample = ` + jimmctl add-cloud-to-controller mycontroller mycloud + jimmctl add-cloud-to-controller mycontroller mycloud --cloud=./cloud-definition.yaml ` ) @@ -78,9 +78,11 @@ type addCloudToControllerCommand struct { // Info implements Command.Info. func (c *addCloudToControllerCommand) Info() *cmd.Info { return jujucmd.Info(&cmd.Info{ - Name: "add-cloud-to-controller", - Purpose: "Add cloud to specific controller in jimm", - Doc: addCloudToControllerCommandDoc, + Name: "add-cloud-to-controller", + Args: " ", + Purpose: "Add cloud to specific controller in jimm", + Doc: addCloudToControllerCommandDoc, + Examples: addCloudToControllerExample, }) } diff --git a/cmd/jimmctl/cmd/addcontroller.go b/cmd/jimmctl/cmd/addcontroller.go index bd1e7fe52..7f4c2245c 100644 --- a/cmd/jimmctl/cmd/addcontroller.go +++ b/cmd/jimmctl/cmd/addcontroller.go @@ -21,11 +21,11 @@ var ( stdinMarkers = []string{"-"} addControllerCommandDoc = ` - add-controller command adds a controller to jimm. - - Example: - jimmctl add-controller - jimmctl add-controller --format json +The add-controller command adds a controller to jimm. +` + addControllerCommandExample = ` + jimmctl add-controller ./controller-info + jimmctl add-controller ./controller-info.yaml --format json ` ) @@ -50,9 +50,11 @@ type addControllerCommand struct { func (c *addControllerCommand) Info() *cmd.Info { return jujucmd.Info(&cmd.Info{ - Name: "add-controller", - Purpose: "Add controller to jimm", - Doc: addControllerCommandDoc, + Name: "add-controller", + Purpose: "Add controller to jimm", + Args: "", + Doc: addControllerCommandDoc, + Examples: addControllerCommandExample, }) } diff --git a/cmd/jimmctl/cmd/auth.go b/cmd/jimmctl/cmd/auth.go index 17faf4f12..fb70a0603 100644 --- a/cmd/jimmctl/cmd/auth.go +++ b/cmd/jimmctl/cmd/auth.go @@ -6,15 +6,16 @@ import ( jujucmd "github.com/juju/cmd/v3" ) -var authDoc = ` -auth enables users to manage authorisation model used by JIMM. +const authDoc = ` +The auth command enables user access management. ` func NewAuthCommand() *jujucmd.SuperCommand { cmd := jujucmd.NewSuperCommand(jujucmd.SuperCommandParams{ - Name: "auth", - Doc: authDoc, - Purpose: "Authorisation model management.", + Name: "auth", + UsagePrefix: "jimmctl", + Doc: authDoc, + Purpose: "Authorisation model management.", }) cmd.Register(NewGroupCommand()) cmd.Register(NewRelationCommand()) diff --git a/cmd/jimmctl/cmd/controllerinfo.go b/cmd/jimmctl/cmd/controllerinfo.go index a803c6c11..21ec7eec0 100644 --- a/cmd/jimmctl/cmd/controllerinfo.go +++ b/cmd/jimmctl/cmd/controllerinfo.go @@ -16,22 +16,20 @@ import ( apiparams "github.com/canonical/jimm/v3/pkg/api/params" ) -var ( +const ( controllerInfoCommandDoc = ` - controller-info command writes controller information contained - in the juju client store to a yaml file. +The controller-info command writes controller information contained +in the juju client store to a yaml file. - If a public address is specified, the output controller information - will contain the public address provided and omit a CA cert, this assumes - that the server is secured with a public certificate. - - Use the --local flag if the server is not configured with a public cert. +If a public address is specified, the output controller information +will contain the public address provided and omit a CA cert, this assumes +that the server is secured with a public certificate. - See examples below for usage. - - Examples: - jimmctl controller-info - jimmctl controller-info --local +Use the --local flag if the server is not configured with a public address. +` + controllerInfoCommandExample = ` + jimmctl controller-info mycontroller ./destination/file.yaml mycontroller.example.com + jimmctl controller-info mycontroller ./destination/file.yaml --local ` ) @@ -60,9 +58,11 @@ type controllerInfoCommand struct { func (c *controllerInfoCommand) Info() *cmd.Info { return jujucmd.Info(&cmd.Info{ - Name: "controller-info", - Purpose: "Stores controller info to a yaml file", - Doc: controllerInfoCommandDoc, + Name: "controller-info", + Args: " []", + Purpose: "Stores controller info to a yaml file", + Doc: controllerInfoCommandDoc, + Examples: controllerInfoCommandExample, }) } @@ -70,7 +70,7 @@ func (c *controllerInfoCommand) Info() *cmd.Info { func (c *controllerInfoCommand) SetFlags(f *gnuflag.FlagSet) { c.CommandBase.SetFlags(f) f.BoolVar(&c.local, "local", false, "If local flag is specified, then the local API address and CA cert of the controller will be used.") - f.StringVar(&c.tlsHostname, "tls-hostname", "", "Specify the hostname for TLS verfiication.") + f.StringVar(&c.tlsHostname, "tls-hostname", "", "Specify the hostname for TLS verification.") } // Init implements the cmd.Command interface. diff --git a/cmd/jimmctl/cmd/crossmodelquery.go b/cmd/jimmctl/cmd/crossmodelquery.go index 296154342..ae9ae901f 100644 --- a/cmd/jimmctl/cmd/crossmodelquery.go +++ b/cmd/jimmctl/cmd/crossmodelquery.go @@ -15,20 +15,20 @@ import ( apiparams "github.com/canonical/jimm/v3/pkg/api/params" ) -var ( +const ( // stdinMarkers contains file names that are taken to be stdin. crossModelQueryDoc = ` -query-models command queries all models available to the current user +The query-models command queries all models available to the current user performing the query against each model status individually, returning the collated query responses for each model. -The query will run against the exact output of "juju status --format json", +The query runs against the output of "juju status --format json", as such you can format your query against an output like this. -The queries will expect a JQ query string. - -Example: - jimmctl query-models '.applications | with_entries(select(.key=="nginx-ingress-integrator"))' +The queries expect a JQ query string. +` + crossModelQueryExample = ` + jimmctl query-models '.applications | with_entries(select(.key=="nginx-ingress-integrator"))' ` ) @@ -80,9 +80,11 @@ func (c *crossModelQueryCommand) SetFlags(f *gnuflag.FlagSet) { // Info implements modelcmd.Command. func (c *crossModelQueryCommand) Info() *cmd.Info { return jujucmd.Info(&cmd.Info{ - Name: "query-models", - Purpose: "Query model statuses", - Doc: crossModelQueryDoc, + Name: "query-models", + Args: "", + Purpose: "Query model statuses", + Doc: crossModelQueryDoc, + Examples: crossModelQueryExample, }) } diff --git a/cmd/jimmctl/cmd/grantauditlogaccess.go b/cmd/jimmctl/cmd/grantauditlogaccess.go index 77e3e17da..f68927e98 100644 --- a/cmd/jimmctl/cmd/grantauditlogaccess.go +++ b/cmd/jimmctl/cmd/grantauditlogaccess.go @@ -16,12 +16,15 @@ import ( apiparams "github.com/canonical/jimm/v3/pkg/api/params" ) -var grantAuditLogAccessDoc = ` - grant-audit-log-access grants user access to audit logs. +const ( + grantAuditLogAccessDoc = ` +Grants a user access to read audit logs. +` - Example: - jimmctl grant-audit-log-access + grantAuditLogAccessExamples = ` + jimmctl grant-audit-log-access ` +) // NewGrantAuditLogAccessCommand returns a command used to grant // users access to audit logs. @@ -45,9 +48,11 @@ type grantAuditLogAccessCommand struct { func (c *grantAuditLogAccessCommand) Info() *cmd.Info { return jujucmd.Info(&cmd.Info{ - Name: "grant-audit-log-access", - Purpose: "Grants access to audit logs.", - Doc: grantAuditLogAccessDoc, + Name: "grant-audit-log-access", + Args: "", + Purpose: "Grants access to audit logs.", + Doc: grantAuditLogAccessDoc, + Examples: grantAuditLogAccessExamples, }) } diff --git a/cmd/jimmctl/cmd/group.go b/cmd/jimmctl/cmd/group.go index 16402a34c..6f0ca5e3a 100644 --- a/cmd/jimmctl/cmd/group.go +++ b/cmd/jimmctl/cmd/group.go @@ -20,47 +20,46 @@ import ( apiparams "github.com/canonical/jimm/v3/pkg/api/params" ) -var ( +const ( groupDoc = ` -group command enables group management for jimm +The group command enables group management for jimm ` addGroupDoc = ` -add command adds group to jimm. - -Example: - jimmctl auth group add +The add command adds group to jimm. +` + addGroupExample = ` + jimmctl auth group add mygroup ` renameGroupDoc = ` -rename command renames a group in jimm. - -Example: - jimmctl auth group rename +The rename command renames a group in jimm. +` + renameGroupExample = ` + jimmctl auth group rename mygroup newgroup ` removeGroupDoc = ` -rename command removes a group in jimm. - -Usage: --y Remove group without promping for confirmation +The remove command removes a group in jimm. +` -Example: - jimmctl auth group remove + removeGroupExample = ` + jimmctl auth group remove mygroup ` listGroupsDoc = ` -list command lists all groups in jimm. - -Example: - jimmctl auth group list +The list command lists all groups in jimm. +` + listGroupsExample = ` + jimmctl auth group list ` ) // NewGroupCommand returns a command for group management. func NewGroupCommand() *jujucmdv3.SuperCommand { cmd := jujucmd.NewSuperCommand(jujucmdv3.SuperCommandParams{ - Name: "group", - Doc: groupDoc, - Purpose: "Group management.", + Name: "group", + UsagePrefix: "auth", + Doc: groupDoc, + Purpose: "Group management.", }) cmd.Register(newAddGroupCommand()) cmd.Register(newRenameGroupCommand()) @@ -93,9 +92,11 @@ type addGroupCommand struct { // Info implements the cmd.Command interface. func (c *addGroupCommand) Info() *cmd.Info { return jujucmd.Info(&cmd.Info{ - Name: "add", - Purpose: "Add group to jimm.", - Doc: addGroupDoc, + Name: "add", + Args: "", + Purpose: "Add group to jimm.", + Doc: addGroupDoc, + Examples: addGroupExample, }) } @@ -170,9 +171,11 @@ type renameGroupCommand struct { // Info implements the cmd.Command interface. func (c *renameGroupCommand) Info() *cmd.Info { return jujucmd.Info(&cmd.Info{ - Name: "rename", - Purpose: "Rename a group.", - Doc: renameGroupDoc, + Name: "rename", + Args: " ", + Purpose: "Rename a group.", + Doc: renameGroupDoc, + Examples: renameGroupExample, }) } @@ -238,9 +241,11 @@ type removeGroupCommand struct { // Info implements the cmd.Command interface. func (c *removeGroupCommand) Info() *cmd.Info { return jujucmd.Info(&cmd.Info{ - Name: "remove", - Purpose: "Remove a group.", - Doc: removeGroupDoc, + Name: "remove", + Args: "", + Purpose: "Remove a group.", + Doc: removeGroupDoc, + Examples: removeGroupExample, }) } @@ -331,9 +336,10 @@ type listGroupsCommand struct { // Info implements the cmd.Command interface. func (c *listGroupsCommand) Info() *cmd.Info { return jujucmd.Info(&cmd.Info{ - Name: "list", - Purpose: "List all groups.", - Doc: listGroupsDoc, + Name: "list", + Purpose: "List all groups.", + Doc: listGroupsDoc, + Examples: listGroupsExample, }) } diff --git a/cmd/jimmctl/cmd/importcloudcredentials.go b/cmd/jimmctl/cmd/importcloudcredentials.go index 9a24aafa5..9b2e5759d 100644 --- a/cmd/jimmctl/cmd/importcloudcredentials.go +++ b/cmd/jimmctl/cmd/importcloudcredentials.go @@ -17,24 +17,27 @@ import ( "github.com/canonical/jimm/v3/internal/errors" ) -//nolint:gosec // Thinks a credential is exposed. -const importCloudCredentialsDoc = ` - import-cloud-credentials imports a set of cloud credentials - loaded from a file containing a series of JSON objects. The JSON - objects specifying the credentials should be of the form: - - { - "_id": , - "type": , - "attributes": { - : , - ... - } +const ( + //nolint:gosec // Thinks a credential is exposed. + importCloudCredentialsDoc = ` +The import-cloud-credentials imports a set of cloud credentials +loaded from a file containing a series of JSON objects. The JSON +objects specifying the credentials should be of the form: + +{ + "_id": , + "type": , + "attributes": { + : , + ... } - - Example: - jimmctl import-cloud-credentials creds.json +} ` + //nolint:gosec // Thinks a credential is exposed. + importCloudCredentialsExample = ` + jimmctl import-cloud-credentials ./path/creds.json +` +) // NewImportCloudCredentialsCommand returns a command to import cloud // credentials. @@ -58,10 +61,11 @@ type importCloudCredentialsCommand struct { // Info implements cmd.Command interface. func (c *importCloudCredentialsCommand) Info() *cmd.Info { return jujucmd.Info(&cmd.Info{ - Name: "import-cloud-credentials", - Args: "", - Purpose: "Import cloud credentials to jimm", - Doc: importCloudCredentialsDoc, + Name: "import-cloud-credentials", + Args: "", + Purpose: "Import cloud credentials to jimm", + Doc: importCloudCredentialsDoc, + Examples: importCloudCredentialsExample, }) } diff --git a/cmd/jimmctl/cmd/importmodel.go b/cmd/jimmctl/cmd/importmodel.go index 520941921..0f7063185 100644 --- a/cmd/jimmctl/cmd/importmodel.go +++ b/cmd/jimmctl/cmd/importmodel.go @@ -16,20 +16,21 @@ import ( apiparams "github.com/canonical/jimm/v3/pkg/api/params" ) -const importModelCommandDoc = ` - import-model imports a model running on a controller to jimm. +const ( + importModelCommandDoc = ` +The import-model imports a model running on a controller to jimm. - When importing, it is necessary for JIMM to contain a set of cloud credentials - that represent a user's access to the incoming model's cloud. +When importing, it is necessary for JIMM to contain a set of cloud credentials +that represent a user's access to the incoming model's cloud. - The --owner command is necessary when importing a model created by a - local user and it will switch the model owner to the desired external user. - E.g. --owner my-user@canonical.com - - Example: - jimmctl import-model - jimmctl import-model --owner +The --owner command is necessary when importing a model created by a +local user and it will switch the model owner to the desired external user. +` + importModelCommandExample = ` + jimmctl import-model mycontroller ac30d6ae-0bed-4398-bba7-75d49e39f189 + jimmctl import-model mycontroller ac30d6ae-0bed-4398-bba7-75d49e39f189 --owner user@canonical.com ` +) // NewImportModelCommand returns a command to import a model. func NewImportModelCommand() cmd.Command { @@ -52,15 +53,17 @@ type importModelCommand struct { // Info implements the cmd.Command interface. func (c *importModelCommand) Info() *cmd.Info { return jujucmd.Info(&cmd.Info{ - Name: "import-model", - Args: " ", - Purpose: "Import a model to jimm", - Doc: importModelCommandDoc, + Name: "import-model", + Args: " ", + Purpose: "Import a model to jimm", + Doc: importModelCommandDoc, + Examples: importModelCommandExample, }) } // SetFlags implements Command.SetFlags. func (c *importModelCommand) SetFlags(f *gnuflag.FlagSet) { + c.CommandBase.SetFlags(f) f.StringVar(&c.req.Owner, "owner", "", "switch the model owner to the desired user") } diff --git a/cmd/jimmctl/cmd/listauditevents.go b/cmd/jimmctl/cmd/listauditevents.go index fe7e66675..a9e66ede5 100644 --- a/cmd/jimmctl/cmd/listauditevents.go +++ b/cmd/jimmctl/cmd/listauditevents.go @@ -20,13 +20,16 @@ import ( apiparams "github.com/canonical/jimm/v3/pkg/api/params" ) -var listAuditEventsCommandDoc = ` - list-audit-events command displays matching audit events. - - Example: - jimmctl list-audit-events --after