From 91b22f53364803fc1efe631990b8998cc25c38cb Mon Sep 17 00:00:00 2001 From: James Gorrie Date: Tue, 3 Dec 2024 16:50:16 +0000 Subject: [PATCH] Add pgAdmin to docker compose for nice local admin UI (#255) * feat: add pgadmin to docker compose * feat: make pgadmin a bit more streamline * fix: remove unecesssary hostname * fix: add trunk ignore to docker-compose * fix: add space for consistency * fix: put depends on localstck back into docker compose --- docker-compose-fulldata.yml | 0 docker-compose.yml | 53 ++++++++++++++++++++++++++++++++++++- 2 files changed, 52 insertions(+), 1 deletion(-) create mode 100644 docker-compose-fulldata.yml diff --git a/docker-compose-fulldata.yml b/docker-compose-fulldata.yml new file mode 100644 index 00000000..e69de29b diff --git a/docker-compose.yml b/docker-compose.yml index 0a670d38..2612e395 100644 --- a/docker-compose.yml +++ b/docker-compose.yml @@ -46,5 +46,56 @@ services: localstack: condition: service_started + pgadmin: + image: dpage/pgadmin4 + container_name: pgadmin4 + restart: always + env_file: + - .env + ports: + - 8000:80 + # This has to have world & group access denied to work + entrypoint: /bin/sh -c "chmod 600 /pgpass; /entrypoint.sh;" + configs: + - source: servers.json + target: /pgadmin4/servers.json + - source: pgpass + target: /pgpass + environment: + # This deavctivates the login screen + PGADMIN_CONFIG_SERVER_MODE: "False" + PGADMIN_CONFIG_MASTER_PASSWORD_REQUIRED: "False" + volumes: + - pgadmin-data:/var/lib/pgadmin + # This is just nice to know as if it fails, it fails quietly + healthcheck: + # there are conflicting trunk errors here. Either + # - having `:` in the URL (fails in Github actions) + # - redundantly quoting the URL (fails locally) + # trunk-ignore(yamllint/quoted-strings) + test: [CMD, wget, -O, "-", "http://localhost:80/misc/ping"] +configs: + pgpass: + content: "admin_backend_db:5432:*:${POSTGRES_USER}:${POSTGRES_PASSWORD}" + servers.json: + content: | + { + "Servers": { + "1": { + "Group": "Servers", + "Name": "Navigator Admin Backend", + "Host": "admin_backend_db", + "Port": 5432, + "MaintenanceDB": "postgres", + "Username": "${POSTGRES_USER}", + "Password": "${POSTGRES_PASSWORD}", + "SSLMode": "prefer" + } + } + } + localstack: + condition: service_started + volumes: - admin-data: + admin-data: {} + pgadmin-data: {}