httpcaddyfile: Add pki app root and intermediate cert/key config (#4514)

This commit is contained in:
Francis Lavoie 2022-01-18 14:18:31 -05:00 committed by GitHub
parent bcb7a19cd3
commit 5a07156894
No known key found for this signature in database
GPG key ID: 4AEE18F83AFDEB23
2 changed files with 89 additions and 1 deletions

View file

@ -31,6 +31,16 @@ func init() {
// name <name> // name <name>
// root_cn <name> // root_cn <name>
// intermediate_cn <name> // intermediate_cn <name>
// root {
// cert <path>
// key <path>
// format <format>
// }
// intermediate {
// cert <path>
// key <path>
// format <format>
// }
// } // }
// } // }
// //
@ -74,6 +84,64 @@ func parsePKIApp(d *caddyfile.Dispenser, existingVal interface{}) (interface{},
} }
pkiCa.IntermediateCommonName = d.Val() pkiCa.IntermediateCommonName = d.Val()
case "root":
if pkiCa.Root == nil {
pkiCa.Root = new(caddypki.KeyPair)
}
for nesting := d.Nesting(); d.NextBlock(nesting); {
switch d.Val() {
case "cert":
if !d.NextArg() {
return nil, d.ArgErr()
}
pkiCa.Root.Certificate = d.Val()
case "key":
if !d.NextArg() {
return nil, d.ArgErr()
}
pkiCa.Root.PrivateKey = d.Val()
case "format":
if !d.NextArg() {
return nil, d.ArgErr()
}
pkiCa.Root.Format = d.Val()
default:
return nil, d.Errf("unrecognized pki ca root option '%s'", d.Val())
}
}
case "intermediate":
if pkiCa.Intermediate == nil {
pkiCa.Intermediate = new(caddypki.KeyPair)
}
for nesting := d.Nesting(); d.NextBlock(nesting); {
switch d.Val() {
case "cert":
if !d.NextArg() {
return nil, d.ArgErr()
}
pkiCa.Intermediate.Certificate = d.Val()
case "key":
if !d.NextArg() {
return nil, d.ArgErr()
}
pkiCa.Intermediate.PrivateKey = d.Val()
case "format":
if !d.NextArg() {
return nil, d.ArgErr()
}
pkiCa.Intermediate.Format = d.Val()
default:
return nil, d.Errf("unrecognized pki ca intermediate option '%s'", d.Val())
}
}
default: default:
return nil, d.Errf("unrecognized pki ca option '%s'", d.Val()) return nil, d.Errf("unrecognized pki ca option '%s'", d.Val())
} }

View file

@ -5,6 +5,16 @@
name "Local" name "Local"
root_cn "Custom Local Root Name" root_cn "Custom Local Root Name"
intermediate_cn "Custom Local Intermediate Name" intermediate_cn "Custom Local Intermediate Name"
root {
cert /path/to/cert.pem
key /path/to/key.pem
format pem_file
}
intermediate {
cert /path/to/cert.pem
key /path/to/key.pem
format pem_file
}
} }
ca foo { ca foo {
name "Foo" name "Foo"
@ -118,7 +128,17 @@ acme-bar.example.com {
"name": "Local", "name": "Local",
"root_common_name": "Custom Local Root Name", "root_common_name": "Custom Local Root Name",
"intermediate_common_name": "Custom Local Intermediate Name", "intermediate_common_name": "Custom Local Intermediate Name",
"install_trust": false "install_trust": false,
"root": {
"certificate": "/path/to/cert.pem",
"private_key": "/path/to/key.pem",
"format": "pem_file"
},
"intermediate": {
"certificate": "/path/to/cert.pem",
"private_key": "/path/to/key.pem",
"format": "pem_file"
}
} }
} }
}, },