OXIESEC PANEL
- Current Dir:
/
/
snap
/
core
/
17200
/
usr
/
lib
/
python3
/
dist-packages
/
cloudinit
Server IP: 139.59.38.164
Upload:
Create Dir:
Name
Size
Modified
Perms
📁
..
-
02/18/2024 07:58:21 PM
rwxr-xr-x
📄
__init__.py
0 bytes
03/19/2021 02:37:22 PM
rw-r--r--
📁
__pycache__
-
02/18/2024 07:58:21 PM
rwxr-xr-x
📁
analyze
-
02/18/2024 07:58:20 PM
rwxr-xr-x
📄
apport.py
4.08 KB
03/19/2021 02:37:22 PM
rw-r--r--
📄
atomic_helper.py
1.33 KB
03/19/2021 02:37:22 PM
rw-r--r--
📄
cloud.py
3.15 KB
03/19/2021 02:37:22 PM
rw-r--r--
📁
cmd
-
02/18/2024 07:58:21 PM
rwxr-xr-x
📁
config
-
02/18/2024 07:58:21 PM
rwxr-xr-x
📄
cs_utils.py
3 KB
03/19/2021 02:37:22 PM
rw-r--r--
📄
dhclient_hook.py
2.48 KB
03/19/2021 02:37:22 PM
rw-r--r--
📁
distros
-
02/18/2024 07:58:21 PM
rwxr-xr-x
📄
dmi.py
5.63 KB
03/19/2021 02:37:22 PM
rw-r--r--
📄
ec2_utils.py
8.75 KB
03/19/2021 02:37:22 PM
rw-r--r--
📄
event.py
450 bytes
03/19/2021 02:37:22 PM
rw-r--r--
📄
features.py
2.03 KB
03/19/2021 02:37:22 PM
rw-r--r--
📁
filters
-
02/18/2024 07:58:21 PM
rwxr-xr-x
📄
gpg.py
3.35 KB
03/19/2021 02:37:22 PM
rw-r--r--
📁
handlers
-
02/18/2024 07:58:21 PM
rwxr-xr-x
📄
helpers.py
15.71 KB
04/25/2023 09:28:10 PM
rw-r--r--
📄
importer.py
1.38 KB
03/19/2021 02:37:22 PM
rw-r--r--
📄
log.py
4.33 KB
03/19/2021 02:37:22 PM
rw-r--r--
📁
mergers
-
02/18/2024 07:58:21 PM
rwxr-xr-x
📁
net
-
02/18/2024 07:58:21 PM
rwxr-xr-x
📄
netinfo.py
18.12 KB
03/19/2021 02:37:22 PM
rw-r--r--
📄
patcher.py
1.23 KB
03/19/2021 02:37:22 PM
rw-r--r--
📄
persistence.py
2.54 KB
03/19/2021 02:37:22 PM
rw-r--r--
📄
registry.py
1.01 KB
03/19/2021 02:37:22 PM
rw-r--r--
📁
reporting
-
02/18/2024 07:58:21 PM
rwxr-xr-x
📄
safeyaml.py
1.19 KB
03/19/2021 02:37:22 PM
rw-r--r--
📄
serial.py
1.15 KB
03/19/2021 02:37:22 PM
rw-r--r--
📄
settings.py
1.89 KB
03/19/2021 02:37:22 PM
rw-r--r--
📄
signal_handler.py
1.8 KB
03/19/2021 02:37:22 PM
rw-r--r--
📄
simpletable.py
1.85 KB
03/19/2021 02:37:22 PM
rw-r--r--
📁
sources
-
02/18/2024 07:58:21 PM
rwxr-xr-x
📄
ssh_util.py
13.37 KB
03/19/2021 02:37:22 PM
rw-r--r--
📄
stages.py
38.67 KB
04/25/2023 09:28:10 PM
rw-r--r--
📄
subp.py
13.06 KB
03/19/2021 02:37:22 PM
rw-r--r--
📄
temp_utils.py
2.87 KB
03/19/2021 02:37:22 PM
rw-r--r--
📄
templater.py
6.4 KB
03/19/2021 02:37:22 PM
rw-r--r--
📄
type_utils.py
726 bytes
03/19/2021 02:37:22 PM
rw-r--r--
📄
url_helper.py
21.74 KB
03/19/2021 02:37:22 PM
rw-r--r--
📄
user_data.py
14.3 KB
03/19/2021 02:37:22 PM
rw-r--r--
📄
util.py
78.86 KB
03/19/2021 02:37:22 PM
rw-r--r--
📄
version.py
599 bytes
04/25/2023 09:28:48 PM
rw-r--r--
📄
warnings.py
3.83 KB
03/19/2021 02:37:22 PM
rw-r--r--
Editing: ec2_utils.py
Close
# Copyright (C) 2012 Yahoo! Inc. # Copyright (C) 2014 Amazon.com, Inc. or its affiliates. # # Author: Joshua Harlow <harlowja@yahoo-inc.com> # Author: Andrew Jorgensen <ajorgens@amazon.com> # # This file is part of cloud-init. See LICENSE file for license information. import functools import json from cloudinit import log as logging from cloudinit import url_helper from cloudinit import util LOG = logging.getLogger(__name__) SKIP_USERDATA_CODES = frozenset([url_helper.NOT_FOUND]) class MetadataLeafDecoder(object): """Decodes a leaf blob into something meaningful.""" def _maybe_json_object(self, text): if not text: return False text = text.strip() if text.startswith("{") and text.endswith("}"): return True return False def __call__(self, field, blob): if not blob: return '' try: blob = util.decode_binary(blob) except UnicodeDecodeError: return blob if self._maybe_json_object(blob): try: # Assume it's json, unless it fails parsing... return json.loads(blob) except (ValueError, TypeError) as e: LOG.warning("Field %s looked like a json object, but it" " was not: %s", field, e) if blob.find("\n") != -1: return blob.splitlines() return blob # See: http://docs.aws.amazon.com/AWSEC2/latest/UserGuide/ # ec2-instance-metadata.html class MetadataMaterializer(object): def __init__(self, blob, base_url, caller, leaf_decoder=None): self._blob = blob self._md = None self._base_url = base_url self._caller = caller if leaf_decoder is None: self._leaf_decoder = MetadataLeafDecoder() else: self._leaf_decoder = leaf_decoder def _parse(self, blob): leaves = {} children = [] blob = util.decode_binary(blob) if not blob: return (leaves, children) def has_children(item): if item.endswith("/"): return True else: return False def get_name(item): if item.endswith("/"): return item.rstrip("/") return item for field in blob.splitlines(): field = field.strip() field_name = get_name(field) if not field or not field_name: continue # Don't materialize credentials if field_name == 'security-credentials': continue if has_children(field): if field_name not in children: children.append(field_name) else: contents = field.split("=", 1) resource = field_name if len(contents) > 1: # What a PITA... (ident, sub_contents) = contents ident = util.safe_int(ident) if ident is not None: resource = "%s/openssh-key" % (ident) field_name = sub_contents leaves[field_name] = resource return (leaves, children) def materialize(self): if self._md is not None: return self._md self._md = self._materialize(self._blob, self._base_url) return self._md def _materialize(self, blob, base_url): (leaves, children) = self._parse(blob) child_contents = {} for c in children: child_url = url_helper.combine_url(base_url, c) if not child_url.endswith("/"): child_url += "/" child_blob = self._caller(child_url) child_contents[c] = self._materialize(child_blob, child_url) leaf_contents = {} for (field, resource) in leaves.items(): leaf_url = url_helper.combine_url(base_url, resource) leaf_blob = self._caller(leaf_url) leaf_contents[field] = self._leaf_decoder(field, leaf_blob) joined = {} joined.update(child_contents) for field in leaf_contents.keys(): if field in joined: LOG.warning("Duplicate key found in results from %s", base_url) else: joined[field] = leaf_contents[field] return joined def skip_retry_on_codes(status_codes, _request_args, cause): """Returns False if cause.code is in status_codes.""" return cause.code not in status_codes def get_instance_userdata(api_version='latest', metadata_address='http://169.254.169.254', ssl_details=None, timeout=5, retries=5, headers_cb=None, headers_redact=None, exception_cb=None): ud_url = url_helper.combine_url(metadata_address, api_version) ud_url = url_helper.combine_url(ud_url, 'user-data') user_data = '' try: if not exception_cb: # It is ok for userdata to not exist (thats why we are stopping if # NOT_FOUND occurs) and just in that case returning an empty # string. exception_cb = functools.partial(skip_retry_on_codes, SKIP_USERDATA_CODES) response = url_helper.read_file_or_url( ud_url, ssl_details=ssl_details, timeout=timeout, retries=retries, exception_cb=exception_cb, headers_cb=headers_cb, headers_redact=headers_redact) user_data = response.contents except url_helper.UrlError as e: if e.code not in SKIP_USERDATA_CODES: util.logexc(LOG, "Failed fetching userdata from url %s", ud_url) except Exception: util.logexc(LOG, "Failed fetching userdata from url %s", ud_url) return user_data def _get_instance_metadata(tree, api_version='latest', metadata_address='http://169.254.169.254', ssl_details=None, timeout=5, retries=5, leaf_decoder=None, headers_cb=None, headers_redact=None, exception_cb=None): md_url = url_helper.combine_url(metadata_address, api_version, tree) caller = functools.partial( url_helper.read_file_or_url, ssl_details=ssl_details, timeout=timeout, retries=retries, headers_cb=headers_cb, headers_redact=headers_redact, exception_cb=exception_cb) def mcaller(url): return caller(url).contents try: response = caller(md_url) materializer = MetadataMaterializer(response.contents, md_url, mcaller, leaf_decoder=leaf_decoder) md = materializer.materialize() if not isinstance(md, (dict)): md = {} return md except Exception: util.logexc(LOG, "Failed fetching %s from url %s", tree, md_url) return {} def get_instance_metadata(api_version='latest', metadata_address='http://169.254.169.254', ssl_details=None, timeout=5, retries=5, leaf_decoder=None, headers_cb=None, headers_redact=None, exception_cb=None): # Note, 'meta-data' explicitly has trailing /. # this is required for CloudStack (LP: #1356855) return _get_instance_metadata(tree='meta-data/', api_version=api_version, metadata_address=metadata_address, ssl_details=ssl_details, timeout=timeout, retries=retries, leaf_decoder=leaf_decoder, headers_redact=headers_redact, headers_cb=headers_cb, exception_cb=exception_cb) def get_instance_identity(api_version='latest', metadata_address='http://169.254.169.254', ssl_details=None, timeout=5, retries=5, leaf_decoder=None, headers_cb=None, headers_redact=None, exception_cb=None): return _get_instance_metadata(tree='dynamic/instance-identity', api_version=api_version, metadata_address=metadata_address, ssl_details=ssl_details, timeout=timeout, retries=retries, leaf_decoder=leaf_decoder, headers_redact=headers_redact, headers_cb=headers_cb, exception_cb=exception_cb) # vi: ts=4 expandtab