File: transition_from_profile.rst

package info (click to toggle)
python-openstacksdk 4.4.0-5
  • links: PTS, VCS
  • area: main
  • in suites: forky, sid, trixie
  • size: 13,352 kB
  • sloc: python: 122,960; sh: 153; makefile: 23
file content (186 lines) | stat: -rw-r--r-- 7,858 bytes parent folder | download | duplicates (4)
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
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
124
125
126
127
128
129
130
131
132
133
134
135
136
137
138
139
140
141
142
143
144
145
146
147
148
149
150
151
152
153
154
155
156
157
158
159
160
161
162
163
164
165
166
167
168
169
170
171
172
173
174
175
176
177
178
179
180
181
182
183
184
185
186
Transition from Profile
=======================

.. note:: This section describes migrating code from a previous interface of
          openstacksdk and can be ignored by people writing new code.

If you have code that currently uses the :class:`~openstack.profile.Profile`
object and/or an ``authenticator`` instance from an object based on
``openstack.auth.base.BaseAuthPlugin``, that code should be updated to use the
:class:`~openstack.config.cloud_region.CloudRegion` object instead.

.. important::

    :class:`~openstack.profile.Profile` is going away. Existing code using it
    should be migrated as soon as possible.

Writing Code that Works with Both
---------------------------------

These examples should all work with both the old and new interface, with one
caveat. With the old interface, the ``CloudConfig`` object comes from the
``os-client-config`` library, and in the new interface that has been moved
into the SDK. In order to write code that works with both the old and new
interfaces, use the following code to import the config namespace:

.. code-block:: python

  try:
      from openstack import config as occ
  except ImportError:
      from os_client_config import config as occ

The examples will assume that the config module has been imported in that
manner.

.. note:: Yes, there is an easier and less verbose way to do all of these.
          These are verbose to handle both the old and new interfaces in the
          same codebase.

Replacing authenticator
-----------------------

There is no direct replacement for ``openstack.auth.base.BaseAuthPlugin``.
``openstacksdk`` uses the `keystoneauth`_ library for authentication
and HTTP interactions. `keystoneauth`_ has `auth plugins`_ that can be used
to control how authentication is done. The ``auth_type`` config parameter
can be set to choose the correct authentication method to be used.

Replacing Profile
-----------------

The right way to replace the use of ``openstack.profile.Profile`` depends
a bit on what you're trying to accomplish. Common patterns are listed below,
but in general the approach is either to pass a cloud name to the
`openstack.connection.Connection` constructor, or to construct a
`openstack.config.cloud_region.CloudRegion` object and pass it to the
constructor.

All of the examples on this page assume that you want to support old and
new interfaces simultaneously. There are easier and less verbose versions
of each that are available if you can just make a clean transition.

Getting a Connection to a named cloud from clouds.yaml
------------------------------------------------------

If you want is to construct a `openstack.connection.Connection` based on
parameters configured in a ``clouds.yaml`` file, or from environment variables:

.. code-block:: python

    import openstack.connection

    conn = connection.from_config(cloud_name='name-of-cloud-you-want')

Getting a Connection from python arguments avoiding clouds.yaml
---------------------------------------------------------------

If, on the other hand, you want to construct a
`openstack.connection.Connection`, but are in a context where reading config
from a clouds.yaml file is undesirable, such as inside of a Service:

* create a `openstack.config.loader.OpenStackConfig` object, telling
  it to not load yaml files. Optionally pass an ``app_name`` and
  ``app_version`` which will be added to user-agent strings.
* get a `openstack.config.cloud_region.CloudRegion` object from it
* get a `openstack.connection.Connection`

.. code-block:: python

    try:
        from openstack import config as occ
    except ImportError:
        from os_client_config import config as occ
    from openstack import connection

    loader = occ.OpenStackConfig(
        load_yaml_files=False,
        app_name='spectacular-app',
        app_version='1.0')
    cloud_region = loader.get_one_cloud(
        region_name='my-awesome-region',
        auth_type='password',
        auth=dict(
            auth_url='https://auth.example.com',
            username='amazing-user',
            user_domain_name='example-domain',
            project_name='astounding-project',
            user_project_name='example-domain',
            password='super-secret-password',
        ))
    conn = connection.from_config(cloud_config=cloud_region)

.. note:: app_name and app_version are completely optional, and auth_type
          defaults to 'password'. They are shown here for clarity as to
          where they should go if they want to be set.

Getting a Connection from python arguments and optionally clouds.yaml
---------------------------------------------------------------------

If you want to make a connection from python arguments and want to allow
one of them to optionally be ``cloud`` to allow selection of a named cloud,
it's essentially the same as the previous example, except without
``load_yaml_files=False``.

.. code-block:: python

    try:
        from openstack import config as occ
    except ImportError:
        from os_client_config import config as occ
    from openstack import connection

    loader = occ.OpenStackConfig(
        app_name='spectacular-app',
        app_version='1.0')
    cloud_region = loader.get_one_cloud(
        region_name='my-awesome-region',
        auth_type='password',
        auth=dict(
            auth_url='https://auth.example.com',
            username='amazing-user',
            user_domain_name='example-domain',
            project_name='astounding-project',
            user_project_name='example-domain',
            password='super-secret-password',
          ))
    conn = connection.from_config(cloud_config=cloud_region)

Parameters to get_one_cloud
---------------------------

The most important things to note are:

* ``auth_type`` specifies which kind of authentication plugin to use. It
  controls how authentication is done, as well as what parameters are required.
* ``auth`` is a dictionary containing the parameters needed by the auth plugin.
  The most common information it needs are user, project, domain, auth_url
  and password.
* The rest of the keyword arguments to
  ``openstack.config.loader.OpenStackConfig.get_one_cloud`` are either
  parameters needed by the `keystoneauth Session`_ object, which control how
  HTTP connections are made, or parameters needed by the
  `keystoneauth Adapter`_ object, which control how services are found in the
  Keystone Catalog.

For `keystoneauth Adapter`_ parameters, since there is one
`openstack.connection.Connection` object but many services, per-service
parameters are formed by using the official ``service_type`` of the service
in question. For instance, to override the endpoint for the ``compute``
service, the parameter ``compute_endpoint_override`` would be used.

``region_name`` in ``openstack.profile.Profile`` was a per-service parameter.
This is no longer a valid concept. An `openstack.connection.Connection` is a
connection to a region of a cloud. If you are in an extreme situation where
you have one service in one region and a different service in a different
region, you must use two different `openstack.connection.Connection` objects.

.. note:: service_type, although a parameter for keystoneauth1.adapter.Adapter,
          is not a valid parameter for get_one_cloud. service_type is the key
          by which services are referred, so saying
          'compute_service_type="henry"' doesn't have any meaning.

.. _keystoneauth: https://docs.openstack.org/keystoneauth/latest/
.. _auth plugins: https://docs.openstack.org/keystoneauth/latest/authentication-plugins.html
.. _keystoneauth Adapter: https://docs.openstack.org/keystoneauth/latest/api/keystoneauth1.html#keystoneauth1.adapter.Adapter
.. _keystoneauth Session: https://docs.openstack.org/keystoneauth/latest/api/keystoneauth1.html#keystoneauth1.session.Session