Commit ed09076b authored by David Wilson's avatar David Wilson

ansible: automatically configure connection plug-in.

parent a35fcf44
...@@ -26,6 +26,7 @@ ...@@ -26,6 +26,7 @@
# OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE. # OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE.
from __future__ import absolute_import from __future__ import absolute_import
import os
import mitogen import mitogen
import mitogen.master import mitogen.master
...@@ -36,7 +37,7 @@ import ansible_mitogen.action.mitogen ...@@ -36,7 +37,7 @@ import ansible_mitogen.action.mitogen
import ansible.errors import ansible.errors
import ansible.plugins.strategy.linear import ansible.plugins.strategy.linear
from ansible.plugins import action_loader import ansible.plugins
class ContextProxyService(mitogen.service.Service): class ContextProxyService(mitogen.service.Service):
...@@ -59,25 +60,40 @@ class ContextProxyService(mitogen.service.Service): ...@@ -59,25 +60,40 @@ class ContextProxyService(mitogen.service.Service):
class StrategyModule(ansible.plugins.strategy.linear.StrategyModule): class StrategyModule(ansible.plugins.strategy.linear.StrategyModule):
def run(self, *args, **kwargs): def __init__(self, *args, **kwargs):
super(StrategyModule, self).__init__(*args, **kwargs)
self.add_connection_plugin_path()
def add_connection_plugin_path(self):
"""Automatically add the connection plug-in directory to the
ModuleLoader path, reduces end-user configuration."""
# ansible_mitogen base directory:
basedir = os.path.dirname(os.path.dirname(__file__))
conn_dir = os.path.join(basedir, 'connection')
ansible.plugins.connection_loader.add_directory(conn_dir)
def run(self, iterator, play_context, result=0):
self.router = mitogen.master.Router() self.router = mitogen.master.Router()
self.listener = mitogen.unix.Listener(self.router, path='/tmp/mitosock') self.listener = mitogen.unix.Listener(self.router, path='/tmp/mitosock')
self.service = ContextProxyService(self.router) self.service = ContextProxyService(self.router)
mitogen.utils.log_to_file() mitogen.utils.log_to_file()
if play_context.connection == 'ssh':
play_context.connection = 'mitogen'
import threading import threading
th = threading.Thread(target=self.service.run) th = threading.Thread(target=self.service.run)
th.setDaemon(True) th.setDaemon(True)
th.start() th.start()
real_get = action_loader.get real_get = ansible.plugins.action_loader.get
def get(name, *args, **kwargs): def get(name, *args, **kwargs):
if name == 'normal': if name == 'normal':
return ansible_mitogen.action.mitogen.ActionModule(*args, **kwargs) return ansible_mitogen.action.mitogen.ActionModule(*args, **kwargs)
return real_get(name, *args, **kwargs) return real_get(name, *args, **kwargs)
action_loader.get = get ansible.plugins.action_loader.get = get
try: try:
return super(StrategyModule, self).run(*args, **kwargs) return super(StrategyModule, self).run(iterator, play_context)
finally: finally:
self.router.broker.shutdown() self.router.broker.shutdown()
[defaults] [defaults]
inventory = hosts inventory = hosts
connection_plugins = ../../ansible_mitogen/connection
strategy_plugins = ../../ansible_mitogen/strategy strategy_plugins = ../../ansible_mitogen/strategy
strategy = mitogen strategy = mitogen
connection = mitogen
retry_files_enabled = False retry_files_enabled = False
[ssh_connection] [ssh_connection]
......
Markdown is supported
0%
or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment