mirror of
https://github.com/CumulusNetworks/ifupdown2.git
synced 2024-05-06 15:54:50 +00:00
Ticket: CM-11043 Reviewed By: roopa Testing Done: used the config mentioned in bug This patch adds a delay before starting IPv6 dhclient to make sure the configured interface/link in up. Also, ifdown on a IPv6 interface, this patch makes sure that the link in up before dhcp release. Dhcp release is done using a default lease file. Signed-off-by: Nikhil <nikhil@cumulusnetworks.com>
104 lines
3.8 KiB
Python
104 lines
3.8 KiB
Python
#!/usr/bin/python
|
|
#
|
|
# Copyright 2014 Cumulus Networks, Inc. All rights reserved.
|
|
# Author: Roopa Prabhu, roopa@cumulusnetworks.com
|
|
#
|
|
|
|
from ifupdown.utils import utils
|
|
from utilsbase import *
|
|
import os
|
|
|
|
|
|
class dhclient(utilsBase):
|
|
""" This class contains helper methods to interact with the dhclient
|
|
utility """
|
|
|
|
def _pid_exists(self, pidfilename):
|
|
if os.path.exists(pidfilename):
|
|
pid = self.read_file_oneline(pidfilename)
|
|
if not os.path.exists('/proc/%s' %pid):
|
|
return False
|
|
else:
|
|
return False
|
|
return True
|
|
|
|
def is_running(self, ifacename):
|
|
return self._pid_exists('/run/dhclient.%s.pid' %ifacename)
|
|
|
|
def is_running6(self, ifacename):
|
|
return self._pid_exists('/run/dhclient6.%s.pid' %ifacename)
|
|
|
|
def _run_dhclient_cmd(self, cmd, cmd_prefix=None):
|
|
if not cmd_prefix:
|
|
cmd_aslist = []
|
|
else:
|
|
cmd_aslist = cmd_prefix.split()
|
|
if cmd_aslist:
|
|
cmd_aslist.extend(cmd)
|
|
else:
|
|
cmd_aslist = cmd
|
|
utils.exec_commandl(cmd_aslist, stdout=None, stderr=None)
|
|
|
|
def stop(self, ifacename, cmd_prefix=None):
|
|
if os.path.exists('/sbin/dhclient3'):
|
|
cmd = ['/sbin/dhclient3', '-x', '-pf',
|
|
'/run/dhclient.%s.pid' %ifacename, '-lf',
|
|
'/var/lib/dhcp3/dhclient.%s.leases' %ifacename,
|
|
'%s' %ifacename]
|
|
else:
|
|
cmd = ['/sbin/dhclient', '-x', '-pf',
|
|
'/run/dhclient.%s.pid' %ifacename,
|
|
'-lf', '/var/lib/dhcp/dhclient.%s.leases' %ifacename,
|
|
'%s' %ifacename]
|
|
self._run_dhclient_cmd(cmd, cmd_prefix)
|
|
|
|
def start(self, ifacename, wait=True, cmd_prefix=None):
|
|
if os.path.exists('/sbin/dhclient3'):
|
|
cmd = ['/sbin/dhclient3', '-pf',
|
|
'/run/dhclient.%s.pid' %ifacename,
|
|
'-lf', '/var/lib/dhcp3/dhclient.%s.leases' %ifacename,
|
|
'%s' %ifacename]
|
|
else:
|
|
cmd = ['/sbin/dhclient', '-pf',
|
|
'/run/dhclient.%s.pid' %ifacename, '-lf',
|
|
'/var/lib/dhcp/dhclient.%s.leases' %ifacename,
|
|
'%s' %ifacename]
|
|
if not wait:
|
|
cmd.append('-nw')
|
|
self._run_dhclient_cmd(cmd, cmd_prefix)
|
|
|
|
def release(self, ifacename, cmd_prefix=None):
|
|
if os.path.exists('/sbin/dhclient3'):
|
|
cmd = ['/sbin/dhclient3', '-r', '-pf',
|
|
'/run/dhclient.%s.pid' %ifacename, '-lf',
|
|
'/var/lib/dhcp3/dhclient.%s.leases' %ifacename,
|
|
'%s' %ifacename]
|
|
else:
|
|
cmd = ['/sbin/dhclient', '-r', '-pf',
|
|
'/run/dhclient.%s.pid' %ifacename,
|
|
'-lf', '/var/lib/dhcp/dhclient.%s.leases' %ifacename,
|
|
'%s' %ifacename]
|
|
self._run_dhclient_cmd(cmd, cmd_prefix)
|
|
|
|
def start6(self, ifacename, wait=True, cmd_prefix=None):
|
|
cmd = ['/sbin/dhclient', '-6', '-pf',
|
|
'/run/dhclient6.%s.pid' %ifacename, '-lf',
|
|
'/var/lib/dhcp/dhclient.%s.leases ' %ifacename,
|
|
'%s' %ifacename]
|
|
if not wait:
|
|
cmd.append('-nw')
|
|
self._run_dhclient_cmd(cmd, cmd_prefix)
|
|
|
|
def stop6(self, ifacename, cmd_prefix=None):
|
|
cmd = ['/sbin/dhclient', '-6', '-x', '-pf',
|
|
'/run/dhclient.%s.pid' %ifacename, '-lf',
|
|
'/var/lib/dhcp/dhclient.%s.leases ' %ifacename,
|
|
'%s' %ifacename]
|
|
self._run_dhclient_cmd(cmd, cmd_prefix)
|
|
|
|
def release6(self, ifacename, cmd_prefix=None):
|
|
cmd = ['/sbin/dhclient', '-6', '-r', '-pf',
|
|
'/run/dhclient6.%s.pid' %ifacename,
|
|
'%s' %ifacename]
|
|
self._run_dhclient_cmd(cmd, cmd_prefix)
|