[mirror] Command-line application for uploading a site to a git-pages server
Go 75.2%
Nix 17.6%
Dockerfile 7.2%
17 1 16

Clone this repository

https://tangled.org/whitequark.org/git-pages-cli https://tangled.org/did:plc:i7ayw57idpkvkyzktdpmtgm7/git-pages-cli
git@tangled.org:whitequark.org/git-pages-cli git@tangled.org:did:plc:i7ayw57idpkvkyzktdpmtgm7/git-pages-cli

For self-hosted knots, clone URLs may differ based on your setup.

Download tar.gz
README.md

git-pages-cli#

git-pages-cli is a command-line application for uploading sites to git-pages.

If you want to publish a site from a Forgejo Actions workflow, use git-pages/action instead.

Installation#

You will need Go 1.25 or newer. Run:

$ go install codeberg.org/git-pages/git-pages-cli

If you prefer, you may also use a Docker container:

docker run --rm codeberg.org/git-pages/git-pages-cli:latest ...

Usage#

To prepare a DNS challenge for a given site and password:

$ git-pages-cli https://example.org --password xyz --challenge
_git-pages-challenge.example.org. 3600 IN TXT "317716dee4379c167e8b5ce9df38eb880e043e5a842d160fe8d5bb408ee0c191"
$ git-pages-cli https://example.org --password xyz --challenge-bare
317716dee4379c167e8b5ce9df38eb880e043e5a842d160fe8d5bb408ee0c191

To upload a site from a git repository available on the internet (--password may be omitted if the repository is allowlisted via DNS):

$ git-pages-cli https://example.org --upload-git https://codeberg.org/username/example.org.git
$ git-pages-cli https://example.org --password xyz --upload-git https://codeberg.org/username/example.org.git

To upload a site from a directory on your machine:

$ git-pages-cli https://example.org --password xyz --upload-dir site-contents

To delete a site:

$ git-pages-cli https://example.org --password xyz --delete

It is not possible to upload a site to a domain for the first time using HTTPS, since the git-pages server is not allowed to acquire a TLS certificate for a domain before a site is published on that domain. Either use plain HTTP instead, or provide a hostname for which the server does have a TLS certificate using the --server option:

$ git-pages-cli https://example.org --server grebedoc.dev --password xyz --upload-dir ...

License#

0-clause BSD