← Back to team overview

launchpad-reviewers team mailing list archive

[Merge] lp:~evilnick/maas/manpage into lp:maas

 

Nick Veitch has proposed merging lp:~evilnick/maas/manpage into lp:maas.

Commit message:
added the manpage for maas-cli

Requested reviews:
  Launchpad code reviewers (launchpad-reviewers)

For more details, see:
https://code.launchpad.net/~evilnick/maas/manpage/+merge/130981

generated a manpage for the maas-cli command
-- 
https://code.launchpad.net/~evilnick/maas/manpage/+merge/130981
Your team Launchpad code reviewers is requested to review the proposed merge of lp:~evilnick/maas/manpage into lp:maas.
=== added file 'man/maas-cli.8'
--- man/maas-cli.8	1970-01-01 00:00:00 +0000
+++ man/maas-cli.8	2012-10-23 12:07:27 +0000
@@ -0,0 +1,619 @@
+.TH "MAAS-CLI" "8" "October 23, 2012" "12.10" "MAAS"
+.SH NAME
+maas-cli \- commandline API access for MAAS
+.
+.nr rst2man-indent-level 0
+.
+.de1 rstReportMargin
+\\$1 \\n[an-margin]
+level \\n[rst2man-indent-level]
+level margin: \\n[rst2man-indent\\n[rst2man-indent-level]]
+-
+\\n[rst2man-indent0]
+\\n[rst2man-indent1]
+\\n[rst2man-indent2]
+..
+.de1 INDENT
+.\" .rstReportMargin pre:
+. RS \\$1
+. nr rst2man-indent\\n[rst2man-indent-level] \\n[an-margin]
+. nr rst2man-indent-level +1
+.\" .rstReportMargin post:
+..
+.de UNINDENT
+. RE
+.\" indent \\n[an-margin]
+.\" old: \\n[rst2man-indent\\n[rst2man-indent-level]]
+.nr rst2man-indent-level -1
+.\" new: \\n[rst2man-indent\\n[rst2man-indent-level]]
+.in \\n[rst2man-indent\\n[rst2man-indent-level]]u
+..
+.\" Man page generated from reStructuredText.
+.
+.SH USAGE
+.INDENT 0.0
+.INDENT 3.5
+$ maas\-cli <profile> <command> [parameters]
+.UNINDENT
+.UNINDENT
+.sp
+The available commands are dependent on the API you are connecting to and the
+profile you use. The currently available options are explained below.
+.SH DESCRIPTION
+.sp
+As well as the web interface, many tasks can be performed by accessing
+the MAAS API directly through the maas\-cli command. It is necessary to log in
+with a registered key (which can be obtained from the web interface as
+described below).
+.sp
+Before the API will accept any commands from maas\-cli, you must first
+login. To do this, you need the API key which can be found in the user
+interface.
+.sp
+Login to the web interface on your MAAS. Click on the username in the
+top right corner and select \(aqPreferences\(aq from the menu which appears.
+.sp
+A new page will load...
+.sp
+The very first item is a list of MAAS keys. One will have already been
+generated when the system was installed. It\(aqs easiest to just select
+and copy the key (it\(aqs quite long!) and then paste it into the
+commandline. The format of the login command is:
+.sp
+.nf
+.ft C
+$ maas\-cli login <profile\-name> <hostname> <key>
+.ft P
+.fi
+.sp
+The profile name created by default when you install MAAS is
+"maas". So an example login might look like this:
+.sp
+.nf
+.ft C
+$ maas\-cli login maas http://10.98.0.13/MAAS/api/1.0 AWSCRMzqMNy:jjk...5e1FenoP82Qm5te2
+.ft P
+.fi
+.sp
+The \fBmaas\-cli\fP command exposes the whole API, so you can do anything
+you actually \fIcan\fP do with MAAS using this command. Unsurprisingly,
+this leaves us with a vast number of options, but before we delve into
+detail on the specifics, here is a sort of \(aqcheat\-sheet\(aq for common
+tasks you might want to do using \fBmaas\-cli\fP.
+.INDENT 0.0
+.INDENT 3.5
+.INDENT 0.0
+.IP \(bu 2
+\fI\%Configure DHCP and DNS services\fP
+.IP \(bu 2
+\fI\%Commission all enlisted nodes\fP
+.IP \(bu 2
+\fI\%Setting IPMI power parameters for a node\fP
+.UNINDENT
+.UNINDENT
+.UNINDENT
+.sp
+The main maas\-cli commands are:
+.INDENT 0.0
+.TP
+.B list
+lists the details [name url auth\-key] of all the currently logged\-in
+profiles.
+.UNINDENT
+.INDENT 0.0
+.TP
+.B login  <profile>  <url>  <key>
+Logs in to the MAAS controller API at the given URL, using the key
+provided and associates this connection with the given profile name.
+.UNINDENT
+.INDENT 0.0
+.TP
+.B refresh
+Refreshes the API descriptions of all the current logged in
+profiles. This may become necessary for example when upgrading the
+maas packages to ensure the command\-line options match with the API.
+.UNINDENT
+.INDENT 0.0
+.TP
+.B <profile> [command] [options] ...
+Using the given profile name instructs \fBmaas\-cli\fP to direct the
+subsequent commands and options to the relevant MAAS, which for the
+current API are detailed below...
+.UNINDENT
+.SH ACCOUNT
+.sp
+This command is used for creating and destroying the
+MAAS authorisation tokens associated with a profile.
+.sp
+Usage: maas\-cli \fI<profile>\fP account [\-d \-\-degug] [\-h \-\-help]
+create\-authorisation\-token | delete\-authorisation\-token [token_key=\fI<value>\fP]
+.INDENT 0.0
+.TP
+.B \-d, \-\-debug
+Displays debug information listing the API responses.
+.UNINDENT
+.INDENT 0.0
+.TP
+.B \-h, \-\-help
+Display usage information.
+.UNINDENT
+.INDENT 0.0
+.TP
+.B \-k, \-\-insecure
+Disables the SSL certificate check.
+.UNINDENT
+.INDENT 0.0
+.TP
+.B \-create\-authorisation\-token \(ga
+Creates a new MAAS authorisation token for the current profile
+which can be used to authenticate connections to the API.
+.UNINDENT
+.INDENT 0.0
+.TP
+.B \-delete\-authorisation\-token token_key=<value>
+Removes the given key from the list of authorisation tokens.
+.UNINDENT
+.SH NODE
+.sp
+API calls which operate on individual nodes. With thes commands, the
+node is always identified by its "system_id" property \- a unique tag
+allocated at the time of enlistment. To discover the value of the
+system_id, you can use the \fBmaas\-cli <profile> nodes list\fP command.
+.sp
+USAGE: maas\-cli <profile> node [\-h] release | start | stop | delete |
+read | update <system_id>
+.INDENT 0.0
+.TP
+.B \-h, \-\-help
+Display usage information.
+.UNINDENT
+.INDENT 0.0
+.TP
+.B release <system_id>
+Releases the node given by  \fI<system_id>\fP
+.UNINDENT
+.INDENT 0.0
+.TP
+.B start <system_id>
+Powers up the node identified by \fI<system_id>\fP (where MAAS has
+information for power management for this node).
+.UNINDENT
+.INDENT 0.0
+.TP
+.B stop <system_id>
+Powers off the node identified by \fI<system_id>\fP (where MAAS has
+information for power management for this node).
+.UNINDENT
+.INDENT 0.0
+.TP
+.B delete <system_id>
+Removes the given node from the MAAS database.
+.UNINDENT
+.INDENT 0.0
+.TP
+.B read <system_id>
+Returns all the current known information aboyt the node specified
+by \fI<system_id>\fP
+.UNINDENT
+.INDENT 0.0
+.TP
+.B update <system_id> [parameters...]
+Used to change or set specific values for the node. The valid
+parameters are listed below:
+.sp
+.nf
+.ft C
+hostname=<value>
+     The new hostname for this node.
+
+architecture=<value>
+     Sets the architecture type, where <value>
+     is a string containing a valid architecture type,
+     e.g. "i386/generic"
+
+power_type=<value>
+     Apply the given dotted decimal value as the
+     broadcast IP address for this subnet.
+
+power_parameters_{param1}... =<value>
+     Set the given power
+     parameters. Note that the valid options for these depend on
+     the power type chosen
+
+power_parameters_skip_check \(aqtrue\(aq | \(aqfalse\(aq
+     Whether to sanity check the supplied parameters against this
+     node\(aqs declared power type. The default is \(aqfalse\(aq.
+.ft P
+.fi
+.UNINDENT
+.sp
+Example: Setting the power parameters for an ipmi enabled node:
+.sp
+.nf
+.ft C
+maas\-cli maas node update <system_id> \e
+  power_type="ipmi" \e
+  power_parameters_power_address=192.168.22.33 \e
+  power_parameters_power_user=root \e
+  power_parameters_power_pass=ubuntu;
+.ft P
+.fi
+.SH NODES
+.sp
+Usage: maas\-cli <profile> nodes [\-h] is\-registered | list\-allocated |
+acquire | list | accept | accept\-all | new | check\-commissioning
+.INDENT 0.0
+.TP
+.B \-h, \-\-help
+Display usage information.
+.UNINDENT
+.INDENT 0.0
+.TP
+.B accept <system_id>
+Accepts the node referenced by <system_id>.
+.UNINDENT
+.INDENT 0.0
+.TP
+.B \-accept\-all
+Accepts all currently discovered but not previously accepted nodes.
+.UNINDENT
+.INDENT 0.0
+.TP
+.B acquire
+Allocates a node to the profile used to issue the command. Any
+ready node may be allocated.
+.UNINDENT
+.INDENT 0.0
+.TP
+.B \-registered mac_address=\(aq<address>\(aq
+Checks to see whether the specified MAC address is registered to a
+node.
+.UNINDENT
+.INDENT 0.0
+.TP
+.B list
+Returns a JSON formatted object listing all the currently known
+nodes, their system_id, status and other details.
+.UNINDENT
+.INDENT 0.0
+.TP
+.B \-list\-allocated
+Returns a JSON formatted object listing all the currently allocated
+nodes, their system_id, status and other details.
+.UNINDENT
+.INDENT 0.0
+.TP
+.B new  architecture=<value> mac_addresses=<value> [parameters]
+Creates a new node entry given the provided key=value information
+for the node. A minimum of the MAC address and architecture must be
+provided. Other parameters may also be supplied:
+.sp
+.nf
+.ft C
+architecture="<value>" \- The architecture of the node, must be
+one of the recognised architecture strings (e.g. "i386/generic")
+hostname="<value>" \- a name for this node. If not supplied a name
+will be generated.
+mac_addresses="<value>" \- The mac address(es)
+allocated to this node.
+powertype="<value>" \- the power type of
+the node (e.g. virsh, ipmi)
+.ft P
+.fi
+.UNINDENT
+.INDENT 0.0
+.TP
+.B \-check\-commissioning
+Displays current status of nodes in the commissioning phase. Any
+that have not returned before the system timeout value are listed
+as "failed".
+.UNINDENT
+.sp
+Examples:
+Accept and commission all discovered nodes:
+.sp
+.nf
+.ft C
+$ maas\-cli maas nodes accept\-all
+.ft P
+.fi
+.sp
+List all known nodes:
+.sp
+.nf
+.ft C
+$ maas\-cli maas nodes list
+.ft P
+.fi
+.sp
+Filter the list using specific key/value pairs:
+.sp
+.nf
+.ft C
+$ maas\-cli maas nodes list architecture="i386/generic"
+.ft P
+.fi
+.SH NODE-GROUPS
+.sp
+Usage: maas\-cli <profile> node\-groups [\-d \-\-debug] [\-h \-\-help] [\-k
+\-\-insecure] register | list | refresh\-workers | accept | reject
+.INDENT 0.0
+.TP
+.B \-d, \-\-debug
+Displays debug information listing the API responses.
+.UNINDENT
+.INDENT 0.0
+.TP
+.B \-h, \-\-help
+Display usage information.
+.UNINDENT
+.INDENT 0.0
+.TP
+.B \-k, \-\-insecure
+Disables the SSL certificate check.
+.UNINDENT
+.INDENT 0.0
+.TP
+.B register uuid=<value> name=<value> interfaces=<json_string>
+Registers a new node group with the given name and uuid. The
+interfaces parameter must be supplied in the form of a JSON string
+comprising the key/value data for the interface to be used, for
+example: interface=\(aq["ip":"192.168.21.5","interface":"eth1", "subnet_mask":"255.255.255.0","broadcast_ip":"192.168.21.255", "router_ip":"192.168.21.1", "ip_range_low":"192.168.21.10", "ip_range_high":"192.168.21.50"}]\(aq
+.UNINDENT
+.INDENT 0.0
+.TP
+.B list
+Returns a JSON list of all currently defined node groups.
+.UNINDENT
+.INDENT 0.0
+.TP
+.B refresh_workers
+It sounds a bit like they will get a cup of tea and a
+biscuit. Actually this just sends each node\-group worker an update
+of it\(aqs credentials (API key, node\-group name). This command is
+usually not needed at a user level, but is often used by worker
+nodes.
+.UNINDENT
+.INDENT 0.0
+.TP
+.B accept <uuid>
+Accepts a node\-group or number of nodegroups indicated by the
+supplied uuid
+.UNINDENT
+.INDENT 0.0
+.TP
+.B reject <uuid>
+Rejects a node\-group or number of nodegroups indicated by the
+supplied uuid
+.UNINDENT
+.SH NODE-GROUP-INTERFACE
+.sp
+For managing the applied interfaces. See :ref:<node_group_interfaces>.
+.sp
+Usage: maas\-cli \fI<profile>\fP node\-group\-interfaces [\-d \-\-degug] [\-h
+\-\-help] [\-k \-\-insecure] read | update | delete [parameters...]
+.sp
+..program:: maas\-cli node\-group\-interface
+.INDENT 0.0
+.TP
+.B read <uuid> <interface>
+Returns the current settings for the given uuid and interface
+.UNINDENT
+.INDENT 0.0
+.TP
+.B update [parameters]
+Changes the settings for the interface according to the given
+parameters:
+.sp
+.nf
+.ft C
+management=  0 | 1 | 2
+     The service to be managed on the interface ( 0= none, 1=DHCP, 2=DHCP and DNS).
+
+subnet_mask=<value>
+     Apply the given dotted decimal value as the subnet mask.
+
+broadcast_ip=<value>
+     Apply the given dotted decimal value as the broadcast IP address for this subnet.
+
+router_ip=<value>
+     Apply the given dotted decimal value as the default router address for this subnet.
+
+ip_range_low=<value>
+     The lowest value of IP address to allocate via DHCP
+
+ip_range_high=<value>
+     The highest value of IP address to allocate via DHCP
+.ft P
+.fi
+.UNINDENT
+.INDENT 0.0
+.TP
+.B delete <uuid> <interface>
+Removes the entry for the given uuid and interface.
+.UNINDENT
+.SH NODE-GROUP-INTERFACES
+.sp
+The node\-group\-interfaces commands are used for configuring the
+management of DHCP and DNS services where these are managed by MAAS.
+.sp
+Usage: maas\-cli \fI<profile>\fP node\-group\-interfaces [\-d \-\-degug] [\-h
+\-\-help] [\-k \-\-insecure] list | new [parameters...]
+.INDENT 0.0
+.TP
+.B \-d, \-\-debug
+Displays debug information listing the API responses.
+.UNINDENT
+.INDENT 0.0
+.TP
+.B \-h, \-\-help
+Display usage information.
+.UNINDENT
+.INDENT 0.0
+.TP
+.B \-k, \-\-insecure
+Disables the SSL certificate check.
+.UNINDENT
+.INDENT 0.0
+.TP
+.B list <label>
+Lists the current stored configurations for the given identifier
+<label> in a key:value format which should be easy to decipher.
+.UNINDENT
+.INDENT 0.0
+.TP
+.B new <label> ip=<value> interface=<if_device> [parameters...]
+Creates a new interface group. The required parameters are the IP
+address and the network interface this appies to (e.g. eth0). In
+order to do anything useful, further parameters are required:
+.sp
+.nf
+.ft C
+management= 0 | 1 | 2
+     The service to be managed on the interface
+     ( 0= none, 1=DHCP, 2=DHCP and DNS).
+
+subnet_mask=<value>
+     Apply the given dotted decimal value as the subnet mask.
+
+broadcast_ip=<value>
+     Apply the given dotted decimal value as the
+     broadcast IP address for this subnet.
+
+router_ip=<value>
+     Apply the given dotted decimal value as the
+     default router address for this subnet.
+
+ip_range_low=<value>
+     The lowest value of IP address to allocate via DHCP
+
+ip_range_high=<value>
+     The highest value of IP address to allocate via DHCP
+.ft P
+.fi
+.UNINDENT
+.sp
+Example:
+Configuring DHCP and DNS under a new label called \(aqmaster\(aq:
+.sp
+.nf
+.ft C
+$ maas\-cli maas node\-group\-interfaces new master \e
+    ip=192.168.21.5             \e
+    interface=eth1              \e
+    management=2                \e
+    subnet_mask=255.255.255.0   \e
+    broadcast_ip=192.168.21.255 \e
+    router_ip=192.168.21.1      \e
+    ip_range_low=192.168.21.10  \e
+    ip_range_high=192.168.21.50
+.ft P
+.fi
+.SH TAG
+.INDENT 0.0
+.TP
+.B Usage: maas\-cli <profile> tag read | update\-nodes | rebuild | update |
+nodes | delete
+.UNINDENT
+.INDENT 0.0
+.TP
+.B read <tag_name>
+Returns information on the tag specified by <name>
+.UNINDENT
+.INDENT 0.0
+.TP
+.B \-nodes <tag_name> [add="<system_id>"]
+.TP
+.B [remove="<system_id>"] [nodegroup="<system_id>"]
+Applies or removes the given tag from a list of nodes specified by
+either or both of add="<system_id>" and remove="<system_id>". The
+nodegroup parameter, which restricts the operations to a particular
+nodegroup, is optional, but only the superuser can execute this
+command without it.
+.UNINDENT
+.INDENT 0.0
+.TP
+.B rebuild
+Triggers a rebuild of the tag to node mapping.
+.UNINDENT
+.INDENT 0.0
+.TP
+.B update <tag_name> [name=<value>] | [comment=<value>]
+.TP
+.B |[definition=<value>]
+Updates the tag identified by tag_name. Any or all of name,comment
+and definition may be supplied as parameters. If no parameters are
+supplied, this command returns the current values.
+.UNINDENT
+.INDENT 0.0
+.TP
+.B nodes <tag_name>
+Returns a list of nodes which are associated with the given tag.
+.UNINDENT
+.INDENT 0.0
+.TP
+.B delete <tag_name>
+Deletes the given tag.
+.UNINDENT
+.SH TAGS
+.sp
+Tags are a really useful way of identifying nodes with particular
+characteristics. For more information on how to use them effectively,
+please see \fIdeploy\-tags\fP
+.sp
+Usage: maas\-cli <profile> tag [\-d \-\-degug] [\-h \-\-help] [\-k
+\-\-insecure] list | new
+.INDENT 0.0
+.TP
+.B \-d, \-\-debug
+Displays debug information listing the API responses.
+.UNINDENT
+.INDENT 0.0
+.TP
+.B \-h, \-\-help
+Display usage information.
+.UNINDENT
+.INDENT 0.0
+.TP
+.B \-k, \-\-insecure
+Disables the SSL certificate check.
+.UNINDENT
+.INDENT 0.0
+.TP
+.B list
+Returns a JSON object listing all the current tags known by the MAAS server
+.UNINDENT
+.INDENT 0.0
+.TP
+.B create name=<value> definition=<value> [comment=<value>]
+Creates a new tag with the given name and definition. A comment is
+optional. Names must be unique, obviously \- an error will be
+returned if the given name already exists. The definition is in the form of
+an XPath expression which parses the XML returned by running \fBlshw\fP on the
+node.
+.UNINDENT
+.sp
+Example:
+Adding a tag to all nodes which have an Intel GPU:
+.sp
+.nf
+.ft C
+$ maas\-cli maas tags new name=\(aqintel\-gpu\(aq \e
+    comment=\(aqMachines which have an Intel display driver\(aq \e
+    definition=\(aqcontains(//node[@id="display"]/vendor, "Intel")
+.ft P
+.fi
+.SH UNUSED COMMANDS
+.sp
+Because the \fBmaas\-cli\fP command exposes all of the API, it also lists
+some command options which are not really intended for end users, such
+as the "file" and "boot\-images" options.
+.SH FURTHER DOCUMENTATION
+.sp
+For more documentation of MAAS, please see \fI\%https://maas.ubuntu.com/docs\fP
+.SH AUTHOR
+<nick.veitch@xxxxxxxxxxxxx>
+.SH COPYRIGHT
+2012, Canonical 
+.\" Generated by docutils manpage writer.
+.


Follow ups