1
0
Fork 0
mirror of https://github.com/ansible-collections/community.general.git synced 2024-09-14 20:13:21 +02:00

Feat: nmcli - Add method4 and method6 (#1894) (#1944)

* Feat: nmcli - Add method4 and method6

Allows to manipulate ipv4.method and ipv6.method.

Is mandatory to manage Bond interfaces with no native vlans but only tagged vlans.

* Fix: nmcli - Add changelog fragment for 1894

* Fix: nmcli - Add choices for method4 and method6

* Update plugins/modules/net_tools/nmcli.py

Co-authored-by: Felix Fontein <felix@fontein.de>

* Update changelogs/fragments/1894-feat-nmcli-add-method4-and-method6.yml

Co-authored-by: Felix Fontein <felix@fontein.de>

* Update plugins/modules/net_tools/nmcli.py

Co-authored-by: Felix Fontein <felix@fontein.de>

* Fix: nmcli - Update documentation

* Update plugins/modules/net_tools/nmcli.py

Co-authored-by: Felix Fontein <felix@fontein.de>

* Update plugins/modules/net_tools/nmcli.py

Co-authored-by: Felix Fontein <felix@fontein.de>

* Fix: nmcli - Simplify code

* Update plugins/modules/net_tools/nmcli.py

Co-authored-by: Felix Fontein <felix@fontein.de>

* Fix: nmcli - Update ip6 documentation

Co-authored-by: Felix Fontein <felix@fontein.de>
(cherry picked from commit 4f98136771)

Co-authored-by: Ox <oxedions@gmail.com>
This commit is contained in:
patchback[bot] 2021-03-02 13:09:38 +01:00 committed by GitHub
parent a61bc5ab34
commit c80416164b
No known key found for this signature in database
GPG key ID: 4AEE18F83AFDEB23
2 changed files with 28 additions and 6 deletions

View file

@ -0,0 +1,2 @@
bugfixes:
- nmcli - add ``method4`` and ``method6`` options (https://github.com/ansible-collections/community.general/pull/1894).

View file

@ -69,6 +69,7 @@ options:
description: description:
- The IPv4 address to this interface. - The IPv4 address to this interface.
- Use the format C(192.0.2.24/24). - Use the format C(192.0.2.24/24).
- If defined and I(method4) is not specified, automatically set C(ipv4.method) to C(manual).
type: str type: str
gw4: gw4:
description: description:
@ -106,10 +107,18 @@ options:
- A list of DNS search domains. - A list of DNS search domains.
elements: str elements: str
type: list type: list
method4:
description:
- Configuration method to be used for IPv4.
- If I(ip4) is set, C(ipv4.method) is automatically set to C(manual) and this parameter is not needed.
type: str
choices: [auto, link-local, manual, shared, disabled]
version_added: 2.2.0
ip6: ip6:
description: description:
- The IPv6 address to this interface. - The IPv6 address to this interface.
- Use the format C(abbe::cafe). - Use the format C(abbe::cafe).
- If defined and I(method6) is not specified, automatically set C(ipv6.method) to C(manual).
type: str type: str
gw6: gw6:
description: description:
@ -127,6 +136,13 @@ options:
- A list of DNS search domains. - A list of DNS search domains.
elements: str elements: str
type: list type: list
method6:
description:
- Configuration method to be used for IPv6
- If I(ip6) is set, C(ipv6.method) is automatically set to C(manual) and this parameter is not needed.
type: str
choices: [ignore, auto, dhcp, link-local, manual, shared]
version_added: 2.2.0
mtu: mtu:
description: description:
- The connection MTU, e.g. 9000. This can't be applied when creating the interface and is done once the interface has been created. - The connection MTU, e.g. 9000. This can't be applied when creating the interface and is done once the interface has been created.
@ -611,10 +627,12 @@ class Nmcli(object):
self.never_default4 = module.params['never_default4'] self.never_default4 = module.params['never_default4']
self.dns4 = module.params['dns4'] self.dns4 = module.params['dns4']
self.dns4_search = module.params['dns4_search'] self.dns4_search = module.params['dns4_search']
self.method4 = module.params['method4']
self.ip6 = module.params['ip6'] self.ip6 = module.params['ip6']
self.gw6 = module.params['gw6'] self.gw6 = module.params['gw6']
self.dns6 = module.params['dns6'] self.dns6 = module.params['dns6']
self.dns6_search = module.params['dns6_search'] self.dns6_search = module.params['dns6_search']
self.method6 = module.params['method6']
self.mtu = module.params['mtu'] self.mtu = module.params['mtu']
self.stp = module.params['stp'] self.stp = module.params['stp']
self.priority = module.params['priority'] self.priority = module.params['priority']
@ -648,18 +666,18 @@ class Nmcli(object):
self.dhcp_client_id = module.params['dhcp_client_id'] self.dhcp_client_id = module.params['dhcp_client_id']
self.zone = module.params['zone'] self.zone = module.params['zone']
if self.ip4: if self.method4:
self.ipv4_method = self.method4
elif self.ip4:
self.ipv4_method = 'manual' self.ipv4_method = 'manual'
else: else:
# supported values for 'ipv4.method': [auto, link-local, manual, shared, disabled]
# TODO: add a new module parameter to specify a non 'manual' value
self.ipv4_method = None self.ipv4_method = None
if self.ip6: if self.method6:
self.ipv6_method = self.method6
elif self.ip6:
self.ipv6_method = 'manual' self.ipv6_method = 'manual'
else: else:
# supported values for 'ipv6.method': [ignore, auto, dhcp, link-local, manual, shared]
# TODO: add a new module parameter to specify a non 'manual' value
self.ipv6_method = None self.ipv6_method = None
def execute_command(self, cmd, use_unsafe_shell=False, data=None): def execute_command(self, cmd, use_unsafe_shell=False, data=None):
@ -1075,11 +1093,13 @@ def main():
never_default4=dict(type='bool', default=False), never_default4=dict(type='bool', default=False),
dns4=dict(type='list', elements='str'), dns4=dict(type='list', elements='str'),
dns4_search=dict(type='list', elements='str'), dns4_search=dict(type='list', elements='str'),
method4=dict(type='str', choices=['auto', 'link-local', 'manual', 'shared', 'disabled']),
dhcp_client_id=dict(type='str'), dhcp_client_id=dict(type='str'),
ip6=dict(type='str'), ip6=dict(type='str'),
gw6=dict(type='str'), gw6=dict(type='str'),
dns6=dict(type='list', elements='str'), dns6=dict(type='list', elements='str'),
dns6_search=dict(type='list', elements='str'), dns6_search=dict(type='list', elements='str'),
method6=dict(type='str', choices=['ignore', 'auto', 'dhcp', 'link-local', 'manual', 'shared']),
# Bond Specific vars # Bond Specific vars
mode=dict(type='str', default='balance-rr', mode=dict(type='str', default='balance-rr',
choices=['802.3ad', 'active-backup', 'balance-alb', 'balance-rr', 'balance-tlb', 'balance-xor', 'broadcast']), choices=['802.3ad', 'active-backup', 'balance-alb', 'balance-rr', 'balance-tlb', 'balance-xor', 'broadcast']),