diff --git a/tasks/configure-shinken.yml b/tasks/configure-shinken.yml index 6dbbd8b..7cf57ea 100644 --- a/tasks/configure-shinken.yml +++ b/tasks/configure-shinken.yml @@ -9,6 +9,31 @@ notify: - restart shinken arbiter +# Following Jinja magic thanks to mikecee +# - name: Build list of admin users +# set_fact: +# admin_users="{{ shinken_contacts | sum(attribute='is_admin', start=[]) | unique }}" + +# - debug: +# msg: "{{ shinken_contacts.0 }}" +# +# - name: Populate admins list +# set_fact: +# admin_users: "{{ admin_users|default([]) | combine( item.name ) }}" +# with_items: shinken_contacts +# when: item.is_admin == 1 +# +# - name: Install admins contact group +# # with_items: "{{ admin_users }}" +# with_items: "{{ shinken_contacts }}" +# template: +# src: contactgroup-admin.cfg.tmpl +# dest: /etc/shinken/contactgroups/admin.cfg +# notify: +# - restart shinken arbiter + +# TODO: after figuring out admins, do that for users too + - name: Create configuration for services to monitor with_items: "{{ shinken_services }}" template: diff --git a/templates/contactgroup-admin.cfg.tmpl b/templates/contactgroup-admin.cfg.tmpl new file mode 100644 index 0000000..07eafd9 --- /dev/null +++ b/templates/contactgroup-admin.cfg.tmpl @@ -0,0 +1,14 @@ +# {{ ansible_managed }} +{% set admin_users = [0] -%} +{% for key, value in item.iteritems() %} + {% if key == 'is_admin' and value == '1' %} + {% set admin_users.append('item.name') %} + {% endif %} +{% endfor %} + +define contactgroup{ + contactgroup_name admins + alias admins + members {{ admin_users }} +} +