\r\n\n\n### Steps to reproduce\n\n.\n\n### Expected behavior\n\n_No response_\n\n### System Info\n\n```shell\n\"next-d126cf9e35\"\n```\n\n\n### Additional context\n\n_No response_\n\n### Validations\n\n- [X] Read the [docs](https://woodpecker-ci.org/docs/intro).\n- [X] Check that there isn't [already an issue](https://github.com/woodpecker-ci/woodpecker/issues) that reports the same bug to avoid creating a duplicate.\n- [X] Checked that the bug isn't fixed in the `next` version already [https://woodpecker-ci.org/faq#which-version-of-woodpecker-should-i-use]",[1984,1987],{"name":1985,"color":1986},"bug","d73a4a",{"name":1988,"color":1989},"ui","46DEA2",4677,"woodpecker-ci","woodpecker","open","`tag` pipelines are missing avatar and commit title","2025-01-12T06:19:42Z","https://github.com/woodpecker-ci/woodpecker/issues/4677",0.7503088,{"description":1999,"labels":2000,"number":2004,"owner":1991,"repository":1992,"state":2005,"title":2006,"updated_at":2007,"url":2008,"score":2009},"It would be nice to have an env var like `CI_COMMIT_PULL_REQUEST_LABELS` containing a list of all set labels of a PR as a comma separated string. This would allow a user to filter steps and pipelines with https://woodpecker-ci.org/docs/next/usage/pipeline-syntax#evaluate to only be executed if a specific label is set or is not set. \r\n\r\nFor example the quite time consuming task of building docker images for PRs could be skipped by default and only be activated if the corresponding label was set by a maintainer.\r\n\r\nLater with the support of label changes triggering pipelines like suggested in https://github.com/woodpecker-ci/woodpecker/issues/286#issuecomment-1116699790 a pipeline could immediately be executed in case a label got added.",[2001],{"name":2002,"color":2003},"enhancement","7E1FE4",1308,"closed","Add env var with labels from PR","2023-03-17T02:43:07Z","https://github.com/woodpecker-ci/woodpecker/issues/1308",0.731377,{"description":2011,"labels":2012,"number":2017,"owner":1991,"repository":1992,"state":2005,"title":2018,"updated_at":2019,"url":2020,"score":2021},"on agent start, it trys to connect to the server and if it cant it stops.\r\n\r\nthere should be retry atempts, as the server could be restarting/starting in just the same moment",[2013,2016],{"name":2014,"color":2015},"agent","ECBCDF",{"name":2002,"color":2003},1721,"Agent Start should have connection retrys","2023-05-03T11:31:31Z","https://github.com/woodpecker-ci/woodpecker/issues/1721",0.73397714,{"description":2023,"labels":2024,"number":2028,"owner":1991,"repository":1992,"state":2005,"title":2029,"updated_at":2030,"url":2031,"score":2032},"### Clear and concise description of the problem\n\nThe [docs](https://woodpecker-ci.org/docs/administration/setup) show that the agent needs access to the docker socket. It's good practice to use a proxy instead of exposing the entire socket. The most common is the [\"tecnativa\" proxy](https://github.com/Tecnativa/docker-socket-proxy) .\r\n\r\nI assume that at the very least, an agent creates new containers, so needs access to the \"containers\" endpoint. Presumably it needs other endpoints too.\n\n### Suggested solution\n\nPlease consider *documenting which parts of the docker api are needed by the agent*. Then we could use the docker socket proxy to allow those and restrict the others.\n\n### Alternative\n\n_No response_\n\n### Additional context\n\nThese are [the docker api's endpoints](https://github.com/Tecnativa/docker-socket-proxy#grant-or-revoke-access-to-certain-api-sections):\r\n- typically allowed:\r\n - EVENTS\r\n - PING\r\n - VERSION\r\n- security-critical and so typically not allowed:\r\n - AUTH\r\n - SECRETS\r\n - POST\r\n- other\r\n - BUILD\r\n - COMMIT\r\n - CONFIGS\r\n - CONTAINERS\r\n - DISTRIBUTION\r\n - EXEC\r\n - GRPC\r\n - IMAGES\r\n - INFO\r\n - NETWORKS\r\n - NODES\r\n - PLUGINS\r\n - SERVICES\r\n - SESSION\r\n - SWARM\r\n - SYSTEM\r\n - TASKS\r\n - VOLUMES\r\n\n\n### Validations\n\n- [X] Checked that the feature isn't part of the `next` version already [https://woodpecker-ci.org/faq#which-version-of-woodpecker-should-i-use]\n- [X] Read the [Contributing Guidelines](https://github.com/woodpecker-ci/woodpecker/blob/master/CONTRIBUTING.md).\n- [X] Read the [docs](https://woodpecker-ci.org/docs/intro).\n- [X] Check that there isn't already an [issue](https://github.com/woodpecker-ci/woodpecker/issues) that request the same feature to avoid creating a duplicate.",[2025],{"name":2026,"color":2027},"feature","180DBE",1917,"Use woodpecker with docker socket proxy","2023-08-20T16:09:23Z","https://github.com/woodpecker-ci/woodpecker/issues/1917",0.73573047,{"description":2034,"labels":2035,"number":2042,"owner":1991,"repository":1992,"state":2005,"title":2043,"updated_at":2044,"url":2045,"score":2046},"### Clear and concise description of the problem\n\nIn the [setup documentation](https://woodpecker-ci.org/docs/administration/setup#docker-compose) it reads:\r\n\r\n> Woodpecker needs to know its own address. You must therefore provide the public address of it in `\u003Cscheme>://\u003Chostname>` format.\r\n> [...]\r\n> `WOODPECKER_HOST=${WOODPECKER_HOST}`\r\n\r\nIt is not clear if `\u003Cscheme>://\u003Chostname>` must contain the http port, e.g., the default port 8000 from the compose file. The [reference](https://woodpecker-ci.org/docs/administration/server-config#woodpecker_host) is not clear about this either.\n\n### Suggested solution\n\nImprove the wording in order to clarify if the port number has to be part of the environment variable `WOODPECKER_HOST`.\n\n### Alternative\n\n_No response_\n\n### Additional context\n\n_No response_\n\n### Validations\n\n- [X] Read the [Contributing Guidelines](https://github.com/woodpecker-ci/woodpecker/blob/master/CONTRIBUTING.md).\n- [X] Read the [docs](https://woodpecker-ci.org/docs/intro).\n- [X] Check that there isn't already an [issue](https://github.com/woodpecker-ci/woodpecker/issues) that request the same feature to avoid creating a duplicate.",[2036,2039],{"name":2037,"color":2038},"documentation","7D625D",{"name":2040,"color":2041},"good first issue","76ea72",1437,"Improve documentation about WOODPECKER_HOST wrt. port number","2023-08-20T17:11:57Z","https://github.com/woodpecker-ci/woodpecker/issues/1437",0.74719226,{"description":2048,"labels":2049,"number":2051,"owner":1991,"repository":1992,"state":2005,"title":2052,"updated_at":2053,"url":2054,"score":2055},"### Component\n\nserver\n\n### Describe the bug\n\nTrying out woodpecker, my docker-compose file:\n```\nservices:\n woodpecker-server:\n image: woodpeckerci/woodpecker-server:v3\n ports:\n - 8000:8000\n volumes:\n - woodpecker-server-data:/var/lib/woodpecker/\n environment:\n - WOODPECKER_OPEN=true\n - WOODPECKER_HOST=http://192.168.10.162:8000\n\nvolumes:\n woodpecker-server-data:\n```\n\nWhen running with `docker compose up`, I get the following:\n```\n~/projects/foss/woodpecker$ docker compose up\n[+] Running 1/1\n ✔ Container woodpecker-woodpecker-server-1 Created 0.1s \nAttaching to woodpecker-server-1\nwoodpecker-server-1 | {\"level\":\"info\",\"time\":\"2025-03-07T05:42:55Z\",\"message\":\"log level: info\"}\nwoodpecker-server-1 | {\"level\":\"warn\",\"time\":\"2025-03-07T05:42:55Z\",\"message\":\"no sqlite3 file found, will create one at '/var/lib/woodpecker/woodpecker.sqlite'\"}\nwoodpecker-server-1 | {\"level\":\"error\",\"error\":\"can't setup store: could not migrate datastore: unable to open database file: no such file or directory\",\"time\":\"2025-03-07T05:42:55Z\",\"message\":\"error running server\"}\nwoodpecker-server-1 exited with code 0\n~/projects/foss/woodpecker$ \n```\n\nAlso, I doubled checked the volume dir, and there is no files there:\n```\nroot@[REDACTED]:/var/lib/docker/volumes/woodpecker_woodpecker-server-data/_data# ls -la\ntotal 0\ndrwxr-xr-x. 1 root root 0 Mar 5 04:50 .\ndrwx-----x. 1 root root 10 Mar 7 18:37 ..\nroot@[REDACTED]:/var/lib/docker/volumes/woodpecker_woodpecker-server-data/_data# \n```\n\n\n### Steps to reproduce\n\n1. Woodperker with docker (configuration from docs) & agent entry removed. (only service)\n2. `docker compose up`\n3. Observe the error\n\n### Expected behavior\n\n_No response_\n\n### System Info\n\n```shell\nDocker version 28.0.1, build 068a01e\n```\n\n### Additional context\n\n**However**, when running with `woodpeckerci/woodpecker-server:v3-alpine` image - this issue goes away.\n\n### Validations\n\n- [x] Read the [docs](https://woodpecker-ci.org/docs/intro).\n- [x] Check that there isn't [already an issue](https://github.com/woodpecker-ci/woodpecker/issues) that reports the same bug to avoid creating a duplicate.\n- [x] Checked that the bug isn't fixed in the `next` version already [https://woodpecker-ci.org/versions]",[2050],{"name":1985,"color":1986},4939,"Fresh run with docker results in \"unable to open database file\"","2025-03-18T16:47:23Z","https://github.com/woodpecker-ci/woodpecker/issues/4939",0.7488058,{"description":2057,"labels":2058,"number":2066,"owner":1991,"repository":1992,"state":2005,"title":2067,"updated_at":2068,"url":2069,"score":2070},"As noticed in several PRs the current option `NetrcOnlyTrusted` is limiting users, but on the other hand not really protecting them as well as netrc credentials could be stolen by a custom clone step with custom commands. \r\n\r\n- https://github.com/woodpecker-ci/woodpecker/pull/2585#issuecomment-1765756023\r\n- https://github.com/woodpecker-ci/woodpecker/pull/2214\r\n\r\nTo prevent this a `pass-netrc-to-plugins` option should replace the `NetrcOnlyTrusted` option. This option would contain list of images which will receive the netrc credentials if they are used as plugins. If the image however uses custom commands it wont get the credentials as those commands could be changed by others than the admin.\r\n\r\nThis will allow all steps and the clone step to use netrc credentials. It will however be breaking as it wont be possible anymore to use clone steps with custom commands.",[2059,2060,2063],{"name":2026,"color":2027},{"name":2061,"color":2062},"breaking","A1B83C",{"name":2064,"color":2065},"security","B60205",2601,"Replace `NetrcOnlyTrusted` with list of trusted plugins for netrc","2024-11-26T13:27:07Z","https://github.com/woodpecker-ci/woodpecker/issues/2601",0.75352,{"description":2072,"labels":2073,"number":2075,"owner":1991,"repository":1992,"state":2005,"title":2076,"updated_at":2077,"url":2078,"score":2079},"### Component\r\n\r\nserver, agent\r\n\r\n### Describe the bug\r\n\r\nAfter renaming on matrix variable and forgetting to change on the `image` property,\r\nI noticed that woodpecker will fail (of cause), but with no meaningful error and without showing the error.\r\n\r\nThe webui only shows \"Unknown error\" and show `exit code 0` within that step (also the step is marked as \"succeeded\").\r\n\r\n\r\n\r\n\r\n### System Info\r\n\r\n```shell\r\n{\"source\":\"https://github.com/woodpecker-ci/woodpecker\",\"version\":\"next-c2b0c1d7\"}\r\n```\r\n\r\n\r\n### Additional context\r\nLog from server:\r\n```shell\r\n{\"level\":\"warn\",\"error\":\"sql: no rows in result set\",\"time\":\"2021-12-14T14:34:17Z\"}\r\n{\"level\":\"warn\",\"error\":\"sql: no rows in result set\",\"time\":\"2021-12-14T14:46:27Z\"}\r\n{\"level\":\"error\",\"time\":\"2021-12-14T14:47:52Z\",\"message\":\"failure to parse yaml from hook for Flaschengeist/flaschengeist-frontend. yaml: line 5: found character that cannot start any token\"}\r\n{\"level\":\"error\",\"error\":\"Error #01: yaml: line 5: found character that cannot start any token\\n\",\"ip\":\"172.22.0.1\",\"latency\":554.057332,\"method\":\"POST\",\"path\":\"/hook\",\"status\":200,\"time\":\"2021-12-14T14:47:52Z\",\"user-agent\":\"Go-http-client/1.1\",\"time\":\"2021-12-14T14:47:52Z\"}\r\n{\"level\":\"warn\",\"error\":\"sql: no rows in result set\",\"time\":\"2021-12-14T14:57:07Z\"}\r\n```\r\nLog from agent: [error.log](https://github.com/woodpecker-ci/woodpecker/files/7758788/error.log)\r\n\r\n### Validations\r\n\r\n- [X] Read the [Contributing Guidelines](https://github.com/woodpecker-ci/woodpecker/blob/master/CONTRIBUTING.md).\r\n- [X] Read the [docs](https://woodpecker-ci.org/docs/intro).\r\n- [X] Check that there isn't [already an issue](https://github.com/woodpecker-ci/woodpecker/issues) that reports the same bug to avoid creating a duplicate.\r\n- [X] Check that this is a concrete bug. For Q&A join our [Discord Chat Server](https://discord.gg/fcMQqSMXJy).",[2074],{"name":2002,"color":2003},637,"Unknown error and invalid state when pipeline contains invalid matrix tags","2024-02-11T23:24:04Z","https://github.com/woodpecker-ci/woodpecker/issues/637",0.7548534,{"description":2081,"labels":2082,"number":2085,"owner":1991,"repository":1992,"state":2005,"title":2086,"updated_at":2087,"url":2088,"score":2089},"### Component\r\n\r\nserver, web-ui\r\n\r\n### Describe the bug\r\n\r\nDownloaded or copy-pasted logs do not have line breaks, appear as one line.\r\n\r\n### Steps to reproduce\r\n\r\n1. Install Woodpecker `2.6.0`.\r\n2. Run pipeline\r\n```yaml\r\nskip_clone: true\r\nsteps:\r\n server:\r\n image: alpine\r\n commands:\r\n - echo Hello\r\n - echo world\r\n```\r\n2. See logs in UI\r\n\r\n3. Download logs\r\n[usr-wp-test-324-server.log](https://github.com/user-attachments/files/15841307/usr-wp-test-324-server.log)\r\n4. Copy logs from UI and paste in some text editor\r\n5. Check, that downloaded logs and copy-pasted one are one-line text\r\n```\r\n+ echo HelloHello+ echo worldworld\r\n```\r\n\r\n### Expected behavior\r\n\r\n1. Install Woodpecker `2.5.0`.\r\n2. Run pipeline\r\n```yaml\r\nskip_clone: true\r\nsteps:\r\n server:\r\n image: alpine\r\n commands:\r\n - echo Hello\r\n - echo world\r\n```\r\n2. See logs in UI\r\n\r\n3. Download logs\r\n[usr-wp-test-323-server.log](https://github.com/user-attachments/files/15841256/usr-wp-test-323-server.log)\r\n4. Copy logs from UI and paste in some text editor\r\n5. Check, that downloaded logs and copy-pasted one are multiple lines\r\n```\r\n+ echo Hello\r\nHello\r\n+ echo world\r\nworld\r\n```\r\n\r\n### System Info\r\n\r\n```shell\r\nWoodpecker 2.6.0, Kubernetes.\r\n```\r\n\r\n\r\n### Additional context\r\n\r\n_No response_\r\n\r\n### Validations\r\n\r\n- [X] Read the [docs](https://woodpecker-ci.org/docs/intro).\r\n- [X] Check that there isn't [already an issue](https://github.com/woodpecker-ci/woodpecker/issues) that reports the same bug to avoid creating a duplicate.\r\n- [X] Checked that the bug isn't fixed in the `next` version already [https://woodpecker-ci.org/faq#which-version-of-woodpecker-should-i-use]",[2083,2084],{"name":1985,"color":1986},{"name":1988,"color":1989},3790,"There is no line breaks in the Step logs","2024-06-21T08:14:01Z","https://github.com/woodpecker-ci/woodpecker/issues/3790",0.75799423,{"description":2091,"labels":2092,"number":2097,"owner":1991,"repository":1992,"state":2005,"title":2098,"updated_at":2099,"url":2100,"score":2101},"forge: gitlab\r\nwoodpecker: next (>2.6)",[2093,2094],{"name":1985,"color":1986},{"name":2095,"color":2096},"forge/gitlab","E96280",3861,"CI_COMMIT_SOURCE_BRANCH, CI_COMMIT_TARGET_BRANCH is not set in PR","2024-08-10T18:43:51Z","https://github.com/woodpecker-ci/woodpecker/issues/3861",0.7595389,["Reactive",2103],{},["Set"],["ShallowReactive",2106],{"TRc1wZytZ_XrK4EfJfei_Sz-An4H4Yy6syhVxH_PVJc":-1,"tQRirIy6-wEAdeGa9yPClC6Wa7Qt0IqcivCeXcjd4XE":-1},"/woodpecker-ci/woodpecker/4935"]