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:
parent
b97c8ce8e7
commit
72ce1e8f14
1 changed files with 18 additions and 11 deletions
|
@ -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:
|
||||||
|
|
Loading…
Reference in a new issue