mirror of
https://github.com/caddyserver/caddy.git
synced 2025-01-19 01:05:37 +03:00
There's a std lib function for that
This commit is contained in:
parent
35225fe2d3
commit
9aaf81328f
3 changed files with 7 additions and 49 deletions
|
@ -4,7 +4,6 @@ import (
|
||||||
"errors"
|
"errors"
|
||||||
"fmt"
|
"fmt"
|
||||||
"os"
|
"os"
|
||||||
"strings"
|
|
||||||
|
|
||||||
"github.com/mholt/caddy/middleware"
|
"github.com/mholt/caddy/middleware"
|
||||||
)
|
)
|
||||||
|
@ -183,15 +182,3 @@ func (p *parser) err(kind, msg string) error {
|
||||||
msg = fmt.Sprintf("%s:%d - %s error: %s", p.filename, p.line(), kind, msg)
|
msg = fmt.Sprintf("%s:%d - %s error: %s", p.filename, p.line(), kind, msg)
|
||||||
return errors.New(msg)
|
return errors.New(msg)
|
||||||
}
|
}
|
||||||
|
|
||||||
// parseAddress takes a host:port string (val), and returns the host
|
|
||||||
// and port as separate values. Empty strings can be returned if
|
|
||||||
// either is missing.
|
|
||||||
func parseAddress(val string) (string, string) {
|
|
||||||
parts := strings.SplitN(val, ":", 3)
|
|
||||||
if len(parts) == 1 {
|
|
||||||
return parts[0], ""
|
|
||||||
} else {
|
|
||||||
return parts[0], parts[1]
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
|
@ -1,6 +1,9 @@
|
||||||
package config
|
package config
|
||||||
|
|
||||||
import "errors"
|
import (
|
||||||
|
"errors"
|
||||||
|
"net"
|
||||||
|
)
|
||||||
|
|
||||||
// This file contains the recursive-descent parsing
|
// This file contains the recursive-descent parsing
|
||||||
// functions.
|
// functions.
|
||||||
|
@ -24,12 +27,12 @@ func (p *parser) begin() error {
|
||||||
|
|
||||||
// address expects that the current token is a host:port
|
// address expects that the current token is a host:port
|
||||||
// combination.
|
// combination.
|
||||||
func (p *parser) address() error {
|
func (p *parser) address() (err error) {
|
||||||
if p.tkn() == "}" || p.tkn() == "{" {
|
if p.tkn() == "}" || p.tkn() == "{" {
|
||||||
return p.err("Syntax", "'"+p.tkn()+"' is not EOF or address")
|
return p.err("Syntax", "'"+p.tkn()+"' is not EOF or address")
|
||||||
}
|
}
|
||||||
p.cfg.Host, p.cfg.Port = parseAddress(p.tkn())
|
p.cfg.Host, p.cfg.Port, err = net.SplitHostPort(p.tkn())
|
||||||
return nil
|
return
|
||||||
}
|
}
|
||||||
|
|
||||||
// addressBlock leads into parsing directives, including
|
// addressBlock leads into parsing directives, including
|
||||||
|
|
|
@ -1,33 +1 @@
|
||||||
package config
|
package config
|
||||||
|
|
||||||
import "testing"
|
|
||||||
|
|
||||||
func TestParseAddress(t *testing.T) {
|
|
||||||
type addr struct {
|
|
||||||
host string
|
|
||||||
port string
|
|
||||||
}
|
|
||||||
testCases := []struct {
|
|
||||||
input string
|
|
||||||
expected addr
|
|
||||||
}{
|
|
||||||
{input: "host:port", expected: addr{host: "host", port: "port"}},
|
|
||||||
{input: "localhost:1234", expected: addr{host: "localhost", port: "1234"}},
|
|
||||||
{input: "127.0.0.1:0", expected: addr{host: "127.0.0.1", port: "0"}},
|
|
||||||
{input: "127.0.0.1", expected: addr{host: "127.0.0.1", port: ""}},
|
|
||||||
{input: "somedomain.com", expected: addr{host: "somedomain.com", port: ""}},
|
|
||||||
{input: "somedomain.com:", expected: addr{host: "somedomain.com", port: ""}},
|
|
||||||
{input: ":80", expected: addr{host: "", port: "80"}},
|
|
||||||
{input: "localhost:8080", expected: addr{host: "localhost", port: "8080"}},
|
|
||||||
{input: "", expected: addr{host: "", port: ""}},
|
|
||||||
}
|
|
||||||
for _, test := range testCases {
|
|
||||||
actualHost, actualPort := parseAddress(test.input)
|
|
||||||
if actualHost != test.expected.host {
|
|
||||||
t.Errorf("For '%s' expected host '%s' but got '%s'", test.input, test.expected.host, actualHost)
|
|
||||||
}
|
|
||||||
if actualPort != test.expected.port {
|
|
||||||
t.Errorf("For '%s' expected port '%s' but got '%s'", test.input, test.expected.port, actualPort)
|
|
||||||
}
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
Loading…
Reference in a new issue