Improve field handling

This commit is contained in:
luk3yx 2023-03-28 14:53:28 +13:00
parent bba30cc267
commit 353d8c7a0b

View File

@ -498,9 +498,17 @@ local function chain_cb(f1, f2)
end end
end end
local function safe_tonumber(str)
local num = tonumber(str)
if num and num == num and num >= 0 then
return num
end
return 0
end
local field_value_transformers = { local field_value_transformers = {
tabheader = tonumber, tabheader = safe_tonumber,
dropdown = tonumber, dropdown = safe_tonumber,
checkbox = minetest.is_yes, checkbox = minetest.is_yes,
table = function(value) table = function(value)
return minetest.explode_table_event(value).row return minetest.explode_table_event(value).row
@ -878,8 +886,17 @@ local function on_fs_input(player, formname, fields)
-- Update the context before calling any callbacks -- Update the context before calling any callbacks
local redraw_fs = false local redraw_fs = false
for field, transformer in pairs(form_info.saved_fields) do for field, transformer in pairs(form_info.saved_fields) do
if fields[field] then local raw_value = fields[field]
local new_value = transformer(fields[field]) if raw_value then
if #raw_value > 1048576 then
-- There's probably no legitimate reason for a client send a
-- large amount of data and very long strings have the
-- potential to break things.
-- TODO: Consider lowering this length limit
minetest.log("warning", "[flow] Player " .. name ..
" tried submitting a large field value (>1MiB), ignoring.")
else
local new_value = transformer(raw_value)
if ctx_form[field] ~= new_value then if ctx_form[field] ~= new_value then
if redraw_if_changed[field] then if redraw_if_changed[field] then
redraw_fs = true redraw_fs = true
@ -891,6 +908,7 @@ local function on_fs_input(player, formname, fields)
ctx_form[field] = new_value ctx_form[field] = new_value
end end
end end
end
-- Run on_event callbacks -- Run on_event callbacks
for field, value in pairs(fields) do for field, value in pairs(fields) do