Building the new Codeberg Pages - with custom domain support, per-repo pages using the "pages" branch, caching and much more!
You can not select more than 25 topics Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.
Moritz Marquardt e73c79da77 Merge pull request 'Refactor: restructure in packages and dont use golbal vars' (#18) from 6543/codeberg-pages:refactoring into main 1 month ago
cmd Add --verbose flag and hide debug messages by default 1 month ago
haproxy-sni Add TODOs 1 month ago
html fix argument check and some nits 1 month ago
server code format 1 month ago
.gitignore ignore vendor/ folder 2 months ago
Justfile Add --verbose flag and hide debug messages by default 1 month ago
LICENSE Release under EUPL v. 1.2 10 months ago Update default to & improve documentation on custom domains 1 month ago
go.mod less panic 1 month ago
go.sum start using urfave/cli 1 month ago
main.go start using urfave/cli 1 month ago


  • HOST & PORT (default: [::] & 443): listen address.
  • PAGES_DOMAIN (default: main domain for pages.
  • RAW_DOMAIN (default: domain for raw resources.
  • GITEA_ROOT (default: root of the upstream Gitea instance.
  • GITEA_API_TOKEN (default: empty): API token for the Gitea instance to access non-public (e.g. limited) repos.
  • RAW_INFO_PAGE (default: info page for raw resources, shown if no resource is provided.
  • ACME_API (default: set this to https://acme.mock.director to use invalid certificates without any verification (great for debugging).
    ZeroSSL might be better in the future as it doesn't have rate limits and doesn't clash with the official Codeberg certificates (which are using Let's Encrypt), but I couldn't get it to work yet.
  • ACME_EMAIL (default: Set this to "true" to accept the Terms of Service of your ACME provider.
  • ACME_EAB_KID & ACME_EAB_HMAC (default: don't use EAB): EAB credentials, for example for ZeroSSL.
  • ACME_ACCEPT_TERMS (default: use self-signed certificate): Set this to "true" to accept the Terms of Service of your ACME provider.
  • ACME_USE_RATE_LIMITS (default: true): Set this to false to disable rate limits, e.g. with ZeroSSL.
  • ENABLE_HTTP_SERVER (default: false): Set this to true to enable the HTTP-01 challenge and redirect all other HTTP requests to HTTPS. Currently only works with port 80.
  • DNS_PROVIDER (default: use self-signed certificate): Code of the ACME DNS provider for the main domain wildcard.
    See for available values & additional environment variables.
  • DEBUG (default: false): Set this to true to enable debug logging.
// Package main is the new Codeberg Pages server, a solution for serving static pages from Gitea repositories.
// Mapping custom domains is not static anymore, but can be done with DNS:
// 1) add a ".domains" text file to your repository, containing the allowed domains, separated by new lines. The
// first line will be the canonical domain/URL; all other occurrences will be redirected to it.
// 2) add a CNAME entry to your domain, pointing to "[[{branch}.]{repo}.]{owner}" (repo defaults to
// "pages", "branch" defaults to the default branch if "repo" is "pages", or to "pages" if "repo" is something else):
// 3) if a CNAME is set for "", you can redirect there from the naked domain by adding an ALIAS record
// for "" (if your provider allows ALIAS or similar records, otherwise use A/AAAA), together with a TXT
// record that points to your repo (just like the CNAME record):
// Certificates are generated, updated and cleaned up automatically via Let's Encrypt through a TLS challenge.