File: 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 (105 lines) | stat: -rw-r--r-- 2,950 bytes parent folder | download | duplicates (3)
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
..
  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.

=================
Managing Profiles
=================

A **profile type**  can be treated as the meta-type of a `Profile` object. A
registry of profile types is built when the Cluster service starts. When
creating a `Profile` object, you will indicate the profile type used in its
`spec` property.


List Profiles
~~~~~~~~~~~~~

To examine the list of profiles:

.. literalinclude:: ../../examples/clustering/profile.py
   :pyobject: list_profiles

When listing profiles, you can specify the sorting option using the ``sort``
parameter and you can do pagination using the ``limit`` and ``marker``
parameters.

Full example: `manage profile`_


Create Profile
~~~~~~~~~~~~~~

When creating a profile, you will provide a dictionary with keys and values
specified according to the profile type referenced.

.. literalinclude:: ../../examples/clustering/profile.py
   :pyobject: create_profile

Optionally, you can specify a ``metadata`` keyword argument that contains some
key-value pairs to be associated with the profile.

Full example: `manage profile`_


Find Profile
~~~~~~~~~~~~

To find a profile based on its name or ID:

.. literalinclude:: ../../examples/clustering/profile.py
   :pyobject: find_profile

The Cluster service doesn't allow updating the ``spec`` of a profile. The only
way to achieve that is to create a new profile.

Full example: `manage profile`_


Get Profile
~~~~~~~~~~~

To get a profile based on its name or ID:

.. literalinclude:: ../../examples/clustering/profile.py
   :pyobject: get_profile

Full example: `manage profile`_


Update Profile
~~~~~~~~~~~~~~

After a profile is created, most of its properties are immutable. Still, you
can update a profile's ``name`` and/or ``metadata``.

.. literalinclude:: ../../examples/clustering/profile.py
   :pyobject: update_profile

The Cluster service doesn't allow updating the ``spec`` of a profile. The only
way to achieve that is to create a new profile.

Full example: `manage profile`_


Delete Profile
~~~~~~~~~~~~~~

A profile can be deleted after creation, provided that it is not referenced
by any active clusters or nodes. If you attempt to delete a profile that is
still in use, you will get an error message.

.. literalinclude:: ../../examples/clustering/profile.py
   :pyobject: delete_profile


.. _manage profile: https://opendev.org/openstack/openstacksdk/src/branch/master/examples/clustering/profile.py