mirror of
https://github.com/ergochat/ergo.git
synced 2025-01-05 09:32:32 +01:00
PROXY: Make sure given IPs are valid and pass them through appropriately
This commit is contained in:
parent
7d140c9e43
commit
38498b752b
@ -2239,9 +2239,21 @@ func proxyHandler(server *Server, client *Client, msg ircmsg.IrcMessage) bool {
|
|||||||
clientHostname := client.hostname
|
clientHostname := client.hostname
|
||||||
for _, address := range server.proxyAllowedFrom {
|
for _, address := range server.proxyAllowedFrom {
|
||||||
if clientHostname == address || clientAddress == address {
|
if clientHostname == address || clientAddress == address {
|
||||||
|
proxiedIP := msg.Params[1]
|
||||||
|
|
||||||
|
// ensure IP is sane
|
||||||
|
parsedProxiedIP := net.ParseIP(proxiedIP)
|
||||||
|
if parsedProxiedIP == nil {
|
||||||
|
client.Quit(fmt.Sprintf("Proxied IP address is not valid: [%s]", proxiedIP))
|
||||||
|
return true
|
||||||
|
}
|
||||||
|
|
||||||
//TODO(dan): check DLINEs and connection throttling/limits
|
//TODO(dan): check DLINEs and connection throttling/limits
|
||||||
|
|
||||||
|
// override the client's regular IP
|
||||||
client.proxiedIP = msg.Params[1]
|
client.proxiedIP = msg.Params[1]
|
||||||
client.hostname = LookupHostname(msg.Params[1])
|
client.hostname = LookupHostname(msg.Params[1])
|
||||||
|
client.rawHostname = LookupHostname(msg.Params[1])
|
||||||
return false
|
return false
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
Loading…
Reference in New Issue
Block a user