Merge pull request #49 from alkivi-sas/master
feat(macro): to use in several state
This commit is contained in:
commit
933b3c9b51
2 changed files with 29 additions and 0 deletions
22
sudoers/macros.sls
Normal file
22
sudoers/macros.sls
Normal file
|
@ -0,0 +1,22 @@
|
||||||
|
{%- macro sudoers(for_user, sudo, config, priority='20', state='present') -%}
|
||||||
|
{%- set filename = priority ~ '-' ~ for_user|replace('.','-') ~ '-' ~ sudo %}
|
||||||
|
|
||||||
|
{% if state == 'present' %}
|
||||||
|
/etc/sudoers.d/{{ filename }}:
|
||||||
|
file.managed:
|
||||||
|
- user: root
|
||||||
|
- group: root
|
||||||
|
- mode: 440
|
||||||
|
- template: jinja
|
||||||
|
- source: salt://sudoers/templates/sudoers.jinja
|
||||||
|
- context:
|
||||||
|
for_user: {{ for_user }}
|
||||||
|
sudo: {{ sudo }}
|
||||||
|
config: {{ config|tojson }}
|
||||||
|
|
||||||
|
{% elif state == 'absent' %}
|
||||||
|
/etc/sudoers.d/{{ filename }}:
|
||||||
|
file.absent
|
||||||
|
{% endif %}
|
||||||
|
|
||||||
|
{%- endmacro %}
|
7
sudoers/templates/sudoers.jinja
Normal file
7
sudoers/templates/sudoers.jinja
Normal file
|
@ -0,0 +1,7 @@
|
||||||
|
{%- if config.command is iterable and config.command is not string -%}
|
||||||
|
{% for command in config.command -%}
|
||||||
|
{{ for_user }} {{ config.privileges }}: {{ command }}
|
||||||
|
{% endfor %}
|
||||||
|
{%- else -%}
|
||||||
|
{{ for_user }} {{ config.privileges }}: {{ config.command }}
|
||||||
|
{%- endif -%}
|
Loading…
Reference in a new issue