From c23efdbdb0c577d78d341aa10398fee5a58420fc Mon Sep 17 00:00:00 2001 From: Jean Baptiste Favre Date: Wed, 19 Jun 2013 11:16:05 +0200 Subject: [PATCH 1/3] PHP 5.4 compatibility: remove call-time pass by reference --- actions/profilecompletion.php | 3 +-- plugins/Aim/AimPlugin.php | 2 +- .../DomainStatusNetwork/lib/domainstatusnetworkinstaller.php | 3 +++ plugins/Irc/IrcPlugin.php | 2 +- plugins/Msn/MsnPlugin.php | 2 +- plugins/Xmpp/XmppPlugin.php | 2 +- 6 files changed, 8 insertions(+), 6 deletions(-) diff --git a/actions/profilecompletion.php b/actions/profilecompletion.php index 045bf68a7f..00dbe9d29d 100644 --- a/actions/profilecompletion.php +++ b/actions/profilecompletion.php @@ -179,8 +179,7 @@ class ProfilecompletionAction extends Action else { $cnt = $profile->find(); } - // @todo FIXME: Call-time pass-by-reference has been deprecated. - Event::handle('EndProfileCompletionSearch', $this, &$profile, $search_engine); + Event::handle('EndProfileCompletionSearch', $this, $profile, $search_engine); } while ($profile->fetch()) { diff --git a/plugins/Aim/AimPlugin.php b/plugins/Aim/AimPlugin.php index e44505b21c..ffb9345877 100644 --- a/plugins/Aim/AimPlugin.php +++ b/plugins/Aim/AimPlugin.php @@ -109,7 +109,7 @@ class AimPlugin extends ImPlugin function onStartImDaemonIoManagers(&$classes) { - parent::onStartImDaemonIoManagers(&$classes); + parent::onStartImDaemonIoManagers($classes); $classes[] = new AimManager($this); // handles sending/receiving return true; } diff --git a/plugins/DomainStatusNetwork/lib/domainstatusnetworkinstaller.php b/plugins/DomainStatusNetwork/lib/domainstatusnetworkinstaller.php index a30ab110ab..dd93a51153 100644 --- a/plugins/DomainStatusNetwork/lib/domainstatusnetworkinstaller.php +++ b/plugins/DomainStatusNetwork/lib/domainstatusnetworkinstaller.php @@ -267,6 +267,9 @@ class DomainStatusNetworkInstaller extends Installer function createDatabase() { // Create the New DB + /* FIXME + * Extension 'mysql_' is deprecated since PHP 5.5 - use mysqli instead. + */ $res = mysql_connect($this->host, $this->rootname, $this->rootpass); if (!$res) { throw new ServerException("Cannot connect to {$this->host} as {$this->rootname}."); diff --git a/plugins/Irc/IrcPlugin.php b/plugins/Irc/IrcPlugin.php index 2c52bb99bd..f74324c186 100644 --- a/plugins/Irc/IrcPlugin.php +++ b/plugins/Irc/IrcPlugin.php @@ -147,7 +147,7 @@ class IrcPlugin extends ImPlugin { * @return boolean */ public function onStartImDaemonIoManagers(&$classes) { - parent::onStartImDaemonIoManagers(&$classes); + parent::onStartImDaemonIoManagers($classes); $classes[] = new IrcManager($this); // handles sending/receiving return true; } diff --git a/plugins/Msn/MsnPlugin.php b/plugins/Msn/MsnPlugin.php index ccc190334d..fdef94ce55 100644 --- a/plugins/Msn/MsnPlugin.php +++ b/plugins/Msn/MsnPlugin.php @@ -120,7 +120,7 @@ class MsnPlugin extends ImPlugin { * @return boolean */ public function onStartImDaemonIoManagers(&$classes) { - parent::onStartImDaemonIoManagers(&$classes); + parent::onStartImDaemonIoManagers($classes); $classes[] = new MsnManager($this); // handles sending/receiving return true; } diff --git a/plugins/Xmpp/XmppPlugin.php b/plugins/Xmpp/XmppPlugin.php index 74e104d974..99d43e47c5 100644 --- a/plugins/Xmpp/XmppPlugin.php +++ b/plugins/Xmpp/XmppPlugin.php @@ -310,7 +310,7 @@ class XmppPlugin extends ImPlugin function onStartImDaemonIoManagers(&$classes) { - parent::onStartImDaemonIoManagers(&$classes); + parent::onStartImDaemonIoManagers($classes); $classes[] = new XmppManager($this); // handles pings/reconnects return true; } From f1a3d5a386b9331284db8c0f3e41a916f0cca64c Mon Sep 17 00:00:00 2001 From: Jean Baptiste Favre Date: Wed, 19 Jun 2013 13:25:28 +0200 Subject: [PATCH 2/3] PHP 5.4 Fix GetValidDaemons function definition for Xmpp & TwitterBridge plugins --- plugins/TwitterBridge/TwitterBridgePlugin.php | 2 +- plugins/Xmpp/XmppPlugin.php | 2 +- 2 files changed, 2 insertions(+), 2 deletions(-) diff --git a/plugins/TwitterBridge/TwitterBridgePlugin.php b/plugins/TwitterBridge/TwitterBridgePlugin.php index 1b8e55e9b7..4d697509dc 100644 --- a/plugins/TwitterBridge/TwitterBridgePlugin.php +++ b/plugins/TwitterBridge/TwitterBridgePlugin.php @@ -249,7 +249,7 @@ class TwitterBridgePlugin extends Plugin * * @return boolean hook return */ - function onGetValidDaemons($daemons) + function onGetValidDaemons(&$daemons) { if (self::hasKeys()) { array_push( diff --git a/plugins/Xmpp/XmppPlugin.php b/plugins/Xmpp/XmppPlugin.php index 99d43e47c5..f56d33f0a3 100644 --- a/plugins/Xmpp/XmppPlugin.php +++ b/plugins/Xmpp/XmppPlugin.php @@ -440,7 +440,7 @@ class XmppPlugin extends ImPlugin * * @return boolean hook return */ - function onGetValidDaemons($daemons) + function onGetValidDaemons(&$daemons) { if( isset($this->server) && isset($this->port) && From 723f0f19295ef40106d18fbd59033a892b7b5b13 Mon Sep 17 00:00:00 2001 From: Jean Baptiste Favre Date: Thu, 20 Jun 2013 11:07:51 +0200 Subject: [PATCH 3/3] PHP 5.4: Fix 'mysql has gone away' error when using mysqli driver with forked daemons (at least TwitterBridge) --- lib/daemon.php | 11 +++++++++++ 1 file changed, 11 insertions(+) diff --git a/lib/daemon.php b/lib/daemon.php index 4c2491e97b..c09531c9d5 100644 --- a/lib/daemon.php +++ b/lib/daemon.php @@ -48,6 +48,17 @@ class Daemon function background() { + /* Starting PHP 5.4 (dotdeb), maybe earlier for some version/distrib + * seems MySQL connection using mysqli driver get lost when fork. + * Need to unset it so that child process recreate it. + * + * Not needed if using mysql driver (but it's deprecated starting PHP 5.5) + * + * @todo FIXME cleaner way to do it ? + */ + global $_DB_DATAOBJECT; + unset($_DB_DATAOBJECT['CONNECTIONS']); + $pid = pcntl_fork(); if ($pid < 0) { // error common_log(LOG_ERR, "Could not fork.");