Compare commits

...

4 Commits

Author SHA1 Message Date
fe0b002258 use home dir directly 2025-04-03 15:32:12 +02:00
f96e9dbecd remove unused submodule file 2025-04-03 14:50:21 +02:00
49581d9829 fix REUSE compliance 2025-04-03 14:49:41 +02:00
d66c55f2ab replace systemd user tasks with separated role 2025-04-03 14:49:07 +02:00
5 changed files with 18 additions and 46 deletions

4
.gitmodules vendored
View File

@@ -1,4 +0,0 @@
# SPDX-FileCopyrightText: 2023 Max Mehl <https://mehl.mx>
#
# SPDX-License-Identifier: Apache-2.0

View File

@@ -14,6 +14,7 @@ and makes sure all requirements and systemd jobs are set up properly.
## Requirements
* [ansible-role-users](https://src.mehl.mx/mxmehl/ansible-role-users)
* [ansible-role-systemd-user](https://src.mehl.mx/mxmehl/ansible-role-systemd-user)
## Configure

View File

@@ -1,3 +1,7 @@
# SPDX-FileCopyrightText: 2025 Max Mehl <https://mehl.mx>
#
# SPDX-License-Identifier: Apache-2.0
---
seafile_cron:
minute: "20"

View File

@@ -11,7 +11,7 @@ StartLimitBurst=3
[Service]
Type=simple
ExecStart=/usr/bin/seaf-daemon -c {{ seafile_local_user_info.home }}/.ccnet -d {{ seafile_local_user_info.home }}/config/seafile-data -w {{ seafile_local_user_info.home }}/config/seafile
ExecStart=/usr/bin/seaf-daemon -c %h/.ccnet -d %h/config/seafile-data -w %h/config/seafile
Restart=always
RestartSec=10
# Restart every day

View File

@@ -17,19 +17,12 @@
name:
- moreutils # chronic
- pipx
- systemd-container # necessary to use machinectl become_method
- seafile-cli
become: false # need to do this as root
- name: Register user info of {{ seafile_local_user.user }}
user:
name: "{{ seafile_local_user.user }}"
check_mode: true
register: seafile_local_user_info
- name: Define directory for Seafile mirror service as fact
set_fact:
seafile_mirror_dir: "{{ seafile_local_user_info.home }}/seafile_mirror"
seafile_mirror_dir: "~/seafile_mirror"
- name: Ensure directory for Seafile mirror service exists
file:
@@ -63,46 +56,24 @@
month: "{{ seafile_cron.month }}"
weekday: "{{ seafile_cron.weekday }}"
- name: Ensure user systemd directory exists
file:
path: "{{ seafile_local_user_info.home }}/.config/systemd/user/"
state: directory
mode: "0755"
- name: Ensure systemd service file is present
template:
src: seaf-daemon.service.j2
dest: "{{ seafile_local_user_info.home }}/.config/systemd/user/seaf-daemon.service"
mode: "0644"
- name: Ensure Seafile config dir exists
file:
path: "{{ seafile_local_user_info.home }}/config"
path: "~/config"
state: directory
mode: "0755"
- name: Ensure Seafile config dir is initialised
command:
cmd: seaf-cli init -d "{{ seafile_local_user_info.home }}/config"
cmd: seaf-cli init -d "~/config"
register: result
changed_when: '"already exists" not in result.stdout'
- name: "Check whether user is lingering: {{ seafile_local_user.user }}"
stat:
path: "/var/lib/systemd/linger/{{ seafile_local_user.user }}"
register: seafile_local_user_lingering
- name: Ensure systemd lingering is enabled for user {{ seafile_local_user.user }}
command: loginctl enable-linger {{ seafile_local_user.user }}
become: false
changed_when: false
when: not seafile_local_user_lingering.stat.exists
- name: Ensure systemd service is running and enabled
systemd:
name: seaf-daemon
state: started
enabled: true
daemon_reload: true
scope: user
become_method: community.general.machinectl # in order to get XDG_RUNTIME_DIR and user's DBUS session
- name: Setup systemd user service
include_role:
name: systemd-user
apply:
become: false
vars:
user: "{{ seafile_local_user.user }}"
service: seaf-daemon
copy_file: seaf-daemon.service