mirror of
https://gitgud.io/fatchan/haproxy-protection.git
synced 2025-05-09 02:05:37 +00:00
Add some reasonable limits to cookie parsing, reduce impact of possible attack
This commit is contained in:
@ -11,11 +11,12 @@ local SEMICOLON = byte(";")
|
||||
local SPACE = byte(" ")
|
||||
local HTAB = byte("\t")
|
||||
|
||||
local MAX_LEN = 10 * 1024 -- in case you are a dumbass and set a high tune.maxrewrite
|
||||
local MAX_COOKIES = 100
|
||||
|
||||
local _M = {}
|
||||
_M._VERSION = '0.01'
|
||||
|
||||
|
||||
function _M.get_cookie_table(text_cookie)
|
||||
if type(text_cookie) ~= "string" then
|
||||
return {}
|
||||
@ -27,10 +28,16 @@ function _M.get_cookie_table(text_cookie)
|
||||
|
||||
local n = 0
|
||||
local len = #text_cookie
|
||||
if len > MAX_LEN then
|
||||
return {}
|
||||
end
|
||||
|
||||
for i=1, len do
|
||||
if byte(text_cookie, i) == SEMICOLON then
|
||||
n = n + 1
|
||||
if n > MAX_COOKIES then
|
||||
return {}
|
||||
end
|
||||
end
|
||||
end
|
||||
|
||||
|
Reference in New Issue
Block a user