diff options
Diffstat (limited to 'ansible_collections/cisco/nxos/plugins/action/rollback.py')
-rw-r--r-- | ansible_collections/cisco/nxos/plugins/action/rollback.py | 125 |
1 files changed, 125 insertions, 0 deletions
diff --git a/ansible_collections/cisco/nxos/plugins/action/rollback.py b/ansible_collections/cisco/nxos/plugins/action/rollback.py new file mode 100644 index 00000000..3602c407 --- /dev/null +++ b/ansible_collections/cisco/nxos/plugins/action/rollback.py @@ -0,0 +1,125 @@ +# +# (c) 2016 Red Hat Inc. +# +# This file is part of Ansible +# +# Ansible is free software: you can redistribute it and/or modify +# it under the terms of the GNU General Public License as published by +# the Free Software Foundation, either version 3 of the License, or +# (at your option) any later version. +# +# Ansible is distributed in the hope that it will be useful, +# but WITHOUT ANY WARRANTY; without even the implied warranty of +# MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the +# GNU General Public License for more details. +# +# You should have received a copy of the GNU General Public License +# along with Ansible. If not, see <http://www.gnu.org/licenses/>. +# +from __future__ import absolute_import, division, print_function + + +__metaclass__ = type + +from ansible import constants as C +from ansible.module_utils.connection import Connection +from ansible.utils.display import Display +from ansible_collections.ansible.netcommon.plugins.action.network import ( + ActionModule as ActionNetworkModule, +) + + +display = Display() + + +class ActionModule(ActionNetworkModule): + def run(self, tmp=None, task_vars=None): + del tmp # tmp no longer has any effect + + module_name = self._task.action.split(".")[-1] + self._config_module = True if module_name in ["nxos_config", "config"] else False + persistent_connection = self._play_context.connection.split(".")[-1] + + warnings = [] + + if (self._play_context.connection == "httpapi") and module_name in ( + "nxos_file_copy", + "nxos_nxapi", + ): + return { + "failed": True, + "msg": "Connection httpapi is not valid for '%s' module." % (module_name), + } + + if module_name == "nxos_file_copy": + # when file_pull is enabled, the file_pull_timeout and connect_ssh_port options + # will override persistent_command_timeout and port + # this has been kept for backwards compatibility till these options are removed + if persistent_connection != "network_cli": + return { + "failed": True, + "msg": "Connection type must be fully qualified name for network_cli connection type, got %s" + % self._play_context.connection, + } + + conn = Connection(self._connection.socket_path) + file_pull = self._task.args.get("file_pull", False) + file_pull_timeout = self._task.args.get("file_pull_timeout", 300) + connect_ssh_port = self._task.args.get("connect_ssh_port", 22) + + if file_pull: + conn.set_option("persistent_command_timeout", file_pull_timeout) + conn.set_option("port", connect_ssh_port) + + if module_name == "nxos_install_os": + connection = self._connection + if connection.transport == "local": + persistent_command_timeout = C.PERSISTENT_COMMAND_TIMEOUT + persistent_connect_timeout = C.PERSISTENT_CONNECT_TIMEOUT + else: + persistent_command_timeout = connection.get_option("persistent_command_timeout") + persistent_connect_timeout = connection.get_option("persistent_connect_timeout") + + display.vvvv( + "PERSISTENT_COMMAND_TIMEOUT is %s" % str(persistent_command_timeout), + self._play_context.remote_addr, + ) + display.vvvv( + "PERSISTENT_CONNECT_TIMEOUT is %s" % str(persistent_connect_timeout), + self._play_context.remote_addr, + ) + if persistent_command_timeout < 600 or persistent_connect_timeout < 600: + msg = "PERSISTENT_COMMAND_TIMEOUT and PERSISTENT_CONNECT_TIMEOUT" + msg += " must be set to 600 seconds or higher when using nxos_install_os module." + msg += " Current persistent_command_timeout setting:" + str( + persistent_command_timeout, + ) + msg += " Current persistent_connect_timeout setting:" + str( + persistent_connect_timeout, + ) + return {"failed": True, "msg": msg} + + if persistent_connection in ("network_cli", "httpapi"): + if module_name == "nxos_gir": + conn = Connection(self._connection.socket_path) + persistent_command_timeout = conn.get_option("persistent_command_timeout") + gir_timeout = 200 + if persistent_command_timeout < gir_timeout: + conn.set_option("persistent_command_timeout", gir_timeout) + msg = "timeout value extended to %ss for nxos_gir" % gir_timeout + display.warning(msg) + + else: + return { + "failed": True, + "msg": "Connection type %s is not valid for this module" + % self._play_context.connection, + } + + result = super(ActionModule, self).run(task_vars=task_vars) + if warnings: + if "warnings" in result: + result["warnings"].extend(warnings) + else: + result["warnings"] = warnings + return result |