- Rolle signage_player: baut Binary lokal (linux/arm64), deployt es, schreibt config.json per Template, installiert und aktiviert systemd-Unit - inventory.yml mit Host info10 (10.0.0.200) - group_vars/signage_players: getrennte vars.yml (oeffentlich) und vault.yml (Secrets, gitignored) fuer MQTT-Credentials - host_vars/info10: ansible_host, ansible_user, screen_id - site.yml zeigt auf signage_players-Gruppe und signage_player-Rolle - Binaries und vault.yml in .gitignore Co-Authored-By: Claude Sonnet 4.6 <noreply@anthropic.com>
59 lines
1.3 KiB
YAML
59 lines
1.3 KiB
YAML
---
|
|
- name: Build agent binary for linux/arm64
|
|
ansible.builtin.command:
|
|
cmd: go build -o {{ role_path }}/files/morz-agent ./cmd/agent
|
|
chdir: "{{ playbook_dir }}/../player/agent"
|
|
environment:
|
|
GOOS: linux
|
|
GOARCH: arm64
|
|
delegate_to: localhost
|
|
changed_when: true
|
|
|
|
- name: Ensure config directory exists
|
|
ansible.builtin.file:
|
|
path: "{{ signage_config_dir }}"
|
|
state: directory
|
|
owner: root
|
|
group: root
|
|
mode: "0755"
|
|
become: true
|
|
|
|
- name: Deploy agent config
|
|
ansible.builtin.template:
|
|
src: config.json.j2
|
|
dest: "{{ signage_config_dir }}/config.json"
|
|
owner: root
|
|
group: "{{ signage_user }}"
|
|
mode: "0640"
|
|
become: true
|
|
notify: Restart morz-agent
|
|
|
|
- name: Deploy agent binary
|
|
ansible.builtin.copy:
|
|
src: morz-agent
|
|
dest: "{{ signage_binary_dest }}"
|
|
owner: root
|
|
group: root
|
|
mode: "0755"
|
|
become: true
|
|
notify: Restart morz-agent
|
|
|
|
- name: Deploy systemd unit
|
|
ansible.builtin.template:
|
|
src: morz-agent.service.j2
|
|
dest: /etc/systemd/system/morz-agent.service
|
|
owner: root
|
|
group: root
|
|
mode: "0644"
|
|
become: true
|
|
notify:
|
|
- Reload systemd
|
|
- Restart morz-agent
|
|
|
|
- name: Enable and start morz-agent
|
|
ansible.builtin.systemd:
|
|
name: morz-agent
|
|
enabled: true
|
|
state: started
|
|
daemon_reload: false
|
|
become: true
|