mirror of
https://github.com/fluencelabs/tendermint
synced 2025-06-17 15:11:21 +00:00
deprecate not fully formed addresses
This commit is contained in:
@ -18,65 +18,51 @@ import (
|
|||||||
)
|
)
|
||||||
|
|
||||||
func StartHTTPServer(listenAddr string, handler http.Handler, logger log.Logger) (listener net.Listener, err error) {
|
func StartHTTPServer(listenAddr string, handler http.Handler, logger log.Logger) (listener net.Listener, err error) {
|
||||||
// listenAddr should be fully formed including tcp:// or unix:// prefix
|
|
||||||
var proto, addr string
|
var proto, addr string
|
||||||
parts := strings.SplitN(listenAddr, "://", 2)
|
parts := strings.SplitN(listenAddr, "://", 2)
|
||||||
if len(parts) != 2 {
|
if len(parts) != 2 {
|
||||||
logger.Error("WARNING (tendermint/rpc/lib): Please use fully formed listening addresses, including the tcp:// or unix:// prefix")
|
return nil, errors.Errorf("Invalid listening address %s (use fully formed addresses, including the tcp:// or unix:// prefix)", listenAddr)
|
||||||
// we used to allow addrs without tcp/unix prefix by checking for a colon
|
|
||||||
// TODO: Deprecate
|
|
||||||
proto = types.SocketType(listenAddr)
|
|
||||||
addr = listenAddr
|
|
||||||
// return nil, errors.Errorf("Invalid listener address %s", lisenAddr)
|
|
||||||
} else {
|
|
||||||
proto, addr = parts[0], parts[1]
|
|
||||||
}
|
}
|
||||||
|
proto, addr = parts[0], parts[1]
|
||||||
|
|
||||||
logger.Info(fmt.Sprintf("Starting RPC HTTP server on %s socket %v", proto, addr))
|
logger.Info(fmt.Sprintf("Starting RPC HTTP server on %s socket %v", proto, addr))
|
||||||
listener, err = net.Listen(proto, addr)
|
listener, err = net.Listen(proto, addr)
|
||||||
if err != nil {
|
if err != nil {
|
||||||
return nil, errors.Errorf("Failed to listen to %v: %v", listenAddr, err)
|
return nil, errors.Errorf("Failed to listen on %v: %v", listenAddr, err)
|
||||||
}
|
}
|
||||||
|
|
||||||
go func() {
|
go func() {
|
||||||
res := http.Serve(
|
err := http.Serve(
|
||||||
listener,
|
listener,
|
||||||
RecoverAndLogHandler(handler, logger),
|
RecoverAndLogHandler(handler, logger),
|
||||||
)
|
)
|
||||||
logger.Error("RPC HTTP server stopped", "result", res)
|
logger.Error("RPC HTTP server stopped", "err", err)
|
||||||
}()
|
}()
|
||||||
return listener, nil
|
return listener, nil
|
||||||
}
|
}
|
||||||
|
|
||||||
func StartHTTPAndTLSServer(listenAddr string, handler http.Handler, certFile, keyFile string, logger log.Logger) (listener net.Listener, err error) {
|
func StartHTTPAndTLSServer(listenAddr string, handler http.Handler, certFile, keyFile string, logger log.Logger) (listener net.Listener, err error) {
|
||||||
// listenAddr should be fully formed including tcp:// or unix:// prefix
|
|
||||||
var proto, addr string
|
var proto, addr string
|
||||||
parts := strings.SplitN(listenAddr, "://", 2)
|
parts := strings.SplitN(listenAddr, "://", 2)
|
||||||
if len(parts) != 2 {
|
if len(parts) != 2 {
|
||||||
logger.Error("WARNING (tendermint/rpc/lib): Please use fully formed listening addresses, including the tcp:// or unix:// prefix")
|
return nil, errors.Errorf("Invalid listening address %s (use fully formed addresses, including the tcp:// or unix:// prefix)", listenAddr)
|
||||||
// we used to allow addrs without tcp/unix prefix by checking for a colon
|
|
||||||
// TODO: Deprecate
|
|
||||||
proto = types.SocketType(listenAddr)
|
|
||||||
addr = listenAddr
|
|
||||||
// return nil, errors.Errorf("Invalid listener address %s", lisenAddr)
|
|
||||||
} else {
|
|
||||||
proto, addr = parts[0], parts[1]
|
|
||||||
}
|
}
|
||||||
|
proto, addr = parts[0], parts[1]
|
||||||
|
|
||||||
logger.Info(fmt.Sprintf("Starting RPC HTTPS server on %s socket %v", proto, addr))
|
logger.Info(fmt.Sprintf("Starting RPC HTTPS server on %s socket %v", proto, addr))
|
||||||
listener, err = net.Listen(proto, addr)
|
listener, err = net.Listen(proto, addr)
|
||||||
if err != nil {
|
if err != nil {
|
||||||
return nil, errors.Errorf("Failed to listen to %v: %v", listenAddr, err)
|
return nil, errors.Errorf("Failed to listen on %v: %v", listenAddr, err)
|
||||||
}
|
}
|
||||||
|
|
||||||
go func() {
|
go func() {
|
||||||
res := http.ServeTLS(
|
err := http.ServeTLS(
|
||||||
listener,
|
listener,
|
||||||
RecoverAndLogHandler(handler, logger),
|
RecoverAndLogHandler(handler, logger),
|
||||||
certFile,
|
certFile,
|
||||||
keyFile,
|
keyFile,
|
||||||
)
|
)
|
||||||
logger.Error("RPC HTTPS server stopped", "result", res)
|
logger.Error("RPC HTTPS server stopped", "err", err)
|
||||||
}()
|
}()
|
||||||
return listener, nil
|
return listener, nil
|
||||||
}
|
}
|
||||||
|
Reference in New Issue
Block a user