pg: support host:port for backwards-compatibility
This commit is contained in:
parent
b1fd2fa8b1
commit
0b856d1a75
2 changed files with 24 additions and 4 deletions
|
@ -3,6 +3,7 @@ package sql
|
|||
import (
|
||||
"database/sql"
|
||||
"fmt"
|
||||
"net"
|
||||
"regexp"
|
||||
"strconv"
|
||||
"strings"
|
||||
|
@ -116,12 +117,24 @@ func (p *Postgres) createDataSourceName() string {
|
|||
|
||||
addParam("connect_timeout", strconv.Itoa(p.ConnectionTimeout))
|
||||
|
||||
if p.Host != "" {
|
||||
addParam("host", dataSourceStr(p.Host))
|
||||
// detect host:port for backwards-compatibility
|
||||
host, port, err := net.SplitHostPort(p.Host)
|
||||
if err != nil {
|
||||
// not host:port, probably unix socket or bare address
|
||||
|
||||
host = p.Host
|
||||
|
||||
if p.Port != 0 {
|
||||
port = strconv.Itoa(int(p.Port))
|
||||
}
|
||||
}
|
||||
|
||||
if p.Port != 0 {
|
||||
addParam("port", strconv.Itoa(int(p.Port)))
|
||||
if host != "" {
|
||||
addParam("host", dataSourceStr(host))
|
||||
}
|
||||
|
||||
if port != "" {
|
||||
addParam("port", port)
|
||||
}
|
||||
|
||||
if p.User != "" {
|
||||
|
|
|
@ -119,6 +119,13 @@ func TestCreateDataSourceName(t *testing.T) {
|
|||
},
|
||||
expected: "connect_timeout=0 host='coreos.com' sslmode='disable'",
|
||||
},
|
||||
{
|
||||
description: "with tcp host:port",
|
||||
input: &Postgres{
|
||||
Host: "coreos.com:6543",
|
||||
},
|
||||
expected: "connect_timeout=0 host='coreos.com' port=6543 sslmode='verify-full'",
|
||||
},
|
||||
{
|
||||
description: "with tcp host and port",
|
||||
input: &Postgres{
|
||||
|
|
Reference in a new issue