Begin copying wiki command list here

* Sort by command objects
* Drop the comparison to the project CLIs
* Minor updates to command help to match docs

Initially include the cross-API commands to establish the structure and format.

Change-Id: I77a7b3c89e088b66aa62941e29ce0b65b532285b
This commit is contained in:
Dean Troyer 2014-11-17 16:42:30 -06:00
parent ae00019c64
commit 254910d3ce
10 changed files with 250 additions and 18 deletions

View File

@ -0,0 +1,9 @@
============
Command List
============
.. toctree::
:glob:
:maxdepth: 2
command-objects/*

View File

@ -0,0 +1,41 @@
=========
extension
=========
Many OpenStack server APIs include API extensions that enable
additional functionality.
extension list
--------------
List API extensions
.. program:: extension list
.. code:: bash
os extension list
[--compute]
[--identity]
[--network]
[--volume]
[--long]
.. option:: --compute
List extensions for the Compute API
.. option:: --identity
List extensions for the Identity API
.. option:: --network
List extensions for the Network API
.. option:: --volume
List extensions for the Volume API
.. option:: --long
List additional fields in output

View File

@ -0,0 +1,28 @@
======
limits
======
The Compute and Volume APIs have resource usage limits.
limits show
-----------
Show compute and volume limits
.. program:: limits show
.. code:: bash
os limits show
--absolute [--reserved] | --rate
.. option:: --absolute
Show absolute limits
.. option:: --rate
Show rate limits
.. option:: --reserved
Include reservations count [only valid with :option:`--absolute`]

View File

@ -0,0 +1,157 @@
=====
quota
=====
Resource quotas appear in multiple APIs, OpenStackClient presents them as a single object with multiple properties.
quota set
---------
Set quotas for project
.. program:: quota set
.. code:: bash
os quota set
# Compute settings
[--cores <num-cores>]
[--fixed-ips <num-fixed-ips>]
[--floating-ips <num-floating-ips>]
[--injected-file-size <injected-file-bytes>]
[--injected-files <num-injected-files>]
[--instances <num-instances>]
[--key-pairs <num-key-pairs>]
[--properties <num-properties>]
[--ram <ram-mb>]
# Volume settings
[--gigabytes <new-gigabytes>]
[--snapshots <new-snapshots>]
[--volumes <new-volumes>]
<project>
Set quotas for class
.. code:: bash
os quota set
--class
# Compute settings
[--cores <num-cores>]
[--fixed-ips <num-fixed-ips>]
[--floating-ips <num-floating-ips>]
[--injected-file-size <injected-file-bytes>]
[--injected-files <num-injected-files>]
[--instances <num-instances>]
[--key-pairs <num-key-pairs>]
[--properties <num-properties>]
[--ram <ram-mb>]
# Volume settings
[--gigabytes <new-gigabytes>]
[--snapshots <new-snapshots>]
[--volumes <new-volumes>]
<class>
.. option:: --class
Set quotas for ``<class>``
.. option:: --properties <new-properties>
New value for the properties quota
.. option:: --ram <new-ram>
New value for the ram quota
.. option:: --secgroup-rules <new-secgroup-rules>
New value for the secgroup-rules quota
.. option:: --instances <new-instances>
New value for the instances quota
.. option:: --key-pairs <new-key-pairs>
New value for the key-pairs quota
.. option:: --fixed-ips <new-fixed-ips>
New value for the fixed-ips quota
.. option:: --secgroups <new-secgroups>
New value for the secgroups quota
.. option:: --injected-file-size <new-injected-file-size>
New value for the injected-file-size quota
.. option:: --floating-ips <new-floating-ips>
New value for the floating-ips quota
.. option:: --injected-files <new-injected-files>
New value for the injected-files quota
.. option:: --cores <new-cores>
New value for the cores quota
.. option:: --injected-path-size <new-injected-path-size>
New value for the injected-path-size quota
.. option:: --gigabytes <new-gigabytes>
New value for the gigabytes quota
.. option:: --volumes <new-volumes>
New value for the volumes quota
.. option:: --snapshots <new-snapshots>
New value for the snapshots quota
quota show
----------
Show quotas for project
.. program:: quota show
.. code:: bash
os quota show
[--default]
<project>
.. option:: --default
Show default quotas for :ref:`\<project\> <quota_show-project>`
.. _quota_show-project:
.. describe:: <project>
Show quotas for class
.. code:: bash
os quota show
--class
<class>
.. option:: --class
Show quotas for :ref:`\<class\> <quota_show-class>`
.. _quota_show-class:
.. describe:: <class>
Class to show

View File

@ -1,8 +1,4 @@
======== =================
Commands
========
Command Structure Command Structure
================= =================
@ -83,7 +79,7 @@ referring to both Compute and Volume quotas.
* ``credential``: Identity - specific to identity providers * ``credential``: Identity - specific to identity providers
* ``domain``: Identity - a grouping of projects * ``domain``: Identity - a grouping of projects
* ``endpoint``: Identity - the base URL used to contact a specific service * ``endpoint``: Identity - the base URL used to contact a specific service
* ``extension``: Compute, Identity, Volume - additional APIs available * ``extension``: (**Compute**, **Identity**, **Volume**) OpenStack server API extensions
* ``flavor``: Compute - pre-defined configurations of servers: ram, root disk, etc * ``flavor``: Compute - pre-defined configurations of servers: ram, root disk, etc
* ``group``: Identity - a grouping of users * ``group``: Identity - a grouping of users
* ``host``: Compute - the physical computer running a hypervisor * ``host``: Compute - the physical computer running a hypervisor
@ -93,13 +89,13 @@ referring to both Compute and Volume quotas.
* ``ip fixed``: Compute, Network - an internal IP address assigned to a server * ``ip fixed``: Compute, Network - an internal IP address assigned to a server
* ``ip floating``: Compute, Network - a public IP address that can be mapped to a server * ``ip floating``: Compute, Network - a public IP address that can be mapped to a server
* ``keypair``: Compute - an SSH public key * ``keypair``: Compute - an SSH public key
* ``limits``: Compute, Volume - resource usage limits * ``limits``: (**Compute**, **Volume**) resource usage limits
* ``module``: internal - installed Python modules in the OSC process * ``module``: internal - installed Python modules in the OSC process
* ``network``: Network - a virtual network for connecting servers and other resources * ``network``: Network - a virtual network for connecting servers and other resources
* ``object``: Object Store - a single file in the Object Store * ``object``: Object Store - a single file in the Object Store
* ``policy``: Identity - determines authorization * ``policy``: Identity - determines authorization
* ``project``: Identity - the owner of a group of resources * ``project``: Identity - the owner of a group of resources
* ``quota``: Compute, Volume - limit on resource usage * ``quota``: (**Compute**, **Volume**) resource usage restrictions
* ``request token``: Identity - temporary OAuth-based token * ``request token``: Identity - temporary OAuth-based token
* ``role``: Identity - a policy object used to determine authorization * ``role``: Identity - a policy object used to determine authorization
* ``security group``: Compute, Network - groups of network access rules * ``security group``: Compute, Network - groups of network access rules
@ -149,7 +145,7 @@ Those actions with an opposite action are noted in parens if applicable.
Implementation Implementation
============== --------------
The command structure is designed to support seamless addition of plugin The command structure is designed to support seamless addition of plugin
command modules via ``setuptools`` entry points. The plugin commands must command modules via ``setuptools`` entry points. The plugin commands must

View File

@ -12,6 +12,7 @@ Contents:
:maxdepth: 1 :maxdepth: 1
releases releases
command-list
commands commands
plugins plugins
authentication authentication

View File

@ -26,7 +26,7 @@ Release Notes
* add ``object create`` and ``object delete`` commands * add ``object create`` and ``object delete`` commands
* add initial support for global ``--timing`` options (similar to nova CLI) * add initial support for global ``--timing`` options (similar to nova CLI)
* complete Python 3 compatibility * complete Python 3 compatibility
* fix ``server resize` command * fix ``server resize`` command
* add authentication via ``--os-trust-id`` for Identity v3 * add authentication via ``--os-trust-id`` for Identity v3
* Add initial support for Network API, ``network create|delete|list|show`` * Add initial support for Network API, ``network create|delete|list|show``

View File

@ -24,7 +24,7 @@ from openstackclient.common import utils
class ListExtension(lister.Lister): class ListExtension(lister.Lister):
"""List extension command""" """List API extensions"""
log = logging.getLogger(__name__ + '.ListExtension') log = logging.getLogger(__name__ + '.ListExtension')
@ -40,11 +40,6 @@ class ListExtension(lister.Lister):
action='store_true', action='store_true',
default=False, default=False,
help='List extensions for the Identity API') help='List extensions for the Identity API')
parser.add_argument(
'--long',
action='store_true',
default=False,
help='List additional fields in output')
parser.add_argument( parser.add_argument(
'--network', '--network',
action='store_true', action='store_true',
@ -55,6 +50,11 @@ class ListExtension(lister.Lister):
action='store_true', action='store_true',
default=False, default=False,
help='List extensions for the Volume API') help='List extensions for the Volume API')
parser.add_argument(
'--long',
action='store_true',
default=False,
help='List additional fields in output')
return parser return parser
def take_action(self, parsed_args): def take_action(self, parsed_args):

View File

@ -72,7 +72,7 @@ class SetQuota(command.Command):
COMPUTE_QUOTAS.items(), VOLUME_QUOTAS.items()): COMPUTE_QUOTAS.items(), VOLUME_QUOTAS.items()):
parser.add_argument( parser.add_argument(
'--%s' % v, '--%s' % v,
metavar='<new-%s>' % v, metavar='<%s>' % v,
type=int, type=int,
help='New value for the %s quota' % v, help='New value for the %s quota' % v,
) )

View File

@ -28,7 +28,7 @@ from openstackclient.identity import common
class CreateEndpoint(show.ShowOne): class CreateEndpoint(show.ShowOne):
"""Create endpoint command""" """Create endpoint"""
log = logging.getLogger(__name__ + '.CreateEndpoint') log = logging.getLogger(__name__ + '.CreateEndpoint')