Comparison

util/xml.lua @ 12202:ebeb4d959fb3 0.11 0.11.13

util.xml: Deduplicate handlers for restricted XML Makes the code more like util.xmppstream, allowing easier comparisons if we ever need to apply fixes in the future.
author Kim Alvefur <zash@zash.se>
date Thu, 20 Jan 2022 10:51:46 +0100
parent 12201:e5e0ab93d7f4
child 12203:320de3e4b579
comparison
equal deleted inserted replaced
12201:e5e0ab93d7f4 12202:ebeb4d959fb3
64 end 64 end
65 function handler:EndElement() 65 function handler:EndElement()
66 stanza:up(); 66 stanza:up();
67 end 67 end
68 -- SECURITY: These two handlers, especially the Doctype one, are required to prevent exploits such as Billion Laughs. 68 -- SECURITY: These two handlers, especially the Doctype one, are required to prevent exploits such as Billion Laughs.
69 function handler:StartDoctypeDecl() 69 local function restricted_handler(parser)
70 if not self.stop or not self:stop() then 70 if not parser.stop or not parser:stop() then
71 error("Failed to abort parsing"); 71 error("Failed to abort parsing");
72 end 72 end
73 end 73 end
74 function handler:ProcessingInstruction() 74 handler.StartDoctypeDecl = restricted_handler;
75 if not self.stop or not self:stop() then 75 handler.ProcessingInstruction = restricted_handler;
76 error("Failed to abort parsing");
77 end
78 end
79 if not options or not options.allow_comments then 76 if not options or not options.allow_comments then
80 -- NOTE: comments are generally harmless and can be useful when parsing configuration files or other data, even user-provided data 77 -- NOTE: comments are generally harmless and can be useful when parsing configuration files or other data, even user-provided data
81 function handler:Comment() 78 handler.Comment = restricted_handler;
82 if not self.stop or not self:stop() then
83 error("Failed to abort parsing");
84 end
85 end
86 end 79 end
87 local parser = lxp.new(handler, ns_separator); 80 local parser = lxp.new(handler, ns_separator);
88 local ok, err, line, col = parser:parse(xml); 81 local ok, err, line, col = parser:parse(xml);
89 if ok then ok, err, line, col = parser:parse(); end 82 if ok then ok, err, line, col = parser:parse(); end
90 --parser:close(); 83 --parser:close();