PATH:
usr
/
lib
/
python2.7
/
site-packages
/
azurelinuxagent
/
common
/
osutil
# # Copyright 2018 Microsoft Corporation # # 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. # # Requires Python 2.6+ and Openssl 1.0+ # import time import azurelinuxagent.common.logger as logger import azurelinuxagent.common.utils.shellutil as shellutil from azurelinuxagent.common.osutil.default import DefaultOSUtil class Ubuntu14OSUtil(DefaultOSUtil): def __init__(self): super(Ubuntu14OSUtil, self).__init__() self.jit_enabled = True self.service_name = self.get_service_name() @staticmethod def get_service_name(): return "walinuxagent" def start_network(self): return shellutil.run("service networking start", chk_err=False) def stop_agent_service(self): try: shellutil.run_command(["service", self.service_name, "stop"]) except shellutil.CommandError as cmd_err: return cmd_err.returncode return 0 def start_agent_service(self): try: shellutil.run_command(["service", self.service_name, "start"]) except shellutil.CommandError as cmd_err: return cmd_err.returncode return 0 def remove_rules_files(self, rules_files=""): pass def restore_rules_files(self, rules_files=""): pass def get_dhcp_lease_endpoint(self): return self.get_endpoint_from_leases_path('/var/lib/dhcp/dhclient.*.leases') class Ubuntu12OSUtil(Ubuntu14OSUtil): def __init__(self): # pylint: disable=W0235 super(Ubuntu12OSUtil, self).__init__() # Override def get_dhcp_pid(self): return self._get_dhcp_pid(["pidof", "dhclient3"]) class Ubuntu16OSUtil(Ubuntu14OSUtil): """ Ubuntu 16.04, 16.10, and 17.04. """ def __init__(self): super(Ubuntu16OSUtil, self).__init__() self.service_name = self.get_service_name() def register_agent_service(self): return shellutil.run("systemctl unmask {0}".format(self.service_name), chk_err=False) def unregister_agent_service(self): return shellutil.run("systemctl mask {0}".format(self.service_name), chk_err=False) class Ubuntu18OSUtil(Ubuntu16OSUtil): """ Ubuntu 18.04, 18.10, 19.04, 19.10, 20.04 """ def __init__(self): super(Ubuntu18OSUtil, self).__init__() self.service_name = self.get_service_name() def restart_if(self, ifname, retries=3, wait=5): """ Restart systemd-networkd """ retry_limit=retries+1 for attempt in range(1, retry_limit): try: shellutil.run_command(["systemctl", "restart", "systemd-networkd"]) except shellutil.CommandError as cmd_err: logger.warn("failed to restart systemd-networkd: return code {1}".format(cmd_err.returncode)) if attempt < retry_limit: logger.info("retrying in {0} seconds".format(wait)) time.sleep(wait) else: logger.warn("exceeded restart retries") def get_dhcp_pid(self): return self._get_dhcp_pid(["pidof", "systemd-networkd"]) def start_network(self): return shellutil.run("systemctl start systemd-networkd", chk_err=False) def stop_network(self): return shellutil.run("systemctl stop systemd-networkd", chk_err=False) def start_dhcp_service(self): return self.start_network() def stop_dhcp_service(self): return self.stop_network() def start_agent_service(self): return shellutil.run("systemctl start {0}".format(self.service_name), chk_err=False) def stop_agent_service(self): return shellutil.run("systemctl stop {0}".format(self.service_name), chk_err=False) class UbuntuOSUtil(Ubuntu16OSUtil): def __init__(self): # pylint: disable=W0235 super(UbuntuOSUtil, self).__init__() def restart_if(self, ifname, retries=3, wait=5): """ Restart an interface by bouncing the link. systemd-networkd observes this event, and forces a renew of DHCP. """ retry_limit = retries+1 for attempt in range(1, retry_limit): return_code = shellutil.run("ip link set {0} down && ip link set {0} up".format(ifname)) if return_code == 0: return logger.warn("failed to restart {0}: return code {1}".format(ifname, return_code)) if attempt < retry_limit: logger.info("retrying in {0} seconds".format(wait)) time.sleep(wait) else: logger.warn("exceeded restart retries") class UbuntuSnappyOSUtil(Ubuntu14OSUtil): def __init__(self): super(UbuntuSnappyOSUtil, self).__init__() self.conf_file_path = '/apps/walinuxagent/current/waagent.conf'
[+]
..
[-] __init__.py
[edit]
[-] alpine.py
[edit]
[-] arch.py
[edit]
[-] bigip.py
[edit]
[-] clearlinux.py
[edit]
[-] coreos.py
[edit]
[-] debian.py
[edit]
[-] default.py
[edit]
[-] factory.py
[edit]
[-] freebsd.py
[edit]
[-] gaia.py
[edit]
[-] openbsd.py
[edit]
[-] redhat.py
[edit]
[-] suse.py
[edit]
[-] ubuntu.py
[edit]
[-] __init__.pyc
[edit]
[-] __init__.pyo
[edit]
[-] alpine.pyc
[edit]
[-] alpine.pyo
[edit]
[-] photonos.pyc
[edit]
[-] arch.pyc
[edit]
[-] arch.pyo
[edit]
[-] photonos.pyo
[edit]
[-] bigip.pyc
[edit]
[-] bigip.pyo
[edit]
[-] photonos.py
[edit]
[-] clearlinux.pyc
[edit]
[-] clearlinux.pyo
[edit]
[-] coreos.pyc
[edit]
[-] coreos.pyo
[edit]
[-] debian.pyc
[edit]
[-] debian.pyo
[edit]
[-] default.pyc
[edit]
[-] default.pyo
[edit]
[-] factory.pyc
[edit]
[-] factory.pyo
[edit]
[-] freebsd.pyc
[edit]
[-] freebsd.pyo
[edit]
[-] gaia.pyc
[edit]
[-] gaia.pyo
[edit]
[-] openbsd.pyc
[edit]
[-] openbsd.pyo
[edit]
[-] redhat.pyc
[edit]
[-] redhat.pyo
[edit]
[-] suse.pyc
[edit]
[-] suse.pyo
[edit]
[-] ubuntu.pyc
[edit]
[-] ubuntu.pyo
[edit]
[-] iosxe.py
[edit]
[-] nsbsd.py
[edit]
[-] openwrt.py
[edit]
[-] iosxe.pyc
[edit]
[-] iosxe.pyo
[edit]
[-] nsbsd.pyc
[edit]
[-] nsbsd.pyo
[edit]
[-] openwrt.pyc
[edit]
[-] openwrt.pyo
[edit]
[-] mariner.py
[edit]
[-] systemd.py
[edit]
[-] mariner.pyc
[edit]
[-] mariner.pyo
[edit]
[-] systemd.pyc
[edit]
[-] systemd.pyo
[edit]