Skip to content

fredagscafeen/web

Folders and files

NameName
Last commit message
Last commit date

Latest commit

 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 

Repository files navigation

After the General Meeting

After the General Meeting some accounts and data needs to updated. We generally add the new board members as soon as possible, but only remove the old board members after the first board meeting.

Before the first board meeting (as soon as possible)

After the first board meeting

New web responsible

This only needs to be done, if there is a new web responsible:

  • Make the new responsible's user a superuser on the website
  • Add new keys to and remove old keys from ~/.ssh/authorized_keys on the server.

Setup

To run project locally

  1. checkout project from vcs: git clone [email protected]:fredagscafeen/web.git
  2. setup virtual env: python3 -mvenv ~/.cache/venvs/fredagscafeen-web
  3. activate virtual env: source ~/.cache/venvs/fredagscafeen-web/bin/activate
  4. install pip-tools: pip install pip-tools
  5. install dependencies: pip-sync requirements.txt dev-requirements.txt
  6. install pre-commit hook: pre-commit install

Installing the required psycopg2 package (PostgreSQL for Python) might require the pg_config binary, which can be installed on Ubuntu with sudo apt install libpq-dev.

  1. migrate database: ./manage.py migrate
  2. create superuser: ./manage.py createsuperuser
  3. run server: ./manage.py runserver

Deploy changes

  1. git push
  2. Build docker image and redeploy: ssh [email protected] 'cd web && git pull && docker compose build && docker compose up -d'

Setup admin user on server

  1. ssh into server: ssh [email protected]
  2. create superuser: docker exec -it web_app_1 ./manage.py createsuperuser
  3. login to admin interface: https://fredagscafeen.dk/admin/

Github hook for automatically updating guide PDFs

  • Generate a new ssh key: ssh-keygen -t ed25519 -C github-action -f /tmp/github-action
  • Add the public key to the servers ~/.ssh/authorized_keys file: ssh [email protected] 'cat >> ~/.ssh/authorized_keys' < /tmp/github-action.pub
  • Add Github action secrets on https://github.com/organizations/fredagscafeen/settings/secrets/actions:
    • Create the action secret UPLOAD_SSH_KNOWN_HOSTS containing the output of running: grep fredagscafeen.dk ~/.ssh/known_hosts
    • Create the action secret UPLOAD_SSH_PRIVATE_KEY containing the output of running: cat /tmp/github-action
    • Make sure both guides and vedtægter repos have access to these

Every time a tex file for a guide is updated, Github will recompile it and update the hosted PDF.

Remote server printing

TODO: This needs to be updated.

Diagram

+----------------------------------------------------+
| htlm5 server:                                      |
|                                                    |
| autossh -N -M 2244                                 |
|         -L 6631:localhost:631                      |
|         remoteprint@localhost                      |
|         -p 2222                          <-\       |
|         -v                                 |  ssh  |
|                                            |       |
|  +-----------------------------------------|---+   |
|  | dokku web instance:                     |   |   |
|  |                                             |   |
|  |                                             |   |
|  | ssh -o StrictHostKeyChecking=no             |   |
|  |     -i media/id_rsa                         |   |
|  |     [email protected]      |   |
|  |     --                                      |   |
|  |     lpstat -h localhost:6631 -E -p          |   |
|  |                                             |   |
|  +---------------------------------------------+   |
+----------------------------------------------------+
                     ^
                     |
                     |
       (reverse ssh port-forwarding)
                     |
                     |
+----------------------------------------------+
| remote AU server:                            |
|                                              |
| autossh -N -M 2233                           |
|         -R 2222:localhost:22                 |
|         [email protected]   |
|         -v                                   |
|                                              |
+----------------------------------------------+

Installing autossh and cups

apt install autossh cups
systemctl disable --now cups
systemctl disable --now cups-browsed

Setting up the reverse tunnel and ssh keys

Open 3 terminal windows:

  • One connected to the remote machine on AU's network (remote)
  • One connected to htlm5 (htlm5)
  • One connected to htlm5 and inside the dokku container: dokku run fredagscafeen.dk bash (dokku)

Then run the following commands in order:

remote:

sudo useradd -m remoteprint
sudo mkhomedir_helper remoteprint
sudo -u remoteprint ssh-keygen
sudo cat /home/remoteprint/.ssh/id_rsa.pub # Key remote

dokku:

mkdir media/ssh
ssh-keygen -f media/ssh/id_rsa
cat media/ssh/id_rsa.pub # Key client

htlm5:

useradd -m remoteprint_relay
mkhomedir_helper remoteprint_relay
sudo -u remoteprint_relay ssh-keygen
cat /home/remoteprint_relay/.ssh/id_rsa.pub # Key relay

sudo -u remoteprint_relay sh -c 'echo "<Key remote>" >> /home/remoteprint_relay/.ssh/authorized_keys'
cat fredagscafeen-media/ssh/id_rsa.pub | sudo -u remoteprint_relay sh -c 'cat >> /home/remoteprint_relay/.ssh/authorized_keys'

remote:

sudo -u remoteprint sh -c 'echo "<Key relay>" >> /home/remoteprint/.ssh/authorized_keys'

Check that the remote can connect to the relay by running the following on the remote:

sudo -u remoteprint /usr/bin/autossh -N -M 2233 -R 2222:localhost:22 [email protected] -v

Check that we can connect to the relay and it can connect to the remote by running the following in dokku:

ssh -o StrictHostKeyChecking=no [email protected] -i media/ssh/id_rsa id
ssh -o StrictHostKeyChecking=no [email protected] -i media/ssh/id_rsa ssh remoteprint@localhost -p 2222 id

Stop the autossh command on the remote and create the file /etc/systemd/system/remoteprinter_autossh.service containing:

[Unit]
Description=Keeps a reverse tunnel to fredagscafeen.dk open
After=network-online.target
After=ssh.service
After=org.cups.cupsd.service

[Service]
ExecStart=/usr/bin/autossh -N -M 2233 -R 2222:localhost:22 [email protected] -v
Restart=on-failure
User=remoteprint
KillSignal=SIGINT
SendSIGKILL=no
Environment=AUTOSSH_GATETIME=0

[Install]
WantedBy=multi-user.target

Then start and enable the service on the remote:

sudo systemctl enable --now remoteprinter_autossh

Test that we can forward port 6631 to the remote's port 631 and it works (run both command at the same time on remote):

sudo -u /usr/bin/autossh -N -M 2244 -L 6631:localhost:631 remoteprint@localhost -p 2222 -v
lpstat -h localhost:6631 -p

Create the file /etc/systemd/system/remoteprinter_cups_forward.service containing:

[Unit]
Description=Forwards port 6631 to port 631 of an AU machine
After=network-online.target
After=ssh.service
After=org.cups.cupsd.service

[Service]
ExecStart=/usr/bin/autossh -N -M 2244 -L 6631:localhost:631 remoteprint@localhost -p 2222 -v
Restart=on-failure
User=remoteprint_relay
KillSignal=SIGINT
SendSIGKILL=no
Environment=AUTOSSH_GATETIME=0

[Install]
WantedBy=multi-user.target

Then start and enable the service on the remote:

sudo systemctl enable --now remoteprinter_cups_forward

Limit remote to only allow forwarding to port 631

Add the following at the bottom of /etc/ssh/sshd_config on the remote:

Match User remoteprint
	AllowTcpForwarding yes
	X11Forwarding no
	PermitTunnel no
	GatewayPorts no
	AllowAgentForwarding no
	PermitOpen localhost:631
	ForceCommand echo 'This account can only be used for printing'

Then reload sshd:

systemctl reload sshd

Setting up the printers to use

The printers should be installed on the remote machine and also be entered into the database.

API usage

Method Overview

  • Auth
  • Items
  • Breweries
  • BeerTypes
  • Bartenders
  • Is-Bartender

Method details

Auth

POST /api/auth/

Request
{
    "username": "...",
    "password": "..."
}
Response
{
    "token": "...",
    "permissions": [...]
}

Items

GET /api/items/

Response
[
    {
        "id": 871,
        "created": "2017-06-02T13:13:49Z",
        "name": "Semiskinned Occultist",
        "description": "",
        "country": "",
        "priceInDKK": 25.0,
        "abv": null,
        "container": null,
        "volumeInCentiliters": null,
        "inStock": true,
        "imageUrl": "",
        "barcode": "",
        "lastModified": "2017-06-02T13:14:53.756808Z",
        "link": "",
        "brewery": 16,
        "type": null
    },
    ...
]

Breweries

GET /api/breweries/

Response
[
    {
        "id": 1,
        "name": "Aarhus Bryghus",
        "description": "",
        "website": ""
    },
    ...
]

BeerTypes

GET /api/beerTypes/

Response
[
    {
        "id": 1,
        "name": "Pilsner",
        "description": "",
        "link": ""
    },
    ...
]

Bartenders

GET /api/bartenders/

Response
[
    {
        "id": 45,
        "name": "Alberte Herold Hansen",
        "username": "alberte",
        "isActiveBartender": true
    },
    ...
]

Is-Bartender

GET /api/is-bartender//

Response
true