Skip to content

rostock/datenwerft

Repository files navigation

Datenwerft.HRO

Web-Anwendung zur einfachen Erfassung von Geodaten, die auf Django aufsetzt

Voraussetzungen

Installation

  1. neue virtuelle Python-Umgebung:
python3 -m venv /usr/local/datenwerft/venv
  1. Projekt klonen:
git clone https://github.com/rostock/datenwerft /usr/local/datenwerft/datenwerft
  1. virtuelle Python-Umgebung aktivieren:
source /usr/local/datenwerft/venv/bin/activate
  1. benötigte Python-Module (unter anderem Django) installieren via pip:
pip install -r /usr/local/datenwerft/datenwerft/requirements.txt
  1. leere PostgreSQL-Datenbank für die Anwendungsadministration anlegen
  2. leere PostgreSQL-Datenbank mit der Erweiterung PostGIS für die App Antragsmanagement anlegen
  3. leere PostgreSQL-Datenbank mit der Erweiterung PostGIS für die App BEMAS anlegen
  4. leere PostgreSQL-Datenbank mit der Erweiterung PostGIS für die App Datenmanagement anlegen
  5. Datenbankschema in Datenbank für die App Datenmanagement installieren (da keines der Datenmodelle in dieser App von Django verwaltet wird):
psql -h [Datenbankhost] -U [Datenbanknutzer] -d [Datenbankname] -f datenmanagement/sql/schema.sql

Konfiguration

  1. Konfigurationsdatei auf Basis der entsprechenden Vorlage erstellen:
cp /usr/local/datenwerft/datenwerft/secrets.template /usr/local/datenwerft/datenwerft/secrets.py
  1. Konfigurationsdatei /usr/local/datenwerft/datenwerft/settings.py entsprechend anpassen
  2. Service-Datei für Celery auf Basis der entsprechenden Vorlage erstellen:
cp /usr/local/datenwerft/datenwerft/celery.service.template /etc/systemd/system/celery.service
  1. Service-Datei für Celery entsprechend anpassen

Initialisierung

  1. virtuelle Python-Umgebung aktivieren:
source /usr/local/datenwerft/venv/bin/activate
  1. JavaScript-Module via npm installieren:
npm install
  1. Anwendung initialisieren:
cd /usr/local/datenwerft/datenwerft
python manage.py migrate --database=antragsmanagement antragsmanagement
python manage.py migrate --database=bemas bemas
python manage.py migrate
python manage.py antragsmanagement_roles_permissions
python manage.py bemas_roles_permissions
  1. Administrator initialisieren:
python manage.py createsuperuser
  1. Webseiten für Hilfe bauen:
cd /usr/local/datenwerft/datenwerft/hilfe
make html
  1. statische Dateien initialisieren:
cd /usr/local/datenwerft/datenwerft
python manage.py collectstatic -c
  1. Besitzer und Gruppe des Anwendungsverzeichnisses entsprechend des genutzten HTTP-Servers anpassen – siehe unten:
sudo chown -R wwwrun:www /usr/local/datenwerft/datenwerft
  1. Celery-Worker-Service aktivieren und starten:
sudo systemctl daemon-reload
sudo systemctl start celery.service
sudo systemctl enable celery.service

Deployment (am Beispiel des Apache HTTP Servers)

Wenn das Deployment mittels Apache HTTP Server realisiert werden soll, muss dessen Modul mod_wsgi (für Python v3.x) installiert sein, das ein Web Server Gateway Interface (WSGI) für das Hosting von Python-Anwendungen zur Verfügung stellt.

Konfigurationsdatei des Apache HTTP Servers öffnen und in etwa folgenden Inhalt einfügen (in diesem Beispiel nutzt die virtuelle Python-Umgebung einen Python-Interpreter der Version 3.10):

Alias                 /datenwerft/static /usr/local/datenwerft/datenwerft/static
Alias                 /datenwerft/uploads /usr/local/datenwerft/datenwerft/uploads
WSGIDaemonProcess     datenwerft processes=[Anzahl CPU x 2] threads=[Anzahl GB RAM x 3] connect-timeout=150 deadlock-timeout=300 eviction-timeout=0 graceful-timeout=150 inactivity-timeout=300 queue-timeout=300 request-timeout=300 shutdown-timeout=5 socket-timeout=300 startup-timeout=15 restart-interval=0 python-path=/usr/local/datenwerft/datenwerft:/usr/local/datenwerft/venv/lib64/python3.11/site-packages:/usr/local/datenwerft/venv/lib/python3.11/site-packages
WSGIProcessGroup      datenwerft
WSGIScriptAlias       /datenwerft /usr/local/datenwerft/datenwerft/datenwerft/wsgi.py process-group=datenwerft
WSGIApplicationGroup  %{GLOBAL}

<Directory /usr/local/datenwerft/datenwerft/datenwerft>
  <Files wsgi.py>
      Order deny,allow
      Require all granted
  </Files>
</Directory>
<Directory /usr/local/datenwerft/datenwerft/static>
  Order deny,allow
  Require all granted
</Directory>
<Directory /usr/local/datenwerft/datenwerft/uploads>
  Order deny,allow
  Require all granted
</Directory>

Cronjobs

Für die App BEMAS kann optional ein Cronjob eingerichtet werden, der folgenden Befehl ausführt:

python manage.py deletepersons

Dieser Befehl führt dazu, dass alle Personen gelöscht werden, die nicht als Ansprechpartner:innen mit Organisationen verknüpft sind, nicht als Betreiber:innen mit Verursachern verknüpft sind und die als Beschwerdeführer:innen nur noch mit Beschwerden verknüpft sind, die seit BEMAS_STATUS_CHANGE_DEADLINE_DAYS (siehe secrets.template) abgeschlossen sind.

PDF-Export mit eigenen Templates

Für den Export von PDF-Dateien mit eigenen Templates aus der App Datenmanagement mittels der App Toolbox siehe hier.

Entwicklung

Grundsätzliches

Bei Einrückungen werden generell zwei Leerzeichen verwendet, bei Umbrucheinrückungen vier.

Python

Der Python-Code orientiert sich an der Python-Styling-Konvention PEP8. Es empfiehlt sich ein Tool wie pycodestyle zur Überprüfung des Codes zu nutzen. Mit Hilfe von zum Beispiel autopep8 können Python-Dateien auch im Nachhinein noch automatisch korrigiert werden, können dadurch allerdings auch unleserlich werden.

Die Python-Dokumentation wird mittels Docstrings in reStructuredText geschrieben.

Nützliche Tools für eine Entwicklungsumgebung, wie etwa pycodestyle oder ruff können zusätzlich via pip installiert werden:

source /usr/local/datenwerft/venv/bin/activate
pip install -r /usr/local/datenwerft/datenwerft/requirements-dev.txt

PEP8-Durchsetzung

Die Vorgaben von PEP8 finden mit zwei Ausnahmen vollständig Anwendung:

  1. Zeilenlänge wird von 79 auf 99 erhöht
  2. Anzahl der Leerzeichen bei der Einrückung wird von vier auf zwei reduziert (ergibt zudem eine Umbrucheinrückung von vier statt acht)

Die entsprechende Konfigurationsdatei setup.cfg für pycodestyle ist bereits im Wurzelverzeichnis des Projekts angelegt.

JavaScript

JavaScript-Funktionen werden mittels JSDoc dokumentiert, angelehnt an diese Übersicht.

Linting

  • Python-Prüfungen mittels pycodestyle:

    cd /usr/local/datenwerft/datenwerft
    sh linting/pycodestyle
  • Django-Prüfungen mittels djLint:

    cd /usr/local/datenwerft/datenwerft
    sh linting/djlint
  • CSS-Prüfungen mittels Stylelint:

    cd /usr/local/datenwerft/datenwerft
    sh linting/stylelint
  • JavaScript-Prüfungen mittels ESLint:

    cd /usr/local/datenwerft/datenwerft
    sh linting/eslint
  • alle vorgenannten Prüfungen nacheinander:

    cd /usr/local/datenwerft/datenwerft
    sh linting/lint

Tests

  • Tests der App Accounts durchführen:

    source /usr/local/datenwerft/venv/bin/activate
    cd /usr/local/datenwerft/datenwerft
    python manage.py test accounts
  • Tests der App Toolbox durchführen:

    source /usr/local/datenwerft/venv/bin/activate
    cd /usr/local/datenwerft/datenwerft
    python manage.py test toolbox
  • Tests der App Datenmanagement durchführen:

    • Einzeltest (Beispiel):

      source /usr/local/datenwerft/venv/bin/activate
      cd /usr/local/datenwerft/datenwerft
      python manage.py test datenmanagement.tests.StrassenTest.test_create
    • alle Tests:

      source /usr/local/datenwerft/venv/bin/activate
      cd /usr/local/datenwerft/datenwerft
      python manage.py test datenmanagement
  • Tests der App Antragsmanagement durchführen:

    source /usr/local/datenwerft/venv/bin/activate
    cd /usr/local/datenwerft/datenwerft
    python manage.py test antragsmanagement
  • Tests der App BEMAS durchführen:

    source /usr/local/datenwerft/venv/bin/activate
    cd /usr/local/datenwerft/datenwerft
    python manage.py test bemas

CI/CD

Ablauf

  1. neuen Branch erstellen – Name des Branches:

    • bei Features: features/<app-name>/<feature-name> (Beispiel: features/datenmanagement/edit-photos)
    • bei Bugfixes: bugfixes/<app-name>/<bugfix-name> (Beispiel: bugfixes/accounts/emails)
  2. Änderungen linten und testen (siehe oben)

  3. Änderungen committen und Commit(s) pushen

  4. Pull-Request im Branch main erstellen

  5. Review anfordern und durchführen lassen

  6. ggf. Änderungen im Nachgang des Reviews committen und Commit(s) pushen

  7. Pull-Request im Branch main abschließen:

    • Commit-Message gemäß der Syntax der Conventional-Commit gestalten
    • mit der Option Squash and merge mergen

GitHub-Actions

Bei Commits und Pull-Requests in der Branch main werden folgende GitHub-Actions ausgeführt:

  • Linting: Linting gemäß .github/workflows/linting.yml
  • Tests: Tests gemäß .github/workflows/tests.yml
  • Release: Release gemäß .github/workflows/release.yml