Linux webserver 6.8.0-49-generic #49~22.04.1-Ubuntu SMP PREEMPT_DYNAMIC Wed Nov 6 17:42:15 UTC 2 x86_64
Apache/2.4.52 (Ubuntu)
Server IP : 192.168.1.1 & Your IP : 3.149.24.115
Domains :
Cant Read [ /etc/named.conf ]
User : www-data
Terminal
Auto Root
Create File
Create Folder
Localroot Suggester
Backdoor Destroyer
Readme
/
usr /
lib /
python3 /
dist-packages /
cloudinit /
sources /
Delete
Unzip
Name
Size
Permission
Date
Action
__pycache__
[ DIR ]
drwxr-xr-x
2024-09-18 19:49
azure
[ DIR ]
drwxr-xr-x
2024-09-18 19:49
helpers
[ DIR ]
drwxr-xr-x
2024-09-18 19:49
DataSourceAkamai.py
12.67
KB
-rw-r--r--
2024-07-03 01:59
DataSourceAliYun.py
3.26
KB
-rw-r--r--
2024-07-03 01:59
DataSourceAltCloud.py
8.42
KB
-rw-r--r--
2024-07-03 01:59
DataSourceAzure.py
73.13
KB
-rw-r--r--
2024-07-03 01:59
DataSourceBigstep.py
1.9
KB
-rw-r--r--
2024-07-03 01:59
DataSourceCloudSigma.py
3.86
KB
-rw-r--r--
2024-07-03 01:59
DataSourceCloudStack.py
11.21
KB
-rw-r--r--
2024-07-03 01:59
DataSourceConfigDrive.py
10.88
KB
-rw-r--r--
2024-07-03 01:59
DataSourceDigitalOcean.py
4.18
KB
-rw-r--r--
2024-07-03 01:59
DataSourceEc2.py
42.44
KB
-rw-r--r--
2024-07-11 21:27
DataSourceExoscale.py
8.79
KB
-rw-r--r--
2024-07-03 01:59
DataSourceGCE.py
13.76
KB
-rw-r--r--
2024-07-03 01:59
DataSourceHetzner.py
5.34
KB
-rw-r--r--
2024-07-03 01:59
DataSourceIBMCloud.py
13.94
KB
-rw-r--r--
2024-07-03 01:59
DataSourceLXD.py
17.28
KB
-rw-r--r--
2024-07-03 01:59
DataSourceMAAS.py
14.85
KB
-rw-r--r--
2024-07-03 01:59
DataSourceNWCS.py
4.36
KB
-rw-r--r--
2024-07-03 01:59
DataSourceNoCloud.py
14.18
KB
-rw-r--r--
2024-07-03 01:59
DataSourceNone.py
1.27
KB
-rw-r--r--
2024-07-03 01:59
DataSourceOVF.py
12.7
KB
-rw-r--r--
2024-07-03 01:59
DataSourceOpenNebula.py
15.67
KB
-rw-r--r--
2024-07-03 01:59
DataSourceOpenStack.py
10.44
KB
-rw-r--r--
2024-07-03 01:59
DataSourceOracle.py
16.72
KB
-rw-r--r--
2024-07-03 01:59
DataSourceRbxCloud.py
7.85
KB
-rw-r--r--
2024-07-03 01:59
DataSourceScaleway.py
15.72
KB
-rw-r--r--
2024-07-03 01:59
DataSourceSmartOS.py
34
KB
-rw-r--r--
2024-07-03 01:59
DataSourceUpCloud.py
5.51
KB
-rw-r--r--
2024-07-03 01:59
DataSourceVMware.py
35.3
KB
-rw-r--r--
2024-07-03 01:59
DataSourceVultr.py
4.5
KB
-rw-r--r--
2024-07-03 01:59
DataSourceWSL.py
11.79
KB
-rw-r--r--
2024-07-03 01:59
__init__.py
43.56
KB
-rw-r--r--
2024-07-03 01:59
Save
Rename
# Author: Eric Benner <ebenner@vultr.com> # # This file is part of cloud-init. See LICENSE file for license information. # Vultr Metadata API: # https://www.vultr.com/metadata/ import logging from typing import Tuple import cloudinit.sources.helpers.vultr as vultr from cloudinit import sources, stages, util, version LOG = logging.getLogger(__name__) BUILTIN_DS_CONFIG = { "url": "http://169.254.169.254", "retries": 30, "timeout": 10, "wait": 5, "user-agent": "Cloud-Init/%s - OS: %s Variant: %s" % ( version.version_string(), util.system_info()["system"], util.system_info()["variant"], ), } class DataSourceVultr(sources.DataSource): dsname = "Vultr" sensitive_metadata_keys: Tuple[ str, ... ] = sources.DataSource.sensitive_metadata_keys + ("startup-script",) def __init__(self, sys_cfg, distro, paths): super(DataSourceVultr, self).__init__(sys_cfg, distro, paths) self.ds_cfg = util.mergemanydict( [ util.get_cfg_by_path(sys_cfg, ["datasource", "Vultr"], {}), BUILTIN_DS_CONFIG, ] ) self.netcfg = None @staticmethod def ds_detect(): return vultr.is_vultr() # Initiate data and check if Vultr def _get_data(self): LOG.debug("Machine is a Vultr instance") # Fetch metadata self.metadata = self.get_metadata() self.userdata_raw = self.metadata["user-data"] # Generate config and process data self.get_datasource_data(self.metadata) # Dump some data so diagnosing failures is manageable LOG.debug("SUBID: %s", self.metadata["instance-id"]) LOG.debug("Hostname: %s", self.metadata["local-hostname"]) return True # Process metadata def get_datasource_data(self, md): # Generate network config if "cloud_interfaces" in md: # In the future we will just drop pre-configured # network configs into the array. They need names though. vultr.add_interface_names(md["cloud_interfaces"]) self.netcfg = md["cloud_interfaces"] else: self.netcfg = vultr.generate_network_config(md["interfaces"]) # Grab vendordata self.vendordata_raw = md["vendor-data"] # Default hostname is "guest" for whitelabel if self.metadata["local-hostname"] == "": self.metadata["local-hostname"] = "guest" self.userdata_raw = md["user-data"] if self.userdata_raw == "": self.userdata_raw = None # Get the metadata by flag def get_metadata(self): return vultr.get_metadata( self.distro, self.ds_cfg["url"], self.ds_cfg["timeout"], self.ds_cfg["retries"], self.ds_cfg["wait"], self.ds_cfg["user-agent"], tmp_dir=self.distro.get_tmp_exec_path(), ) # Compare subid as instance id def check_instance_id(self, sys_cfg): if not vultr.is_vultr(): return False # Baremetal has no way to implement this in local if vultr.is_baremetal(): return False subid = vultr.get_sysinfo()["subid"] return sources.instance_id_matches_system_uuid(subid) # Currently unsupported @property def launch_index(self): return None @property def network_config(self): return self.netcfg # Used to match classes to dependencies datasources = [ (DataSourceVultr, (sources.DEP_FILESYSTEM,)), ] # Return a list of data sources that match this set of dependencies def get_datasource_list(depends): return sources.list_from_depends(depends, datasources) if __name__ == "__main__": import sys if not vultr.is_vultr(): print("Machine is not a Vultr instance") sys.exit(1) # It should probably be safe to try to detect distro via stages.Init(), # which will fall back to Ubuntu if no distro config is found. # this distro object is only used for dhcp fallback. Feedback from user(s) # of __main__ would help determine if a better approach exists. # # we don't needReportEventStack, so reporter=True distro = stages.Init(reporter=True).distro md = vultr.get_metadata( distro, BUILTIN_DS_CONFIG["url"], BUILTIN_DS_CONFIG["timeout"], BUILTIN_DS_CONFIG["retries"], BUILTIN_DS_CONFIG["wait"], BUILTIN_DS_CONFIG["user-agent"], ) config = md["vendor-data"] sysinfo = vultr.get_sysinfo()