mirror of
https://github.com/woodpecker-ci/woodpecker.git
synced 2025-01-24 08:08:38 +00:00
cspell lint docs (#3787)
Co-authored-by: qwerty287 <80460567+qwerty287@users.noreply.github.com>
This commit is contained in:
parent
251129a29c
commit
c8411d7f83
41 changed files with 177 additions and 100 deletions
70
.cspell.json
70
.cspell.json
|
@ -6,27 +6,31 @@
|
||||||
"en_us",
|
"en_us",
|
||||||
// code
|
// code
|
||||||
"go",
|
"go",
|
||||||
"node",
|
"node"
|
||||||
// package names
|
|
||||||
"npm"
|
|
||||||
],
|
],
|
||||||
"words": [
|
"words": [
|
||||||
"abool",
|
"abool",
|
||||||
"anbraten",
|
"anbraten",
|
||||||
"antfu",
|
"antfu",
|
||||||
"apimachinery",
|
"apimachinery",
|
||||||
|
"Archlinux",
|
||||||
"autoincr",
|
"autoincr",
|
||||||
"autoscaler",
|
"autoscaler",
|
||||||
|
"backporting",
|
||||||
|
"backports",
|
||||||
"binutils",
|
"binutils",
|
||||||
"bitbucketdatacenter",
|
"bitbucketdatacenter",
|
||||||
"Boguslawski",
|
"Boguslawski",
|
||||||
"bradrydzewski",
|
"bradrydzewski",
|
||||||
"BUILDPLATFORM",
|
"BUILDPLATFORM",
|
||||||
"buildx",
|
"buildx",
|
||||||
|
"caddyfile",
|
||||||
"ccmenu",
|
"ccmenu",
|
||||||
"certmagic",
|
"certmagic",
|
||||||
"charmbracelet",
|
"charmbracelet",
|
||||||
|
"cicd",
|
||||||
"ciphertext",
|
"ciphertext",
|
||||||
|
"Cloudron",
|
||||||
"Codeberg",
|
"Codeberg",
|
||||||
"compatiblelicenses",
|
"compatiblelicenses",
|
||||||
"corepack",
|
"corepack",
|
||||||
|
@ -38,6 +42,8 @@
|
||||||
"Debugf",
|
"Debugf",
|
||||||
"desaturate",
|
"desaturate",
|
||||||
"devx",
|
"devx",
|
||||||
|
"dind",
|
||||||
|
"Dockle",
|
||||||
"doublestar",
|
"doublestar",
|
||||||
"envsubst",
|
"envsubst",
|
||||||
"errgroup",
|
"errgroup",
|
||||||
|
@ -46,16 +52,21 @@
|
||||||
"excalidraw",
|
"excalidraw",
|
||||||
"favicons",
|
"favicons",
|
||||||
"Fediverse",
|
"Fediverse",
|
||||||
|
"Feishu",
|
||||||
"Fogas",
|
"Fogas",
|
||||||
"forbidigo",
|
"forbidigo",
|
||||||
"Forgejo",
|
"Forgejo",
|
||||||
"fsnotify",
|
"fsnotify",
|
||||||
|
"Geeklab",
|
||||||
"Georgiana",
|
"Georgiana",
|
||||||
"gitea",
|
"gitea",
|
||||||
|
"gitmodules",
|
||||||
"GOARCH",
|
"GOARCH",
|
||||||
"GOBIN",
|
"GOBIN",
|
||||||
"gocritic",
|
"gocritic",
|
||||||
"GODEBUG",
|
"GODEBUG",
|
||||||
|
"godoc",
|
||||||
|
"Gogs",
|
||||||
"golangci",
|
"golangci",
|
||||||
"gomod",
|
"gomod",
|
||||||
"gonic",
|
"gonic",
|
||||||
|
@ -63,6 +74,8 @@
|
||||||
"HEALTHCHECK",
|
"HEALTHCHECK",
|
||||||
"healthz",
|
"healthz",
|
||||||
"Hetzner",
|
"Hetzner",
|
||||||
|
"HETZNERCLOUD",
|
||||||
|
"homelab",
|
||||||
"HTMLURL",
|
"HTMLURL",
|
||||||
"HTTPFS",
|
"HTTPFS",
|
||||||
"httpsig",
|
"httpsig",
|
||||||
|
@ -70,40 +83,56 @@
|
||||||
"httputil",
|
"httputil",
|
||||||
"ianvs",
|
"ianvs",
|
||||||
"iconify",
|
"iconify",
|
||||||
|
"inetutils",
|
||||||
|
"Infima",
|
||||||
"Infof",
|
"Infof",
|
||||||
"Informatyka",
|
"Informatyka",
|
||||||
"intlify",
|
"intlify",
|
||||||
"Ionescu",
|
"Ionescu",
|
||||||
|
"Jetpack",
|
||||||
"Kaniko",
|
"Kaniko",
|
||||||
"Keyfunc",
|
"Keyfunc",
|
||||||
"kyvg",
|
"kyvg",
|
||||||
"LASTEXITCODE",
|
"LASTEXITCODE",
|
||||||
"Laszlo",
|
"Laszlo",
|
||||||
"laszlocph",
|
"laszlocph",
|
||||||
|
"letsencrypt",
|
||||||
|
"loadbalancer",
|
||||||
"logfile",
|
"logfile",
|
||||||
"loglevel",
|
"loglevel",
|
||||||
"LONGBLOB",
|
"LONGBLOB",
|
||||||
"LONGTEXT",
|
"LONGTEXT",
|
||||||
|
"lonix1",
|
||||||
"mapstructure",
|
"mapstructure",
|
||||||
"markdownlint",
|
"markdownlint",
|
||||||
|
"mdbook",
|
||||||
"memswap",
|
"memswap",
|
||||||
"Metas",
|
"Metas",
|
||||||
"mhmxs",
|
"mhmxs",
|
||||||
"moby",
|
"moby",
|
||||||
"Msgf",
|
"Msgf",
|
||||||
|
"mstruebing",
|
||||||
"multiarch",
|
"multiarch",
|
||||||
"multierr",
|
"multierr",
|
||||||
"netdns",
|
"netdns",
|
||||||
"Netrc",
|
"Netrc",
|
||||||
|
"Nextcloud",
|
||||||
"nfpm",
|
"nfpm",
|
||||||
"nixos",
|
"nixos",
|
||||||
|
"nixpkgs",
|
||||||
"nocolor",
|
"nocolor",
|
||||||
"nolint",
|
"nolint",
|
||||||
"norunningpipelines",
|
"norunningpipelines",
|
||||||
"nosniff",
|
"nosniff",
|
||||||
|
"ntfy",
|
||||||
"octocat",
|
"octocat",
|
||||||
|
"opensource",
|
||||||
|
"Pacman",
|
||||||
|
"picus",
|
||||||
"Pinia",
|
"Pinia",
|
||||||
"pkce",
|
"pkce",
|
||||||
|
"pnpx",
|
||||||
|
"Polyform",
|
||||||
"posix",
|
"posix",
|
||||||
"ppid",
|
"ppid",
|
||||||
"Println",
|
"Println",
|
||||||
|
@ -123,6 +152,7 @@
|
||||||
"repology",
|
"repology",
|
||||||
"reslimit",
|
"reslimit",
|
||||||
"Reviewdog",
|
"Reviewdog",
|
||||||
|
"Rieter",
|
||||||
"riscv",
|
"riscv",
|
||||||
"rundll32",
|
"rundll32",
|
||||||
"Rydzewski",
|
"Rydzewski",
|
||||||
|
@ -131,11 +161,15 @@
|
||||||
"securecookie",
|
"securecookie",
|
||||||
"sess",
|
"sess",
|
||||||
"shellescape",
|
"shellescape",
|
||||||
|
"Sonatype",
|
||||||
"SSHURL",
|
"SSHURL",
|
||||||
|
"sslmode",
|
||||||
"stepbuilder",
|
"stepbuilder",
|
||||||
"stretchr",
|
"stretchr",
|
||||||
|
"structs",
|
||||||
"sublicensable",
|
"sublicensable",
|
||||||
"swaggo",
|
"swaggo",
|
||||||
|
"syscalls",
|
||||||
"TARGETARCH",
|
"TARGETARCH",
|
||||||
"TARGETOS",
|
"TARGETOS",
|
||||||
"techknowlogick",
|
"techknowlogick",
|
||||||
|
@ -143,38 +177,47 @@
|
||||||
"threadcreate",
|
"threadcreate",
|
||||||
"tink",
|
"tink",
|
||||||
"tinycolor",
|
"tinycolor",
|
||||||
|
"tmole",
|
||||||
"tmpfs",
|
"tmpfs",
|
||||||
"tmpl",
|
"tmpl",
|
||||||
"tolerations",
|
"tolerations",
|
||||||
|
"Traefik",
|
||||||
"tseslint",
|
"tseslint",
|
||||||
"ttlcache",
|
"ttlcache",
|
||||||
|
"Tunnelmole",
|
||||||
"typecheck",
|
"typecheck",
|
||||||
"Typeflag",
|
"Typeflag",
|
||||||
"unplugin",
|
"unplugin",
|
||||||
"Upsert",
|
"Upsert",
|
||||||
"urfave",
|
"urfave",
|
||||||
|
"usecase",
|
||||||
"varchar",
|
"varchar",
|
||||||
"varz",
|
"varz",
|
||||||
|
"Vieter",
|
||||||
|
"virtualisation",
|
||||||
|
"vite",
|
||||||
"vueuse",
|
"vueuse",
|
||||||
"waivable",
|
"waivable",
|
||||||
"Warnf",
|
"Warnf",
|
||||||
|
"webhookd",
|
||||||
"Weblate",
|
"Weblate",
|
||||||
"windi",
|
"windi",
|
||||||
"windicss",
|
"windicss",
|
||||||
"woodpeckerci",
|
"woodpeckerci",
|
||||||
"WORKDIR",
|
"WORKDIR",
|
||||||
"Wrapf",
|
"Wrapf",
|
||||||
|
"x-enum-varnames",
|
||||||
"xlink",
|
"xlink",
|
||||||
"xlog",
|
"xlog",
|
||||||
"xorm",
|
"xorm",
|
||||||
"xormigrate",
|
"xormigrate",
|
||||||
"xyaml",
|
"xyaml",
|
||||||
"yamls",
|
"yamls",
|
||||||
|
"Yuno",
|
||||||
"zerolog",
|
"zerolog",
|
||||||
"zerologger"
|
"zerologger"
|
||||||
],
|
],
|
||||||
"ignorePaths": [
|
"ignorePaths": [
|
||||||
"**/node_modules/**/*",
|
|
||||||
"*.excalidraw",
|
"*.excalidraw",
|
||||||
"*.svg",
|
"*.svg",
|
||||||
"*_test.go",
|
"*_test.go",
|
||||||
|
@ -185,19 +228,26 @@
|
||||||
".vscode/extensions.json",
|
".vscode/extensions.json",
|
||||||
"CHANGELOG.md",
|
"CHANGELOG.md",
|
||||||
"Makefile",
|
"Makefile",
|
||||||
"flake.lock",
|
|
||||||
"flake.nix",
|
"flake.nix",
|
||||||
"go.mod",
|
"go.mod",
|
||||||
"go.sum",
|
|
||||||
"pipeline/rpc/proto/woodpecker.pb.go",
|
"pipeline/rpc/proto/woodpecker.pb.go",
|
||||||
"pnpm-lock.yaml",
|
|
||||||
"server/store/datastore/migration/**/*",
|
"server/store/datastore/migration/**/*",
|
||||||
"web/components.d.ts",
|
"web/components.d.ts",
|
||||||
"web/src/assets/locales/**/*",
|
"web/src/assets/locales/**/*",
|
||||||
"**/fixtures/**",
|
"**/fixtures/**",
|
||||||
"**/testdata/**",
|
"**/testdata/**",
|
||||||
|
"docs/versioned_docs/",
|
||||||
|
"package.json",
|
||||||
|
"91-migrations.md",
|
||||||
|
// generated
|
||||||
|
"go.sum",
|
||||||
|
"flake.lock",
|
||||||
|
"pnpm-lock.yaml",
|
||||||
|
"**/node_modules/**/*",
|
||||||
|
"cmd/server/docs/docs.go",
|
||||||
// TODO: remove the following
|
// TODO: remove the following
|
||||||
"docs/"
|
"docs/**/*.js",
|
||||||
|
"docs/**/*.ts"
|
||||||
],
|
],
|
||||||
// Exclude imports, because they are also strings.
|
// Exclude imports, because they are also strings.
|
||||||
"ignoreRegExpList": [
|
"ignoreRegExpList": [
|
||||||
|
@ -210,7 +260,9 @@
|
||||||
// ignore nolint directive
|
// ignore nolint directive
|
||||||
"//\\s*nolint:.*",
|
"//\\s*nolint:.*",
|
||||||
// ignore docker image names
|
// ignore docker image names
|
||||||
"\\s*docker\\.io/.*"
|
"\\s*docker\\.io/.*",
|
||||||
|
// ignore inline svg in css
|
||||||
|
"\\s*url\\(\"data:image/svg\\+xml.*"
|
||||||
],
|
],
|
||||||
"enableFiletypes": ["dockercompose"]
|
"enableFiletypes": ["dockercompose"]
|
||||||
}
|
}
|
||||||
|
|
|
@ -45,7 +45,7 @@ NUMBER STATUS EVENT BRANCH COMMIT AUTHO
|
||||||
42 success push
|
42 success push
|
||||||
```
|
```
|
||||||
|
|
||||||
In addition especially useful for programmtic usage there is a `go-template` output format which will output the data using the provided go template like this:
|
In addition especially useful for programmatic usage there is a `go-template` output format which will output the data using the provided go template like this:
|
||||||
|
|
||||||
```bash
|
```bash
|
||||||
########
|
########
|
||||||
|
|
|
@ -17,7 +17,7 @@ checks, tests and routines along the way. A typical pipeline might include the f
|
||||||
|
|
||||||
If you are already using containers in your daily workflow, you'll for sure love Woodpecker. If not yet, you'll be amazed how easy it is to get started with [containers](https://opencontainers.org/).
|
If you are already using containers in your daily workflow, you'll for sure love Woodpecker. If not yet, you'll be amazed how easy it is to get started with [containers](https://opencontainers.org/).
|
||||||
|
|
||||||
## Already have access to a Woodpecker instace?
|
## Already have access to a Woodpecker instance?
|
||||||
|
|
||||||
Then you might want to jump directly into it and [start creating your first pipelines](../20-usage/10-intro.md).
|
Then you might want to jump directly into it and [start creating your first pipelines](../20-usage/10-intro.md).
|
||||||
|
|
||||||
|
|
|
@ -61,7 +61,7 @@ You can use any image from registries like the [Docker Hub](https://hub.docker.c
|
||||||
steps:
|
steps:
|
||||||
- name: build
|
- name: build
|
||||||
- image: debian
|
- image: debian
|
||||||
+ image: mycompany/image-with-awscli
|
+ image: my-company/image-with-aws_cli
|
||||||
commands:
|
commands:
|
||||||
- aws help
|
- aws help
|
||||||
```
|
```
|
||||||
|
|
|
@ -201,7 +201,7 @@ Some of the steps may be allowed to fail without causing the whole workflow and
|
||||||
|
|
||||||
### `when` - Conditional Execution
|
### `when` - Conditional Execution
|
||||||
|
|
||||||
Woodpecker supports defining a list of conditions for a step by using a `when` block. If at least one of the conditions in the `when` block evaluate to true the step is executed, otherwise it is skipped. A condition is evaluated to true if _all_ subconditions are true.
|
Woodpecker supports defining a list of conditions for a step by using a `when` block. If at least one of the conditions in the `when` block evaluate to true the step is executed, otherwise it is skipped. A condition is evaluated to true if _all_ sub-conditions are true.
|
||||||
A condition can be a check like:
|
A condition can be a check like:
|
||||||
|
|
||||||
```diff
|
```diff
|
||||||
|
@ -220,7 +220,7 @@ A condition can be a check like:
|
||||||
The `slack` step is executed if one of these conditions is met:
|
The `slack` step is executed if one of these conditions is met:
|
||||||
|
|
||||||
1. The pipeline is executed from a pull request in the repo `test/test`
|
1. The pipeline is executed from a pull request in the repo `test/test`
|
||||||
2. The pipeline is executed from a push to `maiǹ`
|
2. The pipeline is executed from a push to `main`
|
||||||
|
|
||||||
#### `repo`
|
#### `repo`
|
||||||
|
|
||||||
|
|
|
@ -105,7 +105,7 @@ Create the secrets and limit to a set of images:
|
||||||
woodpecker-cli secret add \
|
woodpecker-cli secret add \
|
||||||
-repository octocat/hello-world \
|
-repository octocat/hello-world \
|
||||||
+ -image plugins/s3 \
|
+ -image plugins/s3 \
|
||||||
+ -image peloton/woodpecker-ecs \
|
+ -image woodpeckerci/plugin-ecs \
|
||||||
-name aws_access_key_id \
|
-name aws_access_key_id \
|
||||||
-value <value>
|
-value <value>
|
||||||
```
|
```
|
||||||
|
|
|
@ -32,8 +32,8 @@ Example registry hostname matching logic:
|
||||||
- Hostname `gcr.io` matches image `gcr.io/foo/bar`
|
- Hostname `gcr.io` matches image `gcr.io/foo/bar`
|
||||||
- Hostname `docker.io` matches `golang`
|
- Hostname `docker.io` matches `golang`
|
||||||
- Hostname `docker.io` matches `library/golang`
|
- Hostname `docker.io` matches `library/golang`
|
||||||
- Hostname `docker.io` matches `bradyrydzewski/golang`
|
- Hostname `docker.io` matches `bradrydzewski/golang`
|
||||||
- Hostname `docker.io` matches `bradyrydzewski/golang:latest`
|
- Hostname `docker.io` matches `bradrydzewski/golang:latest`
|
||||||
|
|
||||||
:::note
|
:::note
|
||||||
The flow above doesn't work in Kubernetes. There is [workaround](../30-administration/22-backends/40-kubernetes.md#images-from-private-registries).
|
The flow above doesn't work in Kubernetes. There is [workaround](../30-administration/22-backends/40-kubernetes.md#images-from-private-registries).
|
||||||
|
|
|
@ -10,7 +10,7 @@ These are passed to your plugin as uppercase env vars with a `PLUGIN_` prefix.
|
||||||
Using a setting like `url` results in an env var named `PLUGIN_URL`.
|
Using a setting like `url` results in an env var named `PLUGIN_URL`.
|
||||||
|
|
||||||
Characters like `-` are converted to an underscore (`_`). `some_String` gets `PLUGIN_SOME_STRING`.
|
Characters like `-` are converted to an underscore (`_`). `some_String` gets `PLUGIN_SOME_STRING`.
|
||||||
CamelCase is not respected, `anInt` get `PLUGIN_ANINT`.
|
CamelCase is not respected, `anInt` get `PLUGIN_ANINT`. <!-- cspell:ignore ANINT -->
|
||||||
|
|
||||||
### Basic settings
|
### Basic settings
|
||||||
|
|
||||||
|
|
|
@ -1,11 +1,12 @@
|
||||||
# Plugins
|
# Plugins
|
||||||
|
|
||||||
Plugins are pipeline steps that perform pre-defined tasks and are configured as steps in your pipeline. Plugins can be used to deploy code, publish artifacts, send notification, and more.
|
Plugins are pipeline steps that perform pre-defined tasks and are configured as steps in your pipeline.
|
||||||
|
Plugins can be used to deploy code, publish artifacts, send notification, and more.
|
||||||
|
|
||||||
They are automatically pulled from the default container registry the agent's have configured.
|
They are automatically pulled from the default container registry the agent's have configured.
|
||||||
|
|
||||||
```dockerfile title="Dockerfile"
|
```dockerfile title="Dockerfile"
|
||||||
FROM laszlocloud/kubectl
|
FROM cloud/kubectl
|
||||||
COPY deploy /usr/local/deploy
|
COPY deploy /usr/local/deploy
|
||||||
ENTRYPOINT ["/usr/local/deploy"]
|
ENTRYPOINT ["/usr/local/deploy"]
|
||||||
```
|
```
|
||||||
|
@ -17,7 +18,7 @@ kubectl apply -f $PLUGIN_TEMPLATE
|
||||||
```yaml title=".woodpecker.yaml"
|
```yaml title=".woodpecker.yaml"
|
||||||
steps:
|
steps:
|
||||||
- name: deploy-to-k8s
|
- name: deploy-to-k8s
|
||||||
image: laszlocloud/my-k8s-plugin
|
image: cloud/my-k8s-plugin
|
||||||
settings:
|
settings:
|
||||||
template: config/k8s/service.yaml
|
template: config/k8s/service.yaml
|
||||||
```
|
```
|
||||||
|
@ -49,9 +50,9 @@ steps:
|
||||||
Plugins are just pipeline steps. They share the build workspace, mounted as a volume, and therefore have access to your source tree.
|
Plugins are just pipeline steps. They share the build workspace, mounted as a volume, and therefore have access to your source tree.
|
||||||
While normal steps are all about arbitrary code execution, plugins should only allow the functions intended by the plugin author.
|
While normal steps are all about arbitrary code execution, plugins should only allow the functions intended by the plugin author.
|
||||||
|
|
||||||
So there are a few limitations, like the workspace base is always mounted at `/woodpecker`, but the working directory is dynamically adjusted acordingly. So as user of a plugin you should not have to care about this.
|
So there are a few limitations, like the workspace base is always mounted at `/woodpecker`, but the working directory is dynamically adjusted accordingly. So as user of a plugin you should not have to care about this.
|
||||||
|
|
||||||
Also instead of using environment variables the plugin should only care about one prefixed with `PLUGIN_` witch are the internaml representation of the **settings** ([read more](./20-creating-plugins.md)).
|
Also instead of using environment variables the plugin should only care about one prefixed with `PLUGIN_` witch are the internal representation of the **settings** ([read more](./20-creating-plugins.md)).
|
||||||
|
|
||||||
## Finding Plugins
|
## Finding Plugins
|
||||||
|
|
||||||
|
|
|
@ -110,5 +110,5 @@ steps:
|
||||||
commands:
|
commands:
|
||||||
- ( apt update && apt dist-upgrade -y && apt install -y mysql-client 2>&1 )> /dev/null
|
- ( apt update && apt dist-upgrade -y && apt install -y mysql-client 2>&1 )> /dev/null
|
||||||
- sleep 30s # need to wait for mysql-server init
|
- sleep 30s # need to wait for mysql-server init
|
||||||
- echo 'SHOW VARIABLES LIKE "version"' | mysql -uroot -hdatabase test -pexample
|
- echo 'SHOW VARIABLES LIKE "version"' | mysql -u root -h database test -p example
|
||||||
```
|
```
|
||||||
|
|
|
@ -97,7 +97,7 @@ steps:
|
||||||
### References
|
### References
|
||||||
|
|
||||||
- [Official YAML specification](https://yaml.org/spec/1.2.2/#3222-anchors-and-aliases)
|
- [Official YAML specification](https://yaml.org/spec/1.2.2/#3222-anchors-and-aliases)
|
||||||
- [YAML Cheatsheet](https://learnxinyminutes.com/docs/yaml)
|
- [YAML cheat sheet](https://learnxinyminutes.com/docs/yaml)
|
||||||
|
|
||||||
## Persisting environment data between steps
|
## Persisting environment data between steps
|
||||||
|
|
||||||
|
|
|
@ -1,4 +1,4 @@
|
||||||
# Gettings started
|
# Getting started
|
||||||
|
|
||||||
A Woodpecker deployment consists of two parts:
|
A Woodpecker deployment consists of two parts:
|
||||||
|
|
||||||
|
@ -45,7 +45,7 @@ By default Woodpecker uses a SQLite database which requires zero installation or
|
||||||
|
|
||||||
## Forge
|
## Forge
|
||||||
|
|
||||||
What would be a CI/CD system without any code? By connecting Woodpecker to your [forge](../20-usage/15-terminology/index.md) like GitHub or Gitea you can start running pipelines on events like pushes or pull requests. Woodpecker will also use your forge for authentication and to report back the status of your pipelines. See the [forge settings](./11-forges/11-overview.md) to conntect it to Woodpecker.
|
What would be a CI/CD system without any code? By connecting Woodpecker to your [forge](../20-usage/15-terminology/index.md) like GitHub or Gitea you can start running pipelines on events like pushes or pull requests. Woodpecker will also use your forge for authentication and to report back the status of your pipelines. See the [forge settings](./11-forges/11-overview.md) to connect it to Woodpecker.
|
||||||
|
|
||||||
## Configuration
|
## Configuration
|
||||||
|
|
||||||
|
|
|
@ -3,7 +3,7 @@
|
||||||
We recommended to deploy Woodpecker using the [Woodpecker helm chart](https://github.com/woodpecker-ci/helm).
|
We recommended to deploy Woodpecker using the [Woodpecker helm chart](https://github.com/woodpecker-ci/helm).
|
||||||
Have a look at the [`values.yaml`](https://github.com/woodpecker-ci/helm/blob/main/charts/woodpecker/values.yaml) config files for all available settings.
|
Have a look at the [`values.yaml`](https://github.com/woodpecker-ci/helm/blob/main/charts/woodpecker/values.yaml) config files for all available settings.
|
||||||
|
|
||||||
The chart contains two subcharts, `server` and `agent` which are automatically configured as needed.
|
The chart contains two sub-charts, `server` and `agent` which are automatically configured as needed.
|
||||||
The chart started off with two independent charts but was merged into one to simplify the deployment at start of 2023.
|
The chart started off with two independent charts but was merged into one to simplify the deployment at start of 2023.
|
||||||
|
|
||||||
A couple of backend-specific config env vars exists which are described in the [kubernetes backend docs](../22-backends/40-kubernetes.md).
|
A couple of backend-specific config env vars exists which are described in the [kubernetes backend docs](../22-backends/40-kubernetes.md).
|
||||||
|
|
|
@ -10,6 +10,8 @@ In practice, the settings are specified declaratively in the NixOS configuration
|
||||||
|
|
||||||
## General Configuration
|
## General Configuration
|
||||||
|
|
||||||
|
<!-- cspell:words Optimisation -->
|
||||||
|
|
||||||
```nix
|
```nix
|
||||||
{ config
|
{ config
|
||||||
, ...
|
, ...
|
||||||
|
|
|
@ -26,14 +26,14 @@ You can **also restrict** registration, by keep registration closed and:
|
||||||
|
|
||||||
```ini
|
```ini
|
||||||
WOODPECKER_OPEN=false
|
WOODPECKER_OPEN=false
|
||||||
WOODPECKER_ADMIN=johnsmith,janedoe
|
WOODPECKER_ADMIN=john.smith,jane_doe
|
||||||
```
|
```
|
||||||
|
|
||||||
### Only allow registration of users, who are members of approved organizations
|
### Only allow registration of users, who are members of approved organizations
|
||||||
|
|
||||||
```ini
|
```ini
|
||||||
WOODPECKER_OPEN=true
|
WOODPECKER_OPEN=true
|
||||||
WOODPECKER_ORGS=dolores,dogpatch
|
WOODPECKER_ORGS=dolores,dog-patch
|
||||||
```
|
```
|
||||||
|
|
||||||
## Administrators
|
## Administrators
|
||||||
|
@ -41,7 +41,7 @@ WOODPECKER_ORGS=dolores,dogpatch
|
||||||
Administrators should also be enumerated in your configuration.
|
Administrators should also be enumerated in your configuration.
|
||||||
|
|
||||||
```ini
|
```ini
|
||||||
WOODPECKER_ADMIN=johnsmith,janedoe
|
WOODPECKER_ADMIN=john.smith,jane_doe
|
||||||
```
|
```
|
||||||
|
|
||||||
## Filtering repositories
|
## Filtering repositories
|
||||||
|
@ -51,7 +51,7 @@ Woodpecker operates with the user's OAuth permission. Due to the coarse permissi
|
||||||
Use the `WOODPECKER_REPO_OWNERS` variable to filter which GitHub user's repos should be synced only. You typically want to put here your company's GitHub name.
|
Use the `WOODPECKER_REPO_OWNERS` variable to filter which GitHub user's repos should be synced only. You typically want to put here your company's GitHub name.
|
||||||
|
|
||||||
```ini
|
```ini
|
||||||
WOODPECKER_REPO_OWNERS=mycompany,mycompanyossgithubuser
|
WOODPECKER_REPO_OWNERS=my_company,my_company_oss_github_user
|
||||||
```
|
```
|
||||||
|
|
||||||
## Global registry setting
|
## Global registry setting
|
||||||
|
@ -133,7 +133,7 @@ The examples below show how to place a banner message in the top navigation bar
|
||||||
### `woodpecker.js`
|
### `woodpecker.js`
|
||||||
|
|
||||||
```javascript
|
```javascript
|
||||||
// place/copy a minified version of jQuery or ZeptoJS here ...
|
// place/copy a minified version of your preferred lightweight JavaScript library here ...
|
||||||
!(function () {
|
!(function () {
|
||||||
'use strict';
|
'use strict';
|
||||||
function e() {} /*...*/
|
function e() {} /*...*/
|
||||||
|
@ -305,7 +305,7 @@ Example: `org1,org2`
|
||||||
|
|
||||||
> Default: empty
|
> Default: empty
|
||||||
|
|
||||||
Comma-separated list of syncable repo owners. ???
|
Repositories by those owners will be allowed to be used in woodpecker.
|
||||||
|
|
||||||
Example: `user1,user2`
|
Example: `user1,user2`
|
||||||
|
|
||||||
|
|
|
@ -35,7 +35,10 @@ Woodpecker uses `git+https` to clone repositories, however, Bitbucket Server doe
|
||||||
|
|
||||||
## Registration
|
## Registration
|
||||||
|
|
||||||
Woodpecker must be registered with Bitbucket Datacenter / Server. In the administration section of Bitbucket choose "Application Links" and then "Create link". Woodpecker should be listed as "External Application" and the direction should be set to "Incomming". Note the client id and client secret of the registration to be used in the configuration of Woodpecker.
|
Woodpecker must be registered with Bitbucket Datacenter / Server.
|
||||||
|
In the administration section of Bitbucket choose "Application Links" and then "Create link".
|
||||||
|
Woodpecker should be listed as "External Application" and the direction should be set to "Incoming".
|
||||||
|
Note the client id and client secret of the registration to be used in the configuration of Woodpecker.
|
||||||
|
|
||||||
See also [Configure an incoming link](https://confluence.atlassian.com/bitbucketserver/configure-an-incoming-link-1108483657.html).
|
See also [Configure an incoming link](https://confluence.atlassian.com/bitbucketserver/configure-an-incoming-link-1108483657.html).
|
||||||
|
|
||||||
|
|
|
@ -32,6 +32,8 @@ The following commands **are destructive** and **irreversible** it is highly rec
|
||||||
|
|
||||||
### Remove all unused images
|
### Remove all unused images
|
||||||
|
|
||||||
|
<!-- cspell:ignore trunc -->
|
||||||
|
|
||||||
```bash
|
```bash
|
||||||
docker image rm $(docker images --filter "dangling=true" -q --no-trunc)
|
docker image rm $(docker images --filter "dangling=true" -q --no-trunc)
|
||||||
```
|
```
|
||||||
|
|
|
@ -107,7 +107,7 @@ steps:
|
||||||
limits:
|
limits:
|
||||||
memory: 256Mi
|
memory: 256Mi
|
||||||
nodeSelector:
|
nodeSelector:
|
||||||
beta.kubernetes.io/instance-type: p3.8xlarge
|
beta.kubernetes.io/instance-type: Standard_D2_v3
|
||||||
tolerations:
|
tolerations:
|
||||||
- key: 'key1'
|
- key: 'key1'
|
||||||
operator: 'Equal'
|
operator: 'Equal'
|
||||||
|
@ -156,6 +156,8 @@ Note that the `backend_options.kubernetes.securityContext` object allows you to
|
||||||
By default, the properties will be set at the Pod level. Properties that are only supported on the container level will be set there instead. So, the
|
By default, the properties will be set at the Pod level. Properties that are only supported on the container level will be set there instead. So, the
|
||||||
configuration shown above will result in something like the following Pod spec:
|
configuration shown above will result in something like the following Pod spec:
|
||||||
|
|
||||||
|
<!-- cspell:disable -->
|
||||||
|
|
||||||
```yaml
|
```yaml
|
||||||
kind: Pod
|
kind: Pod
|
||||||
spec:
|
spec:
|
||||||
|
@ -170,7 +172,9 @@ spec:
|
||||||
[...]
|
[...]
|
||||||
```
|
```
|
||||||
|
|
||||||
You can also restrict a container's syscalls with [seccomp](https://kubernetes.io/docs/tutorials/security/seccomp/) profile
|
<!-- cspell:enable -->
|
||||||
|
|
||||||
|
You can also restrict a syscalls of containers with [seccomp](https://kubernetes.io/docs/tutorials/security/seccomp/) profile.
|
||||||
|
|
||||||
```yaml
|
```yaml
|
||||||
backend_options:
|
backend_options:
|
||||||
|
@ -230,7 +234,8 @@ See [this issue](https://github.com/woodpecker-ci/woodpecker/issues/2510) for mo
|
||||||
|
|
||||||
### `KUBERNETES_SERVICE_HOST` environment variable
|
### `KUBERNETES_SERVICE_HOST` environment variable
|
||||||
|
|
||||||
Like the below env vars used for configuration, this can be set in the environment fonfiguration of the agent. It configures the address of the Kubernetes API server to connect to.
|
Like the below env vars used for configuration, this can be set in the environment for configuration of the agent.
|
||||||
|
It configures the address of the Kubernetes API server to connect to.
|
||||||
|
|
||||||
If running the agent within Kubernetes, this will already be set and you don't have to add it manually.
|
If running the agent within Kubernetes, this will already be set and you don't have to add it manually.
|
||||||
|
|
||||||
|
@ -292,7 +297,7 @@ Determines if Pod annotations can be defined from a step's backend options.
|
||||||
|
|
||||||
Additional node selector to apply to worker pods. Must be a YAML object, e.g. `{"topology.kubernetes.io/region":"eu-central-1"}`.
|
Additional node selector to apply to worker pods. Must be a YAML object, e.g. `{"topology.kubernetes.io/region":"eu-central-1"}`.
|
||||||
|
|
||||||
### `WOODPECKER_BACKEND_K8S_SECCTX_NONROOT`
|
### `WOODPECKER_BACKEND_K8S_SECCTX_NONROOT` <!-- cspell:ignore SECCTX NONROOT -->
|
||||||
|
|
||||||
> Default: `false`
|
> Default: `false`
|
||||||
|
|
||||||
|
|
|
@ -1,6 +1,6 @@
|
||||||
# Custom backends
|
# Custom backends
|
||||||
|
|
||||||
If none of our backends fits your usecases, you can write your own.
|
If none of our backends fits your usecase, you can write your own.
|
||||||
|
|
||||||
Therefore, implement the interface `"go.woodpecker-ci.org/woodpecker/woodpecker/v2/pipeline/backend/types".Backend` and
|
Therefore, implement the interface `"go.woodpecker-ci.org/woodpecker/woodpecker/v2/pipeline/backend/types".Backend` and
|
||||||
build a custom agent using your backend with this `main.go`:
|
build a custom agent using your backend with this `main.go`:
|
||||||
|
|
|
@ -4,6 +4,8 @@
|
||||||
|
|
||||||
This guide provides a brief overview for installing Woodpecker server behind the Apache2 web-server. This is an example configuration:
|
This guide provides a brief overview for installing Woodpecker server behind the Apache2 web-server. This is an example configuration:
|
||||||
|
|
||||||
|
<!-- cspell:ignore apacheconf -->
|
||||||
|
|
||||||
```apacheconf
|
```apacheconf
|
||||||
ProxyPreserveHost On
|
ProxyPreserveHost On
|
||||||
|
|
||||||
|
@ -87,7 +89,7 @@ woodpecker.example.com {
|
||||||
}
|
}
|
||||||
|
|
||||||
# expose gRPC
|
# expose gRPC
|
||||||
woodpeckeragent.example.com {
|
woodpecker-agent.example.com {
|
||||||
reverse_proxy h2c://woodpecker-server:9000
|
reverse_proxy h2c://woodpecker-server:9000
|
||||||
}
|
}
|
||||||
```
|
```
|
||||||
|
@ -132,6 +134,8 @@ Set `WOODPECKER_HOST` to the ngrok URL (usually xxx.ngrok.io) and start the serv
|
||||||
|
|
||||||
To install the Woodpecker server behind a [Traefik](https://traefik.io/) load balancer, you must expose both the `http` and the `gRPC` ports. Here is a comprehensive example, considering you are running Traefik with docker swarm and want to do TLS termination and automatic redirection from http to https.
|
To install the Woodpecker server behind a [Traefik](https://traefik.io/) load balancer, you must expose both the `http` and the `gRPC` ports. Here is a comprehensive example, considering you are running Traefik with docker swarm and want to do TLS termination and automatic redirection from http to https.
|
||||||
|
|
||||||
|
<!-- cspell:words redirectscheme certresolver -->
|
||||||
|
|
||||||
```yaml
|
```yaml
|
||||||
version: '3.8'
|
version: '3.8'
|
||||||
|
|
||||||
|
@ -155,13 +159,13 @@ services:
|
||||||
# web server
|
# web server
|
||||||
- traefik.http.services.woodpecker-service.loadbalancer.server.port=8000
|
- traefik.http.services.woodpecker-service.loadbalancer.server.port=8000
|
||||||
|
|
||||||
- traefik.http.routers.woodpecker-secure.rule=Host(`cd.yourdomain.com`)
|
- traefik.http.routers.woodpecker-secure.rule=Host(`cd.your-domain.com`)
|
||||||
- traefik.http.routers.woodpecker-secure.tls=true
|
- traefik.http.routers.woodpecker-secure.tls=true
|
||||||
- traefik.http.routers.woodpecker-secure.tls.certresolver=letsencrypt
|
- traefik.http.routers.woodpecker-secure.tls.certresolver=letsencrypt
|
||||||
- traefik.http.routers.woodpecker-secure.entrypoints=websecure
|
- traefik.http.routers.woodpecker-secure.entrypoints=web-secure
|
||||||
- traefik.http.routers.woodpecker-secure.service=woodpecker-service
|
- traefik.http.routers.woodpecker-secure.service=woodpecker-service
|
||||||
|
|
||||||
- traefik.http.routers.woodpecker.rule=Host(`cd.yourdomain.com`)
|
- traefik.http.routers.woodpecker.rule=Host(`cd.your-domain.com`)
|
||||||
- traefik.http.routers.woodpecker.entrypoints=web
|
- traefik.http.routers.woodpecker.entrypoints=web
|
||||||
- traefik.http.routers.woodpecker.service=woodpecker-service
|
- traefik.http.routers.woodpecker.service=woodpecker-service
|
||||||
|
|
||||||
|
@ -173,13 +177,13 @@ services:
|
||||||
- traefik.http.services.woodpecker-grpc.loadbalancer.server.port=9000
|
- traefik.http.services.woodpecker-grpc.loadbalancer.server.port=9000
|
||||||
- traefik.http.services.woodpecker-grpc.loadbalancer.server.scheme=h2c
|
- traefik.http.services.woodpecker-grpc.loadbalancer.server.scheme=h2c
|
||||||
|
|
||||||
- traefik.http.routers.woodpecker-grpc-secure.rule=Host(`woodpecker-grpc.yourdomain.com`)
|
- traefik.http.routers.woodpecker-grpc-secure.rule=Host(`woodpecker-grpc.your-domain.com`)
|
||||||
- traefik.http.routers.woodpecker-grpc-secure.tls=true
|
- traefik.http.routers.woodpecker-grpc-secure.tls=true
|
||||||
- traefik.http.routers.woodpecker-grpc-secure.tls.certresolver=letsencrypt
|
- traefik.http.routers.woodpecker-grpc-secure.tls.certresolver=letsencrypt
|
||||||
- traefik.http.routers.woodpecker-grpc-secure.entrypoints=websecure
|
- traefik.http.routers.woodpecker-grpc-secure.entrypoints=web-secure
|
||||||
- traefik.http.routers.woodpecker-grpc-secure.service=woodpecker-grpc
|
- traefik.http.routers.woodpecker-grpc-secure.service=woodpecker-grpc
|
||||||
|
|
||||||
- traefik.http.routers.woodpecker-grpc.rule=Host(`woodpecker-grpc.yourdomain.com`)
|
- traefik.http.routers.woodpecker-grpc.rule=Host(`woodpecker-grpc.your-domain.com`)
|
||||||
- traefik.http.routers.woodpecker-grpc.entrypoints=web
|
- traefik.http.routers.woodpecker-grpc.entrypoints=web
|
||||||
- traefik.http.routers.woodpecker-grpc.service=woodpecker-grpc
|
- traefik.http.routers.woodpecker-grpc.service=woodpecker-grpc
|
||||||
|
|
||||||
|
|
|
@ -26,7 +26,7 @@ WOODPECKER_CONFIG_SERVICE_ENDPOINT=https://example.com/ciconfig
|
||||||
"uid": "",
|
"uid": "",
|
||||||
"user_id": 0,
|
"user_id": 0,
|
||||||
"namespace": "",
|
"namespace": "",
|
||||||
"name": "woodpecker-testpipe",
|
"name": "woodpecker-test-pipe",
|
||||||
"slug": "",
|
"slug": "",
|
||||||
"scm": "git",
|
"scm": "git",
|
||||||
"git_http_url": "",
|
"git_http_url": "",
|
||||||
|
@ -54,7 +54,7 @@ WOODPECKER_CONFIG_SERVICE_ENDPOINT=https://example.com/ciconfig
|
||||||
"author_avatar": "https://myforge.com/avatars/d6b3f7787a685fcdf2a44e2c685c7e03",
|
"author_avatar": "https://myforge.com/avatars/d6b3f7787a685fcdf2a44e2c685c7e03",
|
||||||
"author_email": "my@email.com",
|
"author_email": "my@email.com",
|
||||||
"branch": "main",
|
"branch": "main",
|
||||||
"changed_files": ["somefilename.txt"],
|
"changed_files": ["some-file-name.txt"],
|
||||||
"commit": "2fff90f8d288a4640e90f05049fe30e61a14fd50",
|
"commit": "2fff90f8d288a4640e90f05049fe30e61a14fd50",
|
||||||
"created_at": 0,
|
"created_at": 0,
|
||||||
"deploy_to": "",
|
"deploy_to": "",
|
||||||
|
|
|
@ -29,8 +29,8 @@ services:
|
||||||
- WOODPECKER_MIN_AGENTS=0
|
- WOODPECKER_MIN_AGENTS=0
|
||||||
- WOODPECKER_MAX_AGENTS=3
|
- WOODPECKER_MAX_AGENTS=3
|
||||||
- WOODPECKER_WORKFLOWS_PER_AGENT=2 # the number of workflows each agent can run at the same time
|
- WOODPECKER_WORKFLOWS_PER_AGENT=2 # the number of workflows each agent can run at the same time
|
||||||
- WOODEPCKER_GRPC_ADDR=https://grpc.your-woodpecker-server.tld # the grpc address of your woodpecker server, publicly accessible from the agents
|
- WOODPECKER_GRPC_ADDR=https://grpc.your-woodpecker-server.tld # the grpc address of your woodpecker server, publicly accessible from the agents
|
||||||
- WOODEPCKER_GRPC_SECURE=true
|
- WOODPECKER_GRPC_SECURE=true
|
||||||
- WOODPECKER_AGENT_ENV= # optional environment variables to pass to the agents
|
- WOODPECKER_AGENT_ENV= # optional environment variables to pass to the agents
|
||||||
- WOODPECKER_PROVIDER=hetznercloud # set the provider, you can find all the available ones down below
|
- WOODPECKER_PROVIDER=hetznercloud # set the provider, you can find all the available ones down below
|
||||||
- WOODPECKER_HETZNERCLOUD_API_TOKEN=${WOODPECKER_HETZNERCLOUD_API_TOKEN} # your api token for the Hetzner cloud
|
- WOODPECKER_HETZNERCLOUD_API_TOKEN=${WOODPECKER_HETZNERCLOUD_API_TOKEN} # your api token for the Hetzner cloud
|
||||||
|
|
|
@ -1,4 +1,4 @@
|
||||||
# Adavanced options
|
# Advanced options
|
||||||
|
|
||||||
Why should we be happy with a default setup? We should not! Woodpecker offers a lot of advanced options to configure it to your needs.
|
Why should we be happy with a default setup? We should not! Woodpecker offers a lot of advanced options to configure it to your needs.
|
||||||
|
|
||||||
|
|
|
@ -52,11 +52,11 @@ List of Prometheus metrics specific to Woodpecker:
|
||||||
# HELP woodpecker_pipeline_count Pipeline count.
|
# HELP woodpecker_pipeline_count Pipeline count.
|
||||||
# TYPE woodpecker_pipeline_count counter
|
# TYPE woodpecker_pipeline_count counter
|
||||||
woodpecker_pipeline_count{branch="main",pipeline="total",repo="woodpecker-ci/woodpecker",status="success"} 3
|
woodpecker_pipeline_count{branch="main",pipeline="total",repo="woodpecker-ci/woodpecker",status="success"} 3
|
||||||
woodpecker_pipeline_count{branch="mkdocs",pipeline="total",repo="woodpecker-ci/woodpecker",status="success"} 3
|
woodpecker_pipeline_count{branch="dev",pipeline="total",repo="woodpecker-ci/woodpecker",status="success"} 3
|
||||||
# HELP woodpecker_pipeline_time Build time.
|
# HELP woodpecker_pipeline_time Build time.
|
||||||
# TYPE woodpecker_pipeline_time gauge
|
# TYPE woodpecker_pipeline_time gauge
|
||||||
woodpecker_pipeline_time{branch="main",pipeline="total",repo="woodpecker-ci/woodpecker",status="success"} 116
|
woodpecker_pipeline_time{branch="main",pipeline="total",repo="woodpecker-ci/woodpecker",status="success"} 116
|
||||||
woodpecker_pipeline_time{branch="mkdocs",pipeline="total",repo="woodpecker-ci/woodpecker",status="success"} 155
|
woodpecker_pipeline_time{branch="dev",pipeline="total",repo="woodpecker-ci/woodpecker",status="success"} 155
|
||||||
# HELP woodpecker_pipeline_total_count Total number of builds.
|
# HELP woodpecker_pipeline_total_count Total number of builds.
|
||||||
# TYPE woodpecker_pipeline_total_count gauge
|
# TYPE woodpecker_pipeline_total_count gauge
|
||||||
woodpecker_pipeline_total_count 1025
|
woodpecker_pipeline_total_count 1025
|
||||||
|
|
|
@ -4,12 +4,12 @@ You can develop on your local computer by following the [steps below](#preparati
|
||||||
|
|
||||||
## Gitpod
|
## Gitpod
|
||||||
|
|
||||||
If you want to start development or updating docs as easy as possible, you can use our preconfigured setup for Woodpecker using [Gitpod](https://github.com/gitpod-io/gitpod). Gitpod starts a complete development setup in the cloud containing:
|
If you want to start development or updating docs as easy as possible, you can use our pre-configured setup for Woodpecker using [Gitpod](https://github.com/gitpod-io/gitpod). Gitpod starts a complete development setup in the cloud containing:
|
||||||
|
|
||||||
- An IDE in the browser or bridged to your local VS-Code or Jetbrains
|
- An IDE in the browser or bridged to your local VS-Code or Jetbrains
|
||||||
- A preconfigured [Gitea](https://github.com/go-gitea/gitea) instance as forge
|
- A pre-configured [Gitea](https://github.com/go-gitea/gitea) instance as forge
|
||||||
- A preconfigured Woodpecker server
|
- A pre-configured Woodpecker server
|
||||||
- A single preconfigured Woodpecker agent node
|
- A single pre-configured Woodpecker agent node
|
||||||
- Our docs preview server
|
- Our docs preview server
|
||||||
|
|
||||||
Start Woodpecker in Gitpod by clicking on the following badge. You can log in with `woodpecker` and `password`.
|
Start Woodpecker in Gitpod by clicking on the following badge. You can log in with `woodpecker` and `password`.
|
||||||
|
|
|
@ -19,23 +19,23 @@
|
||||||
|
|
||||||
### Server
|
### Server
|
||||||
|
|
||||||
| package | meaning | imports |
|
| package | meaning | imports |
|
||||||
| -------------------- | ----------------------------------------------------------------------------------- | -------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------- |
|
| -------------------- | ----------------------------------------------------------------------------------- | ------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------- |
|
||||||
| `server/api/**` | handle web requests from `server/router` | `pipeline`, `../badges`, `../ccmenue`, `../logging`, `../model`, `../pubsub`, `../queue`, `../forge`, `../shared`, `../store`, `shared`, (TODO: mv `server/router/middleware/session`) |
|
| `server/api/**` | handle web requests from `server/router` | `pipeline`, `../badges`, `../ccmenu`, `../logging`, `../model`, `../pubsub`, `../queue`, `../forge`, `../shared`, `../store`, `shared`, (TODO: mv `server/router/middleware/session`) |
|
||||||
| `server/badges/**` | generate svg badges for pipelines | `../model` |
|
| `server/badges/**` | generate svg badges for pipelines | `../model` |
|
||||||
| `server/ccmenu/**` | generate xml ccmenu for pipelines | `../model` |
|
| `server/ccmenu/**` | generate xml ccmenu for pipelines | `../model` |
|
||||||
| `server/grpc/**` | gRPC server agents can connect to | `pipeline/rpc/**`, `../logging`, `../model`, `../pubsub`, `../queue`, `../forge`, `../pipeline`, `../store` |
|
| `server/grpc/**` | gRPC server agents can connect to | `pipeline/rpc/**`, `../logging`, `../model`, `../pubsub`, `../queue`, `../forge`, `../pipeline`, `../store` |
|
||||||
| `server/logging/**` | logging lib for gPRC server to stream logs while running | std |
|
| `server/logging/**` | logging lib for gPRC server to stream logs while running | std |
|
||||||
| `server/model/**` | structs for store (db) and api (json) | std |
|
| `server/model/**` | structs for store (db) and api (json) | std |
|
||||||
| `server/plugins/**` | plugins for server | `../model`, `../forge` |
|
| `server/plugins/**` | plugins for server | `../model`, `../forge` |
|
||||||
| `server/pipeline/**` | orchestrate pipelines | `pipeline`, `../model`, `../pubsub`, `../queue`, `../forge`, `../store`, `../plugins` |
|
| `server/pipeline/**` | orchestrate pipelines | `pipeline`, `../model`, `../pubsub`, `../queue`, `../forge`, `../store`, `../plugins` |
|
||||||
| `server/pubsub/**` | pubsub lib for server to push changes to the WebUI | std |
|
| `server/pubsub/**` | pubsub lib for server to push changes to the WebUI | std |
|
||||||
| `server/queue/**` | queue lib for server where agents pull new pipelines from via gRPC | `server/model` |
|
| `server/queue/**` | queue lib for server where agents pull new pipelines from via gRPC | `server/model` |
|
||||||
| `server/forge/**` | forge lib for server to connect and handle forge specific stuff | `shared`, `server/model` |
|
| `server/forge/**` | forge lib for server to connect and handle forge specific stuff | `shared`, `server/model` |
|
||||||
| `server/router/**` | handle requests to REST API (and all middleware) and serve UI and WebUI config | `shared`, `../api`, `../model`, `../forge`, `../store`, `../web` |
|
| `server/router/**` | handle requests to REST API (and all middleware) and serve UI and WebUI config | `shared`, `../api`, `../model`, `../forge`, `../store`, `../web` |
|
||||||
| `server/store/**` | handle database | `server/model` |
|
| `server/store/**` | handle database | `server/model` |
|
||||||
| `server/shared/**` | TODO: move and split [#974](https://github.com/woodpecker-ci/woodpecker/issues/974) | |
|
| `server/shared/**` | TODO: move and split [#974](https://github.com/woodpecker-ci/woodpecker/issues/974) | |
|
||||||
| `server/web/**` | server SPA | |
|
| `server/web/**` | server SPA | |
|
||||||
|
|
||||||
- `../` = `server/`
|
- `../` = `server/`
|
||||||
|
|
||||||
|
|
|
@ -7,7 +7,7 @@ and then being using on the community's website documentation.
|
||||||
|
|
||||||
It's paramount important to keep the gin handler function's godoc documentation up-to-date,
|
It's paramount important to keep the gin handler function's godoc documentation up-to-date,
|
||||||
to always have accurate API documentation.
|
to always have accurate API documentation.
|
||||||
Whenever you change, add or enhance an API endpoint, please update the godocs.
|
Whenever you change, add or enhance an API endpoint, please update the godoc.
|
||||||
|
|
||||||
You don't require any extra tools on your machine, all Swagger tooling is automatically fetched by standard Go tools.
|
You don't require any extra tools on your machine, all Swagger tooling is automatically fetched by standard Go tools.
|
||||||
|
|
||||||
|
@ -41,8 +41,8 @@ These guidelines aim to have consistent wording in the swagger doc:
|
||||||
- first word after `@Summary` and `@Summary` are always uppercase
|
- first word after `@Summary` and `@Summary` are always uppercase
|
||||||
- `@Summary` has no `.` (dot) at the end of the line
|
- `@Summary` has no `.` (dot) at the end of the line
|
||||||
- model structs shall use custom short names, to ease life for API consumers, using `@name`
|
- model structs shall use custom short names, to ease life for API consumers, using `@name`
|
||||||
- `@Success` object or array declarations shall be short, this means the actual `model.User` struct must have a `@name` annotation, so that the model can be renderend in Swagger
|
- `@Success` object or array declarations shall be short, this means the actual `model.User` struct must have a `@name` annotation, so that the model can be rendered in Swagger
|
||||||
- when pagination is used, `@Parame page` and `@Parame perPage` must be added manually
|
- when pagination is used, `@Param page` and `@Param perPage` must be added manually
|
||||||
- `@Param Authorization` is almost always present, there are just a few un-protected endpoints
|
- `@Param Authorization` is almost always present, there are just a few un-protected endpoints
|
||||||
|
|
||||||
There are many examples in the `server/api` package, which you can use a blueprint.
|
There are many examples in the `server/api` package, which you can use a blueprint.
|
||||||
|
|
|
@ -30,11 +30,13 @@ steps:
|
||||||
services:
|
services:
|
||||||
echo:
|
echo:
|
||||||
image: dummy
|
image: dummy
|
||||||
commands: echo "i am a sevice"
|
commands: echo "i am a service"
|
||||||
```
|
```
|
||||||
|
|
||||||
This could be executed via `woodpecker-cli --log-level trace exec --backend-engine dummy example.yaml`:
|
This could be executed via `woodpecker-cli --log-level trace exec --backend-engine dummy example.yaml`:
|
||||||
|
|
||||||
|
<!-- cspell:disable -->
|
||||||
|
|
||||||
```none
|
```none
|
||||||
9:18PM DBG pipeline/pipeline.go:94 > executing 2 stages, in order of: CLI=exec
|
9:18PM DBG pipeline/pipeline.go:94 > executing 2 stages, in order of: CLI=exec
|
||||||
9:18PM DBG pipeline/pipeline.go:104 > stage CLI=exec StagePos=0 Steps=echo
|
9:18PM DBG pipeline/pipeline.go:104 > stage CLI=exec StagePos=0 Steps=echo
|
||||||
|
@ -69,7 +71,9 @@ This could be executed via `woodpecker-cli --log-level trace exec --backend-engi
|
||||||
9:18PM TRC pipeline/backend/dummy/dummy.go:208 > delete workflow environment taskUUID=01J10P578JQE6E25VV1EQF0745
|
9:18PM TRC pipeline/backend/dummy/dummy.go:208 > delete workflow environment taskUUID=01J10P578JQE6E25VV1EQF0745
|
||||||
```
|
```
|
||||||
|
|
||||||
There are also environment variables to alter step behaviour:
|
<!-- cspell:enable -->
|
||||||
|
|
||||||
|
There are also environment variables to alter step behavior:
|
||||||
|
|
||||||
- `SLEEP: 10` will let the step wait 10 seconds
|
- `SLEEP: 10` will let the step wait 10 seconds
|
||||||
- `EXPECT_TYPE` allows to check if a step is a `clone`, `service`, `plugin` or `commands`
|
- `EXPECT_TYPE` allows to check if a step is a `clone`, `service`, `plugin` or `commands`
|
||||||
|
|
|
@ -17,7 +17,7 @@ checks, tests and routines along the way. A typical pipeline might include the f
|
||||||
|
|
||||||
If you are already using containers in your daily workflow, you'll for sure love Woodpecker. If not yet, you'll be amazed how easy it is to get started with [containers](https://opencontainers.org/).
|
If you are already using containers in your daily workflow, you'll for sure love Woodpecker. If not yet, you'll be amazed how easy it is to get started with [containers](https://opencontainers.org/).
|
||||||
|
|
||||||
## Already have access to a Woodpecker instace?
|
## Already have access to a Woodpecker instance?
|
||||||
|
|
||||||
Then you might want to jump directly into it and [start creating your first pipelines](../20-usage/10-intro.md).
|
Then you might want to jump directly into it and [start creating your first pipelines](../20-usage/10-intro.md).
|
||||||
|
|
||||||
|
|
|
@ -220,7 +220,7 @@ A condition can be a check like:
|
||||||
The `slack` step is executed if one of these conditions is met:
|
The `slack` step is executed if one of these conditions is met:
|
||||||
|
|
||||||
1. The pipeline is executed from a pull request in the repo `test/test`
|
1. The pipeline is executed from a pull request in the repo `test/test`
|
||||||
2. The pipeline is executed from a push to `maiǹ`
|
2. The pipeline is executed from a push to `main`
|
||||||
|
|
||||||
#### `repo`
|
#### `repo`
|
||||||
|
|
||||||
|
|
|
@ -49,9 +49,9 @@ steps:
|
||||||
Plugins are just pipeline steps. They share the build workspace, mounted as a volume, and therefore have access to your source tree.
|
Plugins are just pipeline steps. They share the build workspace, mounted as a volume, and therefore have access to your source tree.
|
||||||
While normal steps are all about arbitrary code execution, plugins should only allow the functions intended by the plugin author.
|
While normal steps are all about arbitrary code execution, plugins should only allow the functions intended by the plugin author.
|
||||||
|
|
||||||
So there are a few limitations, like the workspace base is always mounted at `/woodpecker`, but the working directory is dynamically adjusted acordingly. So as user of a plugin you should not have to care about this.
|
So there are a few limitations, like the workspace base is always mounted at `/woodpecker`, but the working directory is dynamically adjusted accordingly. So as user of a plugin you should not have to care about this.
|
||||||
|
|
||||||
Also instead of using environment variables the plugin should only care about one prefixed with `PLUGIN_` witch are the internaml representation of the **settings** ([read more](./20-creating-plugins.md)).
|
Also instead of using environment variables the plugin should only care about one prefixed with `PLUGIN_` witch are the internal representation of the **settings** ([read more](./20-creating-plugins.md)).
|
||||||
|
|
||||||
## Finding Plugins
|
## Finding Plugins
|
||||||
|
|
||||||
|
|
|
@ -1,4 +1,4 @@
|
||||||
# Gettings started
|
# Getting started
|
||||||
|
|
||||||
A Woodpecker deployment consists of two parts:
|
A Woodpecker deployment consists of two parts:
|
||||||
|
|
||||||
|
@ -45,7 +45,7 @@ By default Woodpecker uses a SQLite database which requires zero installation or
|
||||||
|
|
||||||
## Forge
|
## Forge
|
||||||
|
|
||||||
What would be a CI/CD system without any code? By connecting Woodpecker to your [forge](../20-usage/15-terminology/index.md) like GitHub or Gitea you can start running pipelines on events like pushes or pull requests. Woodpecker will also use your forge for authentication and to report back the status of your pipelines. See the [forge settings](./11-forges/11-overview.md) to conntect it to Woodpecker.
|
What would be a CI/CD system without any code? By connecting Woodpecker to your [forge](../20-usage/15-terminology/index.md) like GitHub or Gitea you can start running pipelines on events like pushes or pull requests. Woodpecker will also use your forge for authentication and to report back the status of your pipelines. See the [forge settings](./11-forges/11-overview.md) to connect it to Woodpecker.
|
||||||
|
|
||||||
## Configuration
|
## Configuration
|
||||||
|
|
||||||
|
|
|
@ -305,7 +305,7 @@ Example: `org1,org2`
|
||||||
|
|
||||||
> Default: empty
|
> Default: empty
|
||||||
|
|
||||||
Comma-separated list of syncable repo owners. ???
|
Repositories by those owners will be allowed to be used in woodpecker.
|
||||||
|
|
||||||
Example: `user1,user2`
|
Example: `user1,user2`
|
||||||
|
|
||||||
|
|
|
@ -35,7 +35,10 @@ Woodpecker uses `git+https` to clone repositories, however, Bitbucket Server doe
|
||||||
|
|
||||||
## Registration
|
## Registration
|
||||||
|
|
||||||
Woodpecker must be registered with Bitbucket Datacenter / Server. In the administration section of Bitbucket choose "Application Links" and then "Create link". Woodpecker should be listed as "External Application" and the direction should be set to "Incomming". Note the client id and client secret of the registration to be used in the configuration of Woodpecker.
|
Woodpecker must be registered with Bitbucket Datacenter / Server.
|
||||||
|
In the administration section of Bitbucket choose "Application Links" and then "Create link".
|
||||||
|
Woodpecker should be listed as "External Application" and the direction should be set to "Incoming".
|
||||||
|
Note the client id and client secret of the registration to be used in the configuration of Woodpecker.
|
||||||
|
|
||||||
See also [Configure an incoming link](https://confluence.atlassian.com/bitbucketserver/configure-an-incoming-link-1108483657.html).
|
See also [Configure an incoming link](https://confluence.atlassian.com/bitbucketserver/configure-an-incoming-link-1108483657.html).
|
||||||
|
|
||||||
|
|
|
@ -230,7 +230,8 @@ See [this issue](https://github.com/woodpecker-ci/woodpecker/issues/2510) for mo
|
||||||
|
|
||||||
### `KUBERNETES_SERVICE_HOST` environment variable
|
### `KUBERNETES_SERVICE_HOST` environment variable
|
||||||
|
|
||||||
Like the below env vars used for configuration, this can be set in the environment fonfiguration of the agent. It configures the address of the Kubernetes API server to connect to.
|
Like the below env vars used for configuration, this can be set in the environment for configuration of the agent.
|
||||||
|
It configures the address of the Kubernetes API server to connect to.
|
||||||
|
|
||||||
If running the agent within Kubernetes, this will already be set and you don't have to add it manually.
|
If running the agent within Kubernetes, this will already be set and you don't have to add it manually.
|
||||||
|
|
||||||
|
|
|
@ -1,6 +1,6 @@
|
||||||
# Custom backends
|
# Custom backends
|
||||||
|
|
||||||
If none of our backends fits your usecases, you can write your own.
|
If none of our backends fits your usecase, you can write your own.
|
||||||
|
|
||||||
Therefore, implement the interface `"go.woodpecker-ci.org/woodpecker/woodpecker/v2/pipeline/backend/types".Backend` and
|
Therefore, implement the interface `"go.woodpecker-ci.org/woodpecker/woodpecker/v2/pipeline/backend/types".Backend` and
|
||||||
build a custom agent using your backend with this `main.go`:
|
build a custom agent using your backend with this `main.go`:
|
||||||
|
|
|
@ -29,8 +29,8 @@ services:
|
||||||
- WOODPECKER_MIN_AGENTS=0
|
- WOODPECKER_MIN_AGENTS=0
|
||||||
- WOODPECKER_MAX_AGENTS=3
|
- WOODPECKER_MAX_AGENTS=3
|
||||||
- WOODPECKER_WORKFLOWS_PER_AGENT=2 # the number of workflows each agent can run at the same time
|
- WOODPECKER_WORKFLOWS_PER_AGENT=2 # the number of workflows each agent can run at the same time
|
||||||
- WOODEPCKER_GRPC_ADDR=https://grpc.your-woodpecker-server.tld # the grpc address of your woodpecker server, publicly accessible from the agents
|
- WOODPECKER_GRPC_ADDR=https://grpc.your-woodpecker-server.tld # the grpc address of your woodpecker server, publicly accessible from the agents
|
||||||
- WOODEPCKER_GRPC_SECURE=true
|
- WOODPECKER_GRPC_SECURE=true
|
||||||
- WOODPECKER_AGENT_ENV= # optional environment variables to pass to the agents
|
- WOODPECKER_AGENT_ENV= # optional environment variables to pass to the agents
|
||||||
- WOODPECKER_PROVIDER=hetznercloud # set the provider, you can find all the available ones down below
|
- WOODPECKER_PROVIDER=hetznercloud # set the provider, you can find all the available ones down below
|
||||||
- WOODPECKER_HETZNERCLOUD_API_TOKEN=${WOODPECKER_HETZNERCLOUD_API_TOKEN} # your api token for the Hetzner cloud
|
- WOODPECKER_HETZNERCLOUD_API_TOKEN=${WOODPECKER_HETZNERCLOUD_API_TOKEN} # your api token for the Hetzner cloud
|
||||||
|
|
|
@ -1,4 +1,4 @@
|
||||||
# Adavanced options
|
# Advanced options
|
||||||
|
|
||||||
Why should we be happy with a default setup? We should not! Woodpecker offers a lot of advanced options to configure it to your needs.
|
Why should we be happy with a default setup? We should not! Woodpecker offers a lot of advanced options to configure it to your needs.
|
||||||
|
|
||||||
|
|
|
@ -21,12 +21,12 @@
|
||||||
|
|
||||||
| package | meaning | imports |
|
| package | meaning | imports |
|
||||||
| -------------------- | ----------------------------------------------------------------------------------- | -------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------- |
|
| -------------------- | ----------------------------------------------------------------------------------- | -------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------- |
|
||||||
| `server/api/**` | handle web requests from `server/router` | `pipeline`, `../badges`, `../ccmenue`, `../logging`, `../model`, `../pubsub`, `../queue`, `../forge`, `../shared`, `../store`, `shared`, (TODO: mv `server/router/middleware/session`) |
|
| `server/api/**` | handle web requests from `server/router` | `pipeline`, `../badges`, `../ccmenu`, `../logging`, `../model`, `../pubsub`, `../queue`, `../forge`, `../shared`, `../store`, `shared`, (TODO: mv `server/router/middleware/session`) |
|
||||||
| `server/badges/**` | generate svg badges for pipelines | `../model` |
|
| `server/badges/**` | generate svg badges for pipelines | `../model` |
|
||||||
| `server/ccmenu/**` | generate xml ccmenu for pipelines | `../model` |
|
| `server/ccmenu/**` | generate xml ccmenu for pipelines | `../model` |
|
||||||
| `server/grpc/**` | gRPC server agents can connect to | `pipeline/rpc/**`, `../logging`, `../model`, `../pubsub`, `../queue`, `../forge`, `../pipeline`, `../store` |
|
| `server/grpc/**` | gRPC server agents can connect to | `pipeline/rpc/**`, `../logging`, `../model`, `../pubsub`, `../queue`, `../forge`, `../pipeline`, `../store` |
|
||||||
| `server/logging/**` | logging lib for gPRC server to stream logs while running | std |
|
| `server/logging/**` | logging lib for gPRC server to stream logs while running | std |
|
||||||
| `server/model/**` | structs for store (db) and api (json) | std |
|
| `server/model/**` | structs for store (db) and api (json) | std |
|
||||||
| `server/plugins/**` | plugins for server | `../model`, `../forge` |
|
| `server/plugins/**` | plugins for server | `../model`, `../forge` |
|
||||||
| `server/pipeline/**` | orchestrate pipelines | `pipeline`, `../model`, `../pubsub`, `../queue`, `../forge`, `../store`, `../plugins` |
|
| `server/pipeline/**` | orchestrate pipelines | `pipeline`, `../model`, `../pubsub`, `../queue`, `../forge`, `../store`, `../plugins` |
|
||||||
| `server/pubsub/**` | pubsub lib for server to push changes to the WebUI | std |
|
| `server/pubsub/**` | pubsub lib for server to push changes to the WebUI | std |
|
||||||
|
|
|
@ -7,7 +7,7 @@ and then being using on the community's website documentation.
|
||||||
|
|
||||||
It's paramount important to keep the gin handler function's godoc documentation up-to-date,
|
It's paramount important to keep the gin handler function's godoc documentation up-to-date,
|
||||||
to always have accurate API documentation.
|
to always have accurate API documentation.
|
||||||
Whenever you change, add or enhance an API endpoint, please update the godocs.
|
Whenever you change, add or enhance an API endpoint, please update the godoc.
|
||||||
|
|
||||||
You don't require any extra tools on your machine, all Swagger tooling is automatically fetched by standard Go tools.
|
You don't require any extra tools on your machine, all Swagger tooling is automatically fetched by standard Go tools.
|
||||||
|
|
||||||
|
@ -41,8 +41,8 @@ These guidelines aim to have consistent wording in the swagger doc:
|
||||||
- first word after `@Summary` and `@Summary` are always uppercase
|
- first word after `@Summary` and `@Summary` are always uppercase
|
||||||
- `@Summary` has no `.` (dot) at the end of the line
|
- `@Summary` has no `.` (dot) at the end of the line
|
||||||
- model structs shall use custom short names, to ease life for API consumers, using `@name`
|
- model structs shall use custom short names, to ease life for API consumers, using `@name`
|
||||||
- `@Success` object or array declarations shall be short, this means the actual `model.User` struct must have a `@name` annotation, so that the model can be renderend in Swagger
|
- `@Success` object or array declarations shall be short, this means the actual `model.User` struct must have a `@name` annotation, so that the model can be rendered in Swagger
|
||||||
- when pagination is used, `@Parame page` and `@Parame perPage` must be added manually
|
- when pagination is used, `@Param page` and `@Param perPage` must be added manually
|
||||||
- `@Param Authorization` is almost always present, there are just a few un-protected endpoints
|
- `@Param Authorization` is almost always present, there are just a few un-protected endpoints
|
||||||
|
|
||||||
There are many examples in the `server/api` package, which you can use a blueprint.
|
There are many examples in the `server/api` package, which you can use a blueprint.
|
||||||
|
|
|
@ -30,7 +30,7 @@ steps:
|
||||||
services:
|
services:
|
||||||
echo:
|
echo:
|
||||||
image: dummy
|
image: dummy
|
||||||
commands: echo "i am a sevice"
|
commands: echo "i am a service"
|
||||||
```
|
```
|
||||||
|
|
||||||
This could be executed via `woodpecker-cli --log-level trace exec --backend-engine dummy example.yaml`:
|
This could be executed via `woodpecker-cli --log-level trace exec --backend-engine dummy example.yaml`:
|
||||||
|
@ -69,7 +69,7 @@ This could be executed via `woodpecker-cli --log-level trace exec --backend-engi
|
||||||
9:18PM TRC pipeline/backend/dummy/dummy.go:208 > delete workflow environment taskUUID=01J10P578JQE6E25VV1EQF0745
|
9:18PM TRC pipeline/backend/dummy/dummy.go:208 > delete workflow environment taskUUID=01J10P578JQE6E25VV1EQF0745
|
||||||
```
|
```
|
||||||
|
|
||||||
There are also environment variables to alter step behaviour:
|
There are also environment variables to alter step behavior:
|
||||||
|
|
||||||
- `SLEEP: 10` will let the step wait 10 seconds
|
- `SLEEP: 10` will let the step wait 10 seconds
|
||||||
- `EXPECT_TYPE` allows to check if a step is a `clone`, `service`, `plugin` or `commands`
|
- `EXPECT_TYPE` allows to check if a step is a `clone`, `service`, `plugin` or `commands`
|
||||||
|
|
Loading…
Reference in a new issue