Skip to main content

Migrations

To enhance the usability of Woodpecker and meet evolving security standards, occasional migrations are necessary. While we aim to minimize these changes, some are unavoidable. If you experience significant issues during a migration to a new version, please let us know so maintainers can reassess the updates.

nextโ€‹

  • No changes

3.0.0โ€‹

User-facing migrationsโ€‹

Workflow syntax changesโ€‹

  • secrets have been entirely removed in favor of environment combined with the from_secret syntax (#4363). As secrets are just normal env vars which are masked, the goal was to allow them to be declared next to normal env vars and at the same time reduce the keyword syntax count. Additionally, the from_secret syntax gives more flexibility in naming. Whereas beforehand secrets where always named after their initial secret name, the from_secret reference can now be different. Last, one can inject multiple different env vars from the same secret reference.

    2.x:

    secrets: [my_token]

    3.x:

    environment:
    MY_TOKEN:
    from_secret: my_token

    Learn more about using secrets

  • The includes and excludes event filter options have been removed

  • Previously, env vars have been automatically sanitized to uppercase. As this has been confusing, the type-case of the secret definition is now respected (#3375).

  • The environment filter option has been removed in favor of when.evaluate

  • Grouping of steps via steps.[name].group should now be done using steps.[name].depends_on

Environment variablesโ€‹

  • Environment variables must now be defined as maps. List definitions are disallowed. (#4016)

    2.x:

    environment:
    - ENV1=value1

    3.x:

    environment:
    ENV1: value1

The following built-in environment variables have been removed/replaced:

  • CI_COMMIT_URL has been deprecated in favor of CI_PIPELINE_FORGE_URL
  • CI_STEP_FINISHED as it was empty during execution
  • CI_PIPELINE_FINISHED as it was empty during execution
  • CI_PIPELINE_STATUS due to always being set to success
  • CI_STEP_STATUS due to always being set to success
  • WOODPECKER_WEBHOOK_HOST in favor of WOODPECKER_EXPERT_WEBHOOK_HOST

Environment variables which are empty after workflow parsing are not being injected into the build but filtered out beforehand (#4193)

Securityโ€‹

  • The "gated" option, which restricted which pipelines can start right away without requiring approval, has been replaced by "require-approval" option. Even though this feature (#3348) was backported to 2.8, no default is explicitly set. The new default in 3.0 is to require approval only for forked repositories. This allows easier management of dependency bots and other trusted entities having write access to the repository.

Former deprecationsโ€‹

The following syntax deprecations will now result in an error:

CLI changesโ€‹

The following restructuring was done to achieve a more consistent grouping:

Old CommandNew Command
woodpecker-cli registrywoodpecker-cli repo registry
woodpecker-cli secret --globalwoodpecker-cli admin secret
woodpecker-cli userwoodpecker-cli admin user
woodpecker-cli log-levelwoodpecker-cli admin log-level
woodpecker-cli secret --organizationwoodpecker-cli org secret
woodpecker-cli deploywoodpecker-cli pipeline deploy
woodpecker-cli logwoodpecker-cli pipeline log
woodpecker-cli cronwoodpecker-cli repo cron
woodpecker-cli secret --repositorywoodpecker-cli repo secret
woodpecker-cli pipeline logswoodpecker-cli pipeline log show
woodpecker-cli (registry,secret,...) infowoodpecker-cli (registry,secret,...) show

(#4467 and #4481)

API changesโ€‹

  • Removed deprecated registry/ endpoint. Use registries, /authorize/token

Miscellaneousโ€‹

  • For woodpecker-cli containers, /woodpecker has been set as the default workdir

  • Plugin filters for secrets (in the "secrets" repo settings) can now validate against tags. Additionally, the description has been updated to reflect that these filters only apply to plugins (#4069).

  • SDK changes:

    • The SDK fields start_time, end_time, created_at, started_at, finished_at and reviewed_at have been renamed to started, finished, created, started, finished, reviewed (#3968)
    • The trusted field of the repo model was changed from boolean to object (#4025)
  • CRON definitions now follow standard Linux syntax without seconds. An automatic migration will attempt to update your settings - ensure the update completes successfully.

    Example definition for a CRON job running at 8 am daily:

    2.x:

    0 0 8 * * *

    3.x:

    0 8 * * *
  • Native Let's Encrypt certificate support has been dropped as it was almost unused and causing frequent issues. Let's Encrypt needs to be set up standalone now. The SSL key pair can still be used in WOODPECKER_SERVER_CERT and WOODPECKER_SERVER_KEY as an alternative to using a reverse proxy for TLS termination. (#4541)

  • The filename of the CLI binary changed for DEB and RPM packages, it is now called woodpecker-cli instead of woodpecker.

Admin-facing migrationsโ€‹

Updated tokensโ€‹

The Webhook tokens have been changed for enhanced security and therefore existing repositories need to be updated using the Repair all button in the admin settings (#4013).

Image tagsโ€‹

  • The latest tag has been dropped to avoid accidental major version upgrades. A dedicated semver tag specification must be used, i.e., either a fixed version (like v3.0.0) or a rolling tag (e.g. v3.0 or v3).

  • Previously, some (official) plugins were granted the privileged option by default to allow simplified usage. To streamline this process and enhance security transparency, no plugin is granted the privileged options by default anymore. To allow the use of these plugins in >= 3.0, they must be set explicitly through WOODPECKER_PLUGINS_PRIVILEGED on the admin side. This change mainly impacts the use of the woodpeckerci/plugin-docker-buildx plugin, which now will not work anymore unless explicitly listed through this env var (#4053)

  • Environment variable deprecations:

    Deprecated VariableNew Variable
    WOODPECKER_LOG_XORMWOODPECKER_DATABASE_LOG
    WOODPECKER_LOG_XORM_SQLWOODPECKER_DATABASE_LOG_SQL
    WOODPECKER_FILTER_LABELSWOODPECKER_AGENT_LABELS
    WOODPECKER_ESCALATEWOODPECKER_PLUGINS_PRIVILEGED
    WOODPECKER_DEFAULT_CLONE_IMAGEWOODPECKER_DEFAULT_CLONE_PLUGIN
    WOODPECKER_DEV_OAUTH_HOSTWOODPECKER_EXPERT_FORGE_OAUTH_HOST
    WOODPECKER_DEV_GITEA_OAUTH_URLWOODPECKER_EXPERT_FORGE_OAUTH_HOST
    WOODPECKER_ROOT_PATHWOODPECKER_HOST
    WOODPECKER_ROOT_URLWOODPECKER_HOST
  • The resource limit settings for the "docker" backend were moved from the server into agent configuration. This allows setting limits on an agent-level which allows greater resource definition granularity (#3174)

  • "Kubernetes" backend: previously the image pull secret name was hard-coded to regcred. To allow more flexibility and specifying multiple pull secrets, the default has been removed. Image pull secrets must now be set explicitly via env var WOODPECKER_BACKEND_K8S_PULL_SECRET_NAMES (#4005)

  • Webhook signatures now use the rfc9421 protocol

  • Git is now the only officially supported SCM. No others were supported previously, but the existence of the env var CI_REPO_SCM indicated that others might be. The env var has now been removed including unused code associated with it. (#4346)

Rootless imagesโ€‹

The server and cli images now use a non-privileged user (woodpecker) by default. If you have volume mounts attached to containers, you might need to update the ownership of these directories from root to woodpecker.

note

The agent image must remain rootful by default to be able to mount the Docker socket when Woodpecker is used with the docker backend. The helm chart will start to use a non-privileged user by utilizing securityContext. Running a completely rootless agent with the docker backend may be possible by using a rootless docker daemon. However, this requires more work and is currently not supported.

2.7.2โ€‹

To secure your instance, set WOODPECKER_PLUGINS_PRIVILEGED to only allow specific versions of the woodpeckerci/plugin-docker-buildx plugin, use version 5.0.0 or above. This prevents older, potentially unstable versions from being privileged.

For example, to allow only version 5.0.0, use:

WOODPECKER_PLUGINS_PRIVILEGED=woodpeckerci/plugin-docker-buildx:5.0.0

To allow multiple versions, you can separate them with commas:

WOODPECKER_PLUGINS_PRIVILEGED=woodpeckerci/plugin-docker-buildx:5.0.0,woodpeckerci/plugin-docker-buildx:5.1.0

This setup ensures only specified, stable plugin versions are given privileged access.

Read more about it in #4213

2.0.0โ€‹

  • Dropped deprecated CI_BUILD_*, CI_PREV_BUILD_*, CI_JOB_*, *_LINK, CI_SYSTEM_ARCH, CI_REPO_REMOTE built-in environment variables
  • Deprecated platform: filter in favor of labels:, read more
  • Secrets event property was renamed to events and image to images as both are lists. The new property events / images has to be used in the api. The old properties event and image were removed.
  • The secrets plugin_only option was removed. Secrets with images are now always only available for plugins using listed by the images property. Existing secrets with a list of images will now only be available to the listed images if they are used as a plugin.
  • Removed build alias for pipeline command in CLI
  • Removed ssh backend. Use an agent directly on the SSH machine using the local backend.
  • Removed /hook and /stream API paths in favor of /api/(hook|stream). You may need to use the "Repair repository" button in the repo settings or "Repair all" in the admin settings to recreate the forge hook.
  • Removed WOODPECKER_DOCS config variable
  • Renamed link to url (including all API fields)
  • Deprecated CI_COMMIT_URL env var, use CI_PIPELINE_FORGE_URL

1.0.0โ€‹

  • The signature used to verify extension calls (like those used for the config-extension) done by the Woodpecker server switched from using a shared-secret HMac to an ed25519 key-pair. Read more about it at the config-extensions documentation.
  • Refactored support for old agent filter labels and expressions. Learn how to use the new filter
  • Renamed step environment variable CI_SYSTEM_ARCH to CI_SYSTEM_PLATFORM. Same applies for the cli exec variable.
  • Renamed environment variables CI_BUILD_* and CI_PREV_BUILD_* to CI_PIPELINE_* and CI_PREV_PIPELINE_*, old ones are still available but deprecated
  • Renamed environment variables CI_JOB_* to CI_STEP_*, old ones are still available but deprecated
  • Renamed environment variable CI_REPO_REMOTE to CI_REPO_CLONE_URL, old is still available but deprecated
  • Renamed environment variable *_LINK to *_URL, old ones are still available but deprecated
  • Renamed API endpoints for pipelines (<owner>/<repo>/builds/<buildId> -> <owner>/<repo>/pipelines/<pipelineId>), old ones are still available but deprecated
  • Updated Prometheus gauge build_* to pipeline_*
  • Updated Prometheus gauge *_job_* to *_step_*
  • Renamed config env WOODPECKER_MAX_PROCS to WOODPECKER_MAX_WORKFLOWS (still available as fallback)
  • The pipelines are now also read from .yaml files, the new default order is .woodpecker/*.yml and .woodpecker/*.yaml (without any prioritization) -> .woodpecker.yml -> .woodpecker.yaml
  • Dropped support for Coding, Gogs and Bitbucket Server (Stash).
  • /api/queue/resume & /api/queue/pause endpoint methods were changed from GET to POST
  • rename pipeline: key in your workflow config to steps:
  • If you want to migrate old logs to the new format, watch the error messages on start. If there are none we are good to go, else you have to plan a migration that can take hours. Set WOODPECKER_MIGRATIONS_ALLOW_LONG to true and let it run.
  • Using repo-id in favor of owner/repo combination
    • โš ๏ธ The api endpoints /api/repos/{owner}/{repo}/... were replaced by new endpoints using the repos id /api/repos/{repo-id}
    • To find the id of a repo use the /api/repos/lookup/{repo-full-name-with-slashes} endpoint.
    • The existing badge endpoint /api/badges/{owner}/{repo} will still work, but whenever possible try to use the new endpoint using the repo-id: /api/badges/{repo-id}.
    • The UI urls for a repository changed from /repos/{owner}/{repo}/... to /repos/{repo-id}/.... You will be redirected automatically when using the old url.
    • The woodpecker-go api-client is now using the repo-id instead of owner/repo for all functions
  • Using org-id in favour of owner name
    • โš ๏ธ The api endpoints /api/orgs/{owner}/... were replaced by new endpoints using the orgs id /api/repos/{org-id}
    • To find the id of orgs use the /api/orgs/lookup/{org_full_name} endpoint.
    • The UI urls for a organization changed from /org/{owner}/... to /orgs/{org-id}/.... You will be redirected automatically when using the old url.
    • The woodpecker-go api-client is now using the org-id instead of org name for all functions
  • The command: field has been removed from steps. If you were using it, please check if the entrypoint of the image you used is a shell.
    • If it is a shell, simply rename command: to commands:.
    • If it's not, you need to prepend the entrypoint before and also rename it (e.g., commands: <entrypoint> <cmd>).

0.15.0โ€‹

  • Default value for custom pipeline path is now empty / un-set which results in following resolution:

    .woodpecker/*.yml -> .woodpecker.yml -> .drone.yml

    Only projects created after updating will have an empty value by default. Existing projects will stick to the current pipeline path which is .drone.yml in most cases.

    Read more about it at the Project Settings

  • From version 0.15.0 ongoing there will be three types of docker images: latest, next and x.x.x with an alpine variant for each type like latest-alpine. If you used latest before to try pre-release features you should switch to next after this release.

  • Dropped support for DRONE_* environment variables. The according WOODPECKER_* variables must be used instead. Additionally some alternative namings have been removed to simplify maintenance:

    • WOODPECKER_AGENT_SECRET replaces WOODPECKER_SECRET, DRONE_SECRET, WOODPECKER_PASSWORD, DRONE_PASSWORD and DRONE_AGENT_SECRET.
    • WOODPECKER_HOST replaces DRONE_HOST and DRONE_SERVER_HOST.
    • WOODPECKER_DATABASE_DRIVER replaces DRONE_DATABASE_DRIVER and DATABASE_DRIVER.
    • WOODPECKER_DATABASE_DATASOURCE replaces DRONE_DATABASE_DATASOURCE and DATABASE_CONFIG.
  • Dropped support for DRONE_* environment variables in pipeline steps. Pipeline meta-data can be accessed with CI_* variables.

    • CI_* prefix replaces DRONE_*
    • CI value is now woodpecker
    • DRONE=true has been removed
    • Some variables got deprecated and will be removed in future versions. Please migrate to the new names. Same applies for DRONE_ of them.
      • CI_ARCH => use CI_SYSTEM_ARCH
      • CI_COMMIT => CI_COMMIT_SHA
      • CI_TAG => CI_COMMIT_TAG
      • CI_PULL_REQUEST => CI_COMMIT_PULL_REQUEST
      • CI_REMOTE_URL => use CI_REPO_REMOTE
      • CI_REPO_BRANCH => use CI_REPO_DEFAULT_BRANCH
      • CI_PARENT_BUILD_NUMBER => use CI_BUILD_PARENT
      • CI_BUILD_TARGET => use CI_BUILD_DEPLOY_TARGET
      • CI_DEPLOY_TO => use CI_BUILD_DEPLOY_TARGET
      • CI_COMMIT_AUTHOR_NAME => use CI_COMMIT_AUTHOR
      • CI_PREV_COMMIT_AUTHOR_NAME => use CI_PREV_COMMIT_AUTHOR
      • CI_SYSTEM => use CI_SYSTEM_NAME
      • CI_BRANCH => use CI_COMMIT_BRANCH
      • CI_SOURCE_BRANCH => use CI_COMMIT_SOURCE_BRANCH
      • CI_TARGET_BRANCH => use CI_COMMIT_TARGET_BRANCH

    For all available variables and their descriptions have a look at built-in-environment-variables.

  • Prometheus metrics have been changed from drone_* to woodpecker_*

  • Base path has moved from /var/lib/drone to /var/lib/woodpecker

  • Default workspace base path has moved from /drone to /woodpecker

  • Default SQLite database location has changed:

    • /var/lib/drone/drone.sqlite -> /var/lib/woodpecker/woodpecker.sqlite
    • drone.sqlite -> woodpecker.sqlite
  • Plugin Settings moved into settings section:

     steps:
    something:
    image: my/plugin
    - setting1: foo
    - setting2: bar
    + settings:
    + setting1: foo
    + setting2: bar
  • WOODPECKER_DEBUG option for server and agent got removed in favor of WOODPECKER_LOG_LEVEL=debug

  • Remove unused server flags which can safely be removed from your server config: WOODPECKER_QUIC, WOODPECKER_GITHUB_SCOPE, WOODPECKER_GITHUB_GIT_USERNAME, WOODPECKER_GITHUB_GIT_PASSWORD, WOODPECKER_GITHUB_PRIVATE_MODE, WOODPECKER_GITEA_GIT_USERNAME, WOODPECKER_GITEA_GIT_PASSWORD, WOODPECKER_GITEA_PRIVATE_MODE, WOODPECKER_GITLAB_GIT_USERNAME, WOODPECKER_GITLAB_GIT_PASSWORD, WOODPECKER_GITLAB_PRIVATE_MODE

  • Dropped support for manually setting the agents platform with WOODPECKER_PLATFORM. The platform is now automatically detected.

  • Use WOODPECKER_STATUS_CONTEXT instead of the deprecated options WOODPECKER_GITHUB_CONTEXT and WOODPECKER_GITEA_CONTEXT.

0.14.0โ€‹

No breaking changes

From Droneโ€‹

warning

Migration from Drone is only possible if you were running Drone <= v0.8.

  1. Make sure you are already running Drone v0.8
  2. Upgrade to Woodpecker v0.14.4, migration will be done during startup
  3. Upgrade to the latest Woodpecker version. Pay attention to the breaking changes listed above.