2014-04-03 16:49:31 +00:00
|
|
|
.. _api_v1:
|
|
|
|
|
|
|
|
=======================
|
|
|
|
ironicclient Python API
|
|
|
|
=======================
|
|
|
|
|
|
|
|
The ironicclient python API lets you access ironic, the OpenStack
|
|
|
|
Bare Metal Provisioning Service.
|
|
|
|
|
2015-09-30 23:25:23 +00:00
|
|
|
For example, to manipulate nodes, you interact with an
|
2021-10-18 13:38:42 +00:00
|
|
|
:py:class:`ironicclient.v1.node.Node` object.
|
2015-09-30 23:25:23 +00:00
|
|
|
You obtain access to nodes via attributes of the
|
2021-10-18 13:38:42 +00:00
|
|
|
:py:class:`ironicclient.v1.client.Client` object.
|
2014-04-03 16:49:31 +00:00
|
|
|
|
|
|
|
Usage
|
|
|
|
=====
|
|
|
|
|
|
|
|
Get a Client object
|
|
|
|
-------------------
|
2021-10-18 13:38:42 +00:00
|
|
|
First, create an :py:class:`ironicclient.v1.client.Client` instance by passing
|
|
|
|
your credentials to :py:meth:`ironicclient.client.get_client()`. By default,
|
|
|
|
the Bare Metal Provisioning system is configured so that only administrators
|
2014-04-03 16:49:31 +00:00
|
|
|
(users with 'admin' role) have access.
|
|
|
|
|
2016-07-20 10:26:57 +00:00
|
|
|
.. note::
|
2021-10-18 13:38:42 +00:00
|
|
|
|
|
|
|
Explicit instantiation of :py:class:`ironicclient.v1.client.Client` may
|
|
|
|
cause errors since it doesn't verify provided arguments, using
|
|
|
|
:py:meth:`ironicclient.client.get_client()` is preferred way to get client
|
|
|
|
object.
|
2016-07-20 10:26:57 +00:00
|
|
|
|
2014-04-03 16:49:31 +00:00
|
|
|
There are two different sets of credentials that can be used::
|
|
|
|
|
|
|
|
* ironic endpoint and auth token
|
|
|
|
* Identity Service (keystone) credentials
|
|
|
|
|
|
|
|
Using ironic endpoint and auth token
|
2016-07-20 10:26:57 +00:00
|
|
|
....................................
|
2014-04-03 16:49:31 +00:00
|
|
|
|
|
|
|
An auth token and the ironic endpoint can be used to authenticate::
|
|
|
|
|
|
|
|
* os_auth_token: authentication token (from Identity Service)
|
|
|
|
* ironic_url: ironic API endpoint, eg http://ironic.example.org:6385/v1
|
|
|
|
|
|
|
|
To create the client, you can use the API like so::
|
|
|
|
|
|
|
|
>>> from ironicclient import client
|
|
|
|
>>>
|
2016-07-12 13:34:05 +00:00
|
|
|
>>> kwargs = {'os_auth_token': '3bcc3d3a03f44e3d8377f9247b0ad155',
|
2014-04-03 16:49:31 +00:00
|
|
|
>>> 'ironic_url': 'http://ironic.example.org:6385/'}
|
|
|
|
>>> ironic = client.get_client(1, **kwargs)
|
|
|
|
|
|
|
|
Using Identity Service (keystone) credentials
|
|
|
|
.............................................
|
|
|
|
|
|
|
|
These Identity Service credentials can be used to authenticate::
|
|
|
|
|
|
|
|
* os_username: name of user
|
|
|
|
* os_password: user's password
|
|
|
|
* os_auth_url: Identity Service endpoint for authorization
|
|
|
|
* insecure: Boolean. If True, does not perform X.509 certificate
|
|
|
|
validation when establishing SSL connection with identity
|
|
|
|
service. default: False (optional)
|
|
|
|
* os_tenant_{name|id}: name or ID of tenant
|
|
|
|
|
2018-02-09 03:49:12 +00:00
|
|
|
Also the following parameters are required when using the Identity API v3::
|
|
|
|
|
|
|
|
* os_user_domain_name: name of a domain the user belongs to,
|
|
|
|
usually 'default'
|
|
|
|
* os_project_domain_name: name of a domain the project belongs to,
|
|
|
|
usually 'default'
|
|
|
|
|
2014-04-03 16:49:31 +00:00
|
|
|
To create a client, you can use the API like so::
|
|
|
|
|
|
|
|
>>> from ironicclient import client
|
|
|
|
>>>
|
2015-02-13 11:25:58 +00:00
|
|
|
>>> kwargs = {'os_username': 'name',
|
2014-04-03 16:49:31 +00:00
|
|
|
>>> 'os_password': 'password',
|
|
|
|
>>> 'os_auth_url': 'http://keystone.example.org:5000/',
|
2017-01-13 16:07:04 +00:00
|
|
|
>>> 'os_project_name': 'project'}
|
2014-04-03 16:49:31 +00:00
|
|
|
>>> ironic = client.get_client(1, **kwargs)
|
|
|
|
|
|
|
|
Perform ironic operations
|
|
|
|
-------------------------
|
|
|
|
|
2021-10-18 13:38:42 +00:00
|
|
|
Once you have an :py:class:`ironicclient.v1.client.Client`, you can perform
|
|
|
|
various tasks::
|
2014-04-03 16:49:31 +00:00
|
|
|
|
|
|
|
>>> ironic.driver.list() # list of drivers
|
|
|
|
>>> ironic.node.list() # list of nodes
|
|
|
|
>>> ironic.node.get(node_uuid) # information about a particular node
|
|
|
|
|
2021-10-18 13:38:42 +00:00
|
|
|
When the Client needs to propagate an exception, it will usually raise an
|
|
|
|
instance subclassed from
|
|
|
|
:py:class:`ironicclient.common.apiclient.exceptions.ClientException`.
|
2014-04-03 16:49:31 +00:00
|
|
|
|
|
|
|
Refer to the modules themselves, for more details.
|
|
|
|
|
|
|
|
ironicclient Modules
|
|
|
|
====================
|
|
|
|
|
2018-03-19 08:00:25 +00:00
|
|
|
* :ref:`modindex`
|