From 1015ef0260cefb819baaf75040c4fc36b4d1eb74 Mon Sep 17 00:00:00 2001 From: Mohammed Al Sahaf Date: Thu, 14 Dec 2023 14:55:58 +0300 Subject: [PATCH] add syntax and examples to README --- README.md | 20 ++++++++++++++++++++ 1 file changed, 20 insertions(+) diff --git a/README.md b/README.md index 228ebc4..c579a0b 100644 --- a/README.md +++ b/README.md @@ -62,6 +62,7 @@ Syntax: $ xcaddy build [] [--output ] [--with ...] + [--embed <[alias]:path/to/dir>...] ``` - `` is the core Caddy version to build; defaults to `CADDY_VERSION` env variable or latest.
@@ -72,6 +73,7 @@ $ xcaddy build [] - `--output` changes the output file. - `--with` can be used multiple times to add plugins by specifying the Go module name and optionally its version, similar to `go get`. Module name is required, but specific version and/or local replacement are optional. +- `--embed` can be used multiple times to embed directories into the built Caddy executable. The directory can be prefixed with a custom alias and a colon `:` to use it with the `root` directive and sub-directive. Examples: @@ -107,6 +109,24 @@ $ xcaddy build \ This allows you to hack on Caddy core (and optionally plug in extra modules at the same time!) with relative ease. +``` +$ xcaddy build --embed foo:./sites/foo --embed bar:./sites/bar +$ cat Caddyfile +foo.localhost { + root * /foo + file_server { + fs embedded + } +} + +bar.localhost { + root * /bar + file_server { + fs embedded + } +} +``` +This allows you to serve 2 sites from 2 different embedded directories, which are referenced by aliases, from a single Caddy executable. ### For plugin development