From c56d5f69b1c6f52c443061970eba9d60b0c9ee3a Mon Sep 17 00:00:00 2001 From: =?UTF-8?q?Philipp=20L=C3=BCthi?= Date: Fri, 20 Dec 2024 15:40:17 +0100 Subject: [PATCH 1/2] Fix typos --- README.md | 4 ++-- 1 file changed, 2 insertions(+), 2 deletions(-) diff --git a/README.md b/README.md index a55a8f11..48c9ce43 100644 --- a/README.md +++ b/README.md @@ -20,7 +20,7 @@ Für die Formattierung wird ESLint verwendet. Dazu im Visual Studio unter `Optio - Vor dem ersten Start oder bei Änderungen in den Packages muss in _Geopilot.Frontend_ manuell `npm install` ausgeführt werden. -- Damit die Applikation mit https funktioniert, muss ein lokales dev-cert erstellt werden. Dieses wird durch das npm Script `predev` vor dem start automatisch erstellt. Sollte dies nicht funktionieren, kann mit folgendem Befehl ein Zertifikat manuell erstellt und vertraut werden: `dotnet dev-certs https --trust`. Https muss verwendet werden, damit die STAC-Urls korrekt funktionieren & so der STAC-Browser wie in Produktion verwendet werden kann. +- Damit die Applikation mit HTTPS funktioniert, muss ein lokales dev-cert erstellt werden. Dieses wird durch das npm Script `predev` vor dem Start automatisch erstellt. Sollte dies nicht funktionieren, kann mit folgendem Befehl ein Zertifikat manuell erstellt und vertraut werden: `dotnet dev-certs https --trust`. HTTPS muss verwendet werden, damit die STAC-Urls korrekt funktionieren und so der STAC-Browser wie in einer produktiven Umgebung verwendet werden kann. - Über _Start_ > _Configure Startup Projects_ > _Common Properties_ > _Startup Projects_ müssen _Multiple startup projects_ definiert werden. @@ -33,7 +33,7 @@ Für die Formattierung wird ESLint verwendet. Dazu im Visual Studio unter `Optio ### Starten der Applikation (Docker Compose) 🐳 -Das Projekt unterstützt das Starten der Applikation mit Docker Compose um einer Prod Umgebung möglichst nahe zu kommen. Um https zu unterstützten, benötigt es ein vertrautes dev-cert sowie ein export dessen im PEM format. Diese werden im docker-compose.yml korrekt geladen. Setup wie folgend beschrieben. Die Applikation ist danach unter [https://localhost:5173](https://localhost:5173) erreichbar. +Das Projekt unterstützt das Starten der Applikation mit Docker Compose, um einer produktiven Umgebung möglichst nahe zu kommen. Um HTTPS zu unterstützen, benötigt es ein vertrautes dev-cert sowie ein Export dessen im PEM-Format. Diese werden im [docker-compose.yml](./docker-compose.yml) korrekt geladen. Setup ist nachfolgend beschrieben. Die Applikation ist danach unter [https://localhost:5173](https://localhost:5173) erreichbar. ```bash dotnet dev-certs https --trust From 1c2e7eb5aa66f3cf67c7b2c7cdcb7b6b372b8f8c Mon Sep 17 00:00:00 2001 From: =?UTF-8?q?Philipp=20L=C3=BCthi?= Date: Fri, 20 Dec 2024 16:19:48 +0100 Subject: [PATCH 2/2] Use env variables for cert paths --- .github/workflows/cypress.yml | 11 ++++++++--- 1 file changed, 8 insertions(+), 3 deletions(-) diff --git a/.github/workflows/cypress.yml b/.github/workflows/cypress.yml index d08e7d71..dca5d24d 100644 --- a/.github/workflows/cypress.yml +++ b/.github/workflows/cypress.yml @@ -14,6 +14,11 @@ jobs: - name: Checkout repository uses: actions/checkout@v4 + - name: Set environment variables + run: | + echo PEM_CERT_PATH=$(pwd)/certs/geopilot.pem >> $GITHUB_ENV + echo UBUNTU_TRUSTED_CERT_PATH=/usr/local/share/ca-certificates/geopilot.crt >> $GITHUB_ENV + - name: Setup dotnet uses: actions/setup-dotnet@v4 with: @@ -22,13 +27,13 @@ jobs: - name: Create dev-certs run: | mkdir ./certs - dotnet dev-certs https --export-path ./certs/geopilot.pem --no-password --format PEM + dotnet dev-certs https --export-path ${{ env.PEM_CERT_PATH }} --no-password --format PEM chmod -R 664 ./certs/* - name: Trust dev-certs run: | sudo apt-get install -y ca-certificates - sudo cp ./certs/geopilot.pem /usr/local/share/ca-certificates/geopilot.crt + sudo cp ${{ env.PEM_CERT_PATH }} ${{ env.UBUNTU_TRUSTED_CERT_PATH }} sudo update-ca-certificates - name: Start db and api's @@ -44,4 +49,4 @@ jobs: env: CYPRESS_RECORD_KEY: ${{ secrets.CYPRESS_RECORD_KEY }} GITHUB_TOKEN: ${{ secrets.GITHUB_TOKEN }} - NODE_EXTRA_CA_CERTS: /usr/local/share/ca-certificates/geopilot.crt + NODE_EXTRA_CA_CERTS: ${{ env.UBUNTU_TRUSTED_CERT_PATH }}