From 0e487b02c50e682cb82240a7b1e9f2bf077f8caf Mon Sep 17 00:00:00 2001 From: gyurix Date: Sat, 30 Aug 2025 08:56:08 +0200 Subject: [PATCH 1/3] Add PocketID configuration files for PostgreSQL integration and firewall settings --- applications-tree.json | 6 ++ pocketid/domain-pocketid.json | 60 +++++++++++++++++ pocketid/firewall-pocketid-dns.json | 75 +++++++++++++++++++++ pocketid/firewall-pocketid-smtp.json | 75 +++++++++++++++++++++ pocketid/firewall-pocketid.json | 75 +++++++++++++++++++++ pocketid/pocketid-secret.json | 16 +++++ pocketid/service-pocketid.json | 99 ++++++++++++++++++++++++++++ pocketid/template.json | 43 ++++++++++++ 8 files changed, 449 insertions(+) create mode 100644 pocketid/domain-pocketid.json create mode 100644 pocketid/firewall-pocketid-dns.json create mode 100644 pocketid/firewall-pocketid-smtp.json create mode 100644 pocketid/firewall-pocketid.json create mode 100644 pocketid/pocketid-secret.json create mode 100644 pocketid/service-pocketid.json create mode 100644 pocketid/template.json diff --git a/applications-tree.json b/applications-tree.json index f3dd8e8..d195e7a 100644 --- a/applications-tree.json +++ b/applications-tree.json @@ -71,6 +71,12 @@ "subtitle": "Software Development", "version": "latest", "icon": "" + }, + { + "name": "Pocketid", + "subtitle": "Identity management", + "version": "latest", + "icon": "" } ] } \ No newline at end of file diff --git a/pocketid/domain-pocketid.json b/pocketid/domain-pocketid.json new file mode 100644 index 0000000..def4c89 --- /dev/null +++ b/pocketid/domain-pocketid.json @@ -0,0 +1,60 @@ +{ + "main": { + "SERVICE_NAME": "vaultwarden", + "DOMAIN": "#DOMAIN" + }, + "containers": [ + { + "IMAGE": "safebox/domain-check", + "UPDATE": "true", + "MEMORY": "64M", + "NAME": "domain_checker", + "ROLES": "domain_checker", + "NETWORK": "host", + "SELECTOR": "", + "SCALE": "0", + "EXTRA": "--rm --privileged", + "PRE_START": [], + "DEPEND": [], + "POST_START": [], + "CMD": "", + "ENVS": [ + { + "PROXY": "smarthostloadbalancer" + }, + { + "TARGET": "pocketid-app" + }, + { + "PORT": "3000" + }, + { + "DOMAIN": "#DOMAIN" + }, + { + "SMARTHOST_PROXY_PATH": "/smarthost-domains" + }, + { + "OPERATION": "CREATE" + } + ], + "VOLUMES": [ + { + "SOURCE": "/etc/user/config/smarthost-domains", + "DEST": "/smarthost-domains", + "TYPE": "rw" + }, + { + "SOURCE": "/etc/system/data/dns/hosts.local", + "DEST": "/etc/dns/hosts.local", + "TYPE": "ro" + }, + { + "SOURCE": "/var/run/docker.sock", + "DEST": "/var/run/docker.sock", + "TYPE": "rw" + } + ] + } + ] +} \ No newline at end of file diff --git a/pocketid/firewall-pocketid-dns.json b/pocketid/firewall-pocketid-dns.json new file mode 100644 index 0000000..ad5f35a --- /dev/null +++ b/pocketid/firewall-pocketid-dns.json @@ -0,0 +1,75 @@ +{ + "main": { + "SERVICE_NAME": "firewalls", + "DOMAIN": "null" + }, + "containers": [ + { + "IMAGE": "safebox/firewall", + "NAME": "firewall", + "MEMORY": "64M", + "NETWORK": "host", + "SCALE": "0", + "VOLUMES": [ + { + "SOURCE": "/run/", + "DEST": "/run/", + "TYPE": "rw" + }, + { + "SOURCE": "/etc/user/config/services", + "DEST": "/services", + "TYPE": "ro" + }, + { + "SOURCE": "/etc/system/data/dns/hosts.local", + "DEST": "/etc/dns/hosts.local", + "TYPE": "ro" + }, + { + "SOURCE": "/var/run/docker.sock", + "DEST": "/var/run/docker.sock", + "TYPE": "rw" + } + ], + "PORTS": [], + "READYNESS": [ + { + "tcp": "" + }, + { + "HTTP": "" + }, + { + "EXEC": "/ready.sh" + } + ], + "ENVS": [ + { + "CHAIN": "DOCKER-USER" + }, + { + "SOURCE": "coredns" + }, + { + "TARGET": "pocketid-app" + }, + { + "TYPE": "udp" + }, + { + "TARGET_PORT": "53" + }, + { + "COMMENT": "dns for pocketid-app" + } + ], + "EXTRA": "--privileged --rm", + "DEPEND": "null", + "START_ON_BOOT": "false", + "CMD": "null", + "PRE_START": "null", + "POST_START": "null" + } + ] +} \ No newline at end of file diff --git a/pocketid/firewall-pocketid-smtp.json b/pocketid/firewall-pocketid-smtp.json new file mode 100644 index 0000000..ab41bf3 --- /dev/null +++ b/pocketid/firewall-pocketid-smtp.json @@ -0,0 +1,75 @@ +{ + "main": { + "SERVICE_NAME": "firewalls", + "DOMAIN": "null" + }, + "containers": [ + { + "IMAGE": "safebox/firewall", + "NAME": "firewall", + "MEMORY": "64M", + "NETWORK": "host", + "SCALE": "0", + "VOLUMES": [ + { + "SOURCE": "/run/", + "DEST": "/run/", + "TYPE": "rw" + }, + { + "SOURCE": "/etc/user/config/services", + "DEST": "/services", + "TYPE": "ro" + }, + { + "SOURCE": "/etc/system/data/dns/hosts.local", + "DEST": "/etc/dns/hosts.local", + "TYPE": "ro" + }, + { + "SOURCE": "/var/run/docker.sock", + "DEST": "/var/run/docker.sock", + "TYPE": "rw" + } + ], + "PORTS": [], + "READYNESS": [ + { + "tcp": "" + }, + { + "HTTP": "" + }, + { + "EXEC": "/ready.sh" + } + ], + "ENVS": [ + { + "CHAIN": "DOCKER-USER" + }, + { + "SOURCE": "pocketid-app" + }, + { + "TARGET": "smtp" + }, + { + "TYPE": "tcp" + }, + { + "TARGET_PORT": "25" + }, + { + "COMMENT": "smtp for pocketid-app" + } + ], + "EXTRA": "--privileged --rm", + "DEPEND": "null", + "START_ON_BOOT": "false", + "CMD": "null", + "PRE_START": "null", + "POST_START": "null" + } + ] +} \ No newline at end of file diff --git a/pocketid/firewall-pocketid.json b/pocketid/firewall-pocketid.json new file mode 100644 index 0000000..a7e6a08 --- /dev/null +++ b/pocketid/firewall-pocketid.json @@ -0,0 +1,75 @@ +{ + "main": { + "SERVICE_NAME": "firewalls", + "DOMAIN": "null" + }, + "containers": [ + { + "IMAGE": "safebox/firewall", + "NAME": "firewall", + "MEMORY": "64M", + "NETWORK": "host", + "SCALE": "0", + "VOLUMES": [ + { + "SOURCE": "/run/", + "DEST": "/run/", + "TYPE": "rw" + }, + { + "SOURCE": "/etc/user/config/services", + "DEST": "/services", + "TYPE": "ro" + }, + { + "SOURCE": "/etc/system/data/dns/hosts.local", + "DEST": "/etc/dns/hosts.local", + "TYPE": "ro" + }, + { + "SOURCE": "/var/run/docker.sock", + "DEST": "/var/run/docker.sock", + "TYPE": "rw" + } + ], + "PORTS": [], + "READYNESS": [ + { + "tcp": "" + }, + { + "HTTP": "" + }, + { + "EXEC": "/ready.sh" + } + ], + "ENVS": [ + { + "CHAIN": "DOCKER-USER" + }, + { + "SOURCE": "smarthostbackend" + }, + { + "TARGET": "pocketid-app" + }, + { + "TYPE": "tcp" + }, + { + "TARGET_PORT": "3000" + }, + { + "COMMENT": "proxy for pocketid-app" + } + ], + "EXTRA": "--privileged --rm", + "DEPEND": "null", + "START_ON_BOOT": "false", + "CMD": "null", + "PRE_START": "null", + "POST_START": "null" + } + ] +} \ No newline at end of file diff --git a/pocketid/pocketid-secret.json b/pocketid/pocketid-secret.json new file mode 100644 index 0000000..fb5d976 --- /dev/null +++ b/pocketid/pocketid-secret.json @@ -0,0 +1,16 @@ +{ + "pocketidpostgres": { + "POSTGRES_DB": "#POSTGRES_DB", + "POSTGRES_USER": "#POSTGRES_USER", + "POSTGRES_PASSWORD": "#POSTGRES_PASSWORD", + "POSTGRES_ROOT_PASSWORD": "#POSTGRES_ROOT_PASSWORD" + }, + "pocketidapp": { + "PUBLIC_APP_URL": "https://#DOMAIN", + "TRUST_PROXY": "true", + "PUID": "1000", + "PGID": "1000", + "DB_PROVIDER": "postgres", + "POSTGRES_CONNECTION_STRING": "postgresql://#POSTGRES_USER:#POSTGRES_PASSWORD@pocketidpostgres-db:5432/#POSTGRES_DB" + } +} \ No newline at end of file diff --git a/pocketid/service-pocketid.json b/pocketid/service-pocketid.json new file mode 100644 index 0000000..fb785e9 --- /dev/null +++ b/pocketid/service-pocketid.json @@ -0,0 +1,99 @@ +{ + "main": { + "SERVICE_NAME": "pocketid", + "DOMAIN": "#DOMAIN" + }, + "containers": [ + { + "IMAGE": "alpine:latest", + "UPDATE": "true", + "NAME": "pocketid-init", + "NETWORK": "host", + "MEMORY": "64M", + "VOLUMES": [ + { + "SOURCE": "USER_DATA", + "DEST": "/etc/user/data", + "TYPE": "rw" + } + ], + "EXTRA": "--rm", + "DEPEND": "null", + "START_ON_BOOT": "false", + "ENTRYPOINT": "sh -c", + "CMD": "mkdir -p /mkdir -p /etc/user/data/pocketid/db", + "PRE_START": "null", + "POST_START": "null" + }, + { + "IMAGE": "postgres:16-alpine", + "NAME": "pocketidpostgres-db", + "UPDATE": "true", + "ROLES": "postgres-db patroni", + "MEMORY": "256M", + "NETWORK": "pocketid-net", + "SELECTOR": "pocketidpostgres-db", + "VOLUMES": [ + { + "SOURCE": "/etc/user/data/pocketid/postgresql", + "DEST": "/var/lib/postgresql/data", + "TYPE": "rw" + } + ], + "PORTS": [ + { + "SOURCE": "null", + "DEST": "5432", + "TYPE": "tcp" + } + ], + "ENV_FILES": [ + "/etc/user/secret/pocketid/pocketid.json" + ], + "ENVS": [ + { + "POSTGRES_INITDB_ARGS": "--encoding=UTF8 --locale=C" + } + ], + "EXTRA": "--label logging=promtail_user --label logging_jobname=containers --restart unless-stopped", + "DEPEND": "null", + "START_ON_BOOT": "false", + "CMD": "null", + "PRE_START": [], + "POST_START": [] + }, + { + "IMAGE": "stonith404/pocket-id", + "UPDATE": "true", + "NAME": "pocketidapp", + "DNS": [ + "coredns" + ], + "MEMORY": "256M", + "SELECTOR": "pocketid-app", + "NETWORK": "pocketid-net", + "VOLUMES": [], + "PORTS": [ + { + "SOURCE": "null", + "DEST": "3000", + "TYPE": "tcp" + } + ], + "EXTRA": "--label logging=promtail_user --label logging_jobname=containers --restart unless-stopped", + "ENV_FILES": [ + "/etc/user/secret/pocketid/pocketid.json" + ], + "DEPEND": [], + "START_ON_BOOT": "true", + "CMD": "null", + "PRE_START": "null", + "POST_START": [ + "firewall-pocketid", + "firewall-pocketid-dns", + "firewall-pocketid-smtp", + "domain-pocketid" + ] + } + ] +} \ No newline at end of file diff --git a/pocketid/template.json b/pocketid/template.json new file mode 100644 index 0000000..5e12558 --- /dev/null +++ b/pocketid/template.json @@ -0,0 +1,43 @@ +{ + "name": "Pocketid", + "title": "pocketid", + "subtitle": "Identity management", + "icon": "", + "description": "PocketID is an open-source password manager and secure vault solution that allows users to store, manage, and share sensitive information such as passwords, credit card details, and personal notes. It is designed to provide a high level of security and privacy, with features like end-to-end encryption, two-factor authentication, and self-hosting options.", + "fields": [ + { + "description": "Domain", + "key": "DOMAIN", + "value": "", + "required": "true" + }, + { + "description": "Postgres database name", + "key": "POSTGRES_DB", + "value": "", + "required": "true", + "generated": "" + }, + { + "description": "Postgres username", + "key": "POSTGRES_USER", + "value": "", + "required": "true", + "generated": "time|md5|8" + }, + { + "description": "Postgres password for user", + "key": "POSTGRES_PASSWORD", + "value": "", + "required": "true", + "generated": "random|md5|12" + }, + { + "description": "Postgres root user password", + "key": "POSTGRES_ROOT_PASSWORD", + "value": "", + "required": "true", + "generated": "random|sha256|20" + } + ] +} \ No newline at end of file From 5fd409e79ca59ba580148720589383e0334ec96a Mon Sep 17 00:00:00 2001 From: gyurix Date: Sat, 30 Aug 2025 09:21:01 +0200 Subject: [PATCH 2/3] Update Pocketid icon in applications-tree.json to a new SVG representation --- applications-tree.json | 2 +- pocketid/template.json | 2 +- 2 files changed, 2 insertions(+), 2 deletions(-) diff --git a/applications-tree.json b/applications-tree.json index d195e7a..9a5747b 100644 --- a/applications-tree.json +++ b/applications-tree.json @@ -76,7 +76,7 @@ "name": "Pocketid", "subtitle": "Identity management", "version": "latest", - "icon": "" + "icon": "" } ] } \ No newline at end of file diff --git a/pocketid/template.json b/pocketid/template.json index 5e12558..e24666f 100644 --- a/pocketid/template.json +++ b/pocketid/template.json @@ -2,7 +2,7 @@ "name": "Pocketid", "title": "pocketid", "subtitle": "Identity management", - "icon": "", + "icon": "", "description": "PocketID is an open-source password manager and secure vault solution that allows users to store, manage, and share sensitive information such as passwords, credit card details, and personal notes. It is designed to provide a high level of security and privacy, with features like end-to-end encryption, two-factor authentication, and self-hosting options.", "fields": [ { From 4e19534cae9b1a4436f670eca779ac80721342ec Mon Sep 17 00:00:00 2001 From: gyurix Date: Sat, 30 Aug 2025 09:22:15 +0200 Subject: [PATCH 3/3] Update SERVICE_NAME in domain-pocketid.json from 'vaultwarden' to 'pocketid' --- pocketid/domain-pocketid.json | 2 +- 1 file changed, 1 insertion(+), 1 deletion(-) diff --git a/pocketid/domain-pocketid.json b/pocketid/domain-pocketid.json index def4c89..fcd707e 100644 --- a/pocketid/domain-pocketid.json +++ b/pocketid/domain-pocketid.json @@ -1,6 +1,6 @@ { "main": { - "SERVICE_NAME": "vaultwarden", + "SERVICE_NAME": "pocketid", "DOMAIN": "#DOMAIN" }, "containers": [