- name: Set up packages as root block: - name: Add GPG apt: update_cache: yes name: - gnupg - sudo state: present - name: Import the NodeSource GPG key into apt apt_key: url: https://deb.nodesource.com/gpgkey/nodesource.gpg.key state: present - name: Add nodesource repository ansible.builtin.apt_repository: repo: deb https://deb.nodesource.com/node_20.x nodistro main update_cache: yes - name: Install packages apt: update_cache: yes name: - nodejs state: present - name: Add to dehydrated.conf become: true lineinfile: line: "{{ upload_server_name }}" path: /etc/dehydrated/domains.txt - name: Create or renew cert command: "dehydrated --cron" become: true - name: Create upload user become: true user: name: "{{ upload_user }}" shell: /bin/bash state: present - name: Ensure upload directory exists file: path: "{{ upload_dir }}" owner: "{{ upload_user }}" state: directory - name: Install precompiled version unarchive: src: https://github.com/psi-4ward/psitransfer/releases/download/v2.1.2/psitransfer-v2.1.2.tar.gz dest: "/home/{{ upload_user }}" remote_src: yes - name: Create link file: src: "/home/{{ upload_user }}/psitransfer-v2.1.2" dest: "/home/{{ upload_user }}/psitransfer" state: link - name: Upload production config become: true template: src: config.production.js dest: "/home/{{ upload_user }}/psitransfer/config.production.js" - name: Copy the SSL key become: true copy: remote_src: yes src: "{{ upload_ssl_key }}" dest: "/home/{{ upload_user }}/privkey.pem" - name: Copy the SSL cert become: true copy: remote_src: yes src: "{{ upload_ssl_cert }}" dest: "/home/{{ upload_user }}/fullchain.pem" owner: "{{ upload_user }}" group: "{{ upload_group }}" - name: Install dependencies npm: path: "/home/{{ upload_user }}/psitransfer" production: yes ci: yes - name: Add LibreJS tag start lineinfile: path: /home/{{ upload_user }}/psitransfer/public/app/{{ item.path }} line: // @license {{ item.license }} insertbefore: BOF loop: - path: common.js license: magnet:?xt=urn:btih:d3d9a9a6595521f9666a5e94cc830dab83b65699&dn=expat.txt Expat - path: upload.js license: magnet:?xt=urn:btih:d3d9a9a6595521f9666a5e94cc830dab83b65699&dn=expat.txt Expat - path: admin.js license: magnet:?xt=urn:btih:87f119ba0b429ba17a44b4bffcab33165ebdacc0&dn=freebsd.txt BSD-2-Clause - path: download.js license: magnet:?xt=urn:btih:87f119ba0b429ba17a44b4bffcab33165ebdacc0&dn=freebsd.txt BSD-2-Clause - name: Add license tag end lineinfile: path: /home/{{ upload_user }}/psitransfer/public/app/{{ item.path }} line: // @license-end loop: - path: common.js - path: upload.js - path: admin.js - path: download.js - name: Update head template template: src: head.pug dest: /home/{{ upload_user }}/psitransfer/public/pug/partials/head.pug - name: Change ownership file: path: "/home/{{ upload_user }}" owner: "{{ upload_user }}" group: "{{ upload_group }}" recurse: true - name: Create backup dir to use when the conference is done file: path: "{{ upload_done_dir }}" owner: "{{ upload_user }}" group: "{{ upload_group }}" state: directory - name: Create backup file to use when the conference is done template: src: index.html owner: "{{ upload_user }}" group: "{{ upload_group }}" mode: 0755 dest: "{{ upload_done_dir }}/index.html" - name: Install systemd configuration tags: system become: true template: src: upload.service dest: /etc/systemd/system/upload.service owner: root group: root mode: 0755 when: not use_initd - name: Create main configuration if needed template: src: nginx-site-config dest: /etc/nginx/sites-available/{{ upload_server_name }} - name: Make sure main configuration is enabled file: src: /etc/nginx/sites-available/{{ upload_server_name }} dest: /etc/nginx/sites-enabled/{{ upload_server_name }} owner: "{{ emacsconf_user }}" group: "{{ emacsconf_group }}" force: no state: link - name: Reload configuration become: true service: name: nginx state: reloaded - name: Restart Upload become: true when: upload_enabled service: name: upload state: restarted enabled: true - name: Stop upload become: true when: not upload_enabled service: name: upload state: stopped enabled: false