mirror of
				https://github.com/ansible-collections/community.general.git
				synced 2025-10-24 21:14:00 -07:00 
			
		
		
		
	* nmcli: new arguments to ignore automatic dns servers and gateways
Closes #1087
* Add changelog fragment
* Address review comments
(cherry picked from commit 1ad85849af)
Co-authored-by: Chih-Hsuan Yen <yan12125@gmail.com>
	
	
This commit is contained in:
		
					parent
					
						
							
								b1a4a0ff21
							
						
					
				
			
			
				commit
				
					
						4e1bf2d4ba
					
				
			
		
					 3 changed files with 75 additions and 1 deletions
				
			
		|  | @ -0,0 +1,2 @@ | ||||||
|  | minor_changes: | ||||||
|  |   - nmcli - add new options to ignore automatic DNS servers and gateways (https://github.com/ansible-collections/community.general/issues/1087). | ||||||
|  | @ -77,6 +77,12 @@ options: | ||||||
|             - Use the format C(192.0.2.1). |             - Use the format C(192.0.2.1). | ||||||
|             - This parameter is mutually_exclusive with never_default4 parameter. |             - This parameter is mutually_exclusive with never_default4 parameter. | ||||||
|         type: str |         type: str | ||||||
|  |     gw4_ignore_auto: | ||||||
|  |         description: | ||||||
|  |             - Ignore automatically configured IPv4 routes. | ||||||
|  |         type: bool | ||||||
|  |         default: false | ||||||
|  |         version_added: 3.2.0 | ||||||
|     routes4: |     routes4: | ||||||
|         description: |         description: | ||||||
|             - The list of ipv4 routes. |             - The list of ipv4 routes. | ||||||
|  | @ -107,6 +113,12 @@ options: | ||||||
|             - A list of DNS search domains. |             - A list of DNS search domains. | ||||||
|         elements: str |         elements: str | ||||||
|         type: list |         type: list | ||||||
|  |     dns4_ignore_auto: | ||||||
|  |         description: | ||||||
|  |             - Ignore automatically configured IPv4 name servers. | ||||||
|  |         type: bool | ||||||
|  |         default: false | ||||||
|  |         version_added: 3.2.0 | ||||||
|     method4: |     method4: | ||||||
|         description: |         description: | ||||||
|             - Configuration method to be used for IPv4. |             - Configuration method to be used for IPv4. | ||||||
|  | @ -125,6 +137,12 @@ options: | ||||||
|             - The IPv6 gateway for this interface. |             - The IPv6 gateway for this interface. | ||||||
|             - Use the format C(2001:db8::1). |             - Use the format C(2001:db8::1). | ||||||
|         type: str |         type: str | ||||||
|  |     gw6_ignore_auto: | ||||||
|  |         description: | ||||||
|  |             - Ignore automatically configured IPv6 routes. | ||||||
|  |         type: bool | ||||||
|  |         default: false | ||||||
|  |         version_added: 3.2.0 | ||||||
|     dns6: |     dns6: | ||||||
|         description: |         description: | ||||||
|             - A list of up to 3 dns servers. |             - A list of up to 3 dns servers. | ||||||
|  | @ -136,6 +154,12 @@ options: | ||||||
|             - A list of DNS search domains. |             - A list of DNS search domains. | ||||||
|         elements: str |         elements: str | ||||||
|         type: list |         type: list | ||||||
|  |     dns6_ignore_auto: | ||||||
|  |         description: | ||||||
|  |             - Ignore automatically configured IPv6 name servers. | ||||||
|  |         type: bool | ||||||
|  |         default: false | ||||||
|  |         version_added: 3.2.0 | ||||||
|     method6: |     method6: | ||||||
|         description: |         description: | ||||||
|             - Configuration method to be used for IPv6 |             - Configuration method to be used for IPv6 | ||||||
|  | @ -648,16 +672,20 @@ class Nmcli(object): | ||||||
|         self.type = module.params['type'] |         self.type = module.params['type'] | ||||||
|         self.ip4 = module.params['ip4'] |         self.ip4 = module.params['ip4'] | ||||||
|         self.gw4 = module.params['gw4'] |         self.gw4 = module.params['gw4'] | ||||||
|  |         self.gw4_ignore_auto = module.params['gw4_ignore_auto'] | ||||||
|         self.routes4 = module.params['routes4'] |         self.routes4 = module.params['routes4'] | ||||||
|         self.route_metric4 = module.params['route_metric4'] |         self.route_metric4 = module.params['route_metric4'] | ||||||
|         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.dns4_ignore_auto = module.params['dns4_ignore_auto'] | ||||||
|         self.method4 = module.params['method4'] |         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.gw6_ignore_auto = module.params['gw6_ignore_auto'] | ||||||
|         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.dns6_ignore_auto = module.params['dns6_ignore_auto'] | ||||||
|         self.method6 = module.params['method6'] |         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'] | ||||||
|  | @ -729,7 +757,9 @@ class Nmcli(object): | ||||||
|                 'ipv4.dhcp-client-id': self.dhcp_client_id, |                 'ipv4.dhcp-client-id': self.dhcp_client_id, | ||||||
|                 'ipv4.dns': self.dns4, |                 'ipv4.dns': self.dns4, | ||||||
|                 'ipv4.dns-search': self.dns4_search, |                 'ipv4.dns-search': self.dns4_search, | ||||||
|  |                 'ipv4.ignore-auto-dns': self.dns4_ignore_auto, | ||||||
|                 'ipv4.gateway': self.gw4, |                 'ipv4.gateway': self.gw4, | ||||||
|  |                 'ipv4.ignore-auto-routes': self.gw4_ignore_auto, | ||||||
|                 'ipv4.routes': self.routes4, |                 'ipv4.routes': self.routes4, | ||||||
|                 'ipv4.route-metric': self.route_metric4, |                 'ipv4.route-metric': self.route_metric4, | ||||||
|                 'ipv4.never-default': self.never_default4, |                 'ipv4.never-default': self.never_default4, | ||||||
|  | @ -737,7 +767,9 @@ class Nmcli(object): | ||||||
|                 'ipv6.addresses': self.ip6, |                 'ipv6.addresses': self.ip6, | ||||||
|                 'ipv6.dns': self.dns6, |                 'ipv6.dns': self.dns6, | ||||||
|                 'ipv6.dns-search': self.dns6_search, |                 'ipv6.dns-search': self.dns6_search, | ||||||
|  |                 'ipv6.ignore-auto-dns': self.dns6_ignore_auto, | ||||||
|                 'ipv6.gateway': self.gw6, |                 'ipv6.gateway': self.gw6, | ||||||
|  |                 'ipv6.ignore-auto-routes': self.gw6_ignore_auto, | ||||||
|                 'ipv6.method': self.ipv6_method, |                 'ipv6.method': self.ipv6_method, | ||||||
|             }) |             }) | ||||||
| 
 | 
 | ||||||
|  | @ -900,7 +932,11 @@ class Nmcli(object): | ||||||
|         if setting in ('bridge.stp', |         if setting in ('bridge.stp', | ||||||
|                        'bridge-port.hairpin-mode', |                        'bridge-port.hairpin-mode', | ||||||
|                        'connection.autoconnect', |                        'connection.autoconnect', | ||||||
|                        'ipv4.never-default'): |                        'ipv4.never-default', | ||||||
|  |                        'ipv4.ignore-auto-dns', | ||||||
|  |                        'ipv4.ignore-auto-routes', | ||||||
|  |                        'ipv6.ignore-auto-dns', | ||||||
|  |                        'ipv6.ignore-auto-routes'): | ||||||
|             return bool |             return bool | ||||||
|         elif setting in ('ipv4.dns', |         elif setting in ('ipv4.dns', | ||||||
|                          'ipv4.dns-search', |                          'ipv4.dns-search', | ||||||
|  | @ -1116,17 +1152,21 @@ def main(): | ||||||
|                       ]), |                       ]), | ||||||
|             ip4=dict(type='str'), |             ip4=dict(type='str'), | ||||||
|             gw4=dict(type='str'), |             gw4=dict(type='str'), | ||||||
|  |             gw4_ignore_auto=dict(type='bool', default=False), | ||||||
|             routes4=dict(type='list', elements='str'), |             routes4=dict(type='list', elements='str'), | ||||||
|             route_metric4=dict(type='int'), |             route_metric4=dict(type='int'), | ||||||
|             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'), | ||||||
|  |             dns4_ignore_auto=dict(type='bool', default=False), | ||||||
|             method4=dict(type='str', choices=['auto', 'link-local', 'manual', 'shared', 'disabled']), |             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'), | ||||||
|  |             gw6_ignore_auto=dict(type='bool', default=False), | ||||||
|             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'), | ||||||
|  |             dns6_ignore_auto=dict(type='bool', default=False), | ||||||
|             method6=dict(type='str', choices=['ignore', 'auto', 'dhcp', 'link-local', 'manual', 'shared']), |             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', | ||||||
|  |  | ||||||
|  | @ -95,8 +95,12 @@ connection.autoconnect:                 yes | ||||||
| ipv4.method:                            manual | ipv4.method:                            manual | ||||||
| ipv4.addresses:                         10.10.10.10/24 | ipv4.addresses:                         10.10.10.10/24 | ||||||
| ipv4.gateway:                           10.10.10.1 | ipv4.gateway:                           10.10.10.1 | ||||||
|  | ipv4.ignore-auto-dns:                   no | ||||||
|  | ipv4.ignore-auto-routes:                no | ||||||
| ipv4.never-default:                     no | ipv4.never-default:                     no | ||||||
| ipv6.method:                            auto | ipv6.method:                            auto | ||||||
|  | ipv6.ignore-auto-dns:                   no | ||||||
|  | ipv6.ignore-auto-routes:                no | ||||||
| """ | """ | ||||||
| 
 | 
 | ||||||
| TESTCASE_GENERIC_DNS4_SEARCH = [ | TESTCASE_GENERIC_DNS4_SEARCH = [ | ||||||
|  | @ -120,10 +124,14 @@ connection.autoconnect:                 yes | ||||||
| ipv4.method:                            manual | ipv4.method:                            manual | ||||||
| ipv4.addresses:                         10.10.10.10/24 | ipv4.addresses:                         10.10.10.10/24 | ||||||
| ipv4.gateway:                           10.10.10.1 | ipv4.gateway:                           10.10.10.1 | ||||||
|  | ipv4.ignore-auto-dns:                   no | ||||||
|  | ipv4.ignore-auto-routes:                no | ||||||
| ipv4.never-default:                     no | ipv4.never-default:                     no | ||||||
| ipv4.dns-search:                        search.redhat.com | ipv4.dns-search:                        search.redhat.com | ||||||
| ipv6.dns-search:                        search6.redhat.com | ipv6.dns-search:                        search6.redhat.com | ||||||
| ipv6.method:                            auto | ipv6.method:                            auto | ||||||
|  | ipv6.ignore-auto-dns:                   no | ||||||
|  | ipv6.ignore-auto-routes:                no | ||||||
| """ | """ | ||||||
| 
 | 
 | ||||||
| TESTCASE_GENERIC_ZONE = [ | TESTCASE_GENERIC_ZONE = [ | ||||||
|  | @ -147,8 +155,12 @@ connection.zone:                        external | ||||||
| ipv4.method:                            manual | ipv4.method:                            manual | ||||||
| ipv4.addresses:                         10.10.10.10/24 | ipv4.addresses:                         10.10.10.10/24 | ||||||
| ipv4.gateway:                           10.10.10.1 | ipv4.gateway:                           10.10.10.1 | ||||||
|  | ipv4.ignore-auto-dns:                   no | ||||||
|  | ipv4.ignore-auto-routes:                no | ||||||
| ipv4.never-default:                     no | ipv4.never-default:                     no | ||||||
| ipv6.method:                            auto | ipv6.method:                            auto | ||||||
|  | ipv6.ignore-auto-dns:                   no | ||||||
|  | ipv6.ignore-auto-routes:                no | ||||||
| """ | """ | ||||||
| 
 | 
 | ||||||
| TESTCASE_BOND = [ | TESTCASE_BOND = [ | ||||||
|  | @ -172,8 +184,12 @@ connection.autoconnect:                 yes | ||||||
| ipv4.method:                            manual | ipv4.method:                            manual | ||||||
| ipv4.addresses:                         10.10.10.10/24 | ipv4.addresses:                         10.10.10.10/24 | ||||||
| ipv4.gateway:                           10.10.10.1 | ipv4.gateway:                           10.10.10.1 | ||||||
|  | ipv4.ignore-auto-dns:                   no | ||||||
|  | ipv4.ignore-auto-routes:                no | ||||||
| ipv4.never-default:                     no | ipv4.never-default:                     no | ||||||
| ipv6.method:                            auto | ipv6.method:                            auto | ||||||
|  | ipv6.ignore-auto-dns:                   no | ||||||
|  | ipv6.ignore-auto-routes:                no | ||||||
| bond.options:                           mode=active-backup,primary=non_existent_primary | bond.options:                           mode=active-backup,primary=non_existent_primary | ||||||
| """ | """ | ||||||
| 
 | 
 | ||||||
|  | @ -199,8 +215,12 @@ connection.autoconnect:                 yes | ||||||
| ipv4.method:                            manual | ipv4.method:                            manual | ||||||
| ipv4.addresses:                         10.10.10.10/24 | ipv4.addresses:                         10.10.10.10/24 | ||||||
| ipv4.gateway:                           10.10.10.1 | ipv4.gateway:                           10.10.10.1 | ||||||
|  | ipv4.ignore-auto-dns:                   no | ||||||
|  | ipv4.ignore-auto-routes:                no | ||||||
| ipv4.never-default:                     no | ipv4.never-default:                     no | ||||||
| ipv6.method:                            auto | ipv6.method:                            auto | ||||||
|  | ipv6.ignore-auto-dns:                   no | ||||||
|  | ipv6.ignore-auto-routes:                no | ||||||
| bridge.mac-address:                     52:54:00:AB:CD:EF | bridge.mac-address:                     52:54:00:AB:CD:EF | ||||||
| bridge.stp:                             yes | bridge.stp:                             yes | ||||||
| bridge.max-age:                         100 | bridge.max-age:                         100 | ||||||
|  | @ -252,8 +272,12 @@ connection.autoconnect:                 yes | ||||||
| ipv4.method:                            manual | ipv4.method:                            manual | ||||||
| ipv4.addresses:                         10.10.10.10/24 | ipv4.addresses:                         10.10.10.10/24 | ||||||
| ipv4.gateway:                           10.10.10.1 | ipv4.gateway:                           10.10.10.1 | ||||||
|  | ipv4.ignore-auto-dns:                   no | ||||||
|  | ipv4.ignore-auto-routes:                no | ||||||
| ipv4.never-default:                     no | ipv4.never-default:                     no | ||||||
| ipv6.method:                            auto | ipv6.method:                            auto | ||||||
|  | ipv6.ignore-auto-dns:                   no | ||||||
|  | ipv6.ignore-auto-routes:                no | ||||||
| vlan.id:                                10 | vlan.id:                                10 | ||||||
| """ | """ | ||||||
| 
 | 
 | ||||||
|  | @ -343,8 +367,12 @@ connection.autoconnect:                 yes | ||||||
| 802-3-ethernet.mtu:                     auto | 802-3-ethernet.mtu:                     auto | ||||||
| ipv4.method:                            auto | ipv4.method:                            auto | ||||||
| ipv4.dhcp-client-id:                    00:11:22:AA:BB:CC:DD | ipv4.dhcp-client-id:                    00:11:22:AA:BB:CC:DD | ||||||
|  | ipv4.ignore-auto-dns:                   no | ||||||
|  | ipv4.ignore-auto-routes:                no | ||||||
| ipv4.never-default:                     no | ipv4.never-default:                     no | ||||||
| ipv6.method:                            auto | ipv6.method:                            auto | ||||||
|  | ipv6.ignore-auto-dns:                   no | ||||||
|  | ipv6.ignore-auto-routes:                no | ||||||
| """ | """ | ||||||
| 
 | 
 | ||||||
| TESTCASE_ETHERNET_STATIC = [ | TESTCASE_ETHERNET_STATIC = [ | ||||||
|  | @ -368,9 +396,13 @@ connection.autoconnect:                 yes | ||||||
| ipv4.method:                            manual | ipv4.method:                            manual | ||||||
| ipv4.addresses:                         10.10.10.10/24 | ipv4.addresses:                         10.10.10.10/24 | ||||||
| ipv4.gateway:                           10.10.10.1 | ipv4.gateway:                           10.10.10.1 | ||||||
|  | ipv4.ignore-auto-dns:                   no | ||||||
|  | ipv4.ignore-auto-routes:                no | ||||||
| ipv4.never-default:                     no | ipv4.never-default:                     no | ||||||
| ipv4.dns:                               1.1.1.1,8.8.8.8 | ipv4.dns:                               1.1.1.1,8.8.8.8 | ||||||
| ipv6.method:                            auto | ipv6.method:                            auto | ||||||
|  | ipv6.ignore-auto-dns:                   no | ||||||
|  | ipv6.ignore-auto-routes:                no | ||||||
| """ | """ | ||||||
| 
 | 
 | ||||||
| 
 | 
 | ||||||
|  |  | ||||||
		Loading…
	
	Add table
		Add a link
		
	
		Reference in a new issue