# (c) 2012-2014, Michael DeHaan # # 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 . # Make coding more python3-ish from __future__ import (absolute_import, division, print_function) __metaclass__ = type import json from ansible.plugins.callback import CallbackBase class CallbackModule(CallbackBase): ''' This is the default callback interface, which simply prints messages to stdout when new callback events are received. ''' def _print_banner(self, msg): ''' Prints a header-looking line with stars taking up to 80 columns of width (3 columns, minimum) ''' msg = msg.strip() star_len = (80 - len(msg)) if star_len < 0: star_len = 3 stars = "*" * star_len self._display.display("\n%s %s\n" % (msg, stars)) def on_any(self, *args, **kwargs): pass def runner_on_failed(self, task, result, ignore_errors=False): self._display.display("%s | FAILED! => %s" % (result._host.get_name(), result._result), color='red') def runner_on_ok(self, task, result): self._display.display("%s | SUCCESS => %s" % (result._host.get_name(), json.dumps(result._result, indent=4)), color='green') def runner_on_skipped(self, task, result): pass def runner_on_unreachable(self, task, result): self._display.display("%s | UNREACHABLE!" % result._host.get_name(), color='yellow') def runner_on_no_hosts(self, task): pass def runner_on_async_poll(self, host, res, jid, clock): pass def runner_on_async_ok(self, host, res, jid): pass def runner_on_async_failed(self, host, res, jid): pass def playbook_on_start(self): pass def playbook_on_notify(self, host, handler): pass def playbook_on_no_hosts_matched(self): pass def playbook_on_no_hosts_remaining(self): pass def playbook_on_task_start(self, name, is_conditional): pass def playbook_on_cleanup_task_start(self, name): pass def playbook_on_handler_task_start(self, name): pass def playbook_on_vars_prompt(self, varname, private=True, prompt=None, encrypt=None, confirm=False, salt_size=None, salt=None, default=None): pass def playbook_on_setup(self): pass def playbook_on_import_for_host(self, host, imported_file): pass def playbook_on_not_import_for_host(self, host, missing_file): pass def playbook_on_play_start(self, name): pass def playbook_on_stats(self, stats): pass