--- - hosts: all become: yes remote_user: ansible gather_facts: true vars: docker_compose_definition: | services: wikmd: image: linbreux/wikmd:latest container_name: wikmd environment: - PUID=2002 - PGID=100 - TZ=US/Chicago volumes: - /data/wikmd:/wiki ports: - 5000:5000 restart: unless-stopped tasks: - name: set-debcache.yml - Setup apt proxy debcache import_tasks: ../../lib/set-debcache.yml - name: Upgrade-packages.yml - update packages import_tasks: ../../lib/upgrade-packages.yml - name: Install-docker.yml - setting up docker import_tasks: ../../lib/install-docker.yml - name: setup-restic.yml - setup restic import_tasks: ../../lib/setup-restic.yml - name: Setup-netbird.yml - setting up netbird mesh vpn import_tasks: ../../lib/setup-netbird.yml - name: Create wikmd user user: name: wikmd uid: 2002 group: users state: present create_home: yes home: /data shell: /bin/bash - name: Install Python Packages apt: name: - python3-full - python3-pip - python3-venv # Below are needed for wikmd install - libxml++2.6-dev - libxslt1-dev state: present update_cache: yes - name: Setup Service copy: dest: /etc/systemd/system/wikmd.service content: | [Unit] Description=Wikmd After=network.target [Service] User=wikmd WorkingDirectory=/data/wikmd ExecStart=/bin/bash StartWikmd.sh Restart=always [Install] WantedBy=multi-user.target owner: root group: root mode: '0644' # docker image is broken using manual install method - name: Write docker-compose.yml ansible.builtin.copy: content: "{{ docker_compose_definition }}" dest: /home/docker/docker-compose.yml owner: docker group: docker mode: u=rw,g=r,o=r - name: Start services community.docker.docker_compose_v2: project_src: /home/docker/ register: output - name: Check if wikmd directory exists stat: path: /data/wikmd register: wikmd_stat - name: Restore Wikmd Dir shell: | restic --password-file /home/restic/.resticpassword -r sftp:misamisa://home/restic/$(hostname) --target / restore latest args: chdir: /home/restic creates: /data/wikmd when: not wikmd_stat.stat.exists or not wikmd_stat.stat.isdir - name: Remove VENV directory ansible.builtin.file: path: /data/wikmd/venv state: absent #- name: Create VENV directory # command: # cmd: "python3 -m venv /data/wikmd/venv" # creates: "/data/wikmd/venv/bin/activate" #- name: Upgrade pip in virtual environment # pip: # requirements: "/data/wikmd/requirements.txt" # virtualenv: "/data/wikmd/venv" - name: Reload systemd daemon systemd: daemon_reload: yes - name: Start Wikmd Service systemd: name: wikmd state: started enabled: yes