Commit f3afd700 authored by Miek Gieben's avatar Miek Gieben Committed by GitHub

request: Add LocalAddr() and LocalPort() (#1907)

These are used in the rewrite plugin, makes sense to have a common place
for them.
Signed-off-by: default avatarMiek Gieben <miek@miek.nl>
parent 2fd31cd3
......@@ -47,7 +47,7 @@ func (r *Request) IP() string {
return ip
}
// Port gets the (remote) Port of the client making the request.
// Port gets the (remote) port of the client making the request.
func (r *Request) Port() string {
_, port, err := net.SplitHostPort(r.W.RemoteAddr().String())
if err != nil {
......@@ -56,11 +56,21 @@ func (r *Request) Port() string {
return port
}
// RemoteAddr returns the net.Addr of the client that sent the current request.
func (r *Request) RemoteAddr() string {
return r.W.RemoteAddr().String()
// LocalPort gets the local port of the server handling the request.
func (r *Request) LocalPort() string {
_, port, err := net.SplitHostPort(r.W.LocalAddr().String())
if err != nil {
return "0"
}
return port
}
// RemoteAddr returns the net.Addr of the client that sent the current request.
func (r *Request) RemoteAddr() string { return r.W.RemoteAddr().String() }
// LocalAddr returns the net.Addr of the server handling the current request.
func (r *Request) LocalAddr() string { return r.W.LocalAddr().String() }
// Proto gets the protocol used as the transport. This will be udp or tcp.
func (r *Request) Proto() string { return Proto(r.W) }
......
Markdown is supported
0% or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment