music/trollibox: Run as a distinct user

This commit is contained in:
polyfloyd 2025-05-16 17:35:47 +02:00
parent e9f31417b7
commit 8e5b9f6b30
4 changed files with 22 additions and 14 deletions

View file

@ -1,4 +1,10 @@
---
- name: Create trollibox user
user:
name: "{{ music_trollibox_user }}"
system: true
home: /var/lib/trollibox
- name: Install Trollibox config
ansible.builtin.template:
src: trollibox.yaml
@ -6,27 +12,29 @@
owner: root
group: root
mode: "0644"
notify: Restart trollibox
notify: restart trollibox
- name: Get latest Trollibox version from Github API
ansible.builtin.get_url:
uri:
url: "https://api.github.com/repos/polyfloyd/trollibox/releases/latest"
dest: "/tmp/_ansible_trollibox_latest_release.json"
return_content: true
register: response
changed_when: false
check_mode: false
failed_when: "response is failed or 'json' not in response"
- name: Get download url
ansible.builtin.shell:
cmd: cat /tmp/_ansible_trollibox_latest_release.json | jq .assets[] | select(.name
| contains("linux-amd64")) | .browser_download_url -r
register: "trollibox_download_url"
- name: Format trollibox latest version
set_fact:
trollibox_version: "{{ response['json']['tag_name'] | trim('v') }}"
- name: Download Trollibox
ansible.builtin.unarchive:
src: "{{ trollibox_download_url.stdout }}"
src: "https://github.com/polyfloyd/trollibox/releases/download/v{{ trollibox_version }}/trollibox-x86_64-unknown-linux-gnu.tar.gz"
remote_src: yes
dest: /usr/local/bin
include: [ trollibox ]
mode: "0755"
notify: Restart trollibox
notify: restart trollibox
- name: Install service file
ansible.builtin.template:
@ -35,7 +43,7 @@
owner: root
group: root
mode: "0644"
notify: Restart trollibox
notify: restart trollibox
- name: Enable Trollibox
ansible.builtin.systemd: