bugfix eos shared module handling config replace

fixes an issue with doing a config replace using eapi where the configuration
wasn't being replaced.
This commit is contained in:
Peter Sprygada 2016-04-05 22:45:46 -04:00
parent b97c8ce8e7
commit 72ce1e8f14

View file

@ -159,8 +159,10 @@ class Cli(object):
key_filename = self.module.params['ssh_keyfile'] key_filename = self.module.params['ssh_keyfile']
try: try:
self.shell = Shell(CLI_PROMPTS_RE, CLI_ERRORS_RE) self.shell = Shell(prompts_re=CLI_PROMPTS_RE,
self.shell.open(host, port=port, username=username, password=password, key_filename=key_filename) errors_re=CLI_ERRORS_RE)
self.shell.open(host, port=port, username=username,
password=password, key_filename=key_filename)
except Exception, exc: except Exception, exc:
msg = 'failed to connect to %s:%s - %s' % (host, port, str(exc)) msg = 'failed to connect to %s:%s - %s' % (host, port, str(exc))
self.module.fail_json(msg=msg) self.module.fail_json(msg=msg)
@ -204,24 +206,30 @@ class NetworkModule(AnsibleModule):
return params return params
def connect(self): def connect(self):
if self.params['transport'] == 'eapi':
self.connection = Eapi(self)
else:
self.connection = Cli(self)
try: try:
cls = globals().get(str(self.params['transport']).capitalize())
self.connection = cls(self)
self.connection.connect() self.connection.connect()
self.connection.send('terminal length 0') self.connection.send('terminal length 0')
if self.params['authorize']: if self.params['authorize']:
self.connection.authorize() self.connection.authorize()
except AttributeError, exc:
self.fail_json(msg=exc.message)
except Exception, exc: except Exception, exc:
self.fail_json(msg=exc.message) self.fail_json(msg=exc.message)
self._connected = True self._connected = True
def configure(self, commands): def configure(self, commands, replace=False):
if replace:
responses = self.config_replace(commands)
else:
responses = self.config_terminal(commands)
return responses
def config_terminal(self, commands):
commands = to_list(commands) commands = to_list(commands)
commands.insert(0, 'configure terminal') commands.insert(0, 'configure terminal')
responses = self.execute(commands) responses = self.execute(commands)
@ -231,11 +239,10 @@ class NetworkModule(AnsibleModule):
def config_replace(self, commands): def config_replace(self, commands):
if self.params['transport'] == 'cli': if self.params['transport'] == 'cli':
self.fail_json(msg='config replace only supported over eapi') self.fail_json(msg='config replace only supported over eapi')
cmd = 'configure replace terminal:' cmd = 'configure replace terminal:'
commands = '\n'.join(to_list(commands)) commands = '\n'.join(to_list(commands))
command = dict(cmd=cmd, input=commands) command = dict(cmd=cmd, input=commands)
self.execute(command) return self.execute(command)
def execute(self, commands, **kwargs): def execute(self, commands, **kwargs):
try: try: