diff --git a/applications-tree.json b/applications-tree.json index f3dd8e8..9a5747b 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..fcd707e --- /dev/null +++ b/pocketid/domain-pocketid.json @@ -0,0 +1,60 @@ +{ + "main": { + "SERVICE_NAME": "pocketid", + "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..e24666f --- /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