Compare commits

...

2 Commits

Author SHA1 Message Date
Jef Roosens b2ea4ad0d3
feat: update otter deployment 2025-06-17 18:32:56 +02:00
Jef Roosens 6d50983f84
chore: rename some things 2025-06-14 21:18:23 +02:00
9 changed files with 68 additions and 29 deletions

View File

@ -24,6 +24,6 @@ Ansible configuration repository for my homelab.
`static_ip` host var set to the desired static IP address
8. Comment out `ansible_ssh_user` in `group_vars/all/vars.yml`, as this
overwrites the one set in the hosts file
9. Run `ansible-playbook -i initial-hosts.ini first_run.yml`. This command will
9. Run `ansible-playbook -i inventory/initial_hosts.ini first_run.yml`. This command will
hang at the `restart networking` step; at this point you can Ctrl-C.

View File

@ -1,4 +1,4 @@
[defaults]
vault_password_file = .ansible-password
inventory = hosts.ini
inventory = inventory/local.ini
roles_path = roles

View File

@ -70,12 +70,12 @@
- restic-rest
tags: restic-rest
- name: Install Lander
hosts: nas
become: yes
roles:
- lander
tags: lander
# - name: Install Lander
# hosts: nas
# become: yes
# roles:
# - lander
# tags: lander
- hosts: nas
become: yes

View File

@ -1,9 +1,9 @@
- hosts: web
become: yes
roles:
- lander-web
tags: lander
# - hosts: web
# become: yes
# roles:
# - lander-web
# tags: lander
- hosts: web
become: yes
@ -83,8 +83,8 @@
- webdav-web
tags: webdav
# - hosts: web
# become: yes
# roles:
# - otter-web
# tags: otter
- hosts: web
become: yes
roles:
- otter-web
tags: otter

View File

@ -18,7 +18,7 @@
append: true
create_home: yes
shell: /bin/bash
password: "{{ vault_debian_pass | password_hash('sha512') }}"
password: "{{ debian_pass | password_hash('sha512') }}"
update_password: on_create
- name: Create SSH directory.

View File

@ -1,13 +1,13 @@
[Unit]
Description=Gpodder.net API implementation
After=docker.service
Requires=docker.service
After=network.target network-online.target
[Service]
Type=exec
WorkingDirectory=/etc/otter
ExecStart=/usr/bin/docker compose up
ExecStop=/usr/bin/docker compose down
User=otter
Group=otter
ExecStart=/usr/local/bin/otter serve -c /etc/otter/otter.toml
Restart=always
[Install]
WantedBy=multi-user.target

View File

@ -0,0 +1,7 @@
data_dir = "/mnt/data1/otter/data"
log_level = "debug"
[net]
type = "tcp"
domain = "0.0.0.0"
port = 8017

View File

@ -1,4 +1,27 @@
---
- name: Ensure binary is present
ansible.builtin.get_url:
url: 'https://git.rustybever.be/api/packages/Chewing_Bever/generic/otter/0.2.1/otter-linux-arm64'
dest: '/usr/local/bin/otter'
owner: 'root'
group: 'root'
mode: '755'
- name: Ensure system group exists
ansible.builtin.group:
name: 'otter'
gid: 204
system: true
state: present
- name: Ensure system user exists
ansible.builtin.user:
name: 'otter'
group: 'otter'
uid: 204
system: true
create_home: false
- name: Ensure data directory is present
ansible.builtin.file:
path: '/mnt/data1/otter'
@ -18,8 +41,8 @@
path: "/mnt/data1/otter/{{ item }}"
state: directory
mode: '0755'
owner: '82'
group: '82'
owner: '204'
group: '204'
loop:
- 'data'
@ -29,10 +52,19 @@
state: directory
mode: '0755'
- name: Ensure compose file is present
# - name: Ensure compose file is present
# ansible.builtin.copy:
# src: 'compose.yml'
# dest: '/etc/otter/compose.yml'
# mode: '0644'
# owner: 'root'
# group: 'root'
# notify: 'restart otter'
- name: Ensure config file is present
ansible.builtin.copy:
src: 'compose.yml'
dest: '/etc/otter/compose.yml'
src: 'otter.toml'
dest: '/etc/otter/otter.toml'
mode: '0644'
owner: 'root'
group: 'root'