redirect_to(redirect)
- -- TODO: Implement time invariant string comparison function to mitigate timing attack.
+ -- Lua hashes strings, so these comparisons are time invariant.
if password == nil or password ~= post["password"] then
set_cookie("cgitauth", "")
else
cgit["repo"] = select(9, ...)
cgit["page"] = select(10, ...)
cgit["url"] = select(11, ...)
-
- cgit["login"] = ""
- for _ in cgit["url"]:gfind("/") do
- cgit["login"] = cgit["login"] .. "../"
- end
- cgit["login"] = cgit["login"] .. "?p=login"
+ cgit["login"] = select(12, ...)
end
return nil
end
- -- TODO: implement time invariant comparison to prevent against timing attack.
+ -- Lua hashes strings, so these comparisons are time invariant.
if hmac ~= crypto.hmac.digest("sha1", value .. "|" .. tostring(expiration) .. "|" .. salt, secret) then
return nil
end