diff options
| author | Gage Greenhouse <gsggage@yahoo.com> | 2024-12-16 23:19:28 -0600 | 
|---|---|---|
| committer | Gage Greenhouse <gsggage@yahoo.com> | 2024-12-16 23:19:28 -0600 | 
| commit | d654e16b0d0cca6675478e6c4a4d98a71e40684c (patch) | |
| tree | 315701185065dd0905754267e9cf69b66d0e3a6b /src | |
| parent | 1da518c1100254b14b064de68844cfea372ea6ec (diff) | |
| download | vyos-1x-d654e16b0d0cca6675478e6c4a4d98a71e40684c.tar.gz vyos-1x-d654e16b0d0cca6675478e6c4a4d98a71e40684c.zip | |
T6950: Added if statement to check if the address key is defined
Diffstat (limited to 'src')
| -rw-r--r-- | src/migration-scripts/dns-dynamic/1-to-2 | 33 | 
1 files changed, 20 insertions, 13 deletions
| diff --git a/src/migration-scripts/dns-dynamic/1-to-2 b/src/migration-scripts/dns-dynamic/1-to-2 index 5dca9e32f..7f4938147 100644 --- a/src/migration-scripts/dns-dynamic/1-to-2 +++ b/src/migration-scripts/dns-dynamic/1-to-2 @@ -20,6 +20,10 @@  # - migrate "service dns dynamic address <interface> service <service> protocol dnsexit"  #        to "service dns dynamic address <interface> service <service> protocol dnsexit2" +# T6950: +# - add if statement to prevent processing of "service dns dynamic address" options if they don't exist +#        due to the fact they are no longer valid syntax +  from vyos.configtree import ConfigTree  base_path = ['service', 'dns', 'dynamic'] @@ -36,16 +40,19 @@ def migrate(config: ConfigTree) -> None:      if config.exists(timeout_path):          config.rename(timeout_path, 'interval') -    # Remove "service dns dynamic address <interface> web-options ..." when <interface> != "web" -    for address in config.list_nodes(address_path): -        if config.exists(address_path + [address, 'web-options']) and address != 'web': -            config.delete(address_path + [address, 'web-options']) - -    # Migrate "service dns dynamic address <interface> service <service> protocol dnsexit" -    #      to "service dns dynamic address <interface> service <service> protocol dnsexit2" -    for address in config.list_nodes(address_path): -        for svc_cfg in config.list_nodes(address_path + [address, 'service']): -            if config.exists(address_path + [address, 'service', svc_cfg, 'protocol']): -                protocol = config.return_value(address_path + [address, 'service', svc_cfg, 'protocol']) -                if protocol == 'dnsexit': -                    config.set(address_path + [address, 'service', svc_cfg, 'protocol'], 'dnsexit2') +    # T6950: Can't migrate address if it doesn't exist +    if config.exists(address_path): + +        # Remove "service dns dynamic address <interface> web-options ..." when <interface> != "web" +        for address in config.list_nodes(address_path): +            if config.exists(address_path + [address, 'web-options']) and address != 'web': +                config.delete(address_path + [address, 'web-options']) + +        # Migrate "service dns dynamic address <interface> service <service> protocol dnsexit" +        #      to "service dns dynamic address <interface> service <service> protocol dnsexit2" +        for address in config.list_nodes(address_path): +            for svc_cfg in config.list_nodes(address_path + [address, 'service']): +                if config.exists(address_path + [address, 'service', svc_cfg, 'protocol']): +                    protocol = config.return_value(address_path + [address, 'service', svc_cfg, 'protocol']) +                    if protocol == 'dnsexit': +                        config.set(address_path + [address, 'service', svc_cfg, 'protocol'], 'dnsexit2') | 
