azurelinuxagent/common/osutil/fedora.py (44 lines of code) (raw):
#
# Copyright 2022 Red Hat Inc.
#
# 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 FedoraOSUtil(DefaultOSUtil):
def __init__(self):
super(FedoraOSUtil, self).__init__()
self.agent_conf_file_path = '/etc/waagent.conf'
@staticmethod
def get_systemd_unit_file_install_path():
return '/usr/lib/systemd/system'
@staticmethod
def get_agent_bin_path():
return '/usr/sbin'
def is_dhcp_enabled(self):
return True
def start_network(self):
pass
def restart_if(self, ifname=None, retries=None, wait=None):
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")
def restart_ssh_service(self):
shellutil.run('systemctl restart sshd')
def stop_dhcp_service(self):
pass
def start_dhcp_service(self):
pass
def start_agent_service(self):
return shellutil.run('systemctl start waagent', chk_err=False)
def stop_agent_service(self):
return shellutil.run('systemctl stop waagent', chk_err=False)
def get_dhcp_pid(self):
return self._get_dhcp_pid(["pidof", "dhclient"])
def conf_sshd(self, disable_password):
pass