From 49bb467d1ddc7c1b86fd76543973ed9b5bd1ef61 Mon Sep 17 00:00:00 2001 From: Remi Collet Date: Fri, 9 Sep 2022 14:26:00 +0200 Subject: add patch for PHP 8.2 from https://github.com/php/pecl-web_services-oauth/pull/24 --- oauth-php82.patch | 85 +++++++++++++++++++++++++++++++++++++++++++++++++++++++ 1 file changed, 85 insertions(+) create mode 100644 oauth-php82.patch (limited to 'oauth-php82.patch') diff --git a/oauth-php82.patch b/oauth-php82.patch new file mode 100644 index 0000000..ad8eb4a --- /dev/null +++ b/oauth-php82.patch @@ -0,0 +1,85 @@ +From 66e8e9cf9805c96dd9aa6a7c08ec0da5c2c6b656 Mon Sep 17 00:00:00 2001 +From: Remi Collet +Date: Fri, 9 Sep 2022 14:03:57 +0200 +Subject: [PATCH] fix for php 8.2: declare used properties + +--- + oauth.c | 1 + + provider.c | 13 +++++++++++++ + tests/oauthprovider_001.phpt | 12 ++++++++---- + 3 files changed, 22 insertions(+), 4 deletions(-) + +diff --git a/oauth.c b/oauth.c +index f845893..46eccda 100644 +--- a/oauth.c ++++ b/oauth.c +@@ -2781,6 +2781,7 @@ PHP_MINIT_FUNCTION(oauth) + soo_exception_ce = zend_register_internal_class_ex(&soo_ex_ce, zend_exception_get_default()); + zend_declare_property_null(soo_exception_ce, "lastResponse", sizeof("lastResponse")-1, ZEND_ACC_PUBLIC); + zend_declare_property_null(soo_exception_ce, "debugInfo", sizeof("debugInfo")-1, ZEND_ACC_PUBLIC); ++ zend_declare_property_null(soo_exception_ce, "additionalInfo", sizeof("additionalInfo")-1, ZEND_ACC_PUBLIC); + + REGISTER_STRING_CONSTANT("OAUTH_SIG_METHOD_HMACSHA1", OAUTH_SIG_METHOD_HMACSHA1, CONST_CS | CONST_PERSISTENT); + REGISTER_STRING_CONSTANT("OAUTH_SIG_METHOD_HMACSHA256", OAUTH_SIG_METHOD_HMACSHA256, CONST_CS | CONST_PERSISTENT); +diff --git a/provider.c b/provider.c +index 45880fb..43f2bc0 100644 +--- a/provider.c ++++ b/provider.c +@@ -1184,6 +1184,19 @@ extern int oauth_provider_register_class(void) /* {{{ */ + osce.create_object = oauth_provider_new; + oauthprovider = zend_register_internal_class(&osce); + ++ zend_declare_property_null(oauthprovider, OAUTH_PROVIDER_CONSUMER_KEY, sizeof(OAUTH_PROVIDER_CONSUMER_KEY)-1, ZEND_ACC_PUBLIC); ++ zend_declare_property_null(oauthprovider, OAUTH_PROVIDER_CONSUMER_SECRET, sizeof(OAUTH_PROVIDER_CONSUMER_SECRET)-1, ZEND_ACC_PUBLIC); ++ zend_declare_property_null(oauthprovider, OAUTH_PROVIDER_SIGNATURE, sizeof(OAUTH_PROVIDER_SIGNATURE)-1, ZEND_ACC_PUBLIC); ++ zend_declare_property_null(oauthprovider, OAUTH_PROVIDER_SIGNATURE_METHOD, sizeof(OAUTH_PROVIDER_SIGNATURE_METHOD)-1, ZEND_ACC_PUBLIC); ++ zend_declare_property_null(oauthprovider, OAUTH_PROVIDER_TOKEN, sizeof(OAUTH_PROVIDER_TOKEN)-1, ZEND_ACC_PUBLIC); ++ zend_declare_property_null(oauthprovider, OAUTH_PROVIDER_TOKEN_SECRET, sizeof(OAUTH_PROVIDER_TOKEN_SECRET)-1, ZEND_ACC_PUBLIC); ++ zend_declare_property_null(oauthprovider, OAUTH_PROVIDER_NONCE, sizeof(OAUTH_PROVIDER_NONCE)-1, ZEND_ACC_PUBLIC); ++ zend_declare_property_null(oauthprovider, OAUTH_PROVIDER_TIMESTAMP, sizeof(OAUTH_PROVIDER_TIMESTAMP)-1, ZEND_ACC_PUBLIC); ++ zend_declare_property_null(oauthprovider, OAUTH_PROVIDER_VERSION, sizeof(OAUTH_PROVIDER_VERSION)-1, ZEND_ACC_PUBLIC); ++ zend_declare_property_null(oauthprovider, OAUTH_PROVIDER_CALLBACK, sizeof(OAUTH_PROVIDER_CALLBACK)-1, ZEND_ACC_PUBLIC); ++ zend_declare_property_null(oauthprovider, OAUTH_PROVIDER_VERIFIER, sizeof(OAUTH_PROVIDER_VERIFIER)-1, ZEND_ACC_PUBLIC); ++ zend_declare_property_null(oauthprovider, "request_token_endpoint", sizeof("request_token_endpoint")-1, ZEND_ACC_PUBLIC); ++ + memcpy(&oauth_provider_obj_hndlrs, zend_get_std_object_handlers(), sizeof(zend_object_handlers)); + oauth_provider_obj_hndlrs.offset = XtOffsetOf(php_oauth_provider, zo); + oauth_provider_obj_hndlrs.free_obj = oauth_provider_free_storage; +diff --git a/tests/oauthprovider_001.phpt b/tests/oauthprovider_001.phpt +index e93af65..ab005c4 100644 +--- a/tests/oauthprovider_001.phpt ++++ b/tests/oauthprovider_001.phpt +@@ -6,25 +6,29 @@ $provider = new OAuthProvider(['foo' => 'bar']); + var_dump($provider); + + --EXPECT-- +-object(OAuthProvider)#1 (10) { ++object(OAuthProvider)#1 (12) { + ["consumer_key"]=> + NULL + ["consumer_secret"]=> + NULL +- ["nonce"]=> ++ ["signature"]=> ++ NULL ++ ["signature_method"]=> + NULL + ["token"]=> + NULL + ["token_secret"]=> + NULL ++ ["nonce"]=> ++ NULL + ["timestamp"]=> + NULL + ["version"]=> + NULL +- ["signature_method"]=> +- NULL + ["callback"]=> + NULL ++ ["verifier"]=> ++ NULL + ["request_token_endpoint"]=> + bool(false) + } -- cgit