Poll WIP (#231):

* backend security: avoid spoofing polls
This commit is contained in:
John Livingston 2024-07-01 15:01:30 +02:00
parent 8e2a3335ab
commit 3ef0541886
No known key found for this signature in database
GPG Key ID: B17B5640CE66CDBC
2 changed files with 22 additions and 0 deletions

View File

@ -159,8 +159,25 @@ local function poll_end_message(room)
return message_id; return message_id;
end end
-- security check: we must remove all specific tags, to be sure nobody tries to spoof polls!
local function remove_specific_tags_from_groupchat(event)
event.stanza:maptags(function (child)
if child.name == poll_message_tag then
return nil;
end
if child.name == poll_question_tag then
return nil;
end
if child.name == poll_choice_tag then
return nil;
end
return child;
end);
end
return { return {
poll_start_message = poll_start_message; poll_start_message = poll_start_message;
poll_end_message = poll_end_message; poll_end_message = poll_end_message;
schedule_poll_update_message = schedule_poll_update_message; schedule_poll_update_message = schedule_poll_update_message;
remove_specific_tags_from_groupchat = remove_specific_tags_from_groupchat;
}; };

View File

@ -19,6 +19,7 @@ local xmlns_poll = module:require("constants").xmlns_poll;
local send_form = module:require("form").send_form; local send_form = module:require("form").send_form;
local process_form = module:require("form").process_form; local process_form = module:require("form").process_form;
local handle_groupchat = module:require("poll").handle_groupchat; local handle_groupchat = module:require("poll").handle_groupchat;
local remove_specific_tags_from_groupchat = module:require("message").remove_specific_tags_from_groupchat
local room_restored = module:require("poll").room_restored; local room_restored = module:require("poll").room_restored;
-- new poll creation, get form -- new poll creation, get form
@ -81,6 +82,10 @@ end);
-- Note: we use a high priority, so it will be handled before the slow mode. -- Note: we use a high priority, so it will be handled before the slow mode.
module:hook("muc-occupant-groupchat", handle_groupchat, 1000); module:hook("muc-occupant-groupchat", handle_groupchat, 1000);
-- security check: we must remove all specific tags, to be sure nobody tries to spoof polls!
module:hook("muc-occupant-groupchat", remove_specific_tags_from_groupchat, 1000);
-- when a room is restored (after a server restart for example), -- when a room is restored (after a server restart for example),
-- we must resume any current poll -- we must resume any current poll
module:hook("muc-room-restored", room_restored); module:hook("muc-room-restored", room_restored);