Woodpecker CI
Get Started with Apps!
Keywords: automation, ci
Train: Community
Home Page: https://woodpecker-ci.org
Added: 2025-05-21
Last Updated: 2025-05-23
Woodpecker CI is a simple, yet powerful CI/CD engine with great extensibility.
Run as Context- Woodpecker CI Server runs as any non-root user.
Group: 568 / woodpecker
User: 568 / woodpecker - Woodpecker CI Agent runs as any non-root user.
Group: 568 / woodpecker
User: 568 / woodpecker - Postgres runs as non-root user.
Group: 999 / postgres
User: 999 / postgres
Host Mounts
- /var/run/docker.sock : Docker socket
App Metadata (Raw File)
{
"1.0.0": {
"healthy": true,
"supported": true,
"healthy_error": null,
"location": "/__w/apps/apps/trains/community/woodpecker-ci/1.0.0",
"last_update": "2025-05-23 15:51:44",
"required_features": [],
"human_version": "v3.6.0_1.0.0",
"version": "1.0.0",
"app_metadata": {
"app_version": "v3.6.0",
"capabilities": [],
"categories": [
"productivity"
],
"changelog_url": "https://github.com/woodpecker-ci/woodpecker/releases",
"date_added": "2025-05-21",
"description": "Woodpecker CI is a simple, yet powerful CI/CD engine with great extensibility.",
"home": "https://woodpecker-ci.org",
"host_mounts": [
{
"description": "Docker socket",
"host_path": "/var/run/docker.sock"
}
],
"icon": "https://media.sys.truenas.net/apps/woodpecker-ci/icons/icon.svg",
"keywords": [
"automation",
"ci"
],
"lib_version": "2.1.27",
"lib_version_hash": "565d2e69b987753ffbe487136ed3c370444e4e3d656729c22823d535141526cf",
"maintainers": [
{
"email": "dev@ixsystems.com",
"name": "truenas",
"url": "https://www.truenas.com/"
}
],
"name": "woodpecker-ci",
"run_as_context": [
{
"description": "Woodpecker CI Server runs as any non-root user.",
"gid": 568,
"group_name": "woodpecker",
"uid": 568,
"user_name": "woodpecker"
},
{
"description": "Woodpecker CI Agent runs as any non-root user.",
"gid": 568,
"group_name": "woodpecker",
"uid": 568,
"user_name": "woodpecker"
},
{
"description": "Postgres runs as non-root user.",
"gid": 999,
"group_name": "postgres",
"uid": 999,
"user_name": "postgres"
}
],
"screenshots": [],
"sources": [
"https://woodpecker-ci.org",
"https://github.com/woodpecker-ci/woodpecker",
"https://hub.docker.com/r/woodpeckerci/woodpecker-server",
"https://hub.docker.com/r/woodpeckerci/woodpecker-agent"
],
"title": "Woodpecker CI",
"train": "community",
"version": "1.0.0"
},
"schema": {
"groups": [
{
"name": "Woodpecker CI Configuration",
"description": "Configure Woodpecker CI"
},
{
"name": "User and Group Configuration",
"description": "Configure User and Group for Woodpecker CI"
},
{
"name": "Network Configuration",
"description": "Configure Network for Woodpecker CI"
},
{
"name": "Storage Configuration",
"description": "Configure Storage for Woodpecker CI"
},
{
"name": "Labels Configuration",
"description": "Configure Labels for Woodpecker CI"
},
{
"name": "Resources Configuration",
"description": "Configure Resources for Woodpecker CI"
}
],
"questions": [
{
"variable": "TZ",
"group": "Woodpecker CI Configuration",
"label": "Timezone",
"schema": {
"type": "string",
"default": "Etc/UTC",
"required": true,
"$ref": [
"definitions/timezone"
]
}
},
{
"variable": "woodpecker",
"label": "",
"group": "Woodpecker CI Configuration",
"schema": {
"type": "dict",
"attrs": [
{
"variable": "postgres_image_selector",
"label": "Postgres Image (CAUTION)",
"description": "If you are changing this after the postgres directory has been initialized,</br>\nSTOP! and make sure you have a backup of your data.</br>\nChanging this will trigger an one way database upgrade.</br>\nYou can only select newer versions of postgres.</br>\nSelecting an older version will refuse to start.</br>\nIf something goes wrong, you will have to restore from backup.\n",
"schema": {
"type": "string",
"default": "postgres_17_image",
"required": true,
"enum": [
{
"value": "postgres_17_image",
"description": "Postgres 17"
}
]
}
},
{
"variable": "db_password",
"label": "Database Password",
"description": "The password for Woodpecker CI Database.",
"schema": {
"type": "string",
"default": "",
"required": true,
"private": true
}
},
{
"variable": "external_url",
"label": "External URL",
"description": "The URL that Woodpecker will be accessible from.</br>\nExample: </br>\n- http://server.ip:30166</br>\n- https://server.ip:30168</br>\n- https://woodpecker.example.com\n",
"schema": {
"type": "uri",
"default": "",
"required": true
}
},
{
"variable": "agent_secret",
"label": "Agent Secret",
"description": "The secret that the built-in agent will use to authenticate with the server.",
"schema": {
"type": "string",
"default": "",
"required": true,
"private": true
}
},
{
"variable": "forge",
"label": "Forge Configuration",
"schema": {
"type": "dict",
"attrs": [
{
"variable": "type",
"label": "Type",
"schema": {
"type": "string",
"required": true,
"enum": [
{
"value": "github",
"description": "GitHub"
},
{
"value": "gitea",
"description": "Gitea"
},
{
"value": "forgejo",
"description": "Forgejo"
},
{
"value": "bitbucket",
"description": "Bitbucket"
},
{
"value": "gitlab",
"description": "GitLab"
}
]
}
},
{
"variable": "github",
"label": "GitHub Configuration",
"schema": {
"type": "dict",
"show_if": [
[
"type",
"=",
"github"
]
],
"attrs": [
{
"variable": "client_id",
"label": "Client ID",
"description": "The client ID for the GitHub application.",
"schema": {
"type": "string",
"required": true
}
},
{
"variable": "client_secret",
"label": "Client Secret",
"description": "The client secret for the GitHub application.",
"schema": {
"type": "string",
"required": true
}
}
]
}
},
{
"variable": "gitea",
"label": "Gitea Configuration",
"schema": {
"type": "dict",
"show_if": [
[
"type",
"=",
"gitea"
]
],
"attrs": [
{
"variable": "url",
"label": "URL",
"description": "The URL of the Gitea server.",
"schema": {
"type": "string",
"required": true
}
},
{
"variable": "client_id",
"label": "Client ID",
"description": "The client ID for the Gitea application.",
"schema": {
"type": "string",
"required": true
}
},
{
"variable": "client_secret",
"label": "Client Secret",
"description": "The client secret for the Gitea application.",
"schema": {
"type": "string",
"required": true
}
},
{
"variable": "skip_tls_verify",
"label": "Skip TLS Verify",
"description": "Skip TLS verification.",
"schema": {
"type": "boolean",
"default": false
}
}
]
}
},
{
"variable": "forgejo",
"label": "Forgejo Configuration",
"schema": {
"type": "dict",
"show_if": [
[
"type",
"=",
"forgejo"
]
],
"attrs": [
{
"variable": "url",
"label": "URL",
"description": "The URL of the Forgejo server.",
"schema": {
"type": "string",
"required": true
}
},
{
"variable": "client_id",
"label": "Client ID",
"description": "The client ID for the Forgejo application.",
"schema": {
"type": "string",
"required": true
}
},
{
"variable": "client_secret",
"label": "Client Secret",
"description": "The client secret for the Forgejo application.",
"schema": {
"type": "string",
"required": true
}
},
{
"variable": "skip_tls_verify",
"label": "Skip TLS Verify",
"description": "Skip TLS verification.",
"schema": {
"type": "boolean",
"default": false
}
}
]
}
},
{
"variable": "bitbucket",
"label": "Bitbucket Configuration",
"schema": {
"type": "dict",
"show_if": [
[
"type",
"=",
"bitbucket"
]
],
"attrs": [
{
"variable": "client_id",
"label": "Client ID",
"description": "The client ID for the Bitbucket application.",
"schema": {
"type": "string",
"required": true
}
},
{
"variable": "client_secret",
"label": "Client Secret",
"description": "The client secret for the Bitbucket application.",
"schema": {
"type": "string",
"required": true
}
}
]
}
},
{
"variable": "gitlab",
"label": "GitLab Configuration",
"schema": {
"type": "dict",
"show_if": [
[
"type",
"=",
"gitlab"
]
],
"attrs": [
{
"variable": "url",
"label": "URL",
"description": "The URL of the GitLab server.",
"schema": {
"type": "string",
"required": true
}
},
{
"variable": "client_id",
"label": "Client ID",
"description": "The client ID for the GitLab application.",
"schema": {
"type": "string",
"required": true
}
},
{
"variable": "client_secret",
"label": "Client Secret",
"description": "The client secret for the GitLab application.",
"schema": {
"type": "string",
"required": true
}
},
{
"variable": "skip_tls_verify",
"label": "Skip TLS Verify",
"description": "Skip TLS verification.",
"schema": {
"type": "boolean",
"default": false
}
}
]
}
}
]
}
},
{
"variable": "agent",
"label": "Agent Configuration",
"schema": {
"type": "dict",
"attrs": [
{
"variable": "max_workflows",
"label": "Max Workflows",
"description": "The maximum number of workflows that the built-in agent can be run at the same time.",
"schema": {
"type": "int",
"default": 1,
"min": 1,
"required": true
}
},
{
"variable": "labels",
"label": "Agent Labels",
"description": "The labels that the built-in agent will be have.",
"schema": {
"type": "list",
"default": [],
"items": [
{
"variable": "label",
"label": "Label",
"schema": {
"type": "dict",
"attrs": [
{
"variable": "key",
"label": "Key",
"schema": {
"type": "string",
"required": true
}
},
{
"variable": "value",
"label": "Value",
"schema": {
"type": "string",
"required": true
}
}
]
}
}
]
}
}
]
}
},
{
"variable": "server_additional_envs",
"label": "Additional Environment Variables for Server Container",
"schema": {
"type": "list",
"default": [],
"items": [
{
"variable": "env",
"label": "Environment Variable",
"schema": {
"type": "dict",
"attrs": [
{
"variable": "name",
"label": "Name",
"schema": {
"type": "string",
"required": true
}
},
{
"variable": "value",
"label": "Value",
"schema": {
"type": "string",
"required": true
}
}
]
}
}
]
}
},
{
"variable": "agent_additional_envs",
"label": "Additional Environment Variables for Agent Container",
"schema": {
"type": "list",
"default": [],
"items": [
{
"variable": "env",
"label": "Environment Variable",
"schema": {
"type": "dict",
"attrs": [
{
"variable": "name",
"label": "Name",
"schema": {
"type": "string",
"required": true
}
},
{
"variable": "value",
"label": "Value",
"schema": {
"type": "string",
"required": true
}
}
]
}
}
]
}
}
]
}
},
{
"variable": "run_as",
"label": "",
"group": "User and Group Configuration",
"schema": {
"type": "dict",
"attrs": [
{
"variable": "user",
"label": "User ID",
"description": "The user id that Woodpecker CI files will be owned by.",
"schema": {
"type": "int",
"min": 568,
"default": 568,
"required": true
}
},
{
"variable": "group",
"label": "Group ID",
"description": "The group id that Woodpecker CI files will be owned by.",
"schema": {
"type": "int",
"min": 568,
"default": 568,
"required": true
}
}
]
}
},
{
"variable": "network",
"label": "",
"group": "Network Configuration",
"schema": {
"type": "dict",
"attrs": [
{
"variable": "http_port",
"label": "HTTP Port",
"schema": {
"type": "dict",
"attrs": [
{
"variable": "bind_mode",
"label": "Port Bind Mode",
"description": "The port bind mode.</br>\n- Publish: The port will be published on the host for external access.</br>\n- Expose: The port will be exposed for inter-container communication.</br>\n- None: The port will not be exposed or published.</br>\nNote: If the Dockerfile defines an EXPOSE directive,\nthe port will still be exposed for inter-container communication regardless of this setting.\n",
"schema": {
"type": "string",
"default": "published",
"enum": [
{
"value": "published",
"description": "Publish port on the host for external access"
},
{
"value": "exposed",
"description": "Expose port for inter-container communication"
},
{
"value": "",
"description": "None"
}
]
}
},
{
"variable": "port_number",
"label": "Port Number",
"schema": {
"type": "int",
"default": 30166,
"required": true,
"$ref": [
"definitions/port"
]
}
},
{
"variable": "host_ips",
"label": "Host IPs",
"description": "IPs on the host to bind this port",
"schema": {
"type": "list",
"show_if": [
[
"bind_mode",
"=",
"published"
]
],
"default": [],
"items": [
{
"variable": "host_ip",
"label": "Host IP",
"schema": {
"type": "string",
"required": true,
"$ref": [
"definitions/node_bind_ip"
]
}
}
]
}
}
]
}
},
{
"variable": "grpc_port",
"label": "GRPC Port",
"schema": {
"type": "dict",
"attrs": [
{
"variable": "bind_mode",
"label": "Port Bind Mode",
"description": "The port bind mode.</br>\n- Publish: The port will be published on the host for external access.</br>\n- Expose: The port will be exposed for inter-container communication.</br>\n- None: The port will not be exposed or published.</br>\nNote: If the Dockerfile defines an EXPOSE directive,\nthe port will still be exposed for inter-container communication regardless of this setting.\n",
"schema": {
"type": "string",
"default": "",
"enum": [
{
"value": "published",
"description": "Publish port on the host for external access"
},
{
"value": "exposed",
"description": "Expose port for inter-container communication"
},
{
"value": "",
"description": "None"
}
]
}
},
{
"variable": "port_number",
"label": "Port Number",
"schema": {
"type": "int",
"default": 30167,
"required": true,
"$ref": [
"definitions/port"
]
}
},
{
"variable": "host_ips",
"label": "Host IPs",
"description": "IPs on the host to bind this port",
"schema": {
"type": "list",
"show_if": [
[
"bind_mode",
"=",
"published"
]
],
"default": [],
"items": [
{
"variable": "host_ip",
"label": "Host IP",
"schema": {
"type": "string",
"required": true,
"$ref": [
"definitions/node_bind_ip"
]
}
}
]
}
}
]
}
},
{
"variable": "https_port",
"label": "HTTPS Port",
"schema": {
"type": "dict",
"show_if": [
[
"certificate_id",
"!=",
null
]
],
"attrs": [
{
"variable": "bind_mode",
"label": "Port Bind Mode",
"description": "The port bind mode.</br>\n- Publish: The port will be published on the host for external access.</br>\n- Expose: The port will be exposed for inter-container communication.</br>\n- None: The port will not be exposed or published.</br>\nNote: If the Dockerfile defines an EXPOSE directive,\nthe port will still be exposed for inter-container communication regardless of this setting.\n",
"schema": {
"type": "string",
"default": "published",
"enum": [
{
"value": "published",
"description": "Publish port on the host for external access"
},
{
"value": "exposed",
"description": "Expose port for inter-container communication"
},
{
"value": "",
"description": "None"
}
]
}
},
{
"variable": "port_number",
"label": "Port Number",
"schema": {
"type": "int",
"default": 30168,
"required": true,
"$ref": [
"definitions/port"
]
}
},
{
"variable": "host_ips",
"label": "Host IPs",
"description": "IPs on the host to bind this port",
"schema": {
"type": "list",
"show_if": [
[
"bind_mode",
"=",
"published"
]
],
"default": [],
"items": [
{
"variable": "host_ip",
"label": "Host IP",
"schema": {
"type": "string",
"required": true,
"$ref": [
"definitions/node_bind_ip"
]
}
}
]
}
}
]
}
},
{
"variable": "certificate_id",
"label": "Certificate",
"description": "The certificate to use for Concourse.",
"schema": {
"type": "int",
"null": true,
"$ref": [
"definitions/certificate"
]
}
}
]
}
},
{
"variable": "storage",
"label": "",
"group": "Storage Configuration",
"schema": {
"type": "dict",
"attrs": [
{
"variable": "agent_config",
"label": "Woodpecker CI Agent Configuration Storage",
"schema": {
"type": "dict",
"attrs": [
{
"variable": "type",
"label": "Type",
"description": "ixVolume: Is dataset created automatically by the system.</br>\nHost Path: Is a path that already exists on the system.\n",
"schema": {
"type": "string",
"required": true,
"immutable": true,
"default": "ix_volume",
"enum": [
{
"value": "host_path",
"description": "Host Path (Path that already exists on the system)"
},
{
"value": "ix_volume",
"description": "ixVolume (Dataset created automatically by the system)"
}
]
}
},
{
"variable": "ix_volume_config",
"label": "ixVolume Configuration",
"description": "The configuration for the ixVolume dataset.",
"schema": {
"type": "dict",
"show_if": [
[
"type",
"=",
"ix_volume"
]
],
"$ref": [
"normalize/ix_volume"
],
"attrs": [
{
"variable": "acl_enable",
"label": "Enable ACL",
"description": "Enable ACL for the storage.",
"schema": {
"type": "boolean",
"default": false
}
},
{
"variable": "dataset_name",
"label": "Dataset Name",
"description": "The name of the dataset to use for storage.",
"schema": {
"type": "string",
"required": true,
"immutable": true,
"hidden": true,
"default": "agent_config"
}
},
{
"variable": "acl_entries",
"label": "ACL Configuration",
"schema": {
"type": "dict",
"show_if": [
[
"acl_enable",
"=",
true
]
],
"attrs": []
}
}
]
}
},
{
"variable": "host_path_config",
"label": "Host Path Configuration",
"schema": {
"type": "dict",
"show_if": [
[
"type",
"=",
"host_path"
]
],
"attrs": [
{
"variable": "acl_enable",
"label": "Enable ACL",
"description": "Enable ACL for the storage.",
"schema": {
"type": "boolean",
"default": false
}
},
{
"variable": "acl",
"label": "ACL Configuration",
"schema": {
"type": "dict",
"show_if": [
[
"acl_enable",
"=",
true
]
],
"attrs": [],
"$ref": [
"normalize/acl"
]
}
},
{
"variable": "path",
"label": "Host Path",
"description": "The host path to use for storage.",
"schema": {
"type": "hostpath",
"show_if": [
[
"acl_enable",
"=",
false
]
],
"required": true
}
}
]
}
}
]
}
},
{
"variable": "postgres_data",
"label": "Postgres Data Storage",
"description": "The path to store Postgres Data.",
"schema": {
"type": "dict",
"attrs": [
{
"variable": "type",
"label": "Type",
"description": "ixVolume: Is dataset created automatically by the system.</br>\nHost Path: Is a path that already exists on the system.\n",
"schema": {
"type": "string",
"required": true,
"immutable": true,
"default": "ix_volume",
"enum": [
{
"value": "host_path",
"description": "Host Path (Path that already exists on the system)"
},
{
"value": "ix_volume",
"description": "ixVolume (Dataset created automatically by the system)"
}
]
}
},
{
"variable": "ix_volume_config",
"label": "ixVolume Configuration",
"description": "The configuration for the ixVolume dataset.",
"schema": {
"type": "dict",
"show_if": [
[
"type",
"=",
"ix_volume"
]
],
"$ref": [
"normalize/ix_volume"
],
"attrs": [
{
"variable": "acl_enable",
"label": "Enable ACL",
"description": "Enable ACL for the storage.",
"schema": {
"type": "boolean",
"default": false
}
},
{
"variable": "dataset_name",
"label": "Dataset Name",
"description": "The name of the dataset to use for storage.",
"schema": {
"type": "string",
"required": true,
"immutable": true,
"hidden": true,
"default": "pg_data"
}
},
{
"variable": "acl_entries",
"label": "ACL Configuration",
"schema": {
"type": "dict",
"show_if": [
[
"acl_enable",
"=",
true
]
],
"attrs": []
}
}
]
}
},
{
"variable": "host_path_config",
"label": "Host Path Configuration",
"schema": {
"type": "dict",
"show_if": [
[
"type",
"=",
"host_path"
]
],
"attrs": [
{
"variable": "acl_enable",
"label": "Enable ACL",
"description": "Enable ACL for the storage.",
"schema": {
"type": "boolean",
"default": false
}
},
{
"variable": "acl",
"label": "ACL Configuration",
"schema": {
"type": "dict",
"show_if": [
[
"acl_enable",
"=",
true
]
],
"attrs": [],
"$ref": [
"normalize/acl"
]
}
},
{
"variable": "path",
"label": "Host Path",
"description": "The host path to use for storage.",
"schema": {
"type": "hostpath",
"show_if": [
[
"acl_enable",
"=",
false
]
],
"required": true
}
},
{
"variable": "auto_permissions",
"label": "Automatic Permissions",
"description": "Automatically set permissions for the host path.\nEnabling this, will check the top level directory,</br>\nIf it finds incorrect permissions, it will `chown` the\nhost path to the user and group required for the\npostgres container.\n",
"schema": {
"type": "boolean",
"default": false,
"show_if": [
[
"acl_enable",
"=",
false
]
]
}
}
]
}
}
]
}
},
{
"variable": "additional_storage",
"label": "Additional Storage",
"description": "Additional storage for Woodpecker CI.",
"schema": {
"type": "list",
"default": [],
"items": [
{
"variable": "storageEntry",
"label": "Storage Entry",
"schema": {
"type": "dict",
"attrs": [
{
"variable": "type",
"label": "Type",
"description": "ixVolume: Is dataset created automatically by the system.</br>\nHost Path: Is a path that already exists on the system.</br>\nSMB Share: Is a SMB share that is mounted to as a volume.\n",
"schema": {
"type": "string",
"required": true,
"default": "ix_volume",
"immutable": true,
"enum": [
{
"value": "host_path",
"description": "Host Path (Path that already exists on the system)"
},
{
"value": "ix_volume",
"description": "ixVolume (Dataset created automatically by the system)"
},
{
"value": "cifs",
"description": "SMB/CIFS Share (Mounts a volume to a SMB share)"
}
]
}
},
{
"variable": "read_only",
"label": "Read Only",
"description": "Mount the volume as read only.",
"schema": {
"type": "boolean",
"default": false
}
},
{
"variable": "mount_path",
"label": "Mount Path",
"description": "The path inside the container to mount the storage.",
"schema": {
"type": "path",
"required": true
}
},
{
"variable": "host_path_config",
"label": "Host Path Configuration",
"schema": {
"type": "dict",
"show_if": [
[
"type",
"=",
"host_path"
]
],
"attrs": [
{
"variable": "acl_enable",
"label": "Enable ACL",
"description": "Enable ACL for the storage.",
"schema": {
"type": "boolean",
"default": false
}
},
{
"variable": "acl",
"label": "ACL Configuration",
"schema": {
"type": "dict",
"show_if": [
[
"acl_enable",
"=",
true
]
],
"attrs": [],
"$ref": [
"normalize/acl"
]
}
},
{
"variable": "path",
"label": "Host Path",
"description": "The host path to use for storage.",
"schema": {
"type": "hostpath",
"show_if": [
[
"acl_enable",
"=",
false
]
],
"required": true
}
}
]
}
},
{
"variable": "ix_volume_config",
"label": "ixVolume Configuration",
"description": "The configuration for the ixVolume dataset.",
"schema": {
"type": "dict",
"show_if": [
[
"type",
"=",
"ix_volume"
]
],
"$ref": [
"normalize/ix_volume"
],
"attrs": [
{
"variable": "acl_enable",
"label": "Enable ACL",
"description": "Enable ACL for the storage.",
"schema": {
"type": "boolean",
"default": false
}
},
{
"variable": "dataset_name",
"label": "Dataset Name",
"description": "The name of the dataset to use for storage.",
"schema": {
"type": "string",
"required": true,
"immutable": true,
"default": "storage_entry"
}
},
{
"variable": "acl_entries",
"label": "ACL Configuration",
"schema": {
"type": "dict",
"show_if": [
[
"acl_enable",
"=",
true
]
],
"attrs": [],
"$ref": [
"normalize/acl"
]
}
}
]
}
},
{
"variable": "cifs_config",
"label": "SMB Configuration",
"description": "The configuration for the SMB dataset.",
"schema": {
"type": "dict",
"show_if": [
[
"type",
"=",
"cifs"
]
],
"attrs": [
{
"variable": "server",
"label": "Server",
"description": "The server to mount the SMB share.",
"schema": {
"type": "string",
"required": true
}
},
{
"variable": "path",
"label": "Path",
"description": "The path to mount the SMB share.",
"schema": {
"type": "string",
"required": true
}
},
{
"variable": "username",
"label": "Username",
"description": "The username to use for the SMB share.",
"schema": {
"type": "string",
"required": true
}
},
{
"variable": "password",
"label": "Password",
"description": "The password to use for the SMB share.",
"schema": {
"type": "string",
"required": true,
"private": true
}
},
{
"variable": "domain",
"label": "Domain",
"description": "The domain to use for the SMB share.",
"schema": {
"type": "string"
}
}
]
}
}
]
}
}
]
}
}
]
}
},
{
"variable": "labels",
"label": "",
"group": "Labels Configuration",
"schema": {
"type": "list",
"default": [],
"items": [
{
"variable": "label",
"label": "Label",
"schema": {
"type": "dict",
"attrs": [
{
"variable": "key",
"label": "Key",
"schema": {
"type": "string",
"required": true
}
},
{
"variable": "value",
"label": "Value",
"schema": {
"type": "string",
"required": true
}
},
{
"variable": "containers",
"label": "Containers",
"description": "Containers where the label should be applied",
"schema": {
"type": "list",
"items": [
{
"variable": "container",
"label": "Container",
"schema": {
"type": "string",
"required": true,
"enum": [
{
"value": "server",
"description": "server"
},
{
"value": "agent",
"description": "agent"
},
{
"value": "postgres",
"description": "postgres"
}
]
}
}
]
}
}
]
}
}
]
}
},
{
"variable": "resources",
"label": "",
"group": "Resources Configuration",
"schema": {
"type": "dict",
"attrs": [
{
"variable": "limits",
"label": "Limits",
"schema": {
"type": "dict",
"attrs": [
{
"variable": "cpus",
"label": "CPUs",
"description": "CPUs limit for Woodpecker CI.",
"schema": {
"type": "int",
"default": 2,
"required": true
}
},
{
"variable": "memory",
"label": "Memory (in MB)",
"description": "Memory limit for Woodpecker CI.",
"schema": {
"type": "int",
"default": 4096,
"required": true
}
}
]
}
}
]
}
}
]
},
"readme": "<h1>Woodpecker CI</h1> <p><a href=\"https://woodpecker-ci.org/\">Woodpecker CI</a> is a simple, yet powerful CI/CD engine with great extensibility.</p>",
"changelog": null,
"chart_metadata": {
"app_version": "v3.6.0",
"capabilities": [],
"categories": [
"productivity"
],
"changelog_url": "https://github.com/woodpecker-ci/woodpecker/releases",
"date_added": "2025-05-21",
"description": "Woodpecker CI is a simple, yet powerful CI/CD engine with great extensibility.",
"home": "https://woodpecker-ci.org",
"host_mounts": [
{
"description": "Docker socket",
"host_path": "/var/run/docker.sock"
}
],
"icon": "https://media.sys.truenas.net/apps/woodpecker-ci/icons/icon.svg",
"keywords": [
"automation",
"ci"
],
"lib_version": "2.1.27",
"lib_version_hash": "565d2e69b987753ffbe487136ed3c370444e4e3d656729c22823d535141526cf",
"maintainers": [
{
"email": "dev@ixsystems.com",
"name": "truenas",
"url": "https://www.truenas.com/"
}
],
"name": "woodpecker-ci",
"run_as_context": [
{
"description": "Woodpecker CI Server runs as any non-root user.",
"gid": 568,
"group_name": "woodpecker",
"uid": 568,
"user_name": "woodpecker"
},
{
"description": "Woodpecker CI Agent runs as any non-root user.",
"gid": 568,
"group_name": "woodpecker",
"uid": 568,
"user_name": "woodpecker"
},
{
"description": "Postgres runs as non-root user.",
"gid": 999,
"group_name": "postgres",
"uid": 999,
"user_name": "postgres"
}
],
"screenshots": [],
"sources": [
"https://woodpecker-ci.org",
"https://github.com/woodpecker-ci/woodpecker",
"https://hub.docker.com/r/woodpeckerci/woodpecker-server",
"https://hub.docker.com/r/woodpeckerci/woodpecker-agent"
],
"title": "Woodpecker CI",
"train": "community",
"version": "1.0.0"
}
}
}
Support, maintenance, and documentation for applications within the Community catalog is handled by the TrueNAS community. The TrueNAS Applications Portal hosts but does not validate or maintain any linked resources associated with this app.
There currently aren’t any resources available for this application!
Please help the TrueNAS community add resources here or discuss this application in the TrueNAS Community forum.