deploy: add pogojig
This commit is contained in:
parent
0ada527f0b
commit
aaacaed220
15 changed files with 336 additions and 22 deletions
3
.gitmodules
vendored
Normal file
3
.gitmodules
vendored
Normal file
|
|
@ -0,0 +1,3 @@
|
|||
[submodule "gerboweb/deploy/checkouts/pogojig"]
|
||||
path = gerboweb/deploy/checkouts/pogojig
|
||||
url = https://github.com/jaseg/pogojig.git
|
||||
|
|
@ -13,9 +13,9 @@
|
|||
|
||||
- name: Download arch bootstrap image
|
||||
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
|
||||
checksum: sha256:865c8a25312b663e724923eecf0dfc626f4cd621e2cfcb19eafc69a4fc666756
|
||||
checksum: sha256:9fc9f178db6f5c188be8884c0abf10c69418e7cd38a4389e866fac5d9961297d
|
||||
when: create_container is changed
|
||||
|
||||
- name: Create container image filesystem
|
||||
|
|
|
|||
1
gerboweb/deploy/checkouts/pogojig
Submodule
1
gerboweb/deploy/checkouts/pogojig
Submodule
|
|
@ -0,0 +1 @@
|
|||
Subproject commit 04b34f73c1e0023ce4abdb9f1c9f0d9175247624
|
||||
|
|
@ -36,9 +36,9 @@ http {
|
|||
include /etc/nginx/conf.d/*.conf;
|
||||
|
||||
server {
|
||||
listen 80 default_server;
|
||||
listen [::]:80 default_server;
|
||||
server_name gerbolyze.jaseg.net;
|
||||
listen 80;
|
||||
listen [::]:80;
|
||||
server_name .jaseg.net;
|
||||
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 {
|
||||
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;
|
||||
}
|
||||
}
|
||||
}
|
||||
|
||||
|
|
|
|||
|
|
@ -48,6 +48,7 @@
|
|||
containers:
|
||||
- gerboweb
|
||||
- clippy
|
||||
- pogojig
|
||||
|
||||
- name: Setup web server
|
||||
include_tasks: setup_webserver.yml
|
||||
|
|
@ -60,3 +61,13 @@
|
|||
|
||||
- name: Setup secure download
|
||||
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
gerboweb/deploy/pogojig-job-processor.service.j2
Normal file
9
gerboweb/deploy/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
gerboweb/deploy/pogojig.cfg.j2
Normal file
4
gerboweb/deploy/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
gerboweb/deploy/pogojig_flask_secret.txt
Normal file
1
gerboweb/deploy/pogojig_flask_secret.txt
Normal file
|
|
@ -0,0 +1 @@
|
|||
RhshDKyRVcg.5r4ulH:0f8Vhut0HoFS3
|
||||
25
gerboweb/deploy/pogojig_generate.sh.j2
Executable file
25
gerboweb/deploy/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
gerboweb/deploy/setup_openjscad.yml
Normal file
9
gerboweb/deploy/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
gerboweb/deploy/setup_pogojig.yml
Normal file
118
gerboweb/deploy/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
gerboweb/deploy/setup_tracespace.yml
Normal file
9
gerboweb/deploy/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
|
||||
append: yes
|
||||
|
||||
- name: Create blog.jaseg.net content dir
|
||||
- name: Create subdomain content dirs
|
||||
file:
|
||||
path: /var/www/blog.jaseg.net
|
||||
path: /var/www/{{item}}
|
||||
state: directory
|
||||
owner: nginx
|
||||
group: nginx
|
||||
mode: 0550
|
||||
loop:
|
||||
- blog.jaseg.net
|
||||
- tracespace.jaseg.net
|
||||
- openjscad.jaseg.net
|
||||
|
||||
- name: Copy uwsgi systemd socket config
|
||||
copy:
|
||||
|
|
@ -38,15 +42,16 @@
|
|||
enabled: yes
|
||||
state: restarted
|
||||
|
||||
- name: Create letsencrypt certificate for gerbolyze.jaseg.net
|
||||
command: certbot --nginx certonly -d gerbolyze.jaseg.net -n --agree-tos --email gerboweb@jaseg.net
|
||||
- name: Create subdomain letsencrypt certificates
|
||||
command: certbot --nginx certonly -d {{item}} -n --agree-tos --email {{item}}-letsencrypt@jaseg.net
|
||||
args:
|
||||
creates: /etc/letsencrypt/live/gerbolyze.jaseg.net/fullchain.pem
|
||||
|
||||
- name: Create letsencrypt certificate for blog.jaseg.net
|
||||
command: certbot --nginx certonly -d blog.jaseg.net -n --agree-tos --email blog@jaseg.net
|
||||
args:
|
||||
creates: /etc/letsencrypt/live/blog.jaseg.net/fullchain.pem
|
||||
creates: /etc/letsencrypt/live/{{item}}/fullchain.pem
|
||||
loop:
|
||||
- blog.jaseg.net
|
||||
- gerbolyze.jaseg.net
|
||||
- tracespace.jaseg.net
|
||||
- openjscad.jaseg.net
|
||||
- pogojig.jaseg.net
|
||||
|
||||
- name: Copy final nginx config
|
||||
copy:
|
||||
|
|
|
|||
1
gerboweb/deploy/tmpfiles-pogojig.conf.j2
Normal file
1
gerboweb/deploy/tmpfiles-pogojig.conf.j2
Normal file
|
|
@ -0,0 +1 @@
|
|||
d {{pogojig_cache}} 770 uwsgi-pogojig uwsgi 2d
|
||||
10
gerboweb/deploy/uwsgi-pogojig.ini
Normal file
10
gerboweb/deploy/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