3.9 KiB
Dokploy Open Source Templates
This is the official repository for the Dokploy Open Source Templates.
How to add a new template
- Clone the repository
- Add the template to the
blueprints
folder (docker-compose.yml, template.yml) - Add the template metadata (name, description, version, logo, links, tags) to the
meta.json
file - Add the logo to the template folder
- Commit and push your changes
- Create a pull request
Example
Let's suppose you want to add the Grafana template to the repository.
- Create a new folder inside the
blueprints
folder namedgrafana
- Add the
docker-compose.yml
file to the folder
version: "3.8"
services:
grafana:
image: grafana/grafana-enterprise:9.5.20
restart: unless-stopped
volumes:
- grafana-storage:/var/lib/grafana
volumes:
grafana-storage: {}
- Add the
template.yml
file to the folder, this is where we specify the domains, mounts and env variables, to understand more the structure oftemplate.yml
you can read here []
variables:
main_domain: ${domain}
config:
domains:
- serviceName: grafana
port: 3000
host: ${main_domain}
env: []
mounts: []
- Add the
meta.json
file to the folder
{
"id": "grafana",
"name": "Grafana",
"version": "9.5.20",
"description": "Grafana is an open source platform for data visualization and monitoring.",
"logo": "grafana.svg",
"links": {
"github": "https://github.com/grafana/grafana",
"website": "https://grafana.com/",
"docs": "https://grafana.com/docs/"
},
"tags": [
"monitoring"
]
},
- Add the logo to the folder
- Commit and push your changes
- Create a pull request
Template.yml structure
Dokploy use a defined structure for the template.yml
file, we have 4 sections available:
-
variables
: This is where we define the variables that will be used in thedomains
,env
andmounts
sections. -
domains
: This is where we define the configuration for the template. -
env
: This is where we define the environment variables for the template. -
mounts
: This is where we define the mounts for the template. -
the
variables(Optional)
structure is the following:
1. variables:
main_domain: ${domain}
2. variables:
my-domain: https://my-domain.com
- the
config
structure is the following:
1. config:
domains: # Optional
- serviceName: grafana # Required
port: 3000 # Required
host: ${main_domain} # Required
path: / -> Optional
env: # Optional
- AP_HOST=${main_domain}
- AP_API_KEY=${api_key}
- AP_ENCRYPTION_KEY=${encryption_key}
- AP_JWT_SECRET=${jwt_secret}
- AP_POSTGRES_PASSWORD=${postgres_password}
mounts: # Optional or []
- filePath: /content/file.txt
content: |
My content
Important: you can reference any variable in the domains
, env
and mounts
sections. just use the ${variable_name}
syntax, in the case you don't want to define a variable, you can use the domain
, base64
, password
, hash
, uuid
, randomPort
or timestamp
helpers.
Helpers
We have a few helpers that are very common when creating a template, these are:
domain
: This is a helper that will generate a random domain for the template.base64 or base64:length
: This is a helper that will encode a string to base64.password or password:length
: This is a helper that will generate a random password for the template.hash or hash:length
: This is a helper that will generate a hash for the template.uuid
: This is a helper that will generate a uuid for the template.randomPort
: This is a helper that will generate a random port for the template.timestamp
: This is a helper that will generate a timestamp.jwt or jwt:length
: This is a helper that will generate a jwt for the template.