diff options
| -rwxr-xr-x | python/vyos/ifconfig/interface.py | 4 | ||||
| -rw-r--r-- | python/vyos/ifconfig/loopback.py | 13 | ||||
| -rw-r--r-- | python/vyos/util.py | 4 | ||||
| -rw-r--r-- | src/tests/test_util.py | 15 | 
4 files changed, 25 insertions, 11 deletions
| diff --git a/python/vyos/ifconfig/interface.py b/python/vyos/ifconfig/interface.py index 4fda1c0a9..22265cc3c 100755 --- a/python/vyos/ifconfig/interface.py +++ b/python/vyos/ifconfig/interface.py @@ -39,7 +39,7 @@ from vyos.util import read_file  from vyos.util import get_interface_config  from vyos.util import get_interface_namespace  from vyos.util import is_systemd_service_active -from vyos.util import sysctl_read +from vyos.util import is_ipv6_enabled  from vyos.template import is_ipv4  from vyos.template import is_ipv6  from vyos.validate import is_intf_addr_assigned @@ -1498,7 +1498,7 @@ class Interface(Control):          self.set_ipv4_source_validation(value)          # Only change IPv6 parameters if IPv6 was not explicitly disabled -        if sysctl_read('net.ipv6.conf.all.disable_ipv6') == '0': +        if is_ipv6_enabled():              # Configure MSS value for IPv6 TCP connections              tmp = dict_search('ipv6.adjust_mss', config)              value = tmp if (tmp != None) else '0' diff --git a/python/vyos/ifconfig/loopback.py b/python/vyos/ifconfig/loopback.py index de554ef44..30c890fdf 100644 --- a/python/vyos/ifconfig/loopback.py +++ b/python/vyos/ifconfig/loopback.py @@ -13,9 +13,8 @@  # You should have received a copy of the GNU Lesser General Public  # License along with this library.  If not, see <http://www.gnu.org/licenses/>. -import vyos.util -  from vyos.ifconfig.interface import Interface +from vyos.util import is_ipv6_enabled  @Interface.register  class LoopbackIf(Interface): @@ -34,8 +33,6 @@ class LoopbackIf(Interface):          }      } -    name = 'loopback' -      def remove(self):          """          Loopback interface can not be deleted from operating system. We can @@ -62,11 +59,11 @@ class LoopbackIf(Interface):          on any interface. """          addr = config.get('address', []) -        # We must ensure that the loopback addresses are never deleted from the system -        addr += ['127.0.0.1/8'] -        if (vyos.util.sysctl_read('net.ipv6.conf.all.disable_ipv6') == '0'): -            addr += ['::1/128'] +        # We must ensure that the loopback addresses are never deleted from the system +        addr.append('127.0.0.1/8') +        if is_ipv6_enabled(): +            addr.append('::1/128')          # Update IP address entry in our dictionary          config.update({'address' : addr}) diff --git a/python/vyos/util.py b/python/vyos/util.py index f46775490..f3f323c34 100644 --- a/python/vyos/util.py +++ b/python/vyos/util.py @@ -1019,3 +1019,7 @@ def sysctl_write(name, value):          call(f'sysctl -wq {name}={value}')          return True      return False + +def is_ipv6_enabled() -> bool: +    """ Check if IPv6 support on the system is enabled or not """ +    return (sysctl_read('net.ipv6.conf.all.disable_ipv6') == '0') diff --git a/src/tests/test_util.py b/src/tests/test_util.py index 9bd27adc0..91890262c 100644 --- a/src/tests/test_util.py +++ b/src/tests/test_util.py @@ -1,6 +1,6 @@  #!/usr/bin/env python3  # -# Copyright (C) 2020-2021 VyOS maintainers and contributors +# Copyright (C) 2020-2022 VyOS maintainers and contributors  #  # This program is free software; you can redistribute it and/or modify  # it under the terms of the GNU General Public License version 2 or later as @@ -23,3 +23,16 @@ class TestVyOSUtil(TestCase):          expected_data = {"foo_bar": {"baz_quux": None}}          new_data = mangle_dict_keys(data, '-', '_')          self.assertEqual(new_data, expected_data) + +    def test_sysctl_read(self): +        self.assertEqual(sysctl_read('net.ipv4.conf.lo.forwarding'), '1') + +    def test_ipv6_enabled(self): +        tmp = sysctl_read('net.ipv6.conf.all.disable_ipv6') +        # We need to test for both variants as this depends on how the +        # Docker container is started (with or without IPv6 support) - so we +        # will simply check both cases to not make the users life miserable. +        if tmp == '0': +            self.assertTrue(is_ipv6_enabled()) +        else: +            self.assertFalse(is_ipv6_enabled()) | 
