Compare commits
6 Commits
077f2ab15f
...
master
Author | SHA1 | Date | |
---|---|---|---|
8024449e2b
|
|||
37e659cfc3
|
|||
05d7cef80c
|
|||
6d843a0b65
|
|||
2b9420afa9
|
|||
889383f111
|
40
states/salt/minion/init.sls
Normal file
40
states/salt/minion/init.sls
Normal file
@ -0,0 +1,40 @@
|
|||||||
|
{%- set masters = ['salt.nerdhouse.io'] %}
|
||||||
|
|
||||||
|
salt-minion:
|
||||||
|
pkg.installed:
|
||||||
|
- version: latest
|
||||||
|
service.running:
|
||||||
|
- enable: true
|
||||||
|
- require:
|
||||||
|
- pkg: salt-minion
|
||||||
|
- file: /etc/salt/minion
|
||||||
|
|
||||||
|
restart-salt-minion:
|
||||||
|
cmd.run:
|
||||||
|
- name: sleep 10 && systemctl restart salt-minion
|
||||||
|
- bg: true
|
||||||
|
- order: last
|
||||||
|
- onchanges:
|
||||||
|
- pkg: salt-minion
|
||||||
|
- file: /etc/salt/minion
|
||||||
|
- require:
|
||||||
|
- cmd: check-minion-config
|
||||||
|
|
||||||
|
/etc/salt/minion:
|
||||||
|
file.managed:
|
||||||
|
- source: salt://{{ slspath }}/templates/minion.jinja
|
||||||
|
- template: jinja
|
||||||
|
- user: root
|
||||||
|
- group: root
|
||||||
|
- mode: 644
|
||||||
|
- context:
|
||||||
|
masters: {{ masters|json }}
|
||||||
|
- require:
|
||||||
|
- pkg: salt-minion
|
||||||
|
|
||||||
|
check-minion-config:
|
||||||
|
cmd.run:
|
||||||
|
- name: sudo salt-call --local --skip-grains test.true
|
||||||
|
- onchanges:
|
||||||
|
- pkg: salt-minion
|
||||||
|
- file: /etc/salt/minion
|
26
states/salt/minion/templates/minion.jinja
Normal file
26
states/salt/minion/templates/minion.jinja
Normal file
@ -0,0 +1,26 @@
|
|||||||
|
id: {{ grains.id|lower }}
|
||||||
|
log_level: info
|
||||||
|
ipv6: true
|
||||||
|
ssl: true
|
||||||
|
transport: tcp
|
||||||
|
|
||||||
|
# https://github.com/saltstack/salt/blob/b95213ec903402f25c1e0aeb3990fe8452ab63ce/conf/minion#L39-L47
|
||||||
|
# str, failover or disable
|
||||||
|
master_type: str
|
||||||
|
{% if masters is defined %}
|
||||||
|
master:
|
||||||
|
{%- for master in masters %}
|
||||||
|
- {{ master }}
|
||||||
|
{%- endfor %}
|
||||||
|
{%- endif %}
|
||||||
|
|
||||||
|
# set the default saltenv for highstate
|
||||||
|
# otherwise it tries to run all of them 🤔
|
||||||
|
saltenv: base
|
||||||
|
# useful for influencing git_pillar and gitfs at the same time
|
||||||
|
pillarenv_from_saltenv: true
|
||||||
|
|
||||||
|
enable_fqdns_grains: false
|
||||||
|
enable_gpu_grains: false
|
||||||
|
|
||||||
|
# vim: ft=yaml
|
@ -2,3 +2,4 @@
|
|||||||
'*':
|
'*':
|
||||||
- users
|
- users
|
||||||
- sshd
|
- sshd
|
||||||
|
- salt.minion
|
||||||
|
@ -16,4 +16,9 @@
|
|||||||
{%- if user.shell is defined %}
|
{%- if user.shell is defined %}
|
||||||
- shell: {{ user.shell }}
|
- shell: {{ user.shell }}
|
||||||
{%- endif %}
|
{%- endif %}
|
||||||
|
ssh_auth.manage:
|
||||||
|
- user: {{ name }}
|
||||||
|
{%- if user['ssh-keys'] is defined %}
|
||||||
|
- ssh_keys: {{ user['ssh-keys']|json }}
|
||||||
|
{%- endif %}
|
||||||
{%- endfor %}
|
{%- endfor %}
|
||||||
|
@ -1,15 +1,27 @@
|
|||||||
{%- set sudo_group = 'sudo' if grains.os|lower == 'debian' else 'wheel' %}
|
{%- set sudo_group = 'sudo' if grains.os|lower == 'debian' else 'wheel' %}
|
||||||
|
{%- set admin_groups = [sudo_group] %}
|
||||||
|
{%- if grains.init == 'systemd' %}
|
||||||
|
{%- do admin_groups.append('systemd-journal') %}
|
||||||
|
{%- endif %}
|
||||||
|
|
||||||
|
{# FIXME(frebib): manage Docker group instead of blindly adding it #}
|
||||||
|
{%- do admin_groups.append('docker') %}
|
||||||
|
|
||||||
frebib:
|
frebib:
|
||||||
groups:
|
groups:
|
||||||
- {{ sudo_group }}
|
{%- for group in admin_groups %}
|
||||||
|
- {{ group }}
|
||||||
|
{%- endfor %}
|
||||||
ssh-keys:
|
ssh-keys:
|
||||||
- ssh-ed25519 AAAAC3NzaC1lZDI1NTE5AAAAINk+sOUEXKsGqITyMhna9v77ADGagkr3YMpgZFkrvqcd frebib@frebib-PC
|
- ssh-ed25519 AAAAC3NzaC1lZDI1NTE5AAAAINk+sOUEXKsGqITyMhna9v77ADGagkr3YMpgZFkrvqcd frebib@frebib-PC
|
||||||
- ssh-ed25519 AAAAC3NzaC1lZDI1NTE5AAAAIBIGxhZPQM/3Ck+DNNM0CoIZTsvKqQLKq8fqQoO6fXzX frebib@frebib-OnePlus3
|
- ssh-ed25519 AAAAC3NzaC1lZDI1NTE5AAAAIBIGxhZPQM/3Ck+DNNM0CoIZTsvKqQLKq8fqQoO6fXzX frebib@frebib-OnePlus3
|
||||||
|
- ssh-ed25519 AAAAC3NzaC1lZDI1NTE5AAAAIL+T8ChEU9YmpE2BY77oEtKzedB8HWDSM5bErDN9gcvj frebib@frebib-Cf
|
||||||
|
|
||||||
adam:
|
adam:
|
||||||
groups:
|
groups:
|
||||||
- {{ sudo_group }}
|
{%- for group in admin_groups %}
|
||||||
|
- {{ group }}
|
||||||
|
{%- endfor %}
|
||||||
ssh-keys:
|
ssh-keys:
|
||||||
- ssh-rsa AAAAB3NzaC1yc2EAAAABJQAAAQEAiF/WxxMOOE/r8I/anF8gKarjNFmeoPuXNMYE0Hwo/NMqbJ9qKVONn+4fa5T99yhhAnYy92PBPxjmSsOqex28XZFh4I4GBGKh+Su1tJKLXsts1rbJmB1gSpKGbbjsiZcta4FqbiLKyUGL1wiV6GWucKdkC9lfTfocmH20tLbqSTryTAfy62oaEyEUSSATcwnl6ITF6BaQVGT8e78O4DpMYvYXFDa0nre0GlBigI0bAIHknmo+5JuL9i6RbnLr/zHMBiT3lnqQ8IO0JLNJD3ML/X/vgo3Htd6ovKe28YBi+LV+olpcFlQGSpNj+gE67UYb+Hw4mMTjzG4RhNHfQZCrNw== adampc
|
- ssh-rsa AAAAB3NzaC1yc2EAAAABJQAAAQEAiF/WxxMOOE/r8I/anF8gKarjNFmeoPuXNMYE0Hwo/NMqbJ9qKVONn+4fa5T99yhhAnYy92PBPxjmSsOqex28XZFh4I4GBGKh+Su1tJKLXsts1rbJmB1gSpKGbbjsiZcta4FqbiLKyUGL1wiV6GWucKdkC9lfTfocmH20tLbqSTryTAfy62oaEyEUSSATcwnl6ITF6BaQVGT8e78O4DpMYvYXFDa0nre0GlBigI0bAIHknmo+5JuL9i6RbnLr/zHMBiT3lnqQ8IO0JLNJD3ML/X/vgo3Htd6ovKe28YBi+LV+olpcFlQGSpNj+gE67UYb+Hw4mMTjzG4RhNHfQZCrNw== adampc
|
||||||
- ssh-rsa AAAAB3NzaC1yc2EAAAADAQABAAABAQDYo04d3a7J22F0NlAM1MeqmZrbF7iaF9p9whLQmq/gYgZnFKtW7G/rQCUUG5X8yEn5LXkc9SYdRceyaleNDAe0/uEJIbbm+VPgkShV+pyA8AbP4+OF95JKgCS6/B59IStF8GrVnX9krjYLYVwS3FqwvYt/ZkYriX4hkaTkf3FslLU7eEwrDec3RuGXhTDTdLdFyq6wXsI/bITX2C0b8D5obNNkyPJFVV1zshy9mQ5/5wjHYLyZhUSRzcY6xDOlxWmTSHseYG1U5espgba7t6ZaL/n44IrXzFsuXRIA74rx3ESAtCEesM3TaPI/Q8dHOYsCdDquTyccP/nEkDCxxhl3 adam-laptop
|
- ssh-rsa AAAAB3NzaC1yc2EAAAADAQABAAABAQDYo04d3a7J22F0NlAM1MeqmZrbF7iaF9p9whLQmq/gYgZnFKtW7G/rQCUUG5X8yEn5LXkc9SYdRceyaleNDAe0/uEJIbbm+VPgkShV+pyA8AbP4+OF95JKgCS6/B59IStF8GrVnX9krjYLYVwS3FqwvYt/ZkYriX4hkaTkf3FslLU7eEwrDec3RuGXhTDTdLdFyq6wXsI/bITX2C0b8D5obNNkyPJFVV1zshy9mQ5/5wjHYLyZhUSRzcY6xDOlxWmTSHseYG1U5espgba7t6ZaL/n44IrXzFsuXRIA74rx3ESAtCEesM3TaPI/Q8dHOYsCdDquTyccP/nEkDCxxhl3 adam-laptop
|
||||||
|
Reference in New Issue
Block a user