deploy: add pogojig
This commit is contained in:
parent
54944fcd3d
commit
170ba6d418
14 changed files with 333 additions and 22 deletions
|
|
@ -13,9 +13,9 @@
|
||||||
|
|
||||||
- name: Download arch bootstrap image
|
- name: Download arch bootstrap image
|
||||||
get_url:
|
get_url:
|
||||||
url: http://mirror.rackspace.com/archlinux/iso/2019.03.01/archlinux-bootstrap-2019.03.01-x86_64.tar.gz
|
url: http://mirror.rackspace.com/archlinux/iso/2019.09.01/archlinux-bootstrap-2019.09.01-x86_64.tar.gz
|
||||||
dest: /tmp/arch-bootstrap.tar.xz
|
dest: /tmp/arch-bootstrap.tar.xz
|
||||||
checksum: sha256:865c8a25312b663e724923eecf0dfc626f4cd621e2cfcb19eafc69a4fc666756
|
checksum: sha256:9fc9f178db6f5c188be8884c0abf10c69418e7cd38a4389e866fac5d9961297d
|
||||||
when: create_container is changed
|
when: create_container is changed
|
||||||
|
|
||||||
- name: Create container image filesystem
|
- name: Create container image filesystem
|
||||||
|
|
|
||||||
1
checkouts/pogojig
Submodule
1
checkouts/pogojig
Submodule
|
|
@ -0,0 +1 @@
|
||||||
|
Subproject commit 04b34f73c1e0023ce4abdb9f1c9f0d9175247624
|
||||||
128
nginx.conf
128
nginx.conf
|
|
@ -36,9 +36,9 @@ http {
|
||||||
include /etc/nginx/conf.d/*.conf;
|
include /etc/nginx/conf.d/*.conf;
|
||||||
|
|
||||||
server {
|
server {
|
||||||
listen 80 default_server;
|
listen 80;
|
||||||
listen [::]:80 default_server;
|
listen [::]:80;
|
||||||
server_name gerbolyze.jaseg.net;
|
server_name .jaseg.net;
|
||||||
return 301 https://$host$request_uri;
|
return 301 https://$host$request_uri;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
@ -84,13 +84,6 @@ http {
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
server {
|
|
||||||
listen 80;
|
|
||||||
listen [::]:80;
|
|
||||||
server_name blog.jaseg.net blog.jaseg.net;
|
|
||||||
return 301 https://$host$request_uri;
|
|
||||||
}
|
|
||||||
|
|
||||||
server {
|
server {
|
||||||
listen 443 ssl http2;
|
listen 443 ssl http2;
|
||||||
listen [::]:443 ssl http2;
|
listen [::]:443 ssl http2;
|
||||||
|
|
@ -136,5 +129,120 @@ http {
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
server {
|
||||||
|
listen 443 ssl http2;
|
||||||
|
listen [::]:443 ssl http2;
|
||||||
|
server_name pogojig.jaseg.net;
|
||||||
|
root /usr/share/nginx/html;
|
||||||
|
|
||||||
|
ssl_certificate "/etc/letsencrypt/live/pogojig.jaseg.net/fullchain.pem";
|
||||||
|
ssl_certificate_key "/etc/letsencrypt/live/pogojig.jaseg.net/privkey.pem";
|
||||||
|
ssl_dhparam "/etc/letsencrypt/ssl-dhparams.pem";
|
||||||
|
include /etc/letsencrypt/options-ssl-nginx.conf;
|
||||||
|
|
||||||
|
ssl_stapling on;
|
||||||
|
ssl_stapling_verify on;
|
||||||
|
|
||||||
|
resolver 67.207.67.2 67.207.67.3 valid=300s;
|
||||||
|
resolver_timeout 10s;
|
||||||
|
|
||||||
|
add_header Strict-Transport-Security "max-age=86400";
|
||||||
|
|
||||||
|
# Load configuration files for the default server block.
|
||||||
|
include /etc/nginx/default.d/*.conf;
|
||||||
|
|
||||||
|
location ^~ /pogospace/ {
|
||||||
|
root /var/lib/pogojig/pogospace;
|
||||||
|
}
|
||||||
|
|
||||||
|
location / {
|
||||||
|
include uwsgi_params;
|
||||||
|
uwsgi_pass unix:/run/uwsgi/pogojig.socket;
|
||||||
|
}
|
||||||
|
|
||||||
|
error_page 404 /404.html;
|
||||||
|
location = /40x.html {
|
||||||
|
root /usr/share/nginx/html;
|
||||||
|
}
|
||||||
|
|
||||||
|
error_page 500 502 503 504 /50x.html;
|
||||||
|
location = /50x.html {
|
||||||
|
root /usr/share/nginx/html;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
server {
|
||||||
|
listen 443 ssl http2;
|
||||||
|
listen [::]:443 ssl http2;
|
||||||
|
server_name tracespace.jaseg.net;
|
||||||
|
root /usr/share/nginx/html;
|
||||||
|
|
||||||
|
ssl_certificate "/etc/letsencrypt/live/tracespace.jaseg.net/fullchain.pem";
|
||||||
|
ssl_certificate_key "/etc/letsencrypt/live/tracespace.jaseg.net/privkey.pem";
|
||||||
|
ssl_dhparam "/etc/letsencrypt/ssl-dhparams.pem";
|
||||||
|
include /etc/letsencrypt/options-ssl-nginx.conf;
|
||||||
|
|
||||||
|
ssl_stapling on;
|
||||||
|
ssl_stapling_verify on;
|
||||||
|
|
||||||
|
resolver 67.207.67.2 67.207.67.3 valid=300s;
|
||||||
|
resolver_timeout 10s;
|
||||||
|
|
||||||
|
add_header Strict-Transport-Security "max-age=86400";
|
||||||
|
|
||||||
|
# Load configuration files for the default server block.
|
||||||
|
include /etc/nginx/default.d/*.conf;
|
||||||
|
|
||||||
|
location / {
|
||||||
|
root /var/www/tracespace.jaseg.net;
|
||||||
|
}
|
||||||
|
|
||||||
|
error_page 404 /404.html;
|
||||||
|
location = /40x.html {
|
||||||
|
root /usr/share/nginx/html;
|
||||||
|
}
|
||||||
|
|
||||||
|
error_page 500 502 503 504 /50x.html;
|
||||||
|
location = /50x.html {
|
||||||
|
root /usr/share/nginx/html;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
server {
|
||||||
|
listen 443 ssl http2;
|
||||||
|
listen [::]:443 ssl http2;
|
||||||
|
server_name openjscad.jaseg.net;
|
||||||
|
root /usr/share/nginx/html;
|
||||||
|
|
||||||
|
ssl_certificate "/etc/letsencrypt/live/openjscad.jaseg.net/fullchain.pem";
|
||||||
|
ssl_certificate_key "/etc/letsencrypt/live/openjscad.jaseg.net/privkey.pem";
|
||||||
|
ssl_dhparam "/etc/letsencrypt/ssl-dhparams.pem";
|
||||||
|
include /etc/letsencrypt/options-ssl-nginx.conf;
|
||||||
|
|
||||||
|
ssl_stapling on;
|
||||||
|
ssl_stapling_verify on;
|
||||||
|
|
||||||
|
resolver 67.207.67.2 67.207.67.3 valid=300s;
|
||||||
|
resolver_timeout 10s;
|
||||||
|
|
||||||
|
add_header Strict-Transport-Security "max-age=86400";
|
||||||
|
|
||||||
|
# Load configuration files for the default server block.
|
||||||
|
include /etc/nginx/default.d/*.conf;
|
||||||
|
|
||||||
|
location / {
|
||||||
|
root /var/www/openjscad.jaseg.net;
|
||||||
|
}
|
||||||
|
|
||||||
|
error_page 404 /404.html;
|
||||||
|
location = /40x.html {
|
||||||
|
root /usr/share/nginx/html;
|
||||||
|
}
|
||||||
|
|
||||||
|
error_page 500 502 503 504 /50x.html;
|
||||||
|
location = /50x.html {
|
||||||
|
root /usr/share/nginx/html;
|
||||||
|
}
|
||||||
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
|
||||||
11
playbook.yml
11
playbook.yml
|
|
@ -48,6 +48,7 @@
|
||||||
containers:
|
containers:
|
||||||
- gerboweb
|
- gerboweb
|
||||||
- clippy
|
- clippy
|
||||||
|
- pogojig
|
||||||
|
|
||||||
- name: Setup web server
|
- name: Setup web server
|
||||||
include_tasks: setup_webserver.yml
|
include_tasks: setup_webserver.yml
|
||||||
|
|
@ -60,3 +61,13 @@
|
||||||
|
|
||||||
- name: Setup secure download
|
- name: Setup secure download
|
||||||
include_tasks: setup_secure_download.yml
|
include_tasks: setup_secure_download.yml
|
||||||
|
|
||||||
|
- name: Setup tracespace
|
||||||
|
include_tasks: setup_tracespace.yml
|
||||||
|
|
||||||
|
- name: Setup openjscad
|
||||||
|
include_tasks: setup_openjscad.yml
|
||||||
|
|
||||||
|
- name: Setup pogojig
|
||||||
|
include_tasks: setup_pogojig.yml
|
||||||
|
|
||||||
|
|
|
||||||
9
pogojig-job-processor.service.j2
Normal file
9
pogojig-job-processor.service.j2
Normal file
|
|
@ -0,0 +1,9 @@
|
||||||
|
[Unit]
|
||||||
|
Description=Pogojig render job processor
|
||||||
|
|
||||||
|
[Service]
|
||||||
|
WorkingDirectory=/var/lib/pogojig
|
||||||
|
ExecStart=/usr/bin/python3 job_processor.py {{pogojig_cache}}/job_queue.sqlite3
|
||||||
|
|
||||||
|
[Install]
|
||||||
|
WantedBy=uwsgi-app@pogojig.service
|
||||||
4
pogojig.cfg.j2
Normal file
4
pogojig.cfg.j2
Normal file
|
|
@ -0,0 +1,4 @@
|
||||||
|
MAX_CONTENT_LENGTH=10000000
|
||||||
|
SECRET_KEY="{{lookup('password', 'pogojig_flask_secret.txt length=32')}}"
|
||||||
|
UPLOAD_PATH="{{pogojig_cache}}/upload"
|
||||||
|
JOB_QUEUE_DB="{{pogojig_cache}}/job_queue.sqlite3"
|
||||||
1
pogojig_flask_secret.txt
Normal file
1
pogojig_flask_secret.txt
Normal file
|
|
@ -0,0 +1 @@
|
||||||
|
RhshDKyRVcg.5r4ulH:0f8Vhut0HoFS3
|
||||||
25
pogojig_generate.sh.j2
Executable file
25
pogojig_generate.sh.j2
Executable file
|
|
@ -0,0 +1,25 @@
|
||||||
|
#!/bin/sh
|
||||||
|
|
||||||
|
[ $# != 1 ] && exit 1
|
||||||
|
ID=$1
|
||||||
|
egrep -x -q '^[-0-9A-Za-z]{36}$'<<<"$ID" || exit 2
|
||||||
|
|
||||||
|
systemd-nspawn \
|
||||||
|
-D {{pogojig_root}} \
|
||||||
|
-x --bind={{pogojig_cache}}/upload/$ID:/mnt \
|
||||||
|
/bin/sh -c "set -euo pipefail
|
||||||
|
cd /mnt
|
||||||
|
|
||||||
|
date; echo 'Cleaning up previous output'
|
||||||
|
rm -rf pcb_shape.dxf jig.stl kicad kicad.zip sources.zip
|
||||||
|
|
||||||
|
date; echo 'Rendering'
|
||||||
|
cp -r /var/lib/pogojig_renderer sources
|
||||||
|
cp input.svg sources/
|
||||||
|
make -C sources
|
||||||
|
|
||||||
|
date; echo 'Packing source bundle'
|
||||||
|
cp -r sources/out/pcb_shape.dxf sources/out/jig.stl sources/out/kicad ./
|
||||||
|
zip -r sources.zip sources
|
||||||
|
zip -r kicad.zip kicad
|
||||||
|
rm -rf sources"
|
||||||
9
setup_openjscad.yml
Normal file
9
setup_openjscad.yml
Normal file
|
|
@ -0,0 +1,9 @@
|
||||||
|
---
|
||||||
|
- name: Copy openjscad webapp sources
|
||||||
|
synchronize:
|
||||||
|
# FIXME: make this path configurable
|
||||||
|
src: ~/openjscad_dist/
|
||||||
|
dest: /var/www/openjscad.jaseg.net/
|
||||||
|
group: no
|
||||||
|
owner: no
|
||||||
|
|
||||||
118
setup_pogojig.yml
Normal file
118
setup_pogojig.yml
Normal file
|
|
@ -0,0 +1,118 @@
|
||||||
|
---
|
||||||
|
- name: Set local facts
|
||||||
|
set_fact:
|
||||||
|
pogojig_cache: /var/cache/pogojig
|
||||||
|
|
||||||
|
- name: Copy render script
|
||||||
|
template:
|
||||||
|
src: pogojig_generate.sh.j2
|
||||||
|
dest: /usr/local/sbin/pogojig_generate.sh
|
||||||
|
mode: ug+x
|
||||||
|
|
||||||
|
- name: Install packages into pogojig container
|
||||||
|
shell: arch-chroot "{{pogojig_root}}" pacman -Syu --noconfirm python3 python-pip imagemagick unzip zip openscad inkscape make python-lxml xorg-server-xvfb
|
||||||
|
|
||||||
|
- name: Install python dependencies into pogojig container
|
||||||
|
shell: arch-chroot "{{pogojig_root}}" pip install -U --upgrade-strategy=eager ezdxf xvfbwrapper
|
||||||
|
|
||||||
|
- name: Install pogojig
|
||||||
|
synchronize:
|
||||||
|
# FIXME: make this path configurable
|
||||||
|
src: checkouts/pogojig/renderer/
|
||||||
|
dest: "{{pogojig_root}}/var/lib/pogojig_renderer"
|
||||||
|
group: no
|
||||||
|
|
||||||
|
- name: Copy webapp sources
|
||||||
|
synchronize:
|
||||||
|
# FIXME: make this path configurable
|
||||||
|
src: checkouts/pogojig/webapp/
|
||||||
|
dest: /var/lib/pogojig
|
||||||
|
group: no
|
||||||
|
owner: no
|
||||||
|
|
||||||
|
- name: Create web home for modified tracespace
|
||||||
|
file:
|
||||||
|
path: /var/lib/pogojig/pogospace
|
||||||
|
state: directory
|
||||||
|
owner: nginx
|
||||||
|
group: nginx
|
||||||
|
mode: 0550
|
||||||
|
|
||||||
|
- name: Unpack modified tracespace sources
|
||||||
|
unarchive:
|
||||||
|
src: resource/pogojig-tracespace.tar.gz
|
||||||
|
dest: /var/lib/pogojig/pogospace
|
||||||
|
extra_opts: [--strip-components=1]
|
||||||
|
owner: nginx
|
||||||
|
group: nginx
|
||||||
|
|
||||||
|
- name: Create uwsgi worker user and group
|
||||||
|
user:
|
||||||
|
name: uwsgi-pogojig
|
||||||
|
create_home: no
|
||||||
|
group: uwsgi
|
||||||
|
password: '!'
|
||||||
|
shell: /sbin/nologin
|
||||||
|
system: yes
|
||||||
|
|
||||||
|
- name: Template webapp config
|
||||||
|
template:
|
||||||
|
src: pogojig.cfg.j2
|
||||||
|
dest: /var/lib/pogojig/pogojig_prod.cfg
|
||||||
|
owner: uwsgi-pogojig
|
||||||
|
group: root
|
||||||
|
mode: 0660
|
||||||
|
|
||||||
|
- name: Copy uwsgi config
|
||||||
|
copy:
|
||||||
|
src: uwsgi-pogojig.ini
|
||||||
|
dest: /etc/uwsgi.d/pogojig.ini
|
||||||
|
owner: uwsgi-pogojig
|
||||||
|
group: uwsgi
|
||||||
|
mode: 440
|
||||||
|
|
||||||
|
- name: Copy job processor systemd service config
|
||||||
|
template:
|
||||||
|
src: pogojig-job-processor.service.j2
|
||||||
|
dest: /etc/systemd/system/pogojig-job-processor.service
|
||||||
|
|
||||||
|
- name: Enable uwsgi systemd socket
|
||||||
|
systemd:
|
||||||
|
daemon-reload: yes
|
||||||
|
name: uwsgi-app@pogojig.socket
|
||||||
|
enabled: yes
|
||||||
|
|
||||||
|
# FIXME the socket doesn't seem to work properly
|
||||||
|
- name: Enable uwsgi systemd service
|
||||||
|
systemd:
|
||||||
|
daemon-reload: yes
|
||||||
|
name: uwsgi-app@pogojig.service
|
||||||
|
enabled: yes
|
||||||
|
|
||||||
|
- name: Copy pogojig cache dir tmpfiles.d config
|
||||||
|
template:
|
||||||
|
src: tmpfiles-pogojig.conf.j2
|
||||||
|
dest: /etc/tmpfiles.d/pogojig.conf
|
||||||
|
owner: root
|
||||||
|
group: root
|
||||||
|
mode: 0644
|
||||||
|
register: pogojig_tmpfiles_config
|
||||||
|
|
||||||
|
- name: Kick systemd tmpfiles service to create cache dir
|
||||||
|
command: systemd-tmpfiles --create
|
||||||
|
when: pogojig_tmpfiles_config is changed
|
||||||
|
|
||||||
|
- name: Create job queue db
|
||||||
|
file:
|
||||||
|
path: "{{pogojig_cache}}/job_queue.sqlite3"
|
||||||
|
owner: root
|
||||||
|
group: uwsgi
|
||||||
|
mode: 0660
|
||||||
|
state: touch
|
||||||
|
|
||||||
|
- name: Enable and launch job processor
|
||||||
|
systemd:
|
||||||
|
name: pogojig-job-processor.service
|
||||||
|
enabled: yes
|
||||||
|
state: restarted
|
||||||
|
|
||||||
9
setup_tracespace.yml
Normal file
9
setup_tracespace.yml
Normal file
|
|
@ -0,0 +1,9 @@
|
||||||
|
---
|
||||||
|
- name: Copy tracespace webapp sources
|
||||||
|
synchronize:
|
||||||
|
# FIXME: make this path configurable
|
||||||
|
src: ~/tracespace_dist/
|
||||||
|
dest: /var/www/tracespace.jaseg.net/
|
||||||
|
group: no
|
||||||
|
owner: no
|
||||||
|
|
||||||
|
|
@ -9,13 +9,17 @@
|
||||||
groups: uwsgi
|
groups: uwsgi
|
||||||
append: yes
|
append: yes
|
||||||
|
|
||||||
- name: Create blog.jaseg.net content dir
|
- name: Create subdomain content dirs
|
||||||
file:
|
file:
|
||||||
path: /var/www/blog.jaseg.net
|
path: /var/www/{{item}}
|
||||||
state: directory
|
state: directory
|
||||||
owner: nginx
|
owner: nginx
|
||||||
group: nginx
|
group: nginx
|
||||||
mode: 0550
|
mode: 0550
|
||||||
|
loop:
|
||||||
|
- blog.jaseg.net
|
||||||
|
- tracespace.jaseg.net
|
||||||
|
- openjscad.jaseg.net
|
||||||
|
|
||||||
- name: Copy uwsgi systemd socket config
|
- name: Copy uwsgi systemd socket config
|
||||||
copy:
|
copy:
|
||||||
|
|
@ -38,15 +42,16 @@
|
||||||
enabled: yes
|
enabled: yes
|
||||||
state: restarted
|
state: restarted
|
||||||
|
|
||||||
- name: Create letsencrypt certificate for gerbolyze.jaseg.net
|
- name: Create subdomain letsencrypt certificates
|
||||||
command: certbot --nginx certonly -d gerbolyze.jaseg.net -n --agree-tos --email gerboweb@jaseg.net
|
command: certbot --nginx certonly -d {{item}} -n --agree-tos --email {{item}}-letsencrypt@jaseg.net
|
||||||
args:
|
args:
|
||||||
creates: /etc/letsencrypt/live/gerbolyze.jaseg.net/fullchain.pem
|
creates: /etc/letsencrypt/live/{{item}}/fullchain.pem
|
||||||
|
loop:
|
||||||
- name: Create letsencrypt certificate for blog.jaseg.net
|
- blog.jaseg.net
|
||||||
command: certbot --nginx certonly -d blog.jaseg.net -n --agree-tos --email blog@jaseg.net
|
- gerbolyze.jaseg.net
|
||||||
args:
|
- tracespace.jaseg.net
|
||||||
creates: /etc/letsencrypt/live/blog.jaseg.net/fullchain.pem
|
- openjscad.jaseg.net
|
||||||
|
- pogojig.jaseg.net
|
||||||
|
|
||||||
- name: Copy final nginx config
|
- name: Copy final nginx config
|
||||||
copy:
|
copy:
|
||||||
|
|
|
||||||
1
tmpfiles-pogojig.conf.j2
Normal file
1
tmpfiles-pogojig.conf.j2
Normal file
|
|
@ -0,0 +1 @@
|
||||||
|
d {{pogojig_cache}} 770 uwsgi-pogojig uwsgi 2d
|
||||||
10
uwsgi-pogojig.ini
Normal file
10
uwsgi-pogojig.ini
Normal file
|
|
@ -0,0 +1,10 @@
|
||||||
|
[uwsgi]
|
||||||
|
master = True
|
||||||
|
cheap = True
|
||||||
|
die-on-idle = False
|
||||||
|
manage-script-name = True
|
||||||
|
plugins = python3
|
||||||
|
chdir = /var/lib/pogojig
|
||||||
|
mount = /=pogojig:app
|
||||||
|
env = POGOJIG_SETTINGS=pogojig_prod.cfg
|
||||||
|
|
||||||
Loading…
Add table
Add a link
Reference in a new issue