Beyond coding. We forge. (Code of Conduct: https://codeberg.org/forgejo/code-of-conduct)
Go to file
Giteabot e0fe8a8ab4
Fix panic in storageHandler (#27446) (#27478)
Backport #27446 by @sryze

storageHandler() is written as a middleware but is used as an endpoint
handler, and thus `next` is actually `nil`, which causes a null pointer
dereference when a request URL does not match the pattern (where it
calls `next.ServerHTTP()`).

Example CURL command to trigger the panic:

```
curl -I "http://yourhost/gitea//avatars/a"
```

Fixes #27409

---

Note: the diff looks big but it's actually a small change - all I did
was to remove the outer closure (and one level of indentation) ~and
removed the HTTP method and pattern checks as they seem redundant
because go-chi already does those checks~. You might want to check "Hide
whitespace" when reviewing it.

Alternative solution (a bit simpler): append `, misc.DummyOK` to the
route declarations that utilize `storageHandler()` - this makes it
return an empty response when the URL is invalid. I've tested this one
and it works too. Or maybe it would be better to return a 400 error in
that case (?)

Co-authored-by: Sergey Zolotarev <sryze@outlook.com>
(cherry picked from commit 4ffa683820)
2023-11-14 13:17:11 +01:00
.forgejo [CI] Forgejo Actions based CI for PR & branches (squash) use node:20-bookworm 2023-10-20 17:30:34 +02:00
.gitea [WORKFLOW] issues & pr templates 2023-07-16 23:44:22 +02:00
.github/workflows delete Gitea specific files that need rewriting for Forgejo 2023-07-16 23:44:22 +02:00
assets [BRANDING] add Forgejo logo 2023-07-17 00:25:55 +02:00
build [I18N] Add Locale merger script 2023-07-17 00:25:24 +02:00
cmd Call git.InitSimple for runRepoSyncReleases (#26396) (#26450) 2023-08-21 07:22:18 +02:00
contrib Make environment-to-ini work with INSTALL_LOCK=true (#25926) (#25937) 2023-07-24 07:58:56 +02:00
custom/conf Use secure cookie for HTTPS sites (#26999) (#27013) 2023-09-20 12:50:46 +02:00
docker Do not use deprecated log config options by default (#26592) (#26600) 2023-08-21 07:27:20 +02:00
docs Update database-preparation and add note re: MariaDB (#27232) (#27235) 2023-10-03 14:48:18 +02:00
models [GITEA] rework long-term authentication (squash) add migration 2023-10-05 12:35:59 +02:00
modules Revert "[BRANDING] X-Forgejo-OTP can be used instead of X-Gitea-OTP" 2023-11-14 13:17:11 +01:00
options Add ThreadID parameter for Telegram webhooks (#25996) (#26480) 2023-08-21 07:22:19 +02:00
public [BRANDING] Custom loading animation for Forgejo 2023-07-17 00:25:55 +02:00
releases [DOCS] RELEASE-NOTES.md 2023-07-16 23:44:22 +02:00
routers Fix panic in storageHandler (#27446) (#27478) 2023-11-14 13:17:11 +01:00
services [GITEA] rework long-term authentication 2023-10-05 08:50:54 +02:00
snap Upgrade snap to node 20 (#24990) 2023-05-29 22:41:56 +02:00
templates Revert "[BRANDING] X-Forgejo-OTP can be used instead of X-Gitea-OTP" 2023-11-14 13:17:11 +01:00
tests [GITEA] rework long-term authentication 2023-10-05 08:50:54 +02:00
web_src Fix z-index on markdown completion (#27237) (#27238) 2023-10-03 14:48:18 +02:00
.air.toml Reduce verbosity of dev commands (#24917) 2023-05-24 20:11:04 +00:00
.changelog.yml
.dockerignore Remove the service worker (#25010) 2023-05-31 02:07:04 +00:00
.drone.yml build nightly docker images (#25317) (#25333) 2023-06-18 11:09:30 +00:00
.editorconfig
.eslintrc.yaml Update js dependencies (#25137) (#25151) 2023-06-08 12:05:13 +00:00
.gitattributes Remove more unused Fomantic variants (#25292) (#25323) 2023-06-17 17:14:25 +02:00
.gitignore [I18N] Makefile + gitignore 2023-07-17 00:25:24 +02:00
.gitpod.yml Use official Vue extension in Gitpod (#24609) 2023-05-09 18:03:50 +00:00
.golangci.yml Refactor INI package (first step) (#25024) 2023-06-02 17:27:30 +08:00
.ignore Remove the service worker (#25010) 2023-05-31 02:07:04 +00:00
.markdownlint.yaml
.npmrc Upgrade to npm lockfile v3 and explicitely set it (#23561) 2023-03-18 19:38:10 +01:00
.spectral.yaml
.stylelintrc.yaml Update JS dependencies, remove space after emoji completion (#25266) (#25352) 2023-06-20 05:38:52 +00:00
BSDmakefile update BSDmakefile to latest version from upstream (#24063) 2023-04-11 23:42:22 -04:00
build.go User/Org Feed render description as per web (#23887) 2023-04-04 04:39:47 +01:00
CHANGELOG.md Add 1.20.5 changelog (#27404) 2023-11-14 13:17:11 +01:00
CODE_OF_CONDUCT.md Add Gitea Community Code of Conduct (#23188) 2023-03-09 10:49:34 +08:00
CONTRIBUTING.md [DOCS] CONTRIBUTING 2023-07-16 23:44:22 +02:00
DCO Remove address from DCO (#22595) 2023-01-24 18:52:38 +00:00
Dockerfile [BRANDING] symlink gitea to forgejo in docker containers 2023-07-17 00:25:56 +02:00
Dockerfile.rootless [BRANDING] symlink gitea to forgejo in docker containers 2023-07-17 00:25:56 +02:00
go.mod [GITEA] golang.org/x/net v0.13.0 2023-08-04 23:27:27 +02:00
go.sum [GITEA] golang.org/x/net v0.13.0 2023-08-04 23:27:27 +02:00
LICENSE [DOCS] LICENSE: add Forgejo Authors 2023-07-16 23:44:22 +02:00
main.go Set errwriter for urfave/cli v1 (#26616) 2023-08-21 07:27:20 +02:00
MAINTAINERS Add self to maintainers (#23644) 2023-05-25 07:58:38 +08:00
Makefile [SEMVER] 5.0.6+0-gitea-1.20.5 2023-11-14 13:17:11 +01:00
package-lock.json Always pass 6-digit hex color to monaco (#25780) (#25782) 2023-07-09 13:06:13 +02:00
package.json Always pass 6-digit hex color to monaco (#25780) (#25782) 2023-07-09 13:06:13 +02:00
playwright.config.js Update JS dependencies and eslint config (#21388) 2022-10-10 20:02:20 +08:00
README.md [BRANDING] add Forgejo logo 2023-07-17 00:25:55 +02:00
RELEASE-NOTES.md [DOCS] RELEASE-NOTES: 1.20.0-0-rc0 2023-07-16 23:44:22 +02:00
vitest.config.js Update JS dependencies (#24218) 2023-04-19 22:36:41 -04:00
webpack.config.js [API] Forgejo API /api/forgejo/v1 2023-07-16 23:44:22 +02:00

Welcome to Forgejo

Hi there! Tired of big platforms playing monopoly? Providing Git hosting for your project, friends, company or community? Forgejo (/for'd͡ʒe.jo/ inspired by forĝejo the Esperanto word for forge) has you covered with its intuitive interface, light and easy hosting and a lot of builtin functionality.

Forgejo was created in 2022 because we think that the project should be owned by an independent community. If you second that, then Forgejo is for you! Our promise: Independent Free/Libre Software forever!

What does Forgejo offer?

If you like any of the following, Forgejo is literally meant for you:

  • Lightweight: Forgejo can easily be hosted on nearly every machine. Running on a Raspberry? Small cloud instance? No problem!
  • Project management: Besides Git hosting, Forgejo offers issues, pull requests, wikis, kanban boards and much more to coordinate with your team.
  • Publishing: Have something to share? Use releases to host your software for download, or use the package registry to publish it for docker, npm and many other package managers.
  • Customizable: Want to change your look? Change some settings? There are many config switches to make Forgejo work exactly like you want.
  • Powerful: Organizations & team permissions, CI integration, Code Search, LDAP, OAuth and much more. If you have advanced needs, Forgejo has you covered.
  • Privacy: From update checker to default settings: Forgejo is built to be privacy first for you and your crew.
  • Federation: (WIP) We are actively working to connect software forges with each other through ActivityPub, and create a collaborative network of personal instances.

Learn more

Dive into the documentation, subscribe to releases and blog post on our website, find us on the Fediverse or hop into our Matrix room if you have any questions or want to get involved.

Get involved

If you are interested in making Forgejo better, either by reporting a bug or by changing the governance, please take a look at the contribution guide.