summaryrefslogtreecommitdiff
path: root/doc/source/reference/index.rst
blob: 5678d6578f7328e349197e4e145e00f188a731db (plain)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
..
      Licensed under the Apache License, Version 2.0 (the "License"); you may
      not use this file except in compliance with the License. You may obtain
      a copy of the License at

          http://www.apache.org/licenses/LICENSE-2.0

      Unless required by applicable law or agreed to in writing, software
      distributed under the License is distributed on an "AS IS" BASIS, WITHOUT
      WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. See the
      License for the specific language governing permissions and limitations
      under the License.


      Convention for heading levels in Neutron devref:
      =======  Heading 0 (reserved for the title in a document)
      -------  Heading 1
      ~~~~~~~  Heading 2
      +++++++  Heading 3
      '''''''  Heading 4
      (Avoid deeper levels because they do not render well.)

neutronclient Python API
========================

Basic Usage
-----------

First create a client instance using a keystoneauth Session. For more
information on this keystoneauth API, see `Using Sessions`_.

.. _Using Sessions: https://docs.openstack.org/keystoneauth/latest/using-sessions.html

.. code-block:: python

    from keystoneauth1 import identity
    from keystoneauth1 import session
    from neutronclient.v2_0 import client
    username='username'
    password='password'
    project_name='demo'
    project_domain_id='default'
    user_domain_id='default'
    auth_url='http://auth.example.com:5000/v3'
    auth = identity.Password(auth_url=auth_url,
                             username=username,
                             password=password,
                             project_name=project_name,
                             project_domain_id=project_domain_id,
                             user_domain_id=user_domain_id)
    sess = session.Session(auth=auth)
    neutron = client.Client(session=sess)

If you are using Identity v2.0 API (DEPRECATED), create an auth plugin using
the appropriate parameters and `keystoneauth1.identity` will handle Identity
API version discovery. Then you can create a Session and a Neutronclient just
like the previous example.

.. code-block:: python

    auth = identity.Password(auth_url=auth_url,
                             username=username,
                             password=password,
                             project_name=project_name)
    # create a Session and a Neutronclient

Now you can call various methods on the client instance.

.. code-block:: python

    network = {'name': 'mynetwork', 'admin_state_up': True}
    neutron.create_network({'network':network})
    networks = neutron.list_networks(name='mynetwork')
    print networks
    network_id = networks['networks'][0]['id']
    neutron.delete_network(network_id)

Alternatively, you can create a client instance using an auth token
and a service endpoint URL directly.

.. code-block:: python

    from neutronclient.v2_0 import client
    neutron = client.Client(endpoint_url='http://192.168.206.130:9696/',
                            token='d3f9226f27774f338019aa2611112ef6')

You can get ``X-Openstack-Request-Id`` as ``request_ids`` from the result.

.. code-block:: python

    network = {'name': 'mynetwork', 'admin_state_up': True}
    neutron.create_network({'network':network})
    networks = neutron.list_networks(name='mynetwork')
    print networks.request_ids
    # -> ['req-978a0160-7ab0-44f0-8a93-08e9a4e785fa']