Merge "nocloud: add configurable meta/user data paths"
This commit is contained in:
commit
96376a514f
@ -26,6 +26,7 @@ _OPT_PATHS = (
|
|||||||
'cloudbaseinit.conf.packet.PacketOptions',
|
'cloudbaseinit.conf.packet.PacketOptions',
|
||||||
'cloudbaseinit.conf.vmwareguestinfo.VMwareGuestInfoConfigOptions',
|
'cloudbaseinit.conf.vmwareguestinfo.VMwareGuestInfoConfigOptions',
|
||||||
'cloudbaseinit.conf.gce.GCEOptions',
|
'cloudbaseinit.conf.gce.GCEOptions',
|
||||||
|
'cloudbaseinit.conf.nocloud.NoCloudOptions',
|
||||||
)
|
)
|
||||||
|
|
||||||
|
|
||||||
|
47
cloudbaseinit/conf/nocloud.py
Normal file
47
cloudbaseinit/conf/nocloud.py
Normal file
@ -0,0 +1,47 @@
|
|||||||
|
# Copyright 2024 Cloudbase Solutions Srl
|
||||||
|
#
|
||||||
|
# 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.
|
||||||
|
|
||||||
|
"""Config options available for the OpenStack metadata service."""
|
||||||
|
|
||||||
|
from oslo_config import cfg
|
||||||
|
|
||||||
|
from cloudbaseinit.conf import base as conf_base
|
||||||
|
|
||||||
|
|
||||||
|
class NoCloudOptions(conf_base.Options):
|
||||||
|
|
||||||
|
"""Config options available for the OpenStack metadata service."""
|
||||||
|
|
||||||
|
def __init__(self, config):
|
||||||
|
super(NoCloudOptions, self).__init__(config, group="nocloud")
|
||||||
|
self._options = [
|
||||||
|
cfg.StrOpt(
|
||||||
|
"metadata_file", default="meta-data",
|
||||||
|
help="The file name where the service looks for"
|
||||||
|
"metadata"),
|
||||||
|
cfg.StrOpt(
|
||||||
|
"userdata_file", default="user-data",
|
||||||
|
help="The file name where the service looks for"
|
||||||
|
"userdata"),
|
||||||
|
]
|
||||||
|
|
||||||
|
def register(self):
|
||||||
|
"""Register the current options to the global ConfigOpts object."""
|
||||||
|
group = cfg.OptGroup(self.group_name, title='NoCloud Options')
|
||||||
|
self._config.register_group(group)
|
||||||
|
self._config.register_opts(self._options, group=group)
|
||||||
|
|
||||||
|
def list(self):
|
||||||
|
"""Return a list which contains all the available options."""
|
||||||
|
return self._options
|
@ -32,10 +32,12 @@ CD_LOCATIONS = constant.CD_LOCATIONS
|
|||||||
|
|
||||||
class BaseConfigDriveService(base.BaseMetadataService):
|
class BaseConfigDriveService(base.BaseMetadataService):
|
||||||
|
|
||||||
def __init__(self, drive_label, metadata_file):
|
def __init__(self, drive_label, metadata_file,
|
||||||
|
userdata_file='user-data'):
|
||||||
super(BaseConfigDriveService, self).__init__()
|
super(BaseConfigDriveService, self).__init__()
|
||||||
self._drive_label = drive_label
|
self._drive_label = drive_label
|
||||||
self._metadata_file = metadata_file
|
self._metadata_file = metadata_file
|
||||||
|
self._userdata_file = userdata_file
|
||||||
self._metadata_path = None
|
self._metadata_path = None
|
||||||
self._searched_types = set()
|
self._searched_types = set()
|
||||||
self._searched_locations = set()
|
self._searched_locations = set()
|
||||||
|
@ -541,17 +541,19 @@ class NoCloudConfigDriveService(baseconfigdrive.BaseConfigDriveService):
|
|||||||
|
|
||||||
def __init__(self):
|
def __init__(self):
|
||||||
super(NoCloudConfigDriveService, self).__init__(
|
super(NoCloudConfigDriveService, self).__init__(
|
||||||
'cidata', 'meta-data')
|
'cidata', CONF.nocloud.metadata_file,
|
||||||
|
CONF.nocloud.userdata_file)
|
||||||
self._meta_data = {}
|
self._meta_data = {}
|
||||||
|
|
||||||
def get_user_data(self):
|
def get_user_data(self):
|
||||||
return self._get_cache_data("user-data")
|
return self._get_cache_data(self._userdata_file)
|
||||||
|
|
||||||
def _get_meta_data(self):
|
def _get_meta_data(self):
|
||||||
if self._meta_data:
|
if self._meta_data:
|
||||||
return self._meta_data
|
return self._meta_data
|
||||||
|
|
||||||
raw_meta_data = self._get_cache_data("meta-data", decode=True)
|
raw_meta_data = self._get_cache_data(
|
||||||
|
self._metadata_file, decode=True)
|
||||||
try:
|
try:
|
||||||
self._meta_data = (
|
self._meta_data = (
|
||||||
serialization.parse_json_yaml(raw_meta_data))
|
serialization.parse_json_yaml(raw_meta_data))
|
||||||
|
@ -128,13 +128,15 @@ similar to the EC2 metadata in terms of how the metadata files are named and str
|
|||||||
|
|
||||||
The metadata is provided on a config-drive (vfat or iso9660) with the label cidata or CIDATA.
|
The metadata is provided on a config-drive (vfat or iso9660) with the label cidata or CIDATA.
|
||||||
|
|
||||||
The folder structure for NoCloud is:
|
The default folder structure for NoCloud is:
|
||||||
|
|
||||||
* /user-data
|
* /user-data
|
||||||
* /meta-data
|
* /meta-data
|
||||||
|
|
||||||
The user-data and meta-data files respect the EC2 metadata service format.
|
The user-data and meta-data files respect the EC2 metadata service format.
|
||||||
|
|
||||||
|
The names of the meta-data and user-data files can be configured.
|
||||||
|
|
||||||
Capabilities:
|
Capabilities:
|
||||||
|
|
||||||
* instance id
|
* instance id
|
||||||
@ -153,6 +155,11 @@ Config options for `config_drive` section:
|
|||||||
* types (list: ["vfat", "iso"])
|
* types (list: ["vfat", "iso"])
|
||||||
* locations (list: ["cdrom", "hdd", "partition"])
|
* locations (list: ["cdrom", "hdd", "partition"])
|
||||||
|
|
||||||
|
Config options for `nocloud` section:
|
||||||
|
|
||||||
|
* metadata_file (string: "meta-data")
|
||||||
|
* userdata_file (string: "user-data")
|
||||||
|
|
||||||
Example metadata:
|
Example metadata:
|
||||||
|
|
||||||
.. code-block:: yaml
|
.. code-block:: yaml
|
||||||
|
Loading…
x
Reference in New Issue
Block a user