{%- set tplroot = tpldir.split('/')[0] %} {%- from tplroot ~ "/map.jinja" import salt_settings with context %} {%- from tplroot ~ "/libtofs.jinja" import files_switch with context %} {% if salt_settings.hold_version is defined and salt_settings.install_packages %} include: - .hold {% endif %} {%- if grains.os == 'MacOS' %} {% if salt_settings.install_packages %} download-salt-minion: {% if salt_settings.salt_minion_pkg_source %} {# minion upgrade? #} file.managed: - name: '/tmp/salt.pkg' - source: {{ salt_settings.salt_minion_pkg_source }} {%- if salt_settings.salt_minion_pkg_hash %} - source_hash: {{ salt_settings.salt_minion_pkg_hash }} {% else %} - skip_verify: True {% endif %} - user: root - group: wheel - mode: '0644' - unless: - test -n "{{ salt_settings.version }}" && '/opt/salt/bin/salt-minion --version=.*{{ salt_settings.version }}.*' - require_in: - macpackage: salt-minion - retry: {{ salt_settings.retry_options | json }} {%- elif "workaround https://github.com/saltstack/salt/issues/49348" %} cmd.run: - name: /usr/local/bin/brew install {{ salt_settings.salt_minion }} - onlyif: test -x /usr/local/bin/brew - runas: {{ salt_settings.rootuser }} {%- endif %} salt-minion-macos: file.managed: - onlyif: {{ grains.os == 'MacOS' }} - name: /Library/LaunchDaemons/com.saltstack.salt.minion.plist - source: https://raw.githubusercontent.com/saltstack/salt/master/pkg/osx/scripts/com.saltstack.salt.master.plist - source_hash: {{ salt_settings.salt_minion_macos_plist_hash }} - retry: {{ salt_settings.retry_options | json }} - require_in: - service: salt-minion - watch_in: - service: salt-minion {%- endif %} {%- endif %} salt-minion: {% if salt_settings.install_packages %} {%- if grains.os == 'MacOS' and salt_settings.salt_minion_pkg_source %} macpackage.installed: - name: '/tmp/salt.pkg' - target: / {# macpackage.installed is weird with version_check, detects diff but incomplete install #} - force: True {# workaround #} - unless: - test -n "{{ salt_settings.version }}" && '/opt/salt/bin/salt-minion --version=.*{{ salt_settings.version }}.*' {% if salt_settings.minion_service_details.state != 'ignore' %} - require_in: - service: salt-minion {% endif %} - onchanges_in: - cmd: remove-macpackage-salt {%- elif grains.os != 'MacOS' and "workaround https://github.com/saltstack/salt/issues/49348" %} pkg.installed: - name: {{ salt_settings.salt_minion }} {%- if salt_settings.version is defined %} - version: {{ salt_settings.version }} {%- endif %} {%- if salt_settings.hold_version is defined %} - hold: {{ salt_settings.hold_version }} {%- endif %} {%- if salt_settings.update_holds is defined %} - update_holds: {{ salt_settings.update_holds }} {%- endif %} {% if salt_settings.minion_service_details.state != 'ignore' %} - require_in: - service: salt-minion {% endif %} {%- endif %} {% endif %} file.recurse: - name: {{ salt_settings.config_path | path_join('minion.d') }} {%- if salt_settings.minion_config_use_TOFS %} - template: '' - source: {{ files_switch(['minion.d'], lookup='salt-minion' ) }} {%- else %} - template: jinja - source: salt://{{ tplroot }}/files/minion.d - context: standalone: False {%- endif %} - clean: {{ salt_settings.clean_config_d_dir }} - exclude_pat: _* {% if salt_settings.minion_service_details.state != 'ignore' %} service.{{ salt_settings.minion_service_details.state }}: - enable: {{ salt_settings.minion_service_details.enabled }} - name: {{ salt_settings.minion_service }} {%- if grains.os_family == 'FreeBSD' %} - retry: {{ salt_settings.retry_options | json }} {%- endif %} - watch: - file: remove-old-minion-conf-file - order: last {% endif %} {%- if not salt_settings.restart_via_at %} cmd.run: {%- if grains['saltversioninfo'] >= [ 2016, 3 ] %} {%- if grains['kernel'] == 'Windows' %} - name: 'salt-call.bat --local service.restart {{ salt_settings.minion_service }}' {%- else %} - name: 'salt-call --local service.restart {{ salt_settings.minion_service }} --out-file /dev/null' {%- endif %} - bg: True {%- else %} {%- if grains['kernel'] == 'Windows' %} - name: 'start powershell "Restart-Service -Name {{ salt_settings.minion_service }}"' {%- else %} # old style, pre 2016.3. fork and disown the process - name: |- exec 0>&- # close stdin exec 1>&- # close stdout exec 2>&- # close stderr nohup salt-call --local service.restart {{ salt_settings.minion_service }} --out-file /dev/null & {%- endif %} {%- endif %} - onchanges: {%- if salt_settings.install_packages %} {%- if grains.os == 'MacOS' and salt_settings.salt_minion_pkg_source %} - macpackage: salt-minion {%- elif grains.os == 'MacOS' %} - cmd: download-salt-minion {%- else %} - pkg: salt-minion {%- endif %} {%- endif %} - file: salt-minion - file: remove-old-minion-conf-file {%- else %} {% if grains.os_family not in ['MacOS', 'FreeBSD'] %} {# MacOS and FreeBSD have the 'at' command; but there's no package to install #} at: pkg.installed: - require_in: restart-salt-minion {% endif %} restart-salt-minion: cmd.run: - name: echo salt-call --local service.restart {{ salt_settings.minion_service }} | at now + 1 minute - order: last - onchanges: {%- if salt_settings.install_packages %} {%- if grains.os == 'MacOS' and salt_settings.salt_minion_pkg_source %} - macpackage: salt-minion {%- elif grains.os == 'MacOS' %} - cmd: download-salt-minion {%- else %} - pkg: salt-minion {%- endif %} {%- endif %} - file: salt-minion - file: remove-old-minion-conf-file {%- endif %} {% if 'inotify' in salt_settings.get('minion', {}).get('beacons', {}) and salt_settings.get('pyinotify', False) %} salt-minion-beacon-inotify: pkg.installed: - name: {{ salt_settings.pyinotify }} - require_in: - service: salt-minion - watch_in: - service: salt-minion {% endif %} {% if salt_settings.minion_remove_config %} remove-default-minion-conf-file: file.absent: - name: {{ salt_settings.config_path }}/minion {% endif %} # clean up old _defaults.conf file if they have it around remove-old-minion-conf-file: file.absent: - name: {{ salt_settings.config_path | path_join('minion.d', '_defaults.conf') }} {% if grains.os == 'MacOS' %} remove-macpackage-salt: file.absent: - name: /tmp/salt.pkg - force: True {% endif %} {% if not salt_settings.minion_remove_config %} permissions-minion-config: file.managed: - name: {{ salt_settings.config_path | path_join('minion') }} - user: {{ salt_settings.rootuser }} - group: {%- if grains['kernel'] in ['FreeBSD', 'OpenBSD', 'NetBSD'] %} wheel {%- else %} root {%- endif %} {%- if grains['kernel'] != 'Windows' %} - mode: 640 {% endif %} - replace: False {% endif %} salt-minion-pki-dir: file.directory: {% if 'pki_dir' in salt_settings.minion %} - name: {{ salt_settings.minion.pki_dir }} {% else %} - name: {{ salt_settings.config_path | path_join('pki', 'minion') }} {% endif %} - user: {{ salt_settings.rootuser }} - group: {%- if grains['kernel'] in ['FreeBSD', 'OpenBSD', 'NetBSD'] %} wheel {%- else %} root {%- endif %} {%- if grains['kernel'] != 'Windows' %} - mode: 700 {% endif %} - makedirs: True permissions-minion.pem: file.managed: {% if 'pki_dir' in salt_settings.minion %} - name: {{ salt_settings.minion.pki_dir | path_join('minion.pem') }} {% else %} - name: {{ salt_settings.config_path | path_join('pki', 'minion', 'minion.pem') }} {% endif %} - user: {{ salt_settings.rootuser }} - group: {%- if grains['kernel'] in ['FreeBSD', 'OpenBSD', 'NetBSD'] %} wheel {%- else %} root {%- endif %} {%- if grains['kernel'] != 'Windows' %} - mode: 400 {% endif %} - replace: False - require: - file: salt-minion-pki-dir permissions-minion.pub: file.managed: {% if 'pki_dir' in salt_settings.minion %} - name: {{ salt_settings.minion.pki_dir | path_join('minion.pub') }} {% else %} - name: {{ salt_settings.config_path | path_join('pki', 'minion', 'minion.pub') }} {% endif %} - user: {{ salt_settings.rootuser }} - group: {%- if grains['kernel'] in ['FreeBSD', 'OpenBSD', 'NetBSD'] %} wheel {%- else %} root {%- endif %} {%- if grains['kernel'] != 'Windows' %} - mode: 644 {% endif %} - replace: False - require: - file: salt-minion-pki-dir