mirror of
https://github.com/caddyserver/caddy.git
synced 2025-01-06 22:40:31 -05:00
Expose JSON <-> Caddyfile conversion via command line flags (#2374)
* Expose JSON <-> Caddyfile conversion via command line flags stdin / stdout * cli caddyfile-to-json and json-to-caddyfile
This commit is contained in:
parent
4de9d64c0c
commit
6246d4c3ca
1 changed files with 39 additions and 0 deletions
|
@ -31,6 +31,7 @@ import (
|
||||||
"github.com/google/uuid"
|
"github.com/google/uuid"
|
||||||
"github.com/klauspost/cpuid"
|
"github.com/klauspost/cpuid"
|
||||||
"github.com/mholt/caddy"
|
"github.com/mholt/caddy"
|
||||||
|
"github.com/mholt/caddy/caddyfile"
|
||||||
"github.com/mholt/caddy/caddytls"
|
"github.com/mholt/caddy/caddytls"
|
||||||
"github.com/mholt/caddy/telemetry"
|
"github.com/mholt/caddy/telemetry"
|
||||||
"github.com/mholt/certmagic"
|
"github.com/mholt/certmagic"
|
||||||
|
@ -53,6 +54,7 @@ func init() {
|
||||||
flag.StringVar(&conf, "conf", "", "Caddyfile to load (default \""+caddy.DefaultConfigFile+"\")")
|
flag.StringVar(&conf, "conf", "", "Caddyfile to load (default \""+caddy.DefaultConfigFile+"\")")
|
||||||
flag.StringVar(&cpu, "cpu", "100%", "CPU cap")
|
flag.StringVar(&cpu, "cpu", "100%", "CPU cap")
|
||||||
flag.StringVar(&envFile, "env", "", "Path to file with environment variables to load in KEY=VALUE format")
|
flag.StringVar(&envFile, "env", "", "Path to file with environment variables to load in KEY=VALUE format")
|
||||||
|
flag.BoolVar(&fromJSON, "json-to-caddyfile", false, "From JSON stdin to Caddyfile stdout")
|
||||||
flag.BoolVar(&plugins, "plugins", false, "List installed plugins")
|
flag.BoolVar(&plugins, "plugins", false, "List installed plugins")
|
||||||
flag.StringVar(&certmagic.Email, "email", "", "Default ACME CA account email address")
|
flag.StringVar(&certmagic.Email, "email", "", "Default ACME CA account email address")
|
||||||
flag.DurationVar(&certmagic.HTTPTimeout, "catimeout", certmagic.HTTPTimeout, "Default ACME CA HTTP timeout")
|
flag.DurationVar(&certmagic.HTTPTimeout, "catimeout", certmagic.HTTPTimeout, "Default ACME CA HTTP timeout")
|
||||||
|
@ -63,6 +65,7 @@ func init() {
|
||||||
flag.BoolVar(&caddy.Quiet, "quiet", false, "Quiet mode (no initialization output)")
|
flag.BoolVar(&caddy.Quiet, "quiet", false, "Quiet mode (no initialization output)")
|
||||||
flag.StringVar(&revoke, "revoke", "", "Hostname for which to revoke the certificate")
|
flag.StringVar(&revoke, "revoke", "", "Hostname for which to revoke the certificate")
|
||||||
flag.StringVar(&serverType, "type", "http", "Type of server to run")
|
flag.StringVar(&serverType, "type", "http", "Type of server to run")
|
||||||
|
flag.BoolVar(&toJSON, "caddyfile-to-json", false, "From Caddyfile stdin to JSON stdout")
|
||||||
flag.BoolVar(&version, "version", false, "Show version")
|
flag.BoolVar(&version, "version", false, "Show version")
|
||||||
flag.BoolVar(&validate, "validate", false, "Parse the Caddyfile but do not start the server")
|
flag.BoolVar(&validate, "validate", false, "Parse the Caddyfile but do not start the server")
|
||||||
|
|
||||||
|
@ -145,6 +148,9 @@ func Run() {
|
||||||
os.Exit(0)
|
os.Exit(0)
|
||||||
}
|
}
|
||||||
|
|
||||||
|
// Check if we just need to do a Caddyfile Convert and exit
|
||||||
|
checkJSONCaddyfile()
|
||||||
|
|
||||||
// Set CPU cap
|
// Set CPU cap
|
||||||
err := setCPU(cpu)
|
err := setCPU(cpu)
|
||||||
if err != nil {
|
if err != nil {
|
||||||
|
@ -280,6 +286,37 @@ func setVersion() {
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
func checkJSONCaddyfile() {
|
||||||
|
if fromJSON {
|
||||||
|
jsonBytes, err := ioutil.ReadAll(os.Stdin)
|
||||||
|
if err != nil {
|
||||||
|
fmt.Fprintf(os.Stderr, "Read stdin failed: %v", err)
|
||||||
|
os.Exit(1)
|
||||||
|
}
|
||||||
|
caddyfileBytes, err := caddyfile.FromJSON(jsonBytes)
|
||||||
|
if err != nil {
|
||||||
|
fmt.Fprintf(os.Stderr, "Converting from JSON failed: %v", err)
|
||||||
|
os.Exit(2)
|
||||||
|
}
|
||||||
|
fmt.Println(string(caddyfileBytes))
|
||||||
|
os.Exit(0)
|
||||||
|
}
|
||||||
|
if toJSON {
|
||||||
|
caddyfileBytes, err := ioutil.ReadAll(os.Stdin)
|
||||||
|
if err != nil {
|
||||||
|
fmt.Fprintf(os.Stderr, "Read stdin failed: %v", err)
|
||||||
|
os.Exit(1)
|
||||||
|
}
|
||||||
|
jsonBytes, err := caddyfile.ToJSON(caddyfileBytes)
|
||||||
|
if err != nil {
|
||||||
|
fmt.Fprintf(os.Stderr, "Converting to JSON failed: %v", err)
|
||||||
|
os.Exit(2)
|
||||||
|
}
|
||||||
|
fmt.Println(string(jsonBytes))
|
||||||
|
os.Exit(0)
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
// setCPU parses string cpu and sets GOMAXPROCS
|
// setCPU parses string cpu and sets GOMAXPROCS
|
||||||
// according to its value. It accepts either
|
// according to its value. It accepts either
|
||||||
// a number (e.g. 3) or a percent (e.g. 50%).
|
// a number (e.g. 3) or a percent (e.g. 50%).
|
||||||
|
@ -535,10 +572,12 @@ var (
|
||||||
conf string
|
conf string
|
||||||
cpu string
|
cpu string
|
||||||
envFile string
|
envFile string
|
||||||
|
fromJSON bool
|
||||||
logfile string
|
logfile string
|
||||||
logRollMB int
|
logRollMB int
|
||||||
logRollCompress bool
|
logRollCompress bool
|
||||||
revoke string
|
revoke string
|
||||||
|
toJSON bool
|
||||||
version bool
|
version bool
|
||||||
plugins bool
|
plugins bool
|
||||||
validate bool
|
validate bool
|
||||||
|
|
Loading…
Reference in a new issue