From 6a5d07ecc75d4859d0b4f4bea86fd4deee7fc485 Mon Sep 17 00:00:00 2001 From: Ceri Storey Date: Tue, 7 May 2013 17:20:26 +0100 Subject: [PATCH 1/3] Allow specification of the node we wish to connect to. --- library/messaging/rabbitmq_parameter | 17 +++++++++++++---- library/messaging/rabbitmq_user | 17 +++++++++++++---- library/messaging/rabbitmq_vhost | 17 +++++++++++++---- 3 files changed, 39 insertions(+), 12 deletions(-) diff --git a/library/messaging/rabbitmq_parameter b/library/messaging/rabbitmq_parameter index 96962d9638..58e77428d4 100644 --- a/library/messaging/rabbitmq_parameter +++ b/library/messaging/rabbitmq_parameter @@ -47,6 +47,11 @@ options: - vhost to apply access privileges. required: false default: / + node: + description: + - erlang node name of the rabbit we wish to configure + required: false + default: rabbit state: description: - Specify if user is to be added or removed @@ -61,20 +66,22 @@ rabbitmq_parameter: component=federation name=local-username value='"guest"' sta """ class RabbitMqParameter(object): - def __init__(self, module, component, name, value, vhost): + def __init__(self, module, component, name, value, vhost, node): self.module = module self.component = component self.name = name self.value = value self.vhost = vhost + self.node = node self._value = None self._rabbitmqctl = module.get_bin_path('rabbitmqctl', True) + self._env = module.get_bin_path('env', True) def _exec(self, args, run_in_check_mode=False): if not self.module.check_mode or (self.module.check_mode and run_in_check_mode): - cmd = [self._rabbitmqctl, '-q'] + cmd = [self._env, 'RABBITMQ_NODENAME=%s' % self.node, self._rabbitmqctl, '-q'] rc, out, err = self.module.run_command(cmd + args, check_rc=True) return out.splitlines() return list() @@ -105,7 +112,8 @@ def main(): name=dict(required=True), value=dict(default=None), vhost=dict(default='/'), - state=dict(default='present', choices=['present', 'absent']) + state=dict(default='present', choices=['present', 'absent']), + node=dict(default='rabbit') ) module = AnsibleModule( argument_spec=arg_spec, @@ -117,8 +125,9 @@ def main(): value = module.params['value'] vhost = module.params['vhost'] state = module.params['state'] + node = module.params['node'] - rabbitmq_parameter = RabbitMqParameter(module, component, name, value, vhost) + rabbitmq_parameter = RabbitMqParameter(module, component, name, value, vhost, node) changed = False if rabbitmq_parameter.get(): diff --git a/library/messaging/rabbitmq_user b/library/messaging/rabbitmq_user index ee4c7550e0..1f38c5fd50 100644 --- a/library/messaging/rabbitmq_user +++ b/library/messaging/rabbitmq_user @@ -48,6 +48,11 @@ options: - vhost to apply access privileges. required: false default: / + node: + description: + - erlang node name of the rabbit we wish to configure + required: false + default: rabbit configure_priv: description: - Regular expression to restrict configure actions on a resource @@ -87,10 +92,11 @@ examples: ''' class RabbitMqUser(object): - def __init__(self, module, username, password, tags, vhost, configure_priv, write_priv, read_priv): + def __init__(self, module, username, password, tags, vhost, configure_priv, write_priv, read_priv, node): self.module = module self.username = username self.password = password + self.node = node if tags is None: self.tags = list() else: @@ -107,10 +113,11 @@ class RabbitMqUser(object): self._tags = None self._permissions = None self._rabbitmqctl = module.get_bin_path('rabbitmqctl', True) + self._env = module.get_bin_path('env', True) def _exec(self, args, run_in_check_mode=False): if not self.module.check_mode or (self.module.check_mode and run_in_check_mode): - cmd = [self._rabbitmqctl, '-q'] + cmd = [self._env, 'RABBITMQ_NODENAME=%s' % self.node, self._rabbitmqctl, '-q'] rc, out, err = self.module.run_command(cmd + args, check_rc=True) return out.splitlines() return list() @@ -179,7 +186,8 @@ def main(): write_priv=dict(default='^$'), read_priv=dict(default='^$'), force=dict(default='no', type='bool'), - state=dict(default='present', choices=['present', 'absent']) + state=dict(default='present', choices=['present', 'absent']), + node=dict(default='rabbit') ) module = AnsibleModule( argument_spec=arg_spec, @@ -195,8 +203,9 @@ def main(): read_priv = module.params['read_priv'] force = module.params['force'] state = module.params['state'] + node = module.params['node'] - rabbitmq_user = RabbitMqUser(module, username, password, tags, vhost, configure_priv, write_priv, read_priv) + rabbitmq_user = RabbitMqUser(module, username, password, tags, vhost, configure_priv, write_priv, read_priv, node) changed = False if rabbitmq_user.get(): diff --git a/library/messaging/rabbitmq_vhost b/library/messaging/rabbitmq_vhost index 9ebcc207f8..b3404ff264 100644 --- a/library/messaging/rabbitmq_vhost +++ b/library/messaging/rabbitmq_vhost @@ -34,6 +34,11 @@ options: required: true default: null aliases: [vhost] + node: + description: + - erlang node name of the rabbit we wish to configure + required: false + default: rabbit tracing: description: - Enable/disable tracing for a vhost @@ -51,17 +56,19 @@ examples: ''' class RabbitMqVhost(object): - def __init__(self, module, name, tracing): + def __init__(self, module, name, tracing, node): self.module = module self.name = name self.tracing = tracing + self.node = node self._tracing = False self._rabbitmqctl = module.get_bin_path('rabbitmqctl', True) + self._env = module.get_bin_path('env', True) def _exec(self, args, run_in_check_mode=False): if not self.module.check_mode or (self.module.check_mode and run_in_check_mode): - cmd = [self._rabbitmqctl, '-q'] + cmd = [self._env, 'RABBITMQ_NODENAME=%s' % self.node, self._rabbitmqctl, '-q'] rc, out, err = self.module.run_command(cmd + args, check_rc=True) return out.splitlines() return list() @@ -102,7 +109,8 @@ def main(): arg_spec = dict( name=dict(required=True, aliases=['vhost']), tracing=dict(default='off', aliases=['trace'], type='bool'), - state=dict(default='present', choices=['present', 'absent']) + state=dict(default='present', choices=['present', 'absent']), + node=dict(default='rabbit'), ) module = AnsibleModule( @@ -113,8 +121,9 @@ def main(): name = module.params['name'] tracing = module.params['tracing'] state = module.params['state'] + node = module.params['node'] - rabbitmq_vhost = RabbitMqVhost(module, name, tracing) + rabbitmq_vhost = RabbitMqVhost(module, name, tracing, node) changed = False if rabbitmq_vhost.get(): From 72b60286e119dbd432c3848a3278355fe9029b1c Mon Sep 17 00:00:00 2001 From: Ceri Storey Date: Wed, 8 May 2013 15:34:51 +0100 Subject: [PATCH 2/3] Fix whitespace, changing tabs to spaces. --- library/messaging/rabbitmq_parameter | 4 ++-- library/messaging/rabbitmq_user | 2 +- library/messaging/rabbitmq_vhost | 2 +- 3 files changed, 4 insertions(+), 4 deletions(-) diff --git a/library/messaging/rabbitmq_parameter b/library/messaging/rabbitmq_parameter index 58e77428d4..c5b2a51065 100644 --- a/library/messaging/rabbitmq_parameter +++ b/library/messaging/rabbitmq_parameter @@ -72,12 +72,12 @@ class RabbitMqParameter(object): self.name = name self.value = value self.vhost = vhost - self.node = node + self.node = node self._value = None self._rabbitmqctl = module.get_bin_path('rabbitmqctl', True) - self._env = module.get_bin_path('env', True) + self._env = module.get_bin_path('env', True) def _exec(self, args, run_in_check_mode=False): if not self.module.check_mode or (self.module.check_mode and run_in_check_mode): diff --git a/library/messaging/rabbitmq_user b/library/messaging/rabbitmq_user index 1f38c5fd50..6e84d32545 100644 --- a/library/messaging/rabbitmq_user +++ b/library/messaging/rabbitmq_user @@ -96,7 +96,7 @@ class RabbitMqUser(object): self.module = module self.username = username self.password = password - self.node = node + self.node = node if tags is None: self.tags = list() else: diff --git a/library/messaging/rabbitmq_vhost b/library/messaging/rabbitmq_vhost index b3404ff264..f37edb8970 100644 --- a/library/messaging/rabbitmq_vhost +++ b/library/messaging/rabbitmq_vhost @@ -60,7 +60,7 @@ class RabbitMqVhost(object): self.module = module self.name = name self.tracing = tracing - self.node = node + self.node = node self._tracing = False self._rabbitmqctl = module.get_bin_path('rabbitmqctl', True) From c01992b56496a992c98f4a433b48792e44312e7a Mon Sep 17 00:00:00 2001 From: Ceri Storey Date: Sun, 26 May 2013 14:51:50 +0100 Subject: [PATCH 3/3] Update rabbitmq_user/vhost/parameter to pass the node to rabbitmqctl using -n flag to rabbitmqctl rather than setting the environment variable. --- library/messaging/rabbitmq_parameter | 3 +-- library/messaging/rabbitmq_user | 3 +-- library/messaging/rabbitmq_vhost | 3 +-- 3 files changed, 3 insertions(+), 6 deletions(-) diff --git a/library/messaging/rabbitmq_parameter b/library/messaging/rabbitmq_parameter index c5b2a51065..fe0b2a4f68 100644 --- a/library/messaging/rabbitmq_parameter +++ b/library/messaging/rabbitmq_parameter @@ -77,11 +77,10 @@ class RabbitMqParameter(object): self._value = None self._rabbitmqctl = module.get_bin_path('rabbitmqctl', True) - self._env = module.get_bin_path('env', True) def _exec(self, args, run_in_check_mode=False): if not self.module.check_mode or (self.module.check_mode and run_in_check_mode): - cmd = [self._env, 'RABBITMQ_NODENAME=%s' % self.node, self._rabbitmqctl, '-q'] + cmd = [self._rabbitmqctl, '-q', '-n', self.node] rc, out, err = self.module.run_command(cmd + args, check_rc=True) return out.splitlines() return list() diff --git a/library/messaging/rabbitmq_user b/library/messaging/rabbitmq_user index 6e84d32545..ad38de8bb5 100644 --- a/library/messaging/rabbitmq_user +++ b/library/messaging/rabbitmq_user @@ -113,11 +113,10 @@ class RabbitMqUser(object): self._tags = None self._permissions = None self._rabbitmqctl = module.get_bin_path('rabbitmqctl', True) - self._env = module.get_bin_path('env', True) def _exec(self, args, run_in_check_mode=False): if not self.module.check_mode or (self.module.check_mode and run_in_check_mode): - cmd = [self._env, 'RABBITMQ_NODENAME=%s' % self.node, self._rabbitmqctl, '-q'] + cmd = [self._rabbitmqctl, '-q', '-n', self.node] rc, out, err = self.module.run_command(cmd + args, check_rc=True) return out.splitlines() return list() diff --git a/library/messaging/rabbitmq_vhost b/library/messaging/rabbitmq_vhost index f37edb8970..6a99bd56c6 100644 --- a/library/messaging/rabbitmq_vhost +++ b/library/messaging/rabbitmq_vhost @@ -64,11 +64,10 @@ class RabbitMqVhost(object): self._tracing = False self._rabbitmqctl = module.get_bin_path('rabbitmqctl', True) - self._env = module.get_bin_path('env', True) def _exec(self, args, run_in_check_mode=False): if not self.module.check_mode or (self.module.check_mode and run_in_check_mode): - cmd = [self._env, 'RABBITMQ_NODENAME=%s' % self.node, self._rabbitmqctl, '-q'] + cmd = [self._rabbitmqctl, '-q', '-n', self.node] rc, out, err = self.module.run_command(cmd + args, check_rc=True) return out.splitlines() return list()