You've already forked step-ca-cli
mirror of
https://github.com/smallstep/cli.git
synced 2025-08-09 03:22:43 +03:00
Merge pull request #815 from smallstep/herman/fix-empty-dns-init
Add check for empty DNS value in ca init
This commit is contained in:
@@ -4,6 +4,7 @@ import (
|
||||
"context"
|
||||
"crypto/rand"
|
||||
"crypto/x509"
|
||||
stderrors "errors"
|
||||
"fmt"
|
||||
"io"
|
||||
"net"
|
||||
@@ -823,8 +824,11 @@ func processDNSValue(dnsValue string) ([]string, error) {
|
||||
)
|
||||
dnsValue = strings.ReplaceAll(dnsValue, " ", ",")
|
||||
parts := strings.Split(dnsValue, ",")
|
||||
if allEmpty(parts) {
|
||||
return nil, stderrors.New("dns must not be empty")
|
||||
}
|
||||
for _, name := range parts {
|
||||
if name == "" {
|
||||
if name == "" { // skip empty name
|
||||
continue
|
||||
}
|
||||
if err := dnsValidator(name); err != nil {
|
||||
@@ -845,3 +849,14 @@ func normalize(name string) string {
|
||||
}
|
||||
return name
|
||||
}
|
||||
|
||||
// allEmpty loops through all strings in the slice and returns if
|
||||
// all are empty (length 0).
|
||||
func allEmpty(parts []string) bool {
|
||||
for _, p := range parts {
|
||||
if p != "" {
|
||||
return false
|
||||
}
|
||||
}
|
||||
return true
|
||||
}
|
||||
|
@@ -14,6 +14,19 @@ func Test_processDNSValue(t *testing.T) {
|
||||
want []string
|
||||
wantErr bool
|
||||
}{
|
||||
|
||||
{
|
||||
name: "fail/empty",
|
||||
dnsValue: "",
|
||||
want: nil,
|
||||
wantErr: true,
|
||||
},
|
||||
{
|
||||
name: "fail/empty-multiple",
|
||||
dnsValue: ",,",
|
||||
want: nil,
|
||||
wantErr: true,
|
||||
},
|
||||
{
|
||||
name: "fail/dns",
|
||||
dnsValue: "ca.smallstep.com:8443",
|
||||
@@ -44,6 +57,12 @@ func Test_processDNSValue(t *testing.T) {
|
||||
want: []string{"ca.smallstep.com", "ca.localhost"},
|
||||
wantErr: false,
|
||||
},
|
||||
{
|
||||
name: "ok/multi-dns-with-skip",
|
||||
dnsValue: "ca.smallstep.com,ca.localhost,,test.localhost",
|
||||
want: []string{"ca.smallstep.com", "ca.localhost", "test.localhost"},
|
||||
wantErr: false,
|
||||
},
|
||||
{
|
||||
name: "ok/multi-space-dns",
|
||||
dnsValue: "ca.smallstep.com ca.localhost",
|
||||
|
Reference in New Issue
Block a user