summaryrefslogtreecommitdiff
diff options
context:
space:
mode:
authorRicardo Carrillo Cruz <ricardo.carrillo.cruz@gmail.com>2017-03-28 10:20:52 +0200
committerRicardo Carrillo Cruz <ricardo.carrillo.cruz@gmail.com>2017-03-29 22:53:14 +0200
commit664b27aaf0c820647b704c6d39af4449dbbc2e44 (patch)
tree62f8f6de717eb8e96f799a1b2a9524f6e5ebf445
parent3859551eb328339c17645cab4cc8ad2a0c70f145 (diff)
downloadansible-664b27aaf0c820647b704c6d39af4449dbbc2e44.tar.gz
Introspect flag to use on 'show run' when using defaults in ios_config (#22903)
When the ios_config module has 'defaults' param it runs in the device the command 'show running-config all' but 'all' may not be available in older devices. This change makes introspection by using the help command and run 'full' in case 'all' is not available. Fixes #22747
-rw-r--r--lib/ansible/module_utils/ios.py10
-rw-r--r--lib/ansible/modules/network/ios/ios_config.py3
2 files changed, 12 insertions, 1 deletions
diff --git a/lib/ansible/module_utils/ios.py b/lib/ansible/module_utils/ios.py
index 38412f6eaf..480c8f9880 100644
--- a/lib/ansible/module_utils/ios.py
+++ b/lib/ansible/module_utils/ios.py
@@ -50,6 +50,16 @@ def check_args(module, warnings):
warnings.append('argument %s has been deprecated and will be '
'removed in a future version' % key)
+def get_defaults_flag(module):
+ rc, out, err = exec_command(module, 'show running-config ?')
+
+ commands = set()
+ for line in out.splitlines():
+ if line:
+ commands.add(line.strip().split()[0])
+
+ return 'all' if 'all' in commands else 'full'
+
def get_config(module, flags=[]):
cmd = 'show running-config '
cmd += ' '.join(flags)
diff --git a/lib/ansible/modules/network/ios/ios_config.py b/lib/ansible/modules/network/ios/ios_config.py
index 95d8edcb45..7876068785 100644
--- a/lib/ansible/modules/network/ios/ios_config.py
+++ b/lib/ansible/modules/network/ios/ios_config.py
@@ -206,6 +206,7 @@ import re
import time
from ansible.module_utils.ios import run_commands, get_config, load_config
+from ansible.module_utils.ios import get_defaults_flag
from ansible.module_utils.ios import ios_argument_spec
from ansible.module_utils.ios import check_args as ios_check_args
from ansible.module_utils.basic import AnsibleModule
@@ -266,7 +267,7 @@ def get_running_config(module):
if not contents:
flags = []
if module.params['defaults']:
- flags.append('all')
+ flags.append(get_defaults_flag(module))
contents = get_config(module, flags=flags)
contents, banners = extract_banners(contents)
return NetworkConfig(indent=1, contents=contents), banners