OXIESEC PANEL
- Current Dir:
/
/
usr
/
lib
/
python3
/
dist-packages
/
cloudinit
/
distros
Server IP: 139.59.38.164
Upload:
Create Dir:
Name
Size
Modified
Perms
📁
..
-
05/09/2024 07:15:07 AM
rwxr-xr-x
📄
OpenCloudOS.py
277 bytes
04/20/2023 09:31:09 PM
rw-r--r--
📄
TencentOS.py
277 bytes
04/20/2023 09:31:09 PM
rw-r--r--
📄
__init__.py
42.84 KB
04/20/2023 09:31:09 PM
rw-r--r--
📁
__pycache__
-
05/09/2024 07:15:08 AM
rwxr-xr-x
📄
almalinux.py
174 bytes
04/20/2023 09:31:09 PM
rw-r--r--
📄
alpine.py
6.73 KB
04/20/2023 09:31:09 PM
rw-r--r--
📄
amazon.py
615 bytes
04/20/2023 09:31:09 PM
rw-r--r--
📄
arch.py
8.34 KB
04/20/2023 09:31:09 PM
rw-r--r--
📄
bsd.py
4.91 KB
04/20/2023 09:31:09 PM
rw-r--r--
📄
bsd_utils.py
1.42 KB
04/20/2023 09:31:09 PM
rw-r--r--
📄
centos.py
174 bytes
04/20/2023 09:31:09 PM
rw-r--r--
📄
cloudlinux.py
174 bytes
04/20/2023 09:31:09 PM
rw-r--r--
📄
cos.py
270 bytes
04/20/2023 09:31:09 PM
rw-r--r--
📄
debian.py
13.36 KB
04/20/2023 09:31:09 PM
rw-r--r--
📄
dragonflybsd.py
253 bytes
04/20/2023 09:31:09 PM
rw-r--r--
📄
eurolinux.py
174 bytes
04/20/2023 09:31:09 PM
rw-r--r--
📄
fedora.py
460 bytes
04/20/2023 09:31:09 PM
rw-r--r--
📄
freebsd.py
6.44 KB
04/20/2023 09:31:09 PM
rw-r--r--
📄
gentoo.py
8.95 KB
04/20/2023 09:31:09 PM
rw-r--r--
📄
mariner.py
1.72 KB
04/20/2023 09:31:09 PM
rw-r--r--
📄
miraclelinux.py
174 bytes
04/20/2023 09:31:09 PM
rw-r--r--
📄
net_util.py
6.42 KB
04/20/2023 09:31:09 PM
rw-r--r--
📄
netbsd.py
4.43 KB
04/20/2023 09:31:09 PM
rw-r--r--
📄
networking.py
11.08 KB
04/20/2023 09:31:09 PM
rw-r--r--
📄
openEuler.py
298 bytes
04/20/2023 09:31:09 PM
rw-r--r--
📄
openbsd.py
1.86 KB
04/20/2023 09:31:09 PM
rw-r--r--
📄
openmandriva.py
260 bytes
04/20/2023 09:31:09 PM
rw-r--r--
📄
opensuse-leap.py
270 bytes
04/20/2023 09:31:09 PM
rw-r--r--
📄
opensuse-microos.py
270 bytes
04/20/2023 09:31:09 PM
rw-r--r--
📄
opensuse-tumbleweed.py
270 bytes
04/20/2023 09:31:09 PM
rw-r--r--
📄
opensuse.py
9.36 KB
04/20/2023 09:31:09 PM
rw-r--r--
📁
parsers
-
05/09/2024 07:15:08 AM
rwxr-xr-x
📄
photon.py
4.74 KB
04/20/2023 09:31:09 PM
rw-r--r--
📄
rhel.py
7.11 KB
04/20/2023 09:31:09 PM
rw-r--r--
📄
rhel_util.py
1.44 KB
04/20/2023 09:31:09 PM
rw-r--r--
📄
rocky.py
174 bytes
04/20/2023 09:31:09 PM
rw-r--r--
📄
sle-micro.py
270 bytes
04/20/2023 09:31:09 PM
rw-r--r--
📄
sle_hpc.py
270 bytes
04/20/2023 09:31:09 PM
rw-r--r--
📄
sles.py
270 bytes
04/20/2023 09:31:09 PM
rw-r--r--
📄
ubuntu.py
1.5 KB
04/20/2023 09:31:09 PM
rw-r--r--
📄
ug_util.py
9.8 KB
04/20/2023 09:31:09 PM
rw-r--r--
📄
virtuozzo.py
174 bytes
04/20/2023 09:31:09 PM
rw-r--r--
Editing: photon.py
Close
#!/usr/bin/env python3 # vi: ts=4 expandtab # # Copyright (C) 2021 VMware Inc. # # This file is part of cloud-init. See LICENSE file for license information. from cloudinit import distros, helpers from cloudinit import log as logging from cloudinit import net, subp, util from cloudinit.distros import rhel_util as rhutil from cloudinit.settings import PER_INSTANCE LOG = logging.getLogger(__name__) class Distro(distros.Distro): systemd_hostname_conf_fn = "/etc/hostname" network_conf_dir = "/etc/systemd/network/" systemd_locale_conf_fn = "/etc/locale.conf" resolve_conf_fn = "/etc/systemd/resolved.conf" renderer_configs = { "networkd": { "resolv_conf_fn": resolve_conf_fn, "network_conf_dir": network_conf_dir, } } # Should be fqdn if we can use it prefer_fqdn = True def __init__(self, name, cfg, paths): distros.Distro.__init__(self, name, cfg, paths) # This will be used to restrict certain # calls from repeatly happening (when they # should only happen say once per instance...) self._runner = helpers.Runners(paths) self.osfamily = "photon" self.init_cmd = ["systemctl"] def exec_cmd(self, cmd, capture=True): LOG.debug("Attempting to run: %s", cmd) try: (out, err) = subp.subp(cmd, capture=capture) if err: LOG.warning( "Running %s resulted in stderr output: %s", cmd, err ) return True, out, err return False, out, err except subp.ProcessExecutionError: util.logexc(LOG, "Command %s failed", cmd) return True, None, None def generate_fallback_config(self): key = "disable_fallback_netcfg" disable_fallback_netcfg = self._cfg.get(key, True) LOG.debug("%s value is: %s", key, disable_fallback_netcfg) if not disable_fallback_netcfg: return net.generate_fallback_config() LOG.info( "Skipping generate_fallback_config. Rely on PhotonOS default " "network config" ) return None def apply_locale(self, locale, out_fn=None): # This has a dependancy on glibc-i18n, user need to manually install it # and enable the option in cloud.cfg if not out_fn: out_fn = self.systemd_locale_conf_fn locale_cfg = { "LANG": locale, } rhutil.update_sysconfig_file(out_fn, locale_cfg) # rhutil will modify /etc/locale.conf # For locale change to take effect, reboot is needed or we can restart # systemd-localed. This is equivalent of localectl cmd = ["systemctl", "restart", "systemd-localed"] self.exec_cmd(cmd) def install_packages(self, pkglist): # self.update_package_sources() self.package_command("install", pkgs=pkglist) def _write_hostname(self, hostname, filename): if filename and filename.endswith("/previous-hostname"): util.write_file(filename, hostname) else: ret, _out, err = self.exec_cmd( ["hostnamectl", "set-hostname", str(hostname)] ) if ret: LOG.warning( ( "Error while setting hostname: %s\nGiven hostname: %s", err, hostname, ) ) def _read_system_hostname(self): sys_hostname = self._read_hostname(self.systemd_hostname_conf_fn) return (self.systemd_hostname_conf_fn, sys_hostname) def _read_hostname(self, filename, default=None): if filename and filename.endswith("/previous-hostname"): return util.load_file(filename).strip() _ret, out, _err = self.exec_cmd(["hostname", "-f"]) return out.strip() if out else default def _get_localhost_ip(self): return "127.0.1.1" def set_timezone(self, tz): distros.set_etc_timezone(tz=tz, tz_file=self._find_tz_file(tz)) def package_command(self, command, args=None, pkgs=None): if not pkgs: pkgs = [] cmd = ["tdnf", "-y"] if args and isinstance(args, str): cmd.append(args) elif args and isinstance(args, list): cmd.extend(args) cmd.append(command) pkglist = util.expand_package_list("%s-%s", pkgs) cmd.extend(pkglist) ret, _out, err = self.exec_cmd(cmd) if ret: LOG.error("Error while installing packages: %s", err) def update_package_sources(self): self._runner.run( "update-sources", self.package_command, ["makecache"], freq=PER_INSTANCE, )