summaryrefslogtreecommitdiff
path: root/ext/xml/xml.c
diff options
context:
space:
mode:
authorMark <mrandall@digitellinc.com>2019-10-04 20:38:49 +0100
committerNikita Popov <nikita.ppv@gmail.com>2019-10-07 10:24:41 +0200
commit52376c177dc10993dccdaa1ff20c347c8dda6d0a (patch)
tree4732345daecb4c0ee6f4f0645c7830ae3ec251ef /ext/xml/xml.c
parentdd61edfd7cf5ebe03b502a8da647e01fa0f4f8b5 (diff)
downloadphp-git-52376c177dc10993dccdaa1ff20c347c8dda6d0a.tar.gz
Fix bug #78563
Make XmlParser final, unclonable and unserializable. Closes GH-4778.
Diffstat (limited to 'ext/xml/xml.c')
-rw-r--r--ext/xml/xml.c8
1 files changed, 6 insertions, 2 deletions
diff --git a/ext/xml/xml.c b/ext/xml/xml.c
index f0ffcac961..a033accfdb 100644
--- a/ext/xml/xml.c
+++ b/ext/xml/xml.c
@@ -26,6 +26,7 @@
#include "ext/standard/php_string.h"
#include "ext/standard/info.h"
#include "ext/standard/html.h"
+#include "zend_interfaces.h"
#if HAVE_XML
@@ -308,15 +309,18 @@ PHP_MINIT_FUNCTION(xml)
{
zend_class_entry ce;
INIT_CLASS_ENTRY(ce, "XmlParser", xml_parser_methods);
- ce.create_object = xml_parser_create_object;
- ce.ce_flags |= ZEND_ACC_FINAL;
xml_parser_ce = zend_register_internal_class(&ce);
+ xml_parser_ce->create_object = xml_parser_create_object;
+ xml_parser_ce->ce_flags |= ZEND_ACC_FINAL;
+ xml_parser_ce->serialize = zend_class_serialize_deny;
+ xml_parser_ce->unserialize = zend_class_unserialize_deny;
memcpy(&xml_parser_object_handlers, &std_object_handlers, sizeof(zend_object_handlers));
xml_parser_object_handlers.offset = XtOffsetOf(xml_parser, std);
xml_parser_object_handlers.free_obj = xml_parser_free_obj;
xml_parser_object_handlers.get_gc = xml_parser_get_gc;
xml_parser_object_handlers.get_constructor = xml_parser_get_constructor;
+ xml_parser_object_handlers.clone_obj = NULL;
REGISTER_LONG_CONSTANT("XML_ERROR_NONE", XML_ERROR_NONE, CONST_CS|CONST_PERSISTENT);
REGISTER_LONG_CONSTANT("XML_ERROR_NO_MEMORY", XML_ERROR_NO_MEMORY, CONST_CS|CONST_PERSISTENT);