From 4902cbf105d534a5c2d60c0351ec0e3609a338ed Mon Sep 17 00:00:00 2001 From: Mauricio Siu <47042324+Siumauricio@users.noreply.github.com> Date: Thu, 5 Mar 2026 01:44:01 -0600 Subject: [PATCH] New Version (#737) MIME-Version: 1.0 Content-Type: text/plain; charset=UTF-8 Content-Transfer-Encoding: 8bit * feat(librechat): add LibreChat blueprint with compose, toml, metadata, links and tags * fix: rename templates to template.toml * fix(librechat): rename api service to librechat in docker-compose.yml * Update blueprints/librechat/template.toml * Update blueprints/librechat/template.toml * fix(librechat): add version under [config] and remove stray [config.mounts] header * fix(librechat): remove predefined persistent volume mounts from template.toml * docs(librechat): add authentication reference link to docker-compose.yml * feat: add Rote template - Add Rote deployment template with frontend, backend, and PostgreSQL services - Configure domain routing for frontend (port 80) and backend (port 3000) - Set up automatic password generation and environment variables - Use latest image tag by default - Add logo and metadata to meta.json * fix: process meta.json to fix formatting and sorting * Update GitHub workflows to target 'canary' branch for meta validation * Update pnpm-lock.yaml to upgrade various dependencies, including '@codemirror/autocomplete', '@radix-ui/react-dialog', and React packages to their latest versions. This includes updates to '@types/react' and '@types/react-dom' for improved compatibility and performance. * Enhance GitHub workflows: add production deployment configuration and target 'canary' branch for pull requests. * Refactor GitHub workflow: comment out build preview steps for clarity and future modifications. * Remove unnecessary blank line in deploy-preview.yml for improved readability. * Refactor GitHub workflow: uncomment build preview steps for improved deployment process and clarity. * Update template.toml (#555) * Update template.toml * Update template.toml * Update template.toml * fix: change VITE_API_BASE to http:// for traefik.me compatibility * changed image from sknnr/enshrouded-dedicated-server to mornedhels/enshrouded-server for autoupdate and easier config * Add Openinary Template (#567) * feat: add Openinary template * feat: update Openinary configuration to support ALLOWED_ORIGIN and refactor domain variable * fix: correct DEFAULT_DOMAIN environment variable reference in docker-compose.yml (#562) * add rustfs template (#568) * feat: add pull request template for improved contribution guidelines * fix: update pull request template to clarify issue closing keywords * feat: add validation scripts and configuration for Docker Compose and template files - Introduced a GitHub Actions workflow to validate Docker Compose files and template.toml on pull requests. - Added helper functions for generating random values and processing variables in templates. - Implemented validation scripts for checking the structure, syntax, and best practices of Docker Compose and template files. - Created necessary TypeScript types and configuration files for the build scripts. * Add Passbolt template blueprint to Dokploy templates (#376) * feat(templates): add Passbolt blueprint for Dokploy - Add docker-compose.yml defining services for Passbolt and MariaDB - Create template.toml with configurable domain, email, and database credentials - Add meta.json with metadata, tags, and link to logo * fix(meta): sort meta.json entries * fix: passbolt template had several issues that broke deployment - env variables were using old array format, changed to new table format - mariadb healthcheck was broken (wrong command for mariadb 11) - missing volume mounts for gpg keys, jwt tokens, and database - setup instructions weren't visible to users, moved to docker-compose - email config had circular references causing warnings - tested admin user creation and confirmed working everything works now, fully tested * Update blueprints/passbolt/template.toml --------- Co-authored-by: Mauricio Siu <47042324+Siumauricio@users.noreply.github.com> * feat: Add Kokoro TTS FastAPI template (#353) (#403) * feat: Add Kokoro TTS FastAPI template (#353) - Add CPU-optimized docker-compose.yml with source build - Add GPU-optimized docker-compose-gpu.yml for NVIDIA support - Add comprehensive template.toml with OpenAI-compatible API docs - Add kokoro-tts.svg logo and meta.json entry - Support streaming audio, timestamps, and multi-language TTS - Resolves #353 * updated the meta.json for the build errors * removed the docker-compose-gpu.yml file * Update docker-compose.yml --------- Co-authored-by: Mauricio Siu <47042324+Siumauricio@users.noreply.github.com> * chore: remove package-lock.json file from the app directory * chore: update Tolgee to latest version and fix SMTP config typo (#432) * chore: update Tolgee to latest version and fix SMTP config typo * Update docker-compose.yml * Update docker-compose.yml --------- Co-authored-by: Mauricio Siu <47042324+Siumauricio@users.noreply.github.com> * fix: improve Docker Compose validation workflow to handle subshell issues - Converted the handling of COMPOSE_FILES from a pipe to an array to ensure error propagation in the parent shell. - Updated the loop to iterate over the array for better reliability in the validation process. * refactor: enhance Docker Compose validation workflow to improve error handling - Replaced the pipe with an array to handle directory names, ensuring that errors within the loop propagate correctly to the parent shell. - Updated the loop structure for better reliability in processing the directories. * Feat: Add parseable (#460) * Add parseable * Update docker-compose.yml * Update docker-compose.yml * Update blueprints/parseable/template.toml --------- Co-authored-by: Mauricio Siu <47042324+Siumauricio@users.noreply.github.com> Co-authored-by: Mauricio Siu * feat: add ChirpStack LoRaWAN Network Server template (#486) * feat: add ChirpStack LoRaWAN Network Server template Add complete ChirpStack v4 template with: - Main ChirpStack server with web UI - UDP and Basics Station gateway bridges - REST API interface - PostgreSQL database with PostGIS extensions - Redis cache - Mosquitto MQTT broker Default configuration for EU868 region with secure random credentials. Supports all LoRaWAN frequency bands globally. * fix(chirpstack): use original configurations from chirpstack-docker repo Update template.toml to use exact configuration files from the chirpstack-docker repository instead of simplified versions: - Use original chirpstack.toml with all 15 enabled regions - Use original gateway bridge configuration with documentation links - Use complete Basics Station EU868 config with frequency plans - Keep original Mosquitto and PostgreSQL initialization scripts Template size increased from 131 to 219 lines (4.7KB) to include comprehensive default configurations that match the official setup. * feat: add all 38 region configuration files * fix(chirpstack): add volume mounts to expose config files to containers * fix(chirpstack): remove read-only flag * fix(chirpstack): correct file paths for configuration mounts in docker-compose and template files * fix: update volume paths to be on correct directory level * fix: configure template for dokploy-network with proper DNS resolution - Add dokploy-network configuration to docker-compose.yml - Replace environment variable placeholders with actual service hostnames - Change PostgreSQL DSN from $POSTGRESQL_HOST to postgres - Change Redis server from $REDIS_HOST to redis - Replace $MQTT_BROKER_HOST with mosquitto in all 39 region configurations These changes ensure Docker DNS resolution works correctly by: - Using dokploy-network (overlay) instead of bridge network - Using service names directly in TOML config files (TOML doesn't expand env vars) - Enabling proper service discovery between containers This resolves DNS resolution failures that caused ChirpStack to fail connecting to PostgreSQL and MQTT services during deployment. * fix: add missing network configurations for all services in docker-compose * feat: add internal services to config.domains for proper network configuration * Update docker-compose.yml * fix: enhance domain validation in template validator - Updated the TemplateValidator to ensure that if the 'host' field is provided, it must be a valid string. - Added comments to clarify that 'host' is optional for internal services. * refactor: remove redundant host validation in template validator - Removed the validation for the 'host' field in the TemplateValidator, as it is optional for internal services and does not require a type check if not provided. * refactor: remove internal service domain configurations from template - Eliminated the domain configurations for internal services (Postgres, Redis, Mosquitto) from the template.toml file, streamlining the configuration for better clarity and maintainability. --------- Co-authored-by: Mauricio Siu <47042324+Siumauricio@users.noreply.github.com> Co-authored-by: Mauricio Siu * Update section title from 'Suggestions' to 'Requirements' * Feat : Add MCSManager template support (#521) (#522) * feat: Add MCSManager template support (#521) * Update docker-compose.yml --------- Co-authored-by: Mauricio Siu <47042324+Siumauricio@users.noreply.github.com> * feat: Add MediaCMS template (#524) * Feat : Add Quant-Ux template -#173 (#525) * Feat : Add Quant-Ux template -#173 * Remove extra newline in docker-compose.yml * Update blueprints/quant-ux/docker-compose.yml * Update blueprints/quant-ux/docker-compose.yml * Update blueprints/quant-ux/docker-compose.yml * Update blueprints/quant-ux/docker-compose.yml --------- Co-authored-by: Mauricio Siu <47042324+Siumauricio@users.noreply.github.com> * fix(rustdesk): use explicit ports, use port 21118 on hbbs instead of hbbr (#526) * fix: use explicit ports, use port 21118 on hbbs instead of hbbr * fix: whitespace character in rustdesk * feat: Add anytype template (#527) * add anytype template * sort * Update name field for Anytype in meta.json * Update meta.json * Update docker-compose.yml * Update blueprints/anytype/docker-compose.yml --------- Co-authored-by: Mauricio Siu <47042324+Siumauricio@users.noreply.github.com> * refactor: remove dokploy-network configurations from multiple docker-compose files - Removed the external dokploy-network configuration from various services' docker-compose.yml files to streamline network management. - This change simplifies the setup and ensures consistency across blueprints. * chore: upgrade Infisical from v0.90.1 to v0.135.0 (#529) * chore: upgrade Infisical from v0.90.1 to v0.135.0 * Update docker-compose.yml --------- Co-authored-by: Mauricio Siu <47042324+Siumauricio@users.noreply.github.com> * fix: update pull request template link for clarity - Changed the link in the pull request template from 'general suggestions' to 'general requirements' to better reflect the content and ensure users follow the correct guidelines when creating templates. * chore: add section for screenshots or videos in pull request template - Introduced a new section in the pull request template to encourage contributors to include screenshots or videos, enhancing the clarity and context of their submissions. * Feat : Add MuleSoft ESB Runtime Template (#498) * added the mulesoft esb template * updated the compose and the meta.json * feat(mulesoft-esb): update image and add dynamic env configuration - Updated image to hari1367709/mule-esb:latest - Added dynamic HTTP_PORT for runtime port configuration - Added MULE_VERSION environment variable for Mule ESB version selection * updated the meta.json to use the version as latest * added a comment line to the template file * updated the mule runtime image * fix(mulesoft-esb): update ports configuration to follow guidelines * updated the port to use the env(HTTP_PORT) * Update docker-compose.yml * Update docker-compose.yml * Update blueprints/mulesoft-esb/docker-compose.yml --------- Co-authored-by: Mauricio Siu <47042324+Siumauricio@users.noreply.github.com> * feat(blueprint): update trmnl-byos-laravel template (#533) * feat(blueprint): update trmnl-byos-laravel template * Update docker-compose.yml --------- Co-authored-by: Mauricio Siu <47042324+Siumauricio@users.noreply.github.com> * feat(blueprint): peerdb template (#579) * feat(blueprint): initial attempt at peerdb template * fix: entrypoint and healthcheck * fix: entrypoint * fix: temporarily remove network * fix: temporal port * chore: remove 36987 for minio * fix: remove peerdb 9900 port exposure * fix: port for console * fix: minio env fix * fix: expose peerdb and minio to dokploy network * fix(peerdb): add defaults * fix: remove extra hosts * fix: remove network entries * fix: use consistent environment variables * feat: add Bluesky PDS template (#542) * feat: Bluesky PDS template * chore: add bluesky pds svg * chore: metadata for bluesky pds * yaml > yml * pnpm lock * fix: correct rotation key config * fix volumes * fix: volumes in the pds compose * define volumes in compose * fix: 32 bit rotation key * create pds.env correctly * some extra fixes * more extra fixes * a blank line * update pnpm lock * Add dokploy-prom-monitoring-extension template with comprehensive tests and documentation (#548) * Add dokploy-prom-monitoring-extension template with comprehensive tests and documentation * Fix METRICS_CONFIG environment variable: use single-line JSON format * Fix template.toml: use correct [config.env] syntax for environment variables * Fix docker-compose.yml: add env_file reference to load environment variables * Delete blueprints/dokploy-prom-monitoring-extension/README.md * Delete test-dokploy-prom-monitoring-extension.sh --------- Co-authored-by: Sanjeevi Subramani Co-authored-by: Mauricio Siu <47042324+Siumauricio@users.noreply.github.com> * feat: improve RustDesk template configuration (#571) * feat: improve RustDesk template configuration - Add comprehensive environment variables for RustDesk server - Add RELAY_HOST, API_SERVER, ID_SERVER, and ENCRYPTION_KEY variables - Follow Dokploy best practices (no container_name, proper port format) - Use restart: unless-stopped policy - Add encryption key generation with password helper * fix: use explicit port mapping for RustDesk services RustDesk requires explicit port bindings (host:container format) to function properly. The service uses specific ports for: - 21115-21116 (TCP/UDP): hbbs service for ID and NAT traversal - 21117-21119 (TCP): hbbr relay service Without explicit port mapping, RustDesk clients cannot establish connections to the server. This is an exception to Dokploy's general port guidelines due to RustDesk's specific networking requirements. --------- Co-authored-by: Mauricio Siu <47042324+Siumauricio@users.noreply.github.com> * feat: add Mumble voice chat server template (#572) * feat: add Mumble voice chat server template - Add Mumble VoIP server blueprint with docker-compose.yml - Configure environment variables for superuser password, welcome text, and max users - Add template.toml with auto-generated secure password - Follow Dokploy best practices (no container_name, proper port format) - Add Mumble metadata to meta.json with proper tags - Support for TCP and UDP on port 64738 * Update template.toml * fix: correct JSON formatting in meta.json for Mumble template entry --------- Co-authored-by: Mauricio Siu <47042324+Siumauricio@users.noreply.github.com> Co-authored-by: Mauricio Siu * fix: update WireGuard Easy template for proper functionality (#573) * fix: update WireGuard Easy template for proper functionality - Changed to named volume (etc_wireguard) instead of host path mount - Added explicit port mappings (51820:51820/udp, 51821:51821/tcp) required for WireGuard - Updated environment variables to use correct WG_HOST and PASSWORD format - Added all required WireGuard environment variables: - WG_PORT, PORT, WG_MTU, WG_DEFAULT_DNS, WG_ALLOWED_IPS - WG_POST_UP/WG_POST_DOWN for iptables rules - Added NET_RAW capability for proper network operations - Simplified template.toml to use WIREGUARD_HOST and WIREGUARD_PASSWORD - Removed explicit networks config to enable Dokploy's isolated deployment - Template now works with Dokploy's automatic network isolation This configuration has been tested and confirmed working with isolated deployment enabled. * Update template.toml --------- Co-authored-by: Mauricio Siu <47042324+Siumauricio@users.noreply.github.com> * add: restart policy to MinIO service (#576) restart: unless-stopped is a Docker restart policy that automatically restarts a container if it stops due to an error or Docker daemon restart * Updating copilot instructions.md and AGENTS.md (#452) * docs: add copilot instructions for project development Added comprehensive documentation file (.github/copilot-instructions.md) that provides detailed guidance on the Dokploy Open Source Templates project structure, development workflow, and conventions. The document covers the project overview, key files and directories, development workflow for adding/updating templates, local development setup, CI/CD processes, and established conventions and patterns. This documentation will help onboard new contributors and ensure consistent development practices across the project. * docs(copilot-instructions): enhance project overview and development guide Updated copilot instructions to reflect expanded app capabilities (200+ apps, TypeScript integration, Fuse.js search) and detailed processes for templates, local dev, and CI/CD for improved clarity and accuracy. * refactor: remove frontend development instructions from AGENTS.md and update contributing guidelines - Removed frontend development commands from AGENTS.md to streamline the document. - Updated CONTRIBUTING.md by removing the recommendation to set `restart: unless-stopped` for services. --------- Co-authored-by: Mauricio Siu * Add trailbase template (#590) * Add trailbase * Add comment on mounting local directory * Update meta.json Co-authored-by: Copilot <175728472+Copilot@users.noreply.github.com> --------- Co-authored-by: Mauricio Siu <47042324+Siumauricio@users.noreply.github.com> Co-authored-by: Copilot <175728472+Copilot@users.noreply.github.com> * fix: openpanel and migrate to v2 (#594) * refactor: update docker-compose.yml to include version and restart policy (#599) * feat(blueprint): mage ai template (#601) * feat(blueprint): template for mage-ai * fix: add healthcheck for mage-ai * docs: update copilot instructions to emphasize version pinning in docker-compose.yml Clarified the importance of pinning image versions in docker-compose.yml and explicitly stated to avoid using the `latest` tag to prevent potential issues with template functionality when upstream images change. * refactor: enhance Docker Compose validation workflow Updated the GitHub Actions workflow for validating Docker Compose files by streamlining the detection of changed blueprints and improving the validation process. Removed redundant steps and consolidated the validation of docker-compose.yml and template.toml files into a more efficient structure. Added clearer output messages for validation results and ensured that best practices are checked for each blueprint. This refactor aims to improve maintainability and clarity in the CI/CD process. * fix: update zitadel default instance features (#544) * Add Reactive Resume template (#603) * Initial plan * Add Reactive Resume template with docker-compose, template.toml, and meta.json entry Co-authored-by: Siumauricio <47042324+Siumauricio@users.noreply.github.com> * Fix MinIO storage path alignment between template.toml and docker-compose.yml Co-authored-by: Siumauricio <47042324+Siumauricio@users.noreply.github.com> * Update docker-compose.yml --------- Co-authored-by: copilot-swe-agent[bot] <198982749+Copilot@users.noreply.github.com> Co-authored-by: Siumauricio <47042324+Siumauricio@users.noreply.github.com> * [WIP] Fix mounted prometheus.yml file not working (#605) * Initial plan * Fix Prometheus mounted prometheus.yml file by adding volume mount Co-authored-by: Siumauricio <47042324+Siumauricio@users.noreply.github.com> * Update blueprints/prometheus/template.toml Co-authored-by: Copilot <175728472+Copilot@users.noreply.github.com> --------- Co-authored-by: copilot-swe-agent[bot] <198982749+Copilot@users.noreply.github.com> Co-authored-by: Siumauricio <47042324+Siumauricio@users.noreply.github.com> Co-authored-by: Copilot <175728472+Copilot@users.noreply.github.com> * docs: update copilot instructions to enforce open source requirement Added a clear requirement stating that all services must be open source and only applications with open-source licenses (e.g., MIT, Apache, GPL, AGPL) are allowed. This update aims to ensure compliance and maintain the integrity of the project. * Fix Cap.so template MinIO deployment failure (#604) * Initial plan * Fix Cap.so MinIO image to use official quay.io image Co-authored-by: Siumauricio <47042324+Siumauricio@users.noreply.github.com> * Fix MinIO healthcheck to use curl instead of mc Co-authored-by: Siumauricio <47042324+Siumauricio@users.noreply.github.com> * Update .gitignore --------- Co-authored-by: copilot-swe-agent[bot] <198982749+Copilot@users.noreply.github.com> Co-authored-by: Siumauricio <47042324+Siumauricio@users.noreply.github.com> * Fix Discourse template manifest error - update to bitnamilegacy/discourse:3.5.0 (#606) * Initial plan * Fix Discourse template by updating to bitnamilegacy/discourse:3.5.0 Co-authored-by: Siumauricio <47042324+Siumauricio@users.noreply.github.com> --------- Co-authored-by: copilot-swe-agent[bot] <198982749+Copilot@users.noreply.github.com> Co-authored-by: Siumauricio <47042324+Siumauricio@users.noreply.github.com> * Remove pull request trigger from deploy-preview workflow * Enhance copilot instructions by adding verification steps for Docker images and clarifying URL variable usage. Emphasize the importance of verifying image existence before committing to prevent deployment failures. * Add Easy!Appointments template (#608) * Initial plan * Add Easyappointments template with docker-compose, template.toml, and meta.json entry Co-authored-by: Siumauricio <47042324+Siumauricio@users.noreply.github.com> * Update blueprints/easyappointments/template.toml Co-authored-by: Copilot <175728472+Copilot@users.noreply.github.com> * Update template.toml --------- Co-authored-by: copilot-swe-agent[bot] <198982749+Copilot@users.noreply.github.com> Co-authored-by: Siumauricio <47042324+Siumauricio@users.noreply.github.com> Co-authored-by: Copilot <175728472+Copilot@users.noreply.github.com> * Add Dolibarr ERP & CRM template (#610) * Initial plan * Add Dolibarr ERP & CRM template Co-authored-by: Siumauricio <47042324+Siumauricio@users.noreply.github.com> * Update template.toml * Update blueprints/dolibarr/docker-compose.yml Co-authored-by: Copilot <175728472+Copilot@users.noreply.github.com> --------- Co-authored-by: copilot-swe-agent[bot] <198982749+Copilot@users.noreply.github.com> Co-authored-by: Siumauricio <47042324+Siumauricio@users.noreply.github.com> Co-authored-by: Copilot <175728472+Copilot@users.noreply.github.com> * feat: add Syncthing Template (#636) * Adiciona template do Syncthing com arquivos de configuração e ícone * Remove versão do Docker Compose do template do Syncthing * Update Umami to version v2.20.2 (#641) * Feat : Add InstantDB template (#224) (#530) * feat: add InstantDB template * added the server service also * removed the external network * Update docker-compose.yml * Update blueprints/instantdb/docker-compose.yml * Update blueprints/instantdb/docker-compose.yml * Update docker-compose.yml * Update blueprints/instantdb/template.toml --------- Co-authored-by: Mauricio Siu <47042324+Siumauricio@users.noreply.github.com> * [New Template] Added Lavalink template for dokploy (#535) * Add initial Lavalink configuration template * Added lavalink.svg logo * Create docker-compose.yml for Lavalink setup Add Docker Compose configuration for Lavalink service. * Modify healthcheck interval in docker-compose.yml Increased healthcheck interval from 10s to 100s. * Add Lavalink metadata to meta.json Added metadata for Lavalink audio sending node. * Update server_port variable to use ${port} * Change server port variable to randomPort * Change port variable to randomPort in template.toml * Change port variable in template.toml * Update server port in template.toml * Fix formatting in template.toml for server config * style: Reformat lavalink entry in meta.json. * Update docker-compose.yml --------- Co-authored-by: Mauricio Siu <47042324+Siumauricio@users.noreply.github.com> * chore(blueprint): update Appwrite services to v1.8 (#383) * Update Appwrite version docker images and environment variables * Add separate domains for functions and sites, update environment variables, replace insecure default passwords * Update Appwrite version from 1.6.1 to 1.7.4 in `meta.json` * Fix envs and update domains * Add missing volume mounts for sites * Fix config file syntax * Update runtimes network configuration in template.toml * Update Appwrite to 1.8 * Update appwrite image version to 1.8.0 * Add logging configuration to docker-compose * New Templates (#586) * feat(librechat): add LibreChat blueprint with compose, toml, metadata, links and tags * fix: rename templates to template.toml * fix(librechat): rename api service to librechat in docker-compose.yml * Update blueprints/librechat/template.toml * Update blueprints/librechat/template.toml * fix(librechat): add version under [config] and remove stray [config.mounts] header * fix(librechat): remove predefined persistent volume mounts from template.toml * docs(librechat): add authentication reference link to docker-compose.yml * feat: add Rote template - Add Rote deployment template with frontend, backend, and PostgreSQL services - Configure domain routing for frontend (port 80) and backend (port 3000) - Set up automatic password generation and environment variables - Use latest image tag by default - Add logo and metadata to meta.json * fix: process meta.json to fix formatting and sorting * Update GitHub workflows to target 'canary' branch for meta validation * Update pnpm-lock.yaml to upgrade various dependencies, including '@codemirror/autocomplete', '@radix-ui/react-dialog', and React packages to their latest versions. This includes updates to '@types/react' and '@types/react-dom' for improved compatibility and performance. * Enhance GitHub workflows: add production deployment configuration and target 'canary' branch for pull requests. * Refactor GitHub workflow: comment out build preview steps for clarity and future modifications. * Remove unnecessary blank line in deploy-preview.yml for improved readability. * Refactor GitHub workflow: uncomment build preview steps for improved deployment process and clarity. * Update template.toml (#555) * Update template.toml * Update template.toml * Update template.toml * fix: change VITE_API_BASE to http:// for traefik.me compatibility * changed image from sknnr/enshrouded-dedicated-server to mornedhels/enshrouded-server for autoupdate and easier config * Add Openinary Template (#567) * feat: add Openinary template * feat: update Openinary configuration to support ALLOWED_ORIGIN and refactor domain variable * fix: correct DEFAULT_DOMAIN environment variable reference in docker-compose.yml (#562) * add rustfs template (#568) * feat: add pull request template for improved contribution guidelines * fix: update pull request template to clarify issue closing keywords * feat: add validation scripts and configuration for Docker Compose and template files - Introduced a GitHub Actions workflow to validate Docker Compose files and template.toml on pull requests. - Added helper functions for generating random values and processing variables in templates. - Implemented validation scripts for checking the structure, syntax, and best practices of Docker Compose and template files. - Created necessary TypeScript types and configuration files for the build scripts. * Add Passbolt template blueprint to Dokploy templates (#376) * feat(templates): add Passbolt blueprint for Dokploy - Add docker-compose.yml defining services for Passbolt and MariaDB - Create template.toml with configurable domain, email, and database credentials - Add meta.json with metadata, tags, and link to logo * fix(meta): sort meta.json entries * fix: passbolt template had several issues that broke deployment - env variables were using old array format, changed to new table format - mariadb healthcheck was broken (wrong command for mariadb 11) - missing volume mounts for gpg keys, jwt tokens, and database - setup instructions weren't visible to users, moved to docker-compose - email config had circular references causing warnings - tested admin user creation and confirmed working everything works now, fully tested * Update blueprints/passbolt/template.toml --------- Co-authored-by: Mauricio Siu <47042324+Siumauricio@users.noreply.github.com> * feat: Add Kokoro TTS FastAPI template (#353) (#403) * feat: Add Kokoro TTS FastAPI template (#353) - Add CPU-optimized docker-compose.yml with source build - Add GPU-optimized docker-compose-gpu.yml for NVIDIA support - Add comprehensive template.toml with OpenAI-compatible API docs - Add kokoro-tts.svg logo and meta.json entry - Support streaming audio, timestamps, and multi-language TTS - Resolves #353 * updated the meta.json for the build errors * removed the docker-compose-gpu.yml file * Update docker-compose.yml --------- Co-authored-by: Mauricio Siu <47042324+Siumauricio@users.noreply.github.com> * chore: remove package-lock.json file from the app directory * chore: update Tolgee to latest version and fix SMTP config typo (#432) * chore: update Tolgee to latest version and fix SMTP config typo * Update docker-compose.yml * Update docker-compose.yml --------- Co-authored-by: Mauricio Siu <47042324+Siumauricio@users.noreply.github.com> * fix: improve Docker Compose validation workflow to handle subshell issues - Converted the handling of COMPOSE_FILES from a pipe to an array to ensure error propagation in the parent shell. - Updated the loop to iterate over the array for better reliability in the validation process. * refactor: enhance Docker Compose validation workflow to improve error handling - Replaced the pipe with an array to handle directory names, ensuring that errors within the loop propagate correctly to the parent shell. - Updated the loop structure for better reliability in processing the directories. * Feat: Add parseable (#460) * Add parseable * Update docker-compose.yml * Update docker-compose.yml * Update blueprints/parseable/template.toml --------- Co-authored-by: Mauricio Siu <47042324+Siumauricio@users.noreply.github.com> Co-authored-by: Mauricio Siu * feat: add ChirpStack LoRaWAN Network Server template (#486) * feat: add ChirpStack LoRaWAN Network Server template Add complete ChirpStack v4 template with: - Main ChirpStack server with web UI - UDP and Basics Station gateway bridges - REST API interface - PostgreSQL database with PostGIS extensions - Redis cache - Mosquitto MQTT broker Default configuration for EU868 region with secure random credentials. Supports all LoRaWAN frequency bands globally. * fix(chirpstack): use original configurations from chirpstack-docker repo Update template.toml to use exact configuration files from the chirpstack-docker repository instead of simplified versions: - Use original chirpstack.toml with all 15 enabled regions - Use original gateway bridge configuration with documentation links - Use complete Basics Station EU868 config with frequency plans - Keep original Mosquitto and PostgreSQL initialization scripts Template size increased from 131 to 219 lines (4.7KB) to include comprehensive default configurations that match the official setup. * feat: add all 38 region configuration files * fix(chirpstack): add volume mounts to expose config files to containers * fix(chirpstack): remove read-only flag * fix(chirpstack): correct file paths for configuration mounts in docker-compose and template files * fix: update volume paths to be on correct directory level * fix: configure template for dokploy-network with proper DNS resolution - Add dokploy-network configuration to docker-compose.yml - Replace environment variable placeholders with actual service hostnames - Change PostgreSQL DSN from $POSTGRESQL_HOST to postgres - Change Redis server from $REDIS_HOST to redis - Replace $MQTT_BROKER_HOST with mosquitto in all 39 region configurations These changes ensure Docker DNS resolution works correctly by: - Using dokploy-network (overlay) instead of bridge network - Using service names directly in TOML config files (TOML doesn't expand env vars) - Enabling proper service discovery between containers This resolves DNS resolution failures that caused ChirpStack to fail connecting to PostgreSQL and MQTT services during deployment. * fix: add missing network configurations for all services in docker-compose * feat: add internal services to config.domains for proper network configuration * Update docker-compose.yml * fix: enhance domain validation in template validator - Updated the TemplateValidator to ensure that if the 'host' field is provided, it must be a valid string. - Added comments to clarify that 'host' is optional for internal services. * refactor: remove redundant host validation in template validator - Removed the validation for the 'host' field in the TemplateValidator, as it is optional for internal services and does not require a type check if not provided. * refactor: remove internal service domain configurations from template - Eliminated the domain configurations for internal services (Postgres, Redis, Mosquitto) from the template.toml file, streamlining the configuration for better clarity and maintainability. --------- Co-authored-by: Mauricio Siu <47042324+Siumauricio@users.noreply.github.com> Co-authored-by: Mauricio Siu * Update section title from 'Suggestions' to 'Requirements' * Feat : Add MCSManager template support (#521) (#522) * feat: Add MCSManager template support (#521) * Update docker-compose.yml --------- Co-authored-by: Mauricio Siu <47042324+Siumauricio@users.noreply.github.com> * feat: Add MediaCMS template (#524) * Feat : Add Quant-Ux template -#173 (#525) * Feat : Add Quant-Ux template -#173 * Remove extra newline in docker-compose.yml * Update blueprints/quant-ux/docker-compose.yml * Update blueprints/quant-ux/docker-compose.yml * Update blueprints/quant-ux/docker-compose.yml * Update blueprints/quant-ux/docker-compose.yml --------- Co-authored-by: Mauricio Siu <47042324+Siumauricio@users.noreply.github.com> * fix(rustdesk): use explicit ports, use port 21118 on hbbs instead of hbbr (#526) * fix: use explicit ports, use port 21118 on hbbs instead of hbbr * fix: whitespace character in rustdesk * feat: Add anytype template (#527) * add anytype template * sort * Update name field for Anytype in meta.json * Update meta.json * Update docker-compose.yml * Update blueprints/anytype/docker-compose.yml --------- Co-authored-by: Mauricio Siu <47042324+Siumauricio@users.noreply.github.com> * refactor: remove dokploy-network configurations from multiple docker-compose files - Removed the external dokploy-network configuration from various services' docker-compose.yml files to streamline network management. - This change simplifies the setup and ensures consistency across blueprints. * chore: upgrade Infisical from v0.90.1 to v0.135.0 (#529) * chore: upgrade Infisical from v0.90.1 to v0.135.0 * Update docker-compose.yml --------- Co-authored-by: Mauricio Siu <47042324+Siumauricio@users.noreply.github.com> * fix: update pull request template link for clarity - Changed the link in the pull request template from 'general suggestions' to 'general requirements' to better reflect the content and ensure users follow the correct guidelines when creating templates. * chore: add section for screenshots or videos in pull request template - Introduced a new section in the pull request template to encourage contributors to include screenshots or videos, enhancing the clarity and context of their submissions. * Feat : Add MuleSoft ESB Runtime Template (#498) * added the mulesoft esb template * updated the compose and the meta.json * feat(mulesoft-esb): update image and add dynamic env configuration - Updated image to hari1367709/mule-esb:latest - Added dynamic HTTP_PORT for runtime port configuration - Added MULE_VERSION environment variable for Mule ESB version selection * updated the meta.json to use the version as latest * added a comment line to the template file * updated the mule runtime image * fix(mulesoft-esb): update ports configuration to follow guidelines * updated the port to use the env(HTTP_PORT) * Update docker-compose.yml * Update docker-compose.yml * Update blueprints/mulesoft-esb/docker-compose.yml --------- Co-authored-by: Mauricio Siu <47042324+Siumauricio@users.noreply.github.com> * feat(blueprint): update trmnl-byos-laravel template (#533) * feat(blueprint): update trmnl-byos-laravel template * Update docker-compose.yml --------- Co-authored-by: Mauricio Siu <47042324+Siumauricio@users.noreply.github.com> * feat(blueprint): peerdb template (#579) * feat(blueprint): initial attempt at peerdb template * fix: entrypoint and healthcheck * fix: entrypoint * fix: temporarily remove network * fix: temporal port * chore: remove 36987 for minio * fix: remove peerdb 9900 port exposure * fix: port for console * fix: minio env fix * fix: expose peerdb and minio to dokploy network * fix(peerdb): add defaults * fix: remove extra hosts * fix: remove network entries * fix: use consistent environment variables * feat: add Bluesky PDS template (#542) * feat: Bluesky PDS template * chore: add bluesky pds svg * chore: metadata for bluesky pds * yaml > yml * pnpm lock * fix: correct rotation key config * fix volumes * fix: volumes in the pds compose * define volumes in compose * fix: 32 bit rotation key * create pds.env correctly * some extra fixes * more extra fixes * a blank line * update pnpm lock * Add dokploy-prom-monitoring-extension template with comprehensive tests and documentation (#548) * Add dokploy-prom-monitoring-extension template with comprehensive tests and documentation * Fix METRICS_CONFIG environment variable: use single-line JSON format * Fix template.toml: use correct [config.env] syntax for environment variables * Fix docker-compose.yml: add env_file reference to load environment variables * Delete blueprints/dokploy-prom-monitoring-extension/README.md * Delete test-dokploy-prom-monitoring-extension.sh --------- Co-authored-by: Sanjeevi Subramani Co-authored-by: Mauricio Siu <47042324+Siumauricio@users.noreply.github.com> * feat: improve RustDesk template configuration (#571) * feat: improve RustDesk template configuration - Add comprehensive environment variables for RustDesk server - Add RELAY_HOST, API_SERVER, ID_SERVER, and ENCRYPTION_KEY variables - Follow Dokploy best practices (no container_name, proper port format) - Use restart: unless-stopped policy - Add encryption key generation with password helper * fix: use explicit port mapping for RustDesk services RustDesk requires explicit port bindings (host:container format) to function properly. The service uses specific ports for: - 21115-21116 (TCP/UDP): hbbs service for ID and NAT traversal - 21117-21119 (TCP): hbbr relay service Without explicit port mapping, RustDesk clients cannot establish connections to the server. This is an exception to Dokploy's general port guidelines due to RustDesk's specific networking requirements. --------- Co-authored-by: Mauricio Siu <47042324+Siumauricio@users.noreply.github.com> * feat: add Mumble voice chat server template (#572) * feat: add Mumble voice chat server template - Add Mumble VoIP server blueprint with docker-compose.yml - Configure environment variables for superuser password, welcome text, and max users - Add template.toml with auto-generated secure password - Follow Dokploy best practices (no container_name, proper port format) - Add Mumble metadata to meta.json with proper tags - Support for TCP and UDP on port 64738 * Update template.toml * fix: correct JSON formatting in meta.json for Mumble template entry --------- Co-authored-by: Mauricio Siu <47042324+Siumauricio@users.noreply.github.com> Co-authored-by: Mauricio Siu * fix: update WireGuard Easy template for proper functionality (#573) * fix: update WireGuard Easy template for proper functionality - Changed to named volume (etc_wireguard) instead of host path mount - Added explicit port mappings (51820:51820/udp, 51821:51821/tcp) required for WireGuard - Updated environment variables to use correct WG_HOST and PASSWORD format - Added all required WireGuard environment variables: - WG_PORT, PORT, WG_MTU, WG_DEFAULT_DNS, WG_ALLOWED_IPS - WG_POST_UP/WG_POST_DOWN for iptables rules - Added NET_RAW capability for proper network operations - Simplified template.toml to use WIREGUARD_HOST and WIREGUARD_PASSWORD - Removed explicit networks config to enable Dokploy's isolated deployment - Template now works with Dokploy's automatic network isolation This configuration has been tested and confirmed working with isolated deployment enabled. * Update template.toml --------- Co-authored-by: Mauricio Siu <47042324+Siumauricio@users.noreply.github.com> * add: restart policy to MinIO service (#576) restart: unless-stopped is a Docker restart policy that automatically restarts a container if it stops due to an error or Docker daemon restart --------- Co-authored-by: Sunil Shrestha Co-authored-by: Rabithua Co-authored-by: Mauricio Siu Co-authored-by: Scan <103391616+scanash00@users.noreply.github.com> Co-authored-by: Crackvignoule Co-authored-by: florianheysen <39408021+florianheysen@users.noreply.github.com> Co-authored-by: Thiago MadPin Co-authored-by: BlinkStrike <18644035+BlinkStrike@users.noreply.github.com> Co-authored-by: M Jupri Amin <127651222+Juupeee@users.noreply.github.com> Co-authored-by: Harikrishnan Dhanasekaran Co-authored-by: Kamil Dzieniszewski Co-authored-by: Nick Anderson Co-authored-by: lefolalan Co-authored-by: Chris <31969757+ChrisvanChip@users.noreply.github.com> Co-authored-by: kipavy <88386090+kipavy@users.noreply.github.com> Co-authored-by: Benjamin Nussbaum Co-authored-by: Khiet Tam Nguyen <86177399+nktnet1@users.noreply.github.com> Co-authored-by: Vidhya LKG for IT <24915474+VidhyaSanjeevi@users.noreply.github.com> Co-authored-by: Sanjeevi Subramani Co-authored-by: Muzaffer Kadir YILMAZ <34358176+muzafferkadir@users.noreply.github.com> Co-authored-by: Jemg * Remove `container_name` from all containers * Remove expliced networks * Update blueprints/appwrite/docker-compose.yml Co-authored-by: Copilot <175728472+Copilot@users.noreply.github.com> * Update password variables to use 32-character length * Update Appwrite description and tags in meta.json * Fix JSON formatting in meta.json by adding missing closing bracket * Fix formatting in meta.json by removing trailing spaces in tags array * Add missing SMS and Backblaze storage configuration options in template.toml * Update docker-compose.yml --------- Co-authored-by: Pascal Oberbeck Co-authored-by: Mauricio Siu <47042324+Siumauricio@users.noreply.github.com> Co-authored-by: Sunil Shrestha Co-authored-by: Rabithua Co-authored-by: Mauricio Siu Co-authored-by: Scan <103391616+scanash00@users.noreply.github.com> Co-authored-by: Crackvignoule Co-authored-by: florianheysen <39408021+florianheysen@users.noreply.github.com> Co-authored-by: Thiago MadPin Co-authored-by: BlinkStrike <18644035+BlinkStrike@users.noreply.github.com> Co-authored-by: M Jupri Amin <127651222+Juupeee@users.noreply.github.com> Co-authored-by: Harikrishnan Dhanasekaran Co-authored-by: Kamil Dzieniszewski Co-authored-by: Nick Anderson Co-authored-by: lefolalan Co-authored-by: Chris <31969757+ChrisvanChip@users.noreply.github.com> Co-authored-by: kipavy <88386090+kipavy@users.noreply.github.com> Co-authored-by: Benjamin Nussbaum Co-authored-by: Khiet Tam Nguyen <86177399+nktnet1@users.noreply.github.com> Co-authored-by: Vidhya LKG for IT <24915474+VidhyaSanjeevi@users.noreply.github.com> Co-authored-by: Sanjeevi Subramani Co-authored-by: Muzaffer Kadir YILMAZ <34358176+muzafferkadir@users.noreply.github.com> Co-authored-by: Jemg Co-authored-by: Copilot <175728472+Copilot@users.noreply.github.com> Co-authored-by: Mauricio Siu * feat: emqx template (MQTT Broker) (#556) * feat: template for emqx * chore: process meta * fix: use websocket on port 443 instead of 8084 * docs: improve comments for emqx template * fix: use emqx service name * fix: use dummy domain instead of traefik * fix: explicitly list dokplok-network * fix(emqx): restart unless stopped * fix(emqx): add healthcheck * Dokploy Deployment for Mautic 5 (#564) * first draft * second * try 3 * 4 * Update docker-compose.yml * Update template.toml * Enhance healthchecks and service dependencies in Docker Compose Updated healthcheck configurations for Mautic and MySQL services to improve service reliability. Added conditions to ensure services wait for dependencies to be healthy before starting. * Update Mautic docker-compose with health checks and roles * fix: searxng template (#651) * fix: use major version for openpanel (#680) * Feat/minepanel template (#657) * feat: add Minepanel template * fix: pin images to v1.7.1 and use http for URLs * fix: remove explicit ports, Dokploy handles proxying * chore: process and sort meta.json * fix: consolidate domain variables to main_domain * fix: add version field to docker-compose.yml * Add Komari Monitor template with Docker Compose, icon, and metadata (#XXX) (#623) * Introduce Komari Monitor, a self-hosted server monitoring tool, with its corresponding Docker Compose configuration, icon, and metadata entry. * Add template.toml for configuration and environment variables. * Include necessary links for GitHub and documentation. * Add Misaka Danmu Server template with Docker Compose, icon, and metadata (#624) * Introduce Misaka Danmu Server, a self-hosted danmaku server for live streaming, with its corresponding Docker Compose configuration, icon, and metadata entry. * Add template.toml for configuration and environment variables. * Include necessary links for GitHub and documentation. * fix: pyrodactyl no longer uses main tag for it's latest release (#626) * fix: pyrodactyl no longer uses main tag for it's latest release * Remove custom network settings from docker-compose Removed custom network configuration from docker-compose. * Update MariaDB and Pyrodactyl images in Docker Compose * Add Jenkins blueprint template configuration (#634) - Created a new TOML configuration file for Jenkins blueprint. - Defined main domain variable and service configuration for Jenkins. - Set serviceName to "jenkins" with port 8080 and host as the main domain. * Update Autobase to version 2.5 (#647) * Update Autobase to version 2.5 Bump the autobase-console Docker image from version 2.2.0 to 2.5.2 in docker-compose.yml to use the latest features and fixes. * Update docker-compose.yml * Update docker-compose.yml * Update meta.json * Update Autobase description in meta.json Revised the Autobase package description to clarify it as a self-hosted DBaaS alternative to cloud-managed databases. * Add Cloudreve template (#649) Self-hosted file management and sharing system with multi-cloud storage support. Includes PostgreSQL and Redis for database and caching. * Update to Umami 3.0.3 (#668) * Update Umami version from v2.20.2 to v3.0.3 * Update Umami Docker image to version 3.0.3 * fix: tailscale exitnode authkey env (#669) * Add qbitwebui (#675) * Add qBittorrent Web UI template * Fix healthcheck bug * Create INSTRUCTIONS.md * Rename INSTRUCTIONS.md to instructions.md * feat: add Moltbot template (#683) * feat: add Moltbot template Add template for Moltbot - a WhatsApp gateway CLI with Pi RPC agent. - Uses official ghcr.io/moltbot/moltbot:latest image - Exposes ports 18789 (gateway) and 18790 (bridge) - Includes persistent volumes for config and workspace - Auto-generates gateway token - Optional Claude AI integration support Co-Authored-By: Claude * Update docker-compose.yml * Enhance Moltbot configuration in docker-compose and template files - Added CLAWDBOT_GATEWAY_URL and OPENROUTER_API_KEY to docker-compose.yml - Updated service binding to 'auto' and added init: true for improved service management - Defined CLAWDBOT_GATEWAY_PORT and CLAWDBOT_BRIDGE_PORT in template.toml - Included CLAWDBOT_PLUGINS for plugin configuration in template.toml * Add Moltbot entry to meta.json - Introduced a new entry for Moltbot, a WhatsApp gateway CLI with Pi RPC agent. - Included details such as version, description, logo, links, and relevant tags for better discoverability and integration. --------- Co-authored-by: Claude Co-authored-by: Mauricio Siu <47042324+Siumauricio@users.noreply.github.com> Co-authored-by: Mauricio Siu * feat: add Openclaw template (#694) * feat: rename Moltbot to Openclaw and update related configurations * fix: update Openclaw image version to 2026.1.29 in docker-compose.yml * fix: correct environment variable name for Openclaw gateway * fix: correct volume path for Openclaw workspace in docker-compose.yml * feat: rename Moltbot to Openclaw and update metadata * fix: moving 'openclaw' entry below so the file looks sorted * fix: add missing newline at end of meta.json * fix: update docker-compose.yml to use 'expose' instead of 'ports' and change bind option to 'lan' * feat: update Openclaw service configuration in docker-compose.yml and template.toml - Changed service name from 'openclaw-gateway' to 'openclaw' and updated image version. - Enhanced environment variables for better configuration management. - Added a new 'browser' service with health checks and updated volume paths. * refactor: update environment variable configuration in docker-compose.yml for Openclaw service --------- Co-authored-by: Mauricio Siu * fix: cloudflared documentation links & env variables (#699) * feat(blueprint): Cloudflare DDNS (#689) * feat: added Cloudflare DDNS template * fix: make CLOUDFLARE_API_TOKEN and DOMAINS mandatory env * Fix realtime service name resolution (#563) Expose the CONTAINER_PREFIX environment variable to kong service, then utilize it to format the URL of realtime service. * fix(habitica): add user to mongodb replicaset to enable Dokploy DB backups (#574) * fix: use environment variables from configuration in habitica-server * feat: add users to mongodb replicaSet This commit adds admin and habitica users + enables replicaSet auth by introducing a keyfile. Dokploy DB backups require specifying an user and password, so this enables that feature for Habitica app. * chore: less retries * chore: do not start server until mongo is healthy * fix: ensure habitica user exists for habitica db * fix: remove BASE_URL to prevent infinite redirects * fix: add missing ADMIN_EMAIL --------- Co-authored-by: Jorge Gómez Zarzosa * Refactor wg-easy service configuration to work with latest wg-easy v15 (#598) * New Templates (#586) * feat(librechat): add LibreChat blueprint with compose, toml, metadata, links and tags * fix: rename templates to template.toml * fix(librechat): rename api service to librechat in docker-compose.yml * Update blueprints/librechat/template.toml * Update blueprints/librechat/template.toml * fix(librechat): add version under [config] and remove stray [config.mounts] header * fix(librechat): remove predefined persistent volume mounts from template.toml * docs(librechat): add authentication reference link to docker-compose.yml * feat: add Rote template - Add Rote deployment template with frontend, backend, and PostgreSQL services - Configure domain routing for frontend (port 80) and backend (port 3000) - Set up automatic password generation and environment variables - Use latest image tag by default - Add logo and metadata to meta.json * fix: process meta.json to fix formatting and sorting * Update GitHub workflows to target 'canary' branch for meta validation * Update pnpm-lock.yaml to upgrade various dependencies, including '@codemirror/autocomplete', '@radix-ui/react-dialog', and React packages to their latest versions. This includes updates to '@types/react' and '@types/react-dom' for improved compatibility and performance. * Enhance GitHub workflows: add production deployment configuration and target 'canary' branch for pull requests. * Refactor GitHub workflow: comment out build preview steps for clarity and future modifications. * Remove unnecessary blank line in deploy-preview.yml for improved readability. * Refactor GitHub workflow: uncomment build preview steps for improved deployment process and clarity. * Update template.toml (#555) * Update template.toml * Update template.toml * Update template.toml * fix: change VITE_API_BASE to http:// for traefik.me compatibility * changed image from sknnr/enshrouded-dedicated-server to mornedhels/enshrouded-server for autoupdate and easier config * Add Openinary Template (#567) * feat: add Openinary template * feat: update Openinary configuration to support ALLOWED_ORIGIN and refactor domain variable * fix: correct DEFAULT_DOMAIN environment variable reference in docker-compose.yml (#562) * add rustfs template (#568) * feat: add pull request template for improved contribution guidelines * fix: update pull request template to clarify issue closing keywords * feat: add validation scripts and configuration for Docker Compose and template files - Introduced a GitHub Actions workflow to validate Docker Compose files and template.toml on pull requests. - Added helper functions for generating random values and processing variables in templates. - Implemented validation scripts for checking the structure, syntax, and best practices of Docker Compose and template files. - Created necessary TypeScript types and configuration files for the build scripts. * Add Passbolt template blueprint to Dokploy templates (#376) * feat(templates): add Passbolt blueprint for Dokploy - Add docker-compose.yml defining services for Passbolt and MariaDB - Create template.toml with configurable domain, email, and database credentials - Add meta.json with metadata, tags, and link to logo * fix(meta): sort meta.json entries * fix: passbolt template had several issues that broke deployment - env variables were using old array format, changed to new table format - mariadb healthcheck was broken (wrong command for mariadb 11) - missing volume mounts for gpg keys, jwt tokens, and database - setup instructions weren't visible to users, moved to docker-compose - email config had circular references causing warnings - tested admin user creation and confirmed working everything works now, fully tested * Update blueprints/passbolt/template.toml --------- Co-authored-by: Mauricio Siu <47042324+Siumauricio@users.noreply.github.com> * feat: Add Kokoro TTS FastAPI template (#353) (#403) * feat: Add Kokoro TTS FastAPI template (#353) - Add CPU-optimized docker-compose.yml with source build - Add GPU-optimized docker-compose-gpu.yml for NVIDIA support - Add comprehensive template.toml with OpenAI-compatible API docs - Add kokoro-tts.svg logo and meta.json entry - Support streaming audio, timestamps, and multi-language TTS - Resolves #353 * updated the meta.json for the build errors * removed the docker-compose-gpu.yml file * Update docker-compose.yml --------- Co-authored-by: Mauricio Siu <47042324+Siumauricio@users.noreply.github.com> * chore: remove package-lock.json file from the app directory * chore: update Tolgee to latest version and fix SMTP config typo (#432) * chore: update Tolgee to latest version and fix SMTP config typo * Update docker-compose.yml * Update docker-compose.yml --------- Co-authored-by: Mauricio Siu <47042324+Siumauricio@users.noreply.github.com> * fix: improve Docker Compose validation workflow to handle subshell issues - Converted the handling of COMPOSE_FILES from a pipe to an array to ensure error propagation in the parent shell. - Updated the loop to iterate over the array for better reliability in the validation process. * refactor: enhance Docker Compose validation workflow to improve error handling - Replaced the pipe with an array to handle directory names, ensuring that errors within the loop propagate correctly to the parent shell. - Updated the loop structure for better reliability in processing the directories. * Feat: Add parseable (#460) * Add parseable * Update docker-compose.yml * Update docker-compose.yml * Update blueprints/parseable/template.toml --------- Co-authored-by: Mauricio Siu <47042324+Siumauricio@users.noreply.github.com> Co-authored-by: Mauricio Siu * feat: add ChirpStack LoRaWAN Network Server template (#486) * feat: add ChirpStack LoRaWAN Network Server template Add complete ChirpStack v4 template with: - Main ChirpStack server with web UI - UDP and Basics Station gateway bridges - REST API interface - PostgreSQL database with PostGIS extensions - Redis cache - Mosquitto MQTT broker Default configuration for EU868 region with secure random credentials. Supports all LoRaWAN frequency bands globally. * fix(chirpstack): use original configurations from chirpstack-docker repo Update template.toml to use exact configuration files from the chirpstack-docker repository instead of simplified versions: - Use original chirpstack.toml with all 15 enabled regions - Use original gateway bridge configuration with documentation links - Use complete Basics Station EU868 config with frequency plans - Keep original Mosquitto and PostgreSQL initialization scripts Template size increased from 131 to 219 lines (4.7KB) to include comprehensive default configurations that match the official setup. * feat: add all 38 region configuration files * fix(chirpstack): add volume mounts to expose config files to containers * fix(chirpstack): remove read-only flag * fix(chirpstack): correct file paths for configuration mounts in docker-compose and template files * fix: update volume paths to be on correct directory level * fix: configure template for dokploy-network with proper DNS resolution - Add dokploy-network configuration to docker-compose.yml - Replace environment variable placeholders with actual service hostnames - Change PostgreSQL DSN from $POSTGRESQL_HOST to postgres - Change Redis server from $REDIS_HOST to redis - Replace $MQTT_BROKER_HOST with mosquitto in all 39 region configurations These changes ensure Docker DNS resolution works correctly by: - Using dokploy-network (overlay) instead of bridge network - Using service names directly in TOML config files (TOML doesn't expand env vars) - Enabling proper service discovery between containers This resolves DNS resolution failures that caused ChirpStack to fail connecting to PostgreSQL and MQTT services during deployment. * fix: add missing network configurations for all services in docker-compose * feat: add internal services to config.domains for proper network configuration * Update docker-compose.yml * fix: enhance domain validation in template validator - Updated the TemplateValidator to ensure that if the 'host' field is provided, it must be a valid string. - Added comments to clarify that 'host' is optional for internal services. * refactor: remove redundant host validation in template validator - Removed the validation for the 'host' field in the TemplateValidator, as it is optional for internal services and does not require a type check if not provided. * refactor: remove internal service domain configurations from template - Eliminated the domain configurations for internal services (Postgres, Redis, Mosquitto) from the template.toml file, streamlining the configuration for better clarity and maintainability. --------- Co-authored-by: Mauricio Siu <47042324+Siumauricio@users.noreply.github.com> Co-authored-by: Mauricio Siu * Update section title from 'Suggestions' to 'Requirements' * Feat : Add MCSManager template support (#521) (#522) * feat: Add MCSManager template support (#521) * Update docker-compose.yml --------- Co-authored-by: Mauricio Siu <47042324+Siumauricio@users.noreply.github.com> * feat: Add MediaCMS template (#524) * Feat : Add Quant-Ux template -#173 (#525) * Feat : Add Quant-Ux template -#173 * Remove extra newline in docker-compose.yml * Update blueprints/quant-ux/docker-compose.yml * Update blueprints/quant-ux/docker-compose.yml * Update blueprints/quant-ux/docker-compose.yml * Update blueprints/quant-ux/docker-compose.yml --------- Co-authored-by: Mauricio Siu <47042324+Siumauricio@users.noreply.github.com> * fix(rustdesk): use explicit ports, use port 21118 on hbbs instead of hbbr (#526) * fix: use explicit ports, use port 21118 on hbbs instead of hbbr * fix: whitespace character in rustdesk * feat: Add anytype template (#527) * add anytype template * sort * Update name field for Anytype in meta.json * Update meta.json * Update docker-compose.yml * Update blueprints/anytype/docker-compose.yml --------- Co-authored-by: Mauricio Siu <47042324+Siumauricio@users.noreply.github.com> * refactor: remove dokploy-network configurations from multiple docker-compose files - Removed the external dokploy-network configuration from various services' docker-compose.yml files to streamline network management. - This change simplifies the setup and ensures consistency across blueprints. * chore: upgrade Infisical from v0.90.1 to v0.135.0 (#529) * chore: upgrade Infisical from v0.90.1 to v0.135.0 * Update docker-compose.yml --------- Co-authored-by: Mauricio Siu <47042324+Siumauricio@users.noreply.github.com> * fix: update pull request template link for clarity - Changed the link in the pull request template from 'general suggestions' to 'general requirements' to better reflect the content and ensure users follow the correct guidelines when creating templates. * chore: add section for screenshots or videos in pull request template - Introduced a new section in the pull request template to encourage contributors to include screenshots or videos, enhancing the clarity and context of their submissions. * Feat : Add MuleSoft ESB Runtime Template (#498) * added the mulesoft esb template * updated the compose and the meta.json * feat(mulesoft-esb): update image and add dynamic env configuration - Updated image to hari1367709/mule-esb:latest - Added dynamic HTTP_PORT for runtime port configuration - Added MULE_VERSION environment variable for Mule ESB version selection * updated the meta.json to use the version as latest * added a comment line to the template file * updated the mule runtime image * fix(mulesoft-esb): update ports configuration to follow guidelines * updated the port to use the env(HTTP_PORT) * Update docker-compose.yml * Update docker-compose.yml * Update blueprints/mulesoft-esb/docker-compose.yml --------- Co-authored-by: Mauricio Siu <47042324+Siumauricio@users.noreply.github.com> * feat(blueprint): update trmnl-byos-laravel template (#533) * feat(blueprint): update trmnl-byos-laravel template * Update docker-compose.yml --------- Co-authored-by: Mauricio Siu <47042324+Siumauricio@users.noreply.github.com> * feat(blueprint): peerdb template (#579) * feat(blueprint): initial attempt at peerdb template * fix: entrypoint and healthcheck * fix: entrypoint * fix: temporarily remove network * fix: temporal port * chore: remove 36987 for minio * fix: remove peerdb 9900 port exposure * fix: port for console * fix: minio env fix * fix: expose peerdb and minio to dokploy network * fix(peerdb): add defaults * fix: remove extra hosts * fix: remove network entries * fix: use consistent environment variables * feat: add Bluesky PDS template (#542) * feat: Bluesky PDS template * chore: add bluesky pds svg * chore: metadata for bluesky pds * yaml > yml * pnpm lock * fix: correct rotation key config * fix volumes * fix: volumes in the pds compose * define volumes in compose * fix: 32 bit rotation key * create pds.env correctly * some extra fixes * more extra fixes * a blank line * update pnpm lock * Add dokploy-prom-monitoring-extension template with comprehensive tests and documentation (#548) * Add dokploy-prom-monitoring-extension template with comprehensive tests and documentation * Fix METRICS_CONFIG environment variable: use single-line JSON format * Fix template.toml: use correct [config.env] syntax for environment variables * Fix docker-compose.yml: add env_file reference to load environment variables * Delete blueprints/dokploy-prom-monitoring-extension/README.md * Delete test-dokploy-prom-monitoring-extension.sh --------- Co-authored-by: Sanjeevi Subramani Co-authored-by: Mauricio Siu <47042324+Siumauricio@users.noreply.github.com> * feat: improve RustDesk template configuration (#571) * feat: improve RustDesk template configuration - Add comprehensive environment variables for RustDesk server - Add RELAY_HOST, API_SERVER, ID_SERVER, and ENCRYPTION_KEY variables - Follow Dokploy best practices (no container_name, proper port format) - Use restart: unless-stopped policy - Add encryption key generation with password helper * fix: use explicit port mapping for RustDesk services RustDesk requires explicit port bindings (host:container format) to function properly. The service uses specific ports for: - 21115-21116 (TCP/UDP): hbbs service for ID and NAT traversal - 21117-21119 (TCP): hbbr relay service Without explicit port mapping, RustDesk clients cannot establish connections to the server. This is an exception to Dokploy's general port guidelines due to RustDesk's specific networking requirements. --------- Co-authored-by: Mauricio Siu <47042324+Siumauricio@users.noreply.github.com> * feat: add Mumble voice chat server template (#572) * feat: add Mumble voice chat server template - Add Mumble VoIP server blueprint with docker-compose.yml - Configure environment variables for superuser password, welcome text, and max users - Add template.toml with auto-generated secure password - Follow Dokploy best practices (no container_name, proper port format) - Add Mumble metadata to meta.json with proper tags - Support for TCP and UDP on port 64738 * Update template.toml * fix: correct JSON formatting in meta.json for Mumble template entry --------- Co-authored-by: Mauricio Siu <47042324+Siumauricio@users.noreply.github.com> Co-authored-by: Mauricio Siu * fix: update WireGuard Easy template for proper functionality (#573) * fix: update WireGuard Easy template for proper functionality - Changed to named volume (etc_wireguard) instead of host path mount - Added explicit port mappings (51820:51820/udp, 51821:51821/tcp) required for WireGuard - Updated environment variables to use correct WG_HOST and PASSWORD format - Added all required WireGuard environment variables: - WG_PORT, PORT, WG_MTU, WG_DEFAULT_DNS, WG_ALLOWED_IPS - WG_POST_UP/WG_POST_DOWN for iptables rules - Added NET_RAW capability for proper network operations - Simplified template.toml to use WIREGUARD_HOST and WIREGUARD_PASSWORD - Removed explicit networks config to enable Dokploy's isolated deployment - Template now works with Dokploy's automatic network isolation This configuration has been tested and confirmed working with isolated deployment enabled. * Update template.toml --------- Co-authored-by: Mauricio Siu <47042324+Siumauricio@users.noreply.github.com> * add: restart policy to MinIO service (#576) restart: unless-stopped is a Docker restart policy that automatically restarts a container if it stops due to an error or Docker daemon restart --------- Co-authored-by: Sunil Shrestha Co-authored-by: Rabithua Co-authored-by: Mauricio Siu Co-authored-by: Scan <103391616+scanash00@users.noreply.github.com> Co-authored-by: Crackvignoule Co-authored-by: florianheysen <39408021+florianheysen@users.noreply.github.com> Co-authored-by: Thiago MadPin Co-authored-by: BlinkStrike <18644035+BlinkStrike@users.noreply.github.com> Co-authored-by: M Jupri Amin <127651222+Juupeee@users.noreply.github.com> Co-authored-by: Harikrishnan Dhanasekaran Co-authored-by: Kamil Dzieniszewski Co-authored-by: Nick Anderson Co-authored-by: lefolalan Co-authored-by: Chris <31969757+ChrisvanChip@users.noreply.github.com> Co-authored-by: kipavy <88386090+kipavy@users.noreply.github.com> Co-authored-by: Benjamin Nussbaum Co-authored-by: Khiet Tam Nguyen <86177399+nktnet1@users.noreply.github.com> Co-authored-by: Vidhya LKG for IT <24915474+VidhyaSanjeevi@users.noreply.github.com> Co-authored-by: Sanjeevi Subramani Co-authored-by: Muzaffer Kadir YILMAZ <34358176+muzafferkadir@users.noreply.github.com> Co-authored-by: Jemg * Refactor wg-easy service configuration in docker-compose Updated environment variables for wg-easy v15 * Refactor wg-easy service configuration in docker-compose Updated environment variables for wg-easy v15 --------- Co-authored-by: Mauricio Siu <47042324+Siumauricio@users.noreply.github.com> Co-authored-by: Sunil Shrestha Co-authored-by: Rabithua Co-authored-by: Mauricio Siu Co-authored-by: Scan <103391616+scanash00@users.noreply.github.com> Co-authored-by: Crackvignoule Co-authored-by: florianheysen <39408021+florianheysen@users.noreply.github.com> Co-authored-by: Thiago MadPin Co-authored-by: BlinkStrike <18644035+BlinkStrike@users.noreply.github.com> Co-authored-by: M Jupri Amin <127651222+Juupeee@users.noreply.github.com> Co-authored-by: Harikrishnan Dhanasekaran Co-authored-by: Kamil Dzieniszewski Co-authored-by: Nick Anderson Co-authored-by: lefolalan Co-authored-by: Chris <31969757+ChrisvanChip@users.noreply.github.com> Co-authored-by: kipavy <88386090+kipavy@users.noreply.github.com> Co-authored-by: Benjamin Nussbaum Co-authored-by: Khiet Tam Nguyen <86177399+nktnet1@users.noreply.github.com> Co-authored-by: Vidhya LKG for IT <24915474+VidhyaSanjeevi@users.noreply.github.com> Co-authored-by: Sanjeevi Subramani Co-authored-by: Muzaffer Kadir YILMAZ <34358176+muzafferkadir@users.noreply.github.com> Co-authored-by: Jemg * feat(blueprint): strapi template (#616) * feat(blueprint): strapi template * feat: strapi meta.json * fix: strapi extra colon * fix: docker syntax for expose and depends_on * fix: change image base * fix: strapi healthcheck * fix: add jwt secret and admin jwt secret to strapi * fix: strapi healthcheck start interval * fix(template): strapi v5.33.0 * Update docker-compose.yml --------- Co-authored-by: Mauricio Siu <47042324+Siumauricio@users.noreply.github.com> Co-authored-by: Mauricio Siu * feat: Add Pulse monitoring template (#617) * feat: Add Pulse monitoring template - Add docker-compose.yml with healthcheck and Docker socket access - Add template.toml with domain and authentication variables - Add pulse.svg logo - Add meta.json entry with monitoring, proxmox, docker tags - Supports Proxmox VE, PBS, and Docker monitoring with real-time metrics * fix: Update Pulse docs link to GitHub repository - Replace non-existent docs.pulse.rcourtman.com with GitHub docs path - Use canonical documentation location in Pulse repository * update pulse links * Update blueprints/pulse/docker-compose.yml --------- Co-authored-by: Mauricio Siu <47042324+Siumauricio@users.noreply.github.com> * Fix Obsidian LiveSync template links pointing to CouchDB instead of plugin (#621) * Initial plan * Fix Obsidian LiveSync template links to point to correct project Co-authored-by: Siumauricio <47042324+Siumauricio@users.noreply.github.com> --------- Co-authored-by: copilot-swe-agent[bot] <198982749+Copilot@users.noreply.github.com> Co-authored-by: Siumauricio <47042324+Siumauricio@users.noreply.github.com> * feat: add SeaweedFS template (#630) * feat: add SeaweedFS template * chore: add specific seaweedfs version * Update image versions in docker-compose for AList, Appsmith, and Budibase (#639) * Update image versions in the docker-compose and meta.json files for AList, Appsmith, and Budibase. * Update MinIO image version in docker-compose Pins a specific MinIO image version RELEASE.2025-09-07T16-13-09Z * refactor: add * docs: update CONTRIBUTING.md with pull request guidelines - Added guidelines for keeping pull requests small and focused. - Emphasized the importance of testing contributions before submission to maintain a tidy PR queue. * Add/trilium next (#671) * feat/add trilium next template * fix: test verify to pr * fix: fix validation error in docker-compose * fix: static version to trilium image --------- Co-authored-by: jbello * feat: add wuzapi template (#679) * feat: add wuzapi template * chore: remove temporary meta_entry.json * fix(wuzapi): remove explicit networks and simplify depends_on for Dokploy compatibility * fix(wuzapi): remove invalid config.mounts from template.toml * Update Docker images for wuzapi and PostgreSQL fixed the version of the wuzapi docker image. * feat: add PostgreSQL with PgDog template (#681) * feat: add PostgreSQL with PgDog template Add postgres-pgdog template providing PostgreSQL database with PgDog connection pooler, load balancer, and horizontal scaling proxy. Modern alternative to PgBouncer with multi-threading support. - Configurable PostgreSQL (default: 18-alpine) and PgDog (default: v0.1.26) images - Optional admin interface on port 6433 - Includes healthcheck and dependency management * 🐛 fix(postgres-pgdog): add config mounts and fix postgres volume path - Add [[config.mounts]] for pgdog.toml and users.toml - Mount config files from ../files/ in docker-compose - Change postgres volume to /var/lib/postgresql (postgres 18+ standard) - Add explicit command with config paths to prevent warnings * 🐛 fix(postgres-pgdog): correct binary path and use default config locations - Mount configs to /pgdog/ (default WorkingDir) instead of /etc/pgdog/ - Remove explicit command (binary is /usr/local/bin/pgdog, not /pgdog/pgdog) - Use image's default CMD with default config paths * 🐛 fix(postgres-pgdog): remove invalid admin_port config field - Remove admin_port from [general] section (not a valid field) - Admin DB uses same port 6432 with special database name - Remove commented admin domain config * 🐛 fix(postgres-pgdog): enable external access via fixed port mapping - Add fixed port 6432:6432 to postgres-pgdog service - Remove HTTP domain config (incompatible with TCP protocol) - Add comment for internal-only option Fixes UnsupportedStartup errors when using domain config for PostgreSQL protocol access. * 🐛 fix(postgres-pgdog): use standard port format per convention - Change port mapping from '6432:6432' to '6432' format - Follows Dokploy template convention for port declarations - External access requires checking Dokploy UI for assigned host port * 📝 docs(postgres-pgdog): clarify port settings comment * 🐛 fix(postgres-pgdog): default to internal access with opt-in external port - Remove obsolete version field - Port mapping commented by default for security - Users uncomment to enable external access on port 6432 * Add IPFS Kubo template (#703) * Add IPFS Kubo template * Update init cmds * Remove port forwarding * uptime-kuma: Bump version to 2.1.0 (#706) * Bump version to 2.1.0 * Update meta.json with new version number * feat(blueprint): update trmnl-byos-laravel template (#704) * upgrade nextcloud img version (#705) * fix docker-compose variables and update github link (#701) Co-authored-by: Aaron McGuire * Update InvoiceShelf compose to suit new changes (#693) https://github.com/InvoiceShelf/docker/blob/89bf78cec6fae54db76f84e0a4dc6255a8da710e/upgrade-guide.md * fix: superset template fixed versions, postgres volume mount and network instructions (#595) * fix: superset version fixed, tweak network instructions * chore: simplify mapbox key * fix: volume mount * deps: bump superset to 6.0.0 * feat: Add imgproxy template (#714) * feat: Add imgproxy template * fix: Configure docker-compose to match requirements * fix: Process meta * fix: Change logo name * fix: Remove incorrect mounts * fix: Expose 80 port instead of direct mapping * fix: Change nginx cache keys default zone size and correct format negotiation * fix: Escaping * feat: update to new Evolution API image source and pin it to the latest version (#644) * feat: Enhanced Nextcloud template with Redis, automated config, and improved setup (#672) * Update docker-compose.yml * fix: stable nextcloud, add redis, auto config, fixed mariadb * fix: meta nextcloud * fix: vars * fix: non capital * fix: template.toml * fix: env vars * fix: var naming * fix: command * fix: command * another try * keep it simple * fix toml * retry classic * add: admin user * no aito install * feat: automated fixes * fix file pasth * fix: manual script * fix: script * fix: png logo * fix: meta logo data --------- Co-authored-by: Mauricio Siu <47042324+Siumauricio@users.noreply.github.com> * feat: add MediaFetch template (#688) * feat: add MediaFetch template * Corrected .toml * .toml * feat: add unleash template (#691) * feat: add unleash template * feat: update unleash template to version 7.4.0 and fix formatting * feat: update database user in unleash template from postgres to unleash * Update Notifuse template: replace PASETO with SECRET_KEY auth (#696) * Update Notifuse template: replace PASETO with SECRET_KEY auth * Update docker-compose.yml --------- Co-authored-by: Mauricio Siu <47042324+Siumauricio@users.noreply.github.com> * Change convex port mapping to expose and bump version (#730) * chore: update convex backend and dashboard images, switch from port mapping to expose in docker-compose.yml * fix: set default value for DISABLE_BEACON in docker-compose.yml * Update grafana 12.4 (#731) * Update grafana 12.4 * Update meta.json * feat(blueprint): add Verdaccio - private node.js package registry (#735) * feat: add tuwunel template for matrix (re-made) (#733) * feat: add tuwunel template for matrix * fix: replace HTML placeholder with actual SVG logo for tuwunel * fix: remove enforcement and rename logo --------- Co-authored-by: Sunil Shrestha Co-authored-by: Rabithua Co-authored-by: Mauricio Siu Co-authored-by: Scan <103391616+scanash00@users.noreply.github.com> Co-authored-by: Crackvignoule Co-authored-by: florianheysen <39408021+florianheysen@users.noreply.github.com> Co-authored-by: Thiago MadPin Co-authored-by: BlinkStrike <18644035+BlinkStrike@users.noreply.github.com> Co-authored-by: M Jupri Amin <127651222+Juupeee@users.noreply.github.com> Co-authored-by: Harikrishnan Dhanasekaran Co-authored-by: Kamil Dzieniszewski Co-authored-by: Nick Anderson Co-authored-by: lefolalan Co-authored-by: Chris <31969757+ChrisvanChip@users.noreply.github.com> Co-authored-by: kipavy <88386090+kipavy@users.noreply.github.com> Co-authored-by: Benjamin Nussbaum Co-authored-by: Khiet Tam Nguyen <86177399+nktnet1@users.noreply.github.com> Co-authored-by: Vidhya LKG for IT <24915474+VidhyaSanjeevi@users.noreply.github.com> Co-authored-by: Sanjeevi Subramani Co-authored-by: Muzaffer Kadir YILMAZ <34358176+muzafferkadir@users.noreply.github.com> Co-authored-by: Jemg Co-authored-by: Jainil Prajapati <86187588+jaainil@users.noreply.github.com> Co-authored-by: Ye Liu Co-authored-by: Copilot <175728472+Copilot@users.noreply.github.com> Co-authored-by: Carl-Gerhard Lindesvärd <1987198+lindesvard@users.noreply.github.com> Co-authored-by: Huy Pham Co-authored-by: Copilot <198982749+Copilot@users.noreply.github.com> Co-authored-by: Louan Fontenele Co-authored-by: Alexey Fedorov Co-authored-by: 0zul <26915998+0zul@users.noreply.github.com> Co-authored-by: Pascal Oberbeck <35005267+poberbeck@users.noreply.github.com> Co-authored-by: Pascal Oberbeck Co-authored-by: Christus Vincent Co-authored-by: Huba Tuba <57007485+floxay@users.noreply.github.com> Co-authored-by: Pablo Moraga Sandoval <72164630+Ketbome@users.noreply.github.com> Co-authored-by: Firefly <77047823+Yuri-NagaSaki@users.noreply.github.com> Co-authored-by: Naterfute <106989409+naterfute@users.noreply.github.com> Co-authored-by: Vitaliy Kukharik <37010174+vitabaks@users.noreply.github.com> Co-authored-by: aurorarissime Co-authored-by: фырат ёздэн <31664778+fir4tozden@users.noreply.github.com> Co-authored-by: JoshuaRileyDev <59296334+JoshuaRileyDev@users.noreply.github.com> Co-authored-by: Claude Co-authored-by: vabs Co-authored-by: Jorge Gómez Zarzosa <34076979+jorgegomzar@users.noreply.github.com> Co-authored-by: Jorge Gómez Zarzosa Co-authored-by: Benjamin Robinet Co-authored-by: Naim Hasim Co-authored-by: kadma Co-authored-by: José F. Bello <45277800+bellolongart@users.noreply.github.com> Co-authored-by: jbello Co-authored-by: Harshal Rathore <76205196+HarshalRathore@users.noreply.github.com> Co-authored-by: Vinicios Lugli Co-authored-by: Kien Ngo Co-authored-by: Simon <97951171+SimonSchroffner@users.noreply.github.com> Co-authored-by: Aaron McGuire <89317236+Aaron-McGuire@users.noreply.github.com> Co-authored-by: Aaron McGuire Co-authored-by: Andrew Wong Co-authored-by: Vladyslav Prosolupov Co-authored-by: Matheus Felipe Co-authored-by: Sina Sebastian Eetezadi Co-authored-by: Luke Dunsmore Co-authored-by: Dipanda Aser Co-authored-by: Pierre Co-authored-by: marcbodea Co-authored-by: Wladi Co-authored-by: Adrian Alfred C. Bonpin --- blueprints/convex/docker-compose.yml | 16 +- blueprints/evolutionapi/docker-compose.yml | 2 +- blueprints/grafana/docker-compose.yml | 2 +- blueprints/imgproxy/docker-compose.yml | 76 ++++++ blueprints/imgproxy/imgproxy.png | Bin 0 -> 4603 bytes blueprints/imgproxy/template.toml | 56 +++++ blueprints/mediafetch/docker-compose.yml | 18 ++ blueprints/mediafetch/mediafetch.svg | 1 + blueprints/mediafetch/template.toml | 15 ++ blueprints/nextcloud-aio/docker-compose.yml | 26 +- blueprints/nextcloud-aio/nextcloud-aio.svg | 1 - blueprints/nextcloud-aio/nextcloud.png | Bin 0 -> 11617 bytes blueprints/nextcloud-aio/template.toml | 178 +++++++++++++- blueprints/notifuse/docker-compose.yml | 58 +++-- blueprints/notifuse/template.toml | 19 +- blueprints/tuwunel/docker-compose.yml | 18 ++ blueprints/tuwunel/template.toml | 15 ++ blueprints/tuwunel/tuwunel.svg | 4 + blueprints/unleash/docker-compose.yml | 49 ++++ blueprints/unleash/template.toml | 17 ++ blueprints/unleash/unleash.png | Bin 0 -> 3283 bytes blueprints/verdaccio/docker-compose.yml | 17 ++ blueprints/verdaccio/template.toml | 259 ++++++++++++++++++++ blueprints/verdaccio/verdaccio.svg | 38 +++ meta.json | 117 ++++++++- 25 files changed, 915 insertions(+), 87 deletions(-) create mode 100644 blueprints/imgproxy/docker-compose.yml create mode 100644 blueprints/imgproxy/imgproxy.png create mode 100644 blueprints/imgproxy/template.toml create mode 100644 blueprints/mediafetch/docker-compose.yml create mode 100644 blueprints/mediafetch/mediafetch.svg create mode 100644 blueprints/mediafetch/template.toml delete mode 100644 blueprints/nextcloud-aio/nextcloud-aio.svg create mode 100644 blueprints/nextcloud-aio/nextcloud.png create mode 100644 blueprints/tuwunel/docker-compose.yml create mode 100644 blueprints/tuwunel/template.toml create mode 100644 blueprints/tuwunel/tuwunel.svg create mode 100644 blueprints/unleash/docker-compose.yml create mode 100644 blueprints/unleash/template.toml create mode 100644 blueprints/unleash/unleash.png create mode 100644 blueprints/verdaccio/docker-compose.yml create mode 100644 blueprints/verdaccio/template.toml create mode 100644 blueprints/verdaccio/verdaccio.svg diff --git a/blueprints/convex/docker-compose.yml b/blueprints/convex/docker-compose.yml index 7a7f3987..624271e3 100644 --- a/blueprints/convex/docker-compose.yml +++ b/blueprints/convex/docker-compose.yml @@ -1,9 +1,9 @@ services: backend: - image: ghcr.io/get-convex/convex-backend:33cef775a8a6228cbacee4a09ac2c4073d62ed13 - ports: - - "${PORT:-3210}:3210" - - "${SITE_PROXY_PORT:-3211}:3211" + image: ghcr.io/get-convex/convex-backend:5cdea511cd6527a95dd24152ea0d3c3bb2ab379f + expose: + - "3210" + - "3211" volumes: - data:/convex/data environment: @@ -14,7 +14,7 @@ services: - CONVEX_CLOUD_ORIGIN=${CONVEX_CLOUD_ORIGIN:-http://127.0.0.1:3210} - CONVEX_SITE_ORIGIN=${CONVEX_SITE_ORIGIN:-http://127.0.0.1:3211} - DATABASE_URL=${DATABASE_URL:-} - - DISABLE_BEACON=${DISABLE_BEACON:-} + - DISABLE_BEACON=${DISABLE_BEACON:-FALSE} - REDACT_LOGS_TO_CLIENT=${REDACT_LOGS_TO_CLIENT:-} - RUST_LOG=${RUST_LOG:-info} - RUST_BACKTRACE=${RUST_BACKTRACE:-} @@ -24,9 +24,9 @@ services: start_period: 5s dashboard: - image: ghcr.io/get-convex/convex-dashboard:33cef775a8a6228cbacee4a09ac2c4073d62ed13 - ports: - - "${DASHBOARD_PORT:-6791}:6791" + image: ghcr.io/get-convex/convex-dashboard:5cdea511cd6527a95dd24152ea0d3c3bb2ab379f + expose: + - "6791" environment: - NEXT_PUBLIC_DEPLOYMENT_URL=${NEXT_PUBLIC_DEPLOYMENT_URL:-http://127.0.0.1:3210} depends_on: diff --git a/blueprints/evolutionapi/docker-compose.yml b/blueprints/evolutionapi/docker-compose.yml index 5807ff82..16f12531 100644 --- a/blueprints/evolutionapi/docker-compose.yml +++ b/blueprints/evolutionapi/docker-compose.yml @@ -1,6 +1,6 @@ services: evolution-api: - image: atendai/evolution-api:v2.1.2 + image: evoapicloud/evolution-api:latest restart: always volumes: - evolution-instances:/evolution/instances diff --git a/blueprints/grafana/docker-compose.yml b/blueprints/grafana/docker-compose.yml index 9d913c17..d7ec99a0 100644 --- a/blueprints/grafana/docker-compose.yml +++ b/blueprints/grafana/docker-compose.yml @@ -1,7 +1,7 @@ version: "3.8" services: grafana: - image: grafana/grafana-enterprise:9.5.20 + image: grafana/grafana-enterprise:12.4 restart: unless-stopped volumes: - grafana-storage:/var/lib/grafana diff --git a/blueprints/imgproxy/docker-compose.yml b/blueprints/imgproxy/docker-compose.yml new file mode 100644 index 00000000..e9bc86a1 --- /dev/null +++ b/blueprints/imgproxy/docker-compose.yml @@ -0,0 +1,76 @@ +version: "3.8" +services: + imgproxy: + image: darthsim/imgproxy:v3.30.1 + restart: unless-stopped + environment: + IMGPROXY_KEY: ${IMGPROXY_KEY} + IMGPROXY_SALT: ${IMGPROXY_SALT} + IMGPROXY_ENABLE_WEBP_DETECTION: ${IMGPROXY_ENABLE_WEBP_DETECTION:-true} + IMGPROXY_ENFORCE_WEBP: ${IMGPROXY_ENFORCE_WEBP:-true} + IMGPROXY_TTL: ${IMGPROXY_TTL:-30600} + IMGPROXY_DEVELOPMENT_ERRORS_MODE: ${IMGPROXY_DEVELOPMENT_ERRORS_MODE:-false} + IMGPROXY_READ_TIMEOUT: ${IMGPROXY_READ_TIMEOUT:-10} + IMGPROXY_WRITE_TIMEOUT: ${IMGPROXY_WRITE_TIMEOUT:-10} + IMGPROXY_KEEP_ALIVE_TIMEOUT: ${IMGPROXY_KEEP_ALIVE_TIMEOUT:-10} + IMGPROXY_DOWNLOAD_TIMEOUT: ${IMGPROXY_DOWNLOAD_TIMEOUT:-5} + IMGPROXY_CONCURRENCY: ${IMGPROXY_CONCURRENCY:-} + IMGPROXY_MAX_CLIENTS: ${IMGPROXY_MAX_CLIENTS:-10} + IMGPROXY_SO_REUSEPORT: ${IMGPROXY_SO_REUSEPORT:-} + IMGPROXY_USER_AGENT: ${IMGPROXY_USER_AGENT:-} + IMGPROXY_USE_ETAG: ${IMGPROXY_USE_ETAG:-true} + IMGPROXY_QUALITY: ${IMGPROXY_QUALITY:-80} + IMGPROXY_ALLOWED_SOURCES: ${IMGPROXY_ALLOWED_SOURCES} + IMGPROXY_ALLOW_ORIGIN: ${IMGPROXY_ALLOW_ORIGIN:-*} + IMGPROXY_MAX_SRC_FILE_SIZE: ${IMGPROXY_MAX_SRC_FILE_SIZE:-20971520} + IMGPROXY_MAX_SRC_RESOLUTION: ${IMGPROXY_MAX_SRC_RESOLUTION:-50} + IMGPROXY_LOG_LEVEL: ${IMGPROXY_LOG_LEVEL:-error} + + nginx: + image: nginx:1.28.2-alpine + restart: unless-stopped + expose: + - 80 + environment: + NGINX_CACHE_LEVELS: ${NGINX_CACHE_LEVELS:-1:2} + NGINX_CACHE_KEYS_ZONE_SIZE: ${NGINX_CACHE_KEYS_ZONE_SIZE:-32m} + NGINX_CACHE_MAX_SIZE: ${NGINX_CACHE_MAX_SIZE:-500m} + NGINX_CACHE_INACTIVE: ${NGINX_CACHE_INACTIVE:-30d} + NGINX_CACHE_USE_TEMP_PATH: ${NGINX_CACHE_USE_TEMP_PATH:-off} + NGINX_CACHE_EXPIRES: ${NGINX_CACHE_EXPIRES:-30d} + depends_on: + - imgproxy + volumes: + - nginx-cache:/tmp/cache + command: + - /bin/sh + - -c + - | + cat < /etc/nginx/conf.d/default.conf + proxy_cache_path /tmp/cache levels=$${NGINX_CACHE_LEVELS} keys_zone=my_cache:$${NGINX_CACHE_KEYS_ZONE_SIZE} max_size=$${NGINX_CACHE_MAX_SIZE} inactive=$${NGINX_CACHE_INACTIVE} use_temp_path=$${NGINX_CACHE_USE_TEMP_PATH}; + + server { + listen 80 default_server; + listen [::]:80 default_server; + + location / { + expires $${NGINX_CACHE_EXPIRES}; + access_log off; + set \$$handle_webp 0; + if (\$$http_accept ~* "image/webp") { + set \$$handle_webp 1; + } + proxy_cache my_cache; + proxy_cache_use_stale error timeout updating http_500 http_502 http_503 http_504; + proxy_cache_background_update on; + proxy_cache_lock on; + proxy_cache_key "\$$scheme\$$host\$$uri\$$handle_webp"; + server_tokens off; + proxy_pass http://imgproxy:8080; + } + } + EOF + exec nginx -g 'daemon off;' + +volumes: + nginx-cache: diff --git a/blueprints/imgproxy/imgproxy.png b/blueprints/imgproxy/imgproxy.png new file mode 100644 index 0000000000000000000000000000000000000000..cb26b97bb4ae4bdd5ee2bac9527fc2ed6301e470 GIT binary patch literal 4603 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 \ No newline at end of file diff --git a/blueprints/mediafetch/template.toml b/blueprints/mediafetch/template.toml new file mode 100644 index 00000000..07672d4e --- /dev/null +++ b/blueprints/mediafetch/template.toml @@ -0,0 +1,15 @@ +[variables] +BASIC_AUTH_USER = "admin" +BASIC_AUTH_PASS = "${password:12}" + +[config] +[[config.domains]] +name = "Domain" +variable = "DOMAIN" +serviceName = "mediafetch" +port = 3002 + +[[config.mounts]] +name = "Downloads" +filePath = "/data/downloads" +content = "mediafetch" \ No newline at end of file diff --git a/blueprints/nextcloud-aio/docker-compose.yml b/blueprints/nextcloud-aio/docker-compose.yml index f262b157..9cec8542 100644 --- a/blueprints/nextcloud-aio/docker-compose.yml +++ b/blueprints/nextcloud-aio/docker-compose.yml @@ -1,32 +1,34 @@ services: nextcloud: - image: nextcloud:32.0.5 + image: nextcloud:stable restart: always - - ports: - - 80 volumes: - nextcloud_data:/var/www/html + - ../files/fix-nextcloud.sh:/usr/local/bin/fix-nextcloud.sh:ro environment: - - NEXTCLOUD_TRUSTED_DOMAINS=${NEXTCLOUD_DOMAIN} - MYSQL_HOST=nextcloud_db - MYSQL_DATABASE=nextcloud - MYSQL_USER=nextcloud - - MYSQL_PASSWORD=${MYSQL_SECRET_PASSWORD} - - OVERWRITEPROTOCOL=https + - MYSQL_PASSWORD=${MYSQL_PASSWORD} + depends_on: + - nextcloud_db + - nextcloud_redis nextcloud_db: - image: mariadb + image: mariadb:10.11 restart: always - volumes: - nextcloud_db_data:/var/lib/mysql environment: - - MYSQL_ROOT_PASSWORD=${MYSQL_SECRET_PASSWORD_ROOT} + - MYSQL_ROOT_PASSWORD=${MYSQL_ROOT_PASSWORD} - MYSQL_DATABASE=nextcloud - MYSQL_USER=nextcloud - - MYSQL_PASSWORD=${MYSQL_SECRET_PASSWORD} + - MYSQL_PASSWORD=${MYSQL_PASSWORD} + + nextcloud_redis: + image: redis:alpine + restart: always volumes: nextcloud_data: - nextcloud_db_data: + nextcloud_db_data: \ No newline at end of file diff --git a/blueprints/nextcloud-aio/nextcloud-aio.svg b/blueprints/nextcloud-aio/nextcloud-aio.svg deleted file mode 100644 index 54e6056f..00000000 --- a/blueprints/nextcloud-aio/nextcloud-aio.svg +++ /dev/null @@ -1 +0,0 @@ - \ No newline at end of file diff --git a/blueprints/nextcloud-aio/nextcloud.png b/blueprints/nextcloud-aio/nextcloud.png new file mode 100644 index 0000000000000000000000000000000000000000..119d58b7e8d4792d0dfefb4c25e095a37a14b901 GIT binary patch literal 11617 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 LRk}{fEaZOxpAt}_ literal 0 HcmV?d00001 diff --git a/blueprints/nextcloud-aio/template.toml b/blueprints/nextcloud-aio/template.toml index 30be77a1..d45c89be 100644 --- a/blueprints/nextcloud-aio/template.toml +++ b/blueprints/nextcloud-aio/template.toml @@ -1,17 +1,171 @@ [variables] -main_domain = "${domain}" -db_password = "${password}" -db_root_password = "${password}" + domain_name = "${domain}" + db_password = "${password:32}" + db_root_password = "${password:32}" + region = "DE" [config] -mounts = [] + env = [ + "MYSQL_PASSWORD=${db_password}", + "MYSQL_ROOT_PASSWORD=${db_root_password}", + "DEFAULT_PHONE_REGION=${region}", + "NEXTCLOUD_DOMAIN=${domain_name}", + "OVERWRITEPROTOCOL=https", + "TRUSTED_PROXIES=10.0.0.0/8 172.16.0.0/12", + "REDIS_HOST=nextcloud_redis", + "MYSQL_DATABASE=nextcloud", + "MYSQL_USER=nextcloud" + ] -[[config.domains]] -serviceName = "nextcloud" -port = 80 -host = "${main_domain}" + [[config.domains]] + serviceName = "nextcloud" + port = 80 + host = "${domain_name}" -[config.env] -NEXTCLOUD_DOMAIN = "${main_domain}" -MYSQL_SECRET_PASSWORD = "${db_password}" -MYSQL_SECRET_PASSWORD_ROOT = "${db_root_password}" + [[config.mounts]] + filePath = "fix-nextcloud.sh" + content = """#!/bin/sh +# +# Nextcloud Optimization Script +# ============================== +# This script applies production-ready optimizations to Nextcloud. +# +# MANUAL EXECUTION REQUIRED +# ------------------------- +# After Nextcloud completes its initial setup (create admin account, etc.), +# run this script manually: +# +# Option 1 (From Dokploy UI): +# 1. Go to your Nextcloud service in Dokploy +# 2. Open the Terminal tab +# 3. Run: su -s /bin/sh www-data -c "/bin/sh /usr/local/bin/fix-nextcloud.sh" +# +# Option 2 (From command line): +# docker exec -u www-data /bin/sh /usr/local/bin/fix-nextcloud.sh +# +# Optimizations include: +# - Trusted proxy configuration for reverse proxy support +# - HTTPS protocol override +# - Regional settings (phone region, maintenance window) +# - Performance optimizations (database repair, missing indices) +# - Redis caching configuration (APCu, distributed, locking) +# +# The script is idempotent - it creates a marker file to prevent re-running. +# To re-run manually: delete /var/www/html/data/.nextcloud-optimized and restart container +# + +MARKER_FILE="/var/www/html/data/.nextcloud-optimized" +OCC="php /var/www/html/occ" + +# Check if already run +if [ -f "$MARKER_FILE" ]; then + echo "Optimizations already applied (marker file exists)." + exit 0 +fi + +echo "==========================================" +echo " Nextcloud Optimization Script" +echo "==========================================" +echo "" + +# Check if running as www-data +CURRENT_USER=$(whoami) +if [ "$CURRENT_USER" = "www-data" ]; then + RUN_AS_WWWDATA="" +else + RUN_AS_WWWDATA="su -s /bin/sh www-data -c" +fi + +# Function to run occ command with error handling +run_occ() { + description="$1" + shift + printf " - %s... " "$description" + if [ -z "$RUN_AS_WWWDATA" ]; then + # Already running as www-data + if $OCC "$@" >/dev/null 2>&1; then + echo "✓" + return 0 + else + echo "✗ (failed, but continuing)" + return 1 + fi + else + # Need to switch to www-data + if $RUN_AS_WWWDATA "$OCC $*" >/dev/null 2>&1; then + echo "✓" + return 0 + else + echo "✗ (failed, but continuing)" + return 1 + fi + fi +} + +# Test database connectivity +echo "[1/5] Testing database connectivity..." +if [ -z "$RUN_AS_WWWDATA" ]; then + if $OCC status >/dev/null 2>&1; then + echo " ✓ Database is accessible" + else + echo " ✗ Database not accessible" + exit 1 + fi +else + if $RUN_AS_WWWDATA "$OCC status" >/dev/null 2>&1; then + echo " ✓ Database is accessible" + else + echo " ✗ Database not accessible" + exit 1 + fi +fi + +# Configure trusted proxies +echo "[2/5] Configuring trusted proxies..." +run_occ "Set trusted proxy 10.0.0.0/8" config:system:set trusted_proxies 0 --value='10.0.0.0/8' +run_occ "Set trusted proxy 172.16.0.0/12" config:system:set trusted_proxies 1 --value='172.16.0.0/12' +run_occ "Set trusted proxy 192.168.0.0/16" config:system:set trusted_proxies 2 --value='192.168.0.0/16' +run_occ "Set HTTPS protocol override" config:system:set overwriteprotocol --value='https' + +# Configure regional settings +echo "[3/5] Configuring regional settings..." +run_occ "Set phone region to DE" config:system:set default_phone_region --value='DE' +run_occ "Set maintenance window start" config:system:set maintenance_window_start --value=1 --type=integer + +# Run performance optimizations +echo "[4/5] Running performance optimizations..." +echo " - Running maintenance repair (this may take a while)..." +if [ -z "$RUN_AS_WWWDATA" ]; then + if $OCC maintenance:repair --include-expensive 2>&1 | grep -q "No repair steps available"; then + echo " ✓ No repairs needed" + else + echo " ✓ Repair completed" + fi +else + if $RUN_AS_WWWDATA "$OCC maintenance:repair --include-expensive" 2>&1 | grep -q "No repair steps available"; then + echo " ✓ No repairs needed" + else + echo " ✓ Repair completed" + fi +fi +run_occ "Add missing database indices" db:add-missing-indices + +# Configure Redis caching +echo "[5/5] Configuring Redis caching..." +run_occ "Set APCu for local cache" config:system:set memcache.local --value='\\OC\\Memcache\\APCu' +run_occ "Set Redis for distributed cache" config:system:set memcache.distributed --value='\\OC\\Memcache\\Redis' +run_occ "Set Redis for locking" config:system:set memcache.locking --value='\\OC\\Memcache\\Redis' +run_occ "Set Redis host" config:system:set redis host --value='nextcloud_redis' +run_occ "Set Redis port" config:system:set redis port --value=6379 --type=integer + +# Create marker file +touch "$MARKER_FILE" + +echo "" +echo "==========================================" +echo " Optimization Complete!" +echo "==========================================" +echo "All optimizations have been applied." +echo "Marker file created at: $MARKER_FILE" +echo "" +""" \ No newline at end of file diff --git a/blueprints/notifuse/docker-compose.yml b/blueprints/notifuse/docker-compose.yml index 7a33cd4d..764cfc6c 100644 --- a/blueprints/notifuse/docker-compose.yml +++ b/blueprints/notifuse/docker-compose.yml @@ -3,11 +3,11 @@ services: image: postgres:17-alpine restart: unless-stopped volumes: - - db-data:/var/lib/postgresql/data + - db_data:/var/lib/postgresql/data environment: - - POSTGRES_DB=postgres - - POSTGRES_USER=postgres - - POSTGRES_PASSWORD=postgres + POSTGRES_DB: postgres + POSTGRES_USER: postgres + POSTGRES_PASSWORD: postgres healthcheck: test: ["CMD-SHELL", "pg_isready -U postgres"] interval: 5s @@ -21,38 +21,36 @@ services: - db environment: # Root user configuration - - ROOT_EMAIL=${ROOT_EMAIL} + ROOT_EMAIL: ${ROOT_EMAIL} # API configuration - - API_ENDPOINT=${API_ENDPOINT} + API_ENDPOINT: ${API_ENDPOINT} # Database configuration - - DB_HOST=db - - DB_PORT=5432 - - DB_USER=postgres - - DB_PASSWORD=postgres - - DB_PREFIX=notifuse - - DB_NAME=notifuse_system - - DB_SSLMODE=disable + DB_HOST: db + DB_PORT: 5432 + DB_USER: postgres + DB_PASSWORD: postgres + DB_PREFIX: notifuse + DB_NAME: postgres + DB_SSLMODE: disable - # PASETO keys for authentication - # Default keys for testing - GENERATE YOUR OWN for production at https://paseto.notifuse.com/ - - PASETO_PRIVATE_KEY=${PASETO_PRIVATE_KEY} - - PASETO_PUBLIC_KEY=${PASETO_PUBLIC_KEY} - - # SMTP configuration - - SMTP_HOST=${SMTP_HOST} - - SMTP_PORT=${SMTP_PORT} - - SMTP_USERNAME=${SMTP_USERNAME} - - SMTP_PASSWORD=${SMTP_PASSWORD} - - SMTP_FROM_EMAIL=${SMTP_FROM_EMAIL} - - SMTP_FROM_NAME=${SMTP_FROM_NAME} + # Secret key for authentication (auto-generated) + SECRET_KEY: ${SECRET_KEY} # Server configuration - - SERVER_PORT=8080 - - SERVER_HOST=0.0.0.0 - - ENVIRONMENT=production + SERVER_PORT: 8080 + SERVER_HOST: 0.0.0.0 + ENVIRONMENT: production + volumes: + - notifuse_data:/app/data + healthcheck: + test: ["CMD", "wget", "--no-verbose", "--tries=1", "--spider", "http://localhost:8080/healthz"] + interval: 10s + timeout: 5s + retries: 3 + start_period: 10s volumes: - db-data: - driver: local + db_data: {} + notifuse_data: {} diff --git a/blueprints/notifuse/template.toml b/blueprints/notifuse/template.toml index ec619010..6100203f 100644 --- a/blueprints/notifuse/template.toml +++ b/blueprints/notifuse/template.toml @@ -1,7 +1,6 @@ [variables] main_domain = "${domain}" -paseto_private_key = "d04zCk3Fa45oOjDWHpAvc1AZxnLdGffOnNWK+Jt2yXf37+FTfuMMHb8flcfPMqLluRR3rvhbr555r6j1DEigrA==" -paseto_public_key = "9+/hU37jDB2/H5XHzzKi5bkUd674W6+eea+o9QxIoKw=" +secret_key = "${base64:64}" [config] [[config.domains]] @@ -12,18 +11,4 @@ host = "${main_domain}" [config.env] ROOT_EMAIL = "${email}" API_ENDPOINT = "https://${main_domain}" - -# PASETO keys for authentication -# Default keys for testing - GENERATE YOUR OWN for production at https://paseto.notifuse.com/ -PASETO_PRIVATE_KEY = "${paseto_private_key}" -PASETO_PUBLIC_KEY = "${paseto_public_key}" - -# SMTP Configuration (users need to configure these) -SMTP_HOST = "smtp.gmail.com" -SMTP_PORT = "587" -SMTP_USERNAME = "your-email@gmail.com" -SMTP_PASSWORD = "your-smtp-password" -SMTP_FROM_EMAIL = "noreply@yourdomain.com" -SMTP_FROM_NAME = "Notifuse" - -[[config.mounts]] +SECRET_KEY = "${secret_key}" diff --git a/blueprints/tuwunel/docker-compose.yml b/blueprints/tuwunel/docker-compose.yml new file mode 100644 index 00000000..039ba092 --- /dev/null +++ b/blueprints/tuwunel/docker-compose.yml @@ -0,0 +1,18 @@ +version: "3.8" +services: + tuwunel: + image: ghcr.io/matrix-construct/tuwunel:v1.5.0 + restart: always + environment: + - TUWUNEL_SERVER_NAME=${TUWUNEL_SERVER_NAME:-matrix.local} + - TUWUNEL_ALLOW_REGISTRATION=${TUWUNEL_ALLOW_REGISTRATION:-false} + - TUWUNEL_REGISTRATION_TOKEN=${TUWUNEL_REGISTRATION_TOKEN} + - TUWUNEL_ADDRESS=${TUWUNEL_ADDRESS:-0.0.0.0} + - TUWUNEL_PORT=${TUWUNEL_PORT:-6167} + volumes: + - tuwunel-data:/var/lib/tuwunel/ + expose: + - 6167 + +volumes: + tuwunel-data: diff --git a/blueprints/tuwunel/template.toml b/blueprints/tuwunel/template.toml new file mode 100644 index 00000000..80dae5d5 --- /dev/null +++ b/blueprints/tuwunel/template.toml @@ -0,0 +1,15 @@ +[variables] +main_domain = "${domain}" +registration_token = "${password:32}" + +[config] +env = [ + "TUWUNEL_SERVER_NAME=${main_domain}", + "TUWUNEL_REGISTRATION_TOKEN=${registration_token}" +] +mounts = [] + +[[config.domains]] +serviceName = "tuwunel" +port = 6167 +host = "${main_domain}" diff --git a/blueprints/tuwunel/tuwunel.svg b/blueprints/tuwunel/tuwunel.svg new file mode 100644 index 00000000..79ec68b4 --- /dev/null +++ b/blueprints/tuwunel/tuwunel.svg @@ -0,0 +1,4 @@ + + + T + diff --git a/blueprints/unleash/docker-compose.yml b/blueprints/unleash/docker-compose.yml new file mode 100644 index 00000000..dc34db8d --- /dev/null +++ b/blueprints/unleash/docker-compose.yml @@ -0,0 +1,49 @@ +# The default users credentials are: +# Login: admin +# Password: unleash4all +# It is highly recommended to change the password after first login. +# More info: https://github.com/Unleash/unleash?tab=readme-ov-file#unleash-open-source +version: "3.8" + +services: + unleash: + image: unleashorg/unleash-server:7.4.0 + restart: unless-stopped + environment: + DATABASE_URL: "postgres://${DB_USER}:${DB_PASSWORD}@db/${DB_NAME}" + DATABASE_SSL: "false" + LOG_LEVEL: "warn" + depends_on: + db: + condition: service_healthy + healthcheck: + test: wget --no-verbose --tries=1 --spider http://localhost:4242/health || exit 1 + interval: 1s + timeout: 1m + retries: 5 + start_period: 15s + db: + image: postgres:15 + restart: unless-stopped + environment: + POSTGRES_DB: "${DB_NAME}" + POSTGRES_USER: "${DB_USER}" + POSTGRES_PASSWORD: "${DB_PASSWORD}" + volumes: + - db_data:/var/lib/postgresql/data + healthcheck: + test: + [ + "CMD", + "pg_isready", + "--username=${DB_USER}", + "--host=127.0.0.1", + "--port=5432", + ] + interval: 2s + timeout: 1m + retries: 5 + start_period: 10s + +volumes: + db_data: diff --git a/blueprints/unleash/template.toml b/blueprints/unleash/template.toml new file mode 100644 index 00000000..f57ef975 --- /dev/null +++ b/blueprints/unleash/template.toml @@ -0,0 +1,17 @@ +[variables] +main_domain = "${domain}" +db_name = "unleash" +db_user = "unleash" +db_password = "${password:32}" + +[config] +env = [ + "DB_NAME=${db_name}", + "DB_USER=${db_user}", + "DB_PASSWORD=${db_password}" +] + +[[config.domains]] +serviceName = "unleash" +port = 4242 +host = "${main_domain}" \ No newline at end of file diff --git a/blueprints/unleash/unleash.png b/blueprints/unleash/unleash.png new file mode 100644 index 0000000000000000000000000000000000000000..9b6b5b8dc454faa831e15e48551bfe89beaf8013 GIT binary patch literal 3283 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 + # metaScripts: + # - '' + # - '' + # - '' + # + # HTML tags injected as first child in + # scriptsBodyBefore: + # - '
html before webpack scripts
' + # + # HTML tags injected as last child in + # scriptsBodyAfter: + # - '' + # + # Public path for template manifest scripts (only manifest) + # publicPath: http://somedomain.org/ + +# Settings for authentication plugin +# https://verdaccio.org/docs/configuration#authentication +auth: + htpasswd: + file: /verdaccio/storage/htpasswd + # Maximum amount of users allowed to register, defaults to "+inf". + # You can set this to -1 to disable registration. + max_users: 1 + +# A list of other known repositories we can talk to +# https://verdaccio.org/docs/configuration#uplinks +uplinks: + npmjs: + url: https://registry.npmjs.org/ + +# Learn how to protect your packages +# https://verdaccio.org/docs/protect-your-dependencies/ +# https://verdaccio.org/docs/configuration#packages +packages: + '@*/*': + # scoped packages + access: $all + publish: $authenticated + unpublish: $authenticated + proxy: npmjs + + '**': + # allow all users (including non-authenticated users) to read and + # publish all packages + # + # you can specify usernames/groupnames (depending on your auth plugin) + # and three keywords: "$all", "$anonymous", "$authenticated" + access: $all + + # allow all known users to publish/unpublish packages + # (anyone can register by default, remember?) + publish: $authenticated + unpublish: $authenticated + + # if package is not available locally, proxy requests to 'npmjs' registry + proxy: npmjs + +# To improve your security configuration and avoid dependency confusion +# consider removing the proxy property for private packages +# https://verdaccio.org/docs/best#remove-proxy-to-increase-security-at-private-packages + +# https://verdaccio.org/docs/configuration#server +# You can specify HTTP/1.1 server keep alive timeout in seconds for incoming connections. +# A value of 0 makes the http server behave similarly to Node.js versions prior to 8.0.0, which did not have a keep-alive timeout. +# WORKAROUND: Through given configuration you can workaround following issue https://github.com/verdaccio/verdaccio/issues/301. Set to 0 in case 60 is not enough. +server: + keepAliveTimeout: 60 + # The pluginPrefix replaces the default plugins prefix which is `verdaccio`. Please don't include `-`. If `something` is provided + # the resolved package will be `something-xxxx`. + # pluginPrefix: something + # A regex for the password validation /.{3}$/ (3 characters min) + # An example to limit to 10 characters minimum + # passwordValidationRegex: /.{10}$/ + # Allow `req.ip` to resolve properly when Verdaccio is behind a proxy or load-balancer + # https://expressjs.com/en/guide/behind-proxies.html + # trustProxy: '127.0.0.1' + +# https://verdaccio.org/docs/configuration#offline-publish +# publish: +# allow_offline: false +# check_owners: false +# keep_readmes: 'latest' | 'tagged' | 'all' + +# Define public URL of registry in combination with VERDACCIO_PUBLIC_URL environment variable +# https://verdaccio.org/docs/configuration#url-prefix +# url_prefix: /verdaccio/ +# +# Examples: +# VERDACCIO_PUBLIC_URL='https://somedomain.org' +# url_prefix: '/my_prefix' +# // url -> https://somedomain.org/my_prefix/ +# +# VERDACCIO_PUBLIC_URL='https://somedomain.org' +# url_prefix: '/' +# // url -> https://somedomain.org/ +# +# VERDACCIO_PUBLIC_URL='https://somedomain.org/first_prefix' +# url_prefix: '/second_prefix' +# // url -> https://somedomain.org/second_prefix/ + +# Security settings +# https://verdaccio.org/docs/configuration#security +# security: +# api: +# legacy: true +# jwt: +# sign: +# expiresIn: 29d +# verify: +# someProp: [value] +# web: +# sign: +# expiresIn: 1h # 1 hour by default +# verify: +# someProp: [value] + +# https://verdaccio.org/docs/configuration#user-rate-limit +# userRateLimit: +# windowMs: 50000 +# max: 1000 + +# https://verdaccio.org/docs/configuration#max-body-size +# max_body_size: 10mb + +# https://verdaccio.org/docs/configuration#listen-port +# listen: +# - localhost:4873 # default value +# - http://localhost:4873 # same thing +# - 0.0.0.0:4873 # listen on all addresses (INADDR_ANY) +# - https://example.org:4873 # if you want to use https +# - "[::1]:4873" # ipv6 +# - unix:/tmp/verdaccio.sock # unix socket + +# The HTTPS configuration is useful if you do not consider use a HTTP Proxy +# https://verdaccio.org/docs/configuration#https +# https: +# key: ./path/verdaccio-key.pem +# cert: ./path/verdaccio-cert.pem +# ca: ./path/verdaccio-csr.pem + +# https://verdaccio.org/docs/configuration#proxy +# http_proxy: http://something.local/ +# https_proxy: https://something.local/ +# no_proxy: localhost,127.0.0.1,server.local + +# https://verdaccio.org/docs/configuration#notifications +# notify: +# method: 'POST' +# headers: '[{ "Content-Type": "application/json" }]' +# endpoint: 'https://usagge.hipchat.com/v2/room/3729485/notification?auth_token=mySecretToken' +# content: '{"color":"green","message":"New package published: * {{ name }}*","notify":true,"message_format":"text"}' + +# Settings for middleware plugins +# https://verdaccio.org/docs/plugins#middleware-configuration +middlewares: + audit: + enabled: true + # timeout: 10000 + +# Log settings +# https://verdaccio.org/docs/logger +# Redaction: https://getpino.io/#/docs/redaction +# Synchronous logging: https://getpino.io/#/docs/asynchronous +log: + type: stdout + format: pretty + level: http +# redact: +# paths: ['req.header.authorization','req.header.cookie','req.remoteAddress','req.remotePort','ip','remoteIP','user','msg'] +# censor: '' +# sync: true + +# Feature flags (experimental settings that can be changed or removed in the future) +# https://verdaccio.org/docs/configuration#experiments +# experiments: +# # Support for npm token command +# token: false +# # Enable tarball URL redirect for hosting tarball with a different server. +# # The tarball_url_redirect can be a template string +# tarball_url_redirect: 'https://mycdn.com/verdaccio/${packageName}/${filename}' +# # The tarball_url_redirect can be a function, takes packageName and filename and returns the url, +# # when working with a js configuration file +# tarball_url_redirect(packageName, filename) { +# const signedUrl = // generate a signed url +# return signedUrl; +# } +# Renamed from "experiments" to "flags" in next major release +# flags: +# changePassword: true +# searchRemote: true + +# Translate your registry, API and web UI +# List of the available translations https://github.com/verdaccio/verdaccio/blob/master/packages/plugins/ui-theme/src/i18n/ABOUT_TRANSLATIONS.md +i18n: + web: en-US +""" \ No newline at end of file diff --git a/blueprints/verdaccio/verdaccio.svg b/blueprints/verdaccio/verdaccio.svg new file mode 100644 index 00000000..a9e07b29 --- /dev/null +++ b/blueprints/verdaccio/verdaccio.svg @@ -0,0 +1,38 @@ + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + diff --git a/meta.json b/meta.json index 42cdf342..3ae0cb5e 100644 --- a/meta.json +++ b/meta.json @@ -2831,7 +2831,7 @@ { "id": "grafana", "name": "Grafana", - "version": "9.5.20", + "version": "12.4", "description": "Grafana is an open source platform for data visualization and monitoring.", "logo": "grafana.svg", "links": { @@ -3099,6 +3099,25 @@ "group-finances" ] }, + { + "id": "imgproxy", + "name": "imgproxy", + "version": "v3.30.1", + "description": "imgproxy is a fast and secure image processing server, fronted by nginx with built-in response caching for repeated transformations.", + "logo": "imgproxy.png", + "links": { + "github": "https://github.com/imgproxy/imgproxy", + "website": "https://imgproxy.net/", + "docs": "https://docs.imgproxy.net/" + }, + "tags": [ + "images", + "media", + "proxy", + "cdn", + "caching" + ] + }, { "id": "immich", "name": "Immich", @@ -3929,6 +3948,23 @@ "self-hosted" ] }, + { + "id": "mediafetch", + "name": "MediaFetch", + "version": "1.1.1", + "description": "A tiny, self-hosted web wrapper for yt-dlp to download video and audio. Optional basic auth.", + "logo": "mediafetch.svg", + "links": { + "github": "https://github.com/lukedunsmoto/mediafetch", + "website": "https://www.lukedunsmore.com/mediafetch", + "docs": "https://docs.lukedunsmore.com/docs/self-hosted/mediafetch/" + }, + "tags": [ + "utilities", + "media", + "downloader" + ] + }, { "id": "meilisearch", "name": "Meilisearch", @@ -4294,10 +4330,10 @@ }, { "id": "nextcloud-aio", - "name": "Nextcloud All in One", - "version": "30.0.2", - "description": "Nextcloud (AIO) is a self-hosted file storage and sync platform with powerful collaboration capabilities. It integrates Files, Talk, Groupware, Office, Assistant and more into a single platform for remote work and data protection.", - "logo": "nextcloud-aio.svg", + "name": "Nextcloud", + "version": "stable", + "description": "Nextcloud is a self-hosted file storage and sync platform with powerful collaboration capabilities. It integrates Files, Talk, Groupware, Office, Assistant and more into a single platform for remote work and data protection.", + "logo": "nextcloud.png", "links": { "github": "https://github.com/nextcloud/docker", "website": "https://nextcloud.com/", @@ -5879,6 +5915,24 @@ "open-source" ] }, + { + "id": "strapi", + "name": "Strapi", + "version": "v5.33.0", + "description": "Open-source headless CMS to build powerful APIs with built-in content management.", + "logo": "strapi.svg", + "links": { + "github": "https://github.com/strapi/strapi", + "discord": "https://discord.com/invite/strapi", + "docs": "https://docs.strapi.io", + "website": "https://strapi.io" + }, + "tags": [ + "headless", + "cms", + "content-management" + ] + }, { "id": "streamflow", "name": "StreamFlow", @@ -6173,6 +6227,24 @@ "e-ink" ] }, + { + "id": "tuwunel", + "name": "Tuwunel", + "version": "v1.5.0", + "description": "High performance Matrix homeserver written in Rust. Official successor to conduwuit - a scalable, low-cost, enterprise-ready alternative to Synapse.", + "logo": "tuwunel.svg", + "links": { + "github": "https://github.com/matrix-construct/tuwunel", + "website": "https://tuwunel.chat", + "docs": "https://matrix-construct.github.io/tuwunel/" + }, + "tags": [ + "matrix", + "chat", + "messaging", + "rust" + ] + }, { "id": "twenty", "name": "Twenty CRM", @@ -6270,6 +6342,24 @@ "networking" ] }, + { + "id": "unleash", + "name": "Unleash", + "version": "7.4.0", + "description": "Open-source feature management platform", + "logo": "unleash.png", + "links": { + "github": "https://github.com/unleash/unleash", + "website": "https://www.getunleash.io/", + "docs": "https://docs.getunleash.io/" + }, + "tags": [ + "feature-flag", + "feature-management", + "feature-toggle", + "remote-configuration" + ] + }, { "id": "upsnap", "name": "Upsnap", @@ -6372,6 +6462,23 @@ "open-source" ] }, + { + "id": "verdaccio", + "name": "Verdaccio", + "version": "6", + "description": "A lightweight Node.js private proxy registry", + "logo": "verdaccio.svg", + "links": { + "github": "https://github.com/verdaccio/verdaccio", + "website": "https://www.verdaccio.org/", + "docs": "https://www.verdaccio.org/docs/what-is-verdaccio" + }, + "tags": [ + "node.js", + "package-repository", + "npm" + ] + }, { "id": "vikunja", "name": "Vikunja",