summaryrefslogtreecommitdiffstats
path: root/qtip
diff options
context:
space:
mode:
authorYujun Zhang <zhang.yujunz@zte.com.cn>2017-04-07 07:32:00 +0000
committerGerrit Code Review <gerrit@opnfv.org>2017-04-07 07:32:00 +0000
commit1189453319e6a6994cfd7aa9c891d748337c191c (patch)
treeffd37d242cc881ac7aae77f57937bdcb3e7349dd /qtip
parent02e2c3372a654ffeb6cb34c6a0076da51cb568ea (diff)
parentc6c68d91a08dc9315da8c209e2046e9a0300c997 (diff)
Merge "Add ansible action plugin `collect`"
Diffstat (limited to 'qtip')
-rw-r--r--qtip/ansible_library/plugins/__init__.py0
-rw-r--r--qtip/ansible_library/plugins/action/__init__.py0
-rw-r--r--qtip/ansible_library/plugins/action/collect.py45
3 files changed, 45 insertions, 0 deletions
diff --git a/qtip/ansible_library/plugins/__init__.py b/qtip/ansible_library/plugins/__init__.py
new file mode 100644
index 00000000..e69de29b
--- /dev/null
+++ b/qtip/ansible_library/plugins/__init__.py
diff --git a/qtip/ansible_library/plugins/action/__init__.py b/qtip/ansible_library/plugins/action/__init__.py
new file mode 100644
index 00000000..e69de29b
--- /dev/null
+++ b/qtip/ansible_library/plugins/action/__init__.py
diff --git a/qtip/ansible_library/plugins/action/collect.py b/qtip/ansible_library/plugins/action/collect.py
new file mode 100644
index 00000000..88ad0e35
--- /dev/null
+++ b/qtip/ansible_library/plugins/action/collect.py
@@ -0,0 +1,45 @@
+#!/usr/bin/python
+
+###############################################################
+# Copyright (c) 2017 ZTE Corporation
+#
+# All rights reserved. This program and the accompanying materials
+# are made available under the terms of the Apache License, Version 2.0
+# which accompanies this distribution, and is available at
+# http://www.apache.org/licenses/LICENSE-2.0
+##############################################################################
+
+from collections import defaultdict
+import re
+
+from ansible.plugins.action import ActionBase
+
+
+class ActionModule(ActionBase):
+
+ def run(self, tmp=None, task_vars=None):
+ result = super(ActionModule, self).run(tmp, task_vars)
+
+ if result.get('skipped', False):
+ return result
+
+ string = self._task.args.get('string')
+ patterns = self._task.args.get('patterns')
+
+ return collect(patterns, string)
+
+
+def collect(patterns, string):
+ """collect all named subgroups of the match into a list keyed by subgroup name
+ """
+ captured = defaultdict(list)
+
+ if not isinstance(patterns, list):
+ patterns = [patterns]
+
+ for p in patterns:
+ for match_obj in re.finditer(p, string, re.MULTILINE):
+ for (key, value) in match_obj.groupdict().items():
+ captured[key].append(value)
+
+ return captured