summaryrefslogtreecommitdiff
diff options
context:
space:
mode:
authorHarald Radi <phanto@php.net>2003-03-03 01:22:43 +0000
committerHarald Radi <phanto@php.net>2003-03-03 01:22:43 +0000
commita700180f5d9e9c7467caefb351118e402ed8832e (patch)
tree8858887b7c5e09e64319c1de95a66244d21490a0
parentacef51e677fd0aa837444c0b2ac289653a987628 (diff)
downloadphp-git-a700180f5d9e9c7467caefb351118e402ed8832e.tar.gz
commiting zend_disable_class patch for George:
disabled classes will be replaced by dummy classes that print a warning upon instanciation
-rw-r--r--Zend/zend_API.c28
-rw-r--r--Zend/zend_API.h4
2 files changed, 31 insertions, 1 deletions
diff --git a/Zend/zend_API.c b/Zend/zend_API.c
index b772b15c74..3caedab723 100644
--- a/Zend/zend_API.c
+++ b/Zend/zend_API.c
@@ -1419,6 +1419,34 @@ ZEND_API int zend_disable_function(char *function_name, uint function_name_lengt
return zend_register_functions(NULL, disabled_function, CG(function_table), MODULE_PERSISTENT TSRMLS_CC);
}
+static zend_object_value display_disabled_class(zend_class_entry *class_type TSRMLS_DC)
+{
+ zend_object_value retval;
+ zend_object *intern;
+ retval = zend_objects_new(&intern, class_type);
+ ALLOC_HASHTABLE(intern->properties);
+ zend_hash_init(intern->properties, 0, NULL, ZVAL_PTR_DTOR, 0);
+ zend_error(E_WARNING, "%s() has been disabled for security reasons", class_type->name);
+ return retval;
+}
+
+static zend_function_entry disabled_class_new[] = {
+ { NULL, NULL, NULL }
+};
+
+ZEND_API int zend_disable_class(char *class_name, uint class_name_length TSRMLS_DC)
+{
+ zend_class_entry *disabled_class;
+ disabled_class = (zend_class_entry *) emalloc(sizeof(zend_class_entry));
+ if (zend_hash_del(CG(class_table), class_name, class_name_length+1)==FAILURE) {
+ return FAILURE;
+ }
+ INIT_CLASS_ENTRY((*disabled_class), class_name, disabled_class_new);
+ disabled_class->create_object = display_disabled_class;
+ zend_register_internal_class(disabled_class TSRMLS_CC);
+ return 1;
+}
+
zend_bool zend_is_callable(zval *callable, zend_bool syntax_only, char **callable_name)
{
char *lcname;
diff --git a/Zend/zend_API.h b/Zend/zend_API.h
index 445d855229..26f7879ded 100644
--- a/Zend/zend_API.h
+++ b/Zend/zend_API.h
@@ -90,7 +90,7 @@ BEGIN_EXTERN_C()
#define INIT_OVERLOADED_CLASS_ENTRY(class_container, class_name, functions, handle_fcall, handle_propget, handle_propset) \
{ \
class_container.name = strdup(class_name); \
- class_container.name_length = sizeof(class_name)-1; \
+ class_container.name_length = strlen(class_name); \
class_container.builtin_functions = functions; \
class_container.constructor = NULL; \
class_container.destructor = NULL; \
@@ -136,6 +136,7 @@ ZEND_API zend_class_entry *zend_register_internal_class(zend_class_entry *class_
ZEND_API zend_class_entry *zend_register_internal_class_ex(zend_class_entry *class_entry, zend_class_entry *parent_ce, char *parent_name TSRMLS_DC);
ZEND_API int zend_disable_function(char *function_name, uint function_name_length TSRMLS_DC);
+ZEND_API int zend_disable_class(char *class_name, uint class_name_length TSRMLS_DC);
ZEND_API void zend_wrong_param_count(TSRMLS_D);
ZEND_API zend_bool zend_is_callable(zval *callable, zend_bool syntax_only, char **callable_name);
@@ -250,6 +251,7 @@ ZEND_API int zend_set_hash_symbol(zval *symbol, char *name, int name_length,
#define add_method(arg, key, method) add_assoc_function((arg), (key), (method))
ZEND_API ZEND_FUNCTION(display_disabled_function);
+ZEND_API ZEND_FUNCTION(display_disabled_class);
#if ZEND_DEBUG
#define CHECK_ZVAL_STRING(z) \