Software /
code /
prosody
Diff
plugins/mod_proxy65.lua @ 11012:027af78d8125
mod_proxy65: Limit dump of invalid data to 300 bytes (like mod_c2s)
author | Kim Alvefur <zash@zash.se> |
---|---|
date | Fri, 17 Jul 2020 08:29:03 +0200 |
parent | 11011:c079103c9172 |
child | 11560:3bbb1af92514 |
line wrap: on
line diff
--- a/plugins/mod_proxy65.lua Thu Jul 16 10:26:36 2020 +0200 +++ b/plugins/mod_proxy65.lua Fri Jul 17 08:29:03 2020 +0200 @@ -44,7 +44,7 @@ end -- else error, unexpected input conn:write("\5\255"); -- send (SOCKS version 5, no acceptable method) conn:close(); - module:log("debug", "Invalid SOCKS5 greeting received: %q", data); + module:log("debug", "Invalid SOCKS5 greeting received: %q", data:sub(1, 300)); else -- connection request --local head = string.char( 0x05, 0x01, 0x00, 0x03, 40 ); -- ( VER=5=SOCKS5, CMD=1=CONNECT, RSV=0=RESERVED, ATYP=3=DOMAIMNAME, SHA-1 size ) if #data == 47 and data:sub(1,5) == "\5\1\0\3\40" and data:sub(-2) == "\0\0" then @@ -66,7 +66,7 @@ else -- error, unexpected input conn:write("\5\1\0\3\0\0\0"); -- VER, REP, RSV, ATYP, BND.ADDR (sha), BND.PORT (2 Byte) conn:close(); - module:log("debug", "Invalid SOCKS5 negotiation received: %q", data); + module:log("debug", "Invalid SOCKS5 negotiation received: %q", data:sub(1, 300)); end end end