Skip to content

Virtual machine password handling in ConfigDrive #501

New issue

Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.

By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.

Already on GitHub? Sign in to your account

Open
wants to merge 1 commit into
base: 4.20
Choose a base branch
from
Open
Changes from all commits
Commits
File filter

Filter by extension

Filter by extension

Conversations
Failed to load comments.
Loading
Jump to
Jump to file
Failed to load files.
Loading
Diff view
Diff view
25 changes: 24 additions & 1 deletion source/adminguide/api.rst
Original file line number Diff line number Diff line change
Expand Up @@ -12,7 +12,7 @@
KIND, either express or implied. See the License for the
specific language governing permissions and limitations
under the License.


The CloudStack API is a low level API that has been used to implement
the CloudStack web UIs. It is also a good basis for implementing other
Expand Down Expand Up @@ -177,6 +177,29 @@ VMdata - a list of String arrays representing [“directory”, “filename”,

- default: config-2

Virtual machine password via ConfigDrive
~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~

The ConfigDrive metadata provider delivers the virtual machine password simultaneously in two variants, leaving which one to use to the user discretion:

1. As the ``<mountdir>/cloudstack/password/vm_password.txt`` file.

This file is intended to be used by an external script that runs inside the virtual machine every boot, and changes the password if needed.
The init-script that implements this functionality can be found in the `Cloudstack source <https://github.com/apache/cloudstack/blob/main/setup/bindir/cloud-set-guest-password-configdrive.in>`_.

.. note::
The ``vm_password.txt`` file is not compatible with cloud-init password module, so the cloud-init will ignore it.
It is up to Cloudstack administrator to include the script processing it in the virtual machines and/or their templates.

2. As the ``<mountdir>/openstack/latest/vendor_data.json``.
This is a standard password location supported by cloud-init's both ConfigDrive datasource and the password module.
Therefore, this variant allows using cloud-init as the only tool for provisioning a virtual machine, without using external scripts.

.. warning::
Cloud-init password module is designed to only perform the initial virtual machine password setup.
It will ignore the changes in ``vendor_data.json`` after the first run. Therefore, resetting the virtual machine password from Cloudstack will not work with this variant.


For more detailed information about the Config Drive implementation refer to
the `Wiki Article
<https://cwiki.apache.org/confluence/display/CLOUDSTACK/Using+ConfigDrive+for+Metadata%2C+Userdata+and+Password#:~:text=CLOUDSTACK%2D9813%20%2D%20(),%2Dkeys)%20and%20password%20files>`_