forked from GNUsocial/gnu-social
		
	[DATABASE] Use "<>" as an SQL non-equality sign in more cases
A follow-up to commit 644b417f6c
			
			
This commit is contained in:
		| @@ -1,23 +1,25 @@ | |||||||
| <?php | <?php | ||||||
|  | // This file is part of GNU social - https://www.gnu.org/software/social | ||||||
|  | // | ||||||
|  | // GNU social is free software: you can redistribute it and/or modify | ||||||
|  | // it under the terms of the GNU Affero General Public License as published by | ||||||
|  | // the Free Software Foundation, either version 3 of the License, or | ||||||
|  | // (at your option) any later version. | ||||||
|  | // | ||||||
|  | // GNU social is distributed in the hope that it will be useful, | ||||||
|  | // but WITHOUT ANY WARRANTY; without even the implied warranty of | ||||||
|  | // MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the | ||||||
|  | // GNU Affero General Public License for more details. | ||||||
|  | // | ||||||
|  | // You should have received a copy of the GNU Affero General Public License | ||||||
|  | // along with GNU social.  If not, see <http://www.gnu.org/licenses/>. | ||||||
|  |  | ||||||
| /* | /* | ||||||
|  * StatusNet - the distributed open-source microblogging tool |  * @copyright 2008, 2009 StatusNet, Inc. | ||||||
|  * Copyright (C) 2008, 2009, StatusNet, Inc. |  * @license   https://www.gnu.org/licenses/agpl.html GNU AGPL v3 or later | ||||||
|  * |  | ||||||
|  * This program is free software: you can redistribute it and/or modify |  | ||||||
|  * it under the terms of the GNU Affero General Public License as published by |  | ||||||
|  * the Free Software Foundation, either version 3 of the License, or |  | ||||||
|  * (at your option) any later version. |  | ||||||
|  * |  | ||||||
|  * This program is distributed in the hope that it will be useful, |  | ||||||
|  * but WITHOUT ANY WARRANTY; without even the implied warranty of |  | ||||||
|  * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the |  | ||||||
|  * GNU Affero General Public License for more details. |  | ||||||
|  * |  | ||||||
|  * You should have received a copy of the GNU Affero General Public License |  | ||||||
|  * along with this program.  If not, see <http://www.gnu.org/licenses/>. |  | ||||||
|  */ |  */ | ||||||
|  |  | ||||||
| if (!defined('GNUSOCIAL')) { exit(1); } | defined('GNUSOCIAL') || die(); | ||||||
|  |  | ||||||
| define('LISTENER', 1); | define('LISTENER', 1); | ||||||
| define('LISTENEE', -1); | define('LISTENEE', -1); | ||||||
| @@ -26,7 +28,7 @@ define('BOTH', 0); | |||||||
| // @todo XXX: Documentation missing. | // @todo XXX: Documentation missing. | ||||||
| class FoafAction extends ManagedAction | class FoafAction extends ManagedAction | ||||||
| { | { | ||||||
|     function isReadOnly($args) |     public function isReadOnly($args) | ||||||
|     { |     { | ||||||
|         return true; |         return true; | ||||||
|     } |     } | ||||||
| @@ -45,9 +47,13 @@ class FoafAction extends ManagedAction | |||||||
|         // Permanent redirect on non-canonical nickname |         // Permanent redirect on non-canonical nickname | ||||||
|  |  | ||||||
|         if ($nickname_arg != $this->nickname) { |         if ($nickname_arg != $this->nickname) { | ||||||
|             common_redirect(common_local_url('foaf', |             common_redirect( | ||||||
|                                              array('nickname' => $this->nickname)), |                 common_local_url( | ||||||
|                             301); |                     'foaf', | ||||||
|  |                     ['nickname' => $this->nickname] | ||||||
|  |                 ), | ||||||
|  |                 301 | ||||||
|  |             ); | ||||||
|         } |         } | ||||||
|  |  | ||||||
|         $this->user = User::getKV('nickname', $this->nickname); |         $this->user = User::getKV('nickname', $this->nickname); | ||||||
| @@ -152,16 +158,21 @@ class FoafAction extends ManagedAction | |||||||
|             // No avatar for this user! |             // No avatar for this user! | ||||||
|         } |         } | ||||||
|  |  | ||||||
|         $person = $this->showMicrobloggingAccount($this->profile, |         $person = $this->showMicrobloggingAccount( | ||||||
|                                      common_root_url(), $this->user->getUri(), |             $this->profile, | ||||||
|                                      /*$fetchSubscriptions*/true, |             common_root_url(), | ||||||
|                                      /*$isSubscriber*/false); |             $this->user->getUri(), | ||||||
|  |             // $fetchSubscriptions | ||||||
|  |             true, | ||||||
|  |             // $isSubscriber | ||||||
|  |             false | ||||||
|  |         ); | ||||||
|  |  | ||||||
|         // Get people who subscribe to user |         // Get people who subscribe to user | ||||||
|  |  | ||||||
|         $sub = new Subscription(); |         $sub = new Subscription(); | ||||||
|         $sub->subscribed = $this->profile->id; |         $sub->subscribed = $this->profile->id; | ||||||
|         $sub->whereAdd('subscriber != subscribed'); |         $sub->whereAdd('subscriber <> subscribed'); | ||||||
|  |  | ||||||
|         if ($sub->find()) { |         if ($sub->find()) { | ||||||
|             while ($sub->fetch()) { |             while ($sub->fetch()) { | ||||||
| @@ -206,11 +217,15 @@ class FoafAction extends ManagedAction | |||||||
|             if ($type == BOTH) { |             if ($type == BOTH) { | ||||||
|                 $this->element('knows', array('rdf:resource' => $this->user->getUri())); |                 $this->element('knows', array('rdf:resource' => $this->user->getUri())); | ||||||
|             } |             } | ||||||
|             $this->showMicrobloggingAccount($profile, |             $this->showMicrobloggingAccount( | ||||||
|                                    ($local == 'local') ? common_root_url() : null, |                 $profile, | ||||||
|  |                 ($local === 'local') ? common_root_url() : null, | ||||||
|                 $uri, |                 $uri, | ||||||
|                                    /*$fetchSubscriptions*/false, |                 // $fetchSubscriptions | ||||||
|                                    /*$isSubscriber*/($type == LISTENER || $type == BOTH)); |                 false, | ||||||
|  |                 // $isSubscriber | ||||||
|  |                 ($type == LISTENER || $type == BOTH) | ||||||
|  |             ); | ||||||
|             if ($foaf_url) { |             if ($foaf_url) { | ||||||
|                 $this->element('rdfs:seeAlso', array('rdf:resource' => $foaf_url)); |                 $this->element('rdfs:seeAlso', array('rdf:resource' => $foaf_url)); | ||||||
|             } |             } | ||||||
| @@ -227,7 +242,7 @@ class FoafAction extends ManagedAction | |||||||
|         $this->endXML(); |         $this->endXML(); | ||||||
|     } |     } | ||||||
|  |  | ||||||
|     function showPpd($foaf_url, $person_uri) |     public function showPpd($foaf_url, $person_uri) | ||||||
|     { |     { | ||||||
|         $this->elementStart('PersonalProfileDocument', array('rdf:about' => $foaf_url)); |         $this->elementStart('PersonalProfileDocument', array('rdf:about' => $foaf_url)); | ||||||
|         $this->element('maker', array('rdf:resource' => $person_uri)); |         $this->element('maker', array('rdf:resource' => $person_uri)); | ||||||
| @@ -248,7 +263,7 @@ class FoafAction extends ManagedAction | |||||||
|      * @return array if $fetchSubscribers is set, return a list of info on those |      * @return array if $fetchSubscribers is set, return a list of info on those | ||||||
|      *               subscriptions. |      *               subscriptions. | ||||||
|      */ |      */ | ||||||
|     function showMicrobloggingAccount($profile, $service=null, $useruri=null, $fetchSubscriptions=false, $isSubscriber=false) |     public function showMicrobloggingAccount($profile, $service = null, $useruri = null, $fetchSubscriptions = false, $isSubscriber = false) | ||||||
|     { |     { | ||||||
|         $attr = array(); |         $attr = array(); | ||||||
|         if ($useruri) { |         if ($useruri) { | ||||||
| @@ -274,7 +289,7 @@ class FoafAction extends ManagedAction | |||||||
|             // Get people user is subscribed to |             // Get people user is subscribed to | ||||||
|             $sub = new Subscription(); |             $sub = new Subscription(); | ||||||
|             $sub->subscriber = $profile->id; |             $sub->subscriber = $profile->id; | ||||||
|             $sub->whereAdd('subscriber != subscribed'); |             $sub->whereAdd('subscriber <> subscribed'); | ||||||
|  |  | ||||||
|             if ($sub->find()) { |             if ($sub->find()) { | ||||||
|                 while ($sub->fetch()) { |                 while ($sub->fetch()) { | ||||||
|   | |||||||
| @@ -1,42 +1,38 @@ | |||||||
| <?php | <?php | ||||||
|  | // This file is part of GNU social - https://www.gnu.org/software/social | ||||||
|  | // | ||||||
|  | // GNU social is free software: you can redistribute it and/or modify | ||||||
|  | // it under the terms of the GNU Affero General Public License as published by | ||||||
|  | // the Free Software Foundation, either version 3 of the License, or | ||||||
|  | // (at your option) any later version. | ||||||
|  | // | ||||||
|  | // GNU social is distributed in the hope that it will be useful, | ||||||
|  | // but WITHOUT ANY WARRANTY; without even the implied warranty of | ||||||
|  | // MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the | ||||||
|  | // GNU Affero General Public License for more details. | ||||||
|  | // | ||||||
|  | // You should have received a copy of the GNU Affero General Public License | ||||||
|  | // along with GNU social.  If not, see <http://www.gnu.org/licenses/>. | ||||||
|  |  | ||||||
| /** | /** | ||||||
|  * StatusNet, the distributed open-source microblogging tool |  | ||||||
|  * |  | ||||||
|  * List the OAuth applications that a user has registered with this instance |  * List the OAuth applications that a user has registered with this instance | ||||||
|  * |  * | ||||||
|  * PHP version 5 |  | ||||||
|  * |  | ||||||
|  * LICENCE: This program is free software: you can redistribute it and/or modify |  | ||||||
|  * it under the terms of the GNU Affero General Public License as published by |  | ||||||
|  * the Free Software Foundation, either version 3 of the License, or |  | ||||||
|  * (at your option) any later version. |  | ||||||
|  * |  | ||||||
|  * This program is distributed in the hope that it will be useful, |  | ||||||
|  * but WITHOUT ANY WARRANTY; without even the implied warranty of |  | ||||||
|  * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the |  | ||||||
|  * GNU Affero General Public License for more details. |  | ||||||
|  * |  | ||||||
|  * You should have received a copy of the GNU Affero General Public License |  | ||||||
|  * along with this program.  If not, see <http://www.gnu.org/licenses/>. |  | ||||||
|  * |  | ||||||
|  * @category  Settings |  * @category  Settings | ||||||
|  * @package   StatusNet |  * @package   GNUsocial | ||||||
|  * @author    Zach Copley <zach@status.net> |  * @author    Zach Copley <zach@status.net> | ||||||
|  * @copyright 2008-2009 StatusNet, Inc. |  * @copyright 2008-2009 StatusNet, Inc. | ||||||
|  * @license   http://www.fsf.org/licensing/licenses/agpl-3.0.html GNU Affero General Public License version 3.0 |  * @license   https://www.gnu.org/licenses/agpl.html GNU AGPL v3 or later | ||||||
|  * @link      http://status.net/ |  | ||||||
|  */ |  */ | ||||||
|  |  | ||||||
| if (!defined('GNUSOCIAL')) { exit(1); } | defined('GNUSOCIAL') || die(); | ||||||
|  |  | ||||||
| /** | /** | ||||||
|  * Show a user's registered OAuth applications |  * Show a user's registered OAuth applications | ||||||
|  * |  * | ||||||
|  * @category  Settings |  * @category  Settings | ||||||
|  * @package  StatusNet |  * @package   GNUsocial | ||||||
|  * @author    Zach Copley <zach@status.net> |  * @author    Zach Copley <zach@status.net> | ||||||
|  * @license  http://www.fsf.org/licensing/licenses/agpl-3.0.html GNU Affero General Public License version 3.0 |  * @license   https://www.gnu.org/licenses/agpl.html GNU AGPL v3 or later | ||||||
|  * @link     http://status.net/ |  | ||||||
|  * |  * | ||||||
|  * @see      SettingsAction |  * @see      SettingsAction | ||||||
|  */ |  */ | ||||||
| @@ -56,7 +52,7 @@ class OauthappssettingsAction extends SettingsAction | |||||||
|      * @return string Title of the page |      * @return string Title of the page | ||||||
|      */ |      */ | ||||||
|  |  | ||||||
|     function title() |     public function title() | ||||||
|     { |     { | ||||||
|         // TRANS: Page title for OAuth applications |         // TRANS: Page title for OAuth applications | ||||||
|         return _('OAuth applications'); |         return _('OAuth applications'); | ||||||
| @@ -68,20 +64,20 @@ class OauthappssettingsAction extends SettingsAction | |||||||
|      * @return instructions for use |      * @return instructions for use | ||||||
|      */ |      */ | ||||||
|  |  | ||||||
|     function getInstructions() |     public function getInstructions() | ||||||
|     { |     { | ||||||
|         // TRANS: Page instructions for OAuth applications |         // TRANS: Page instructions for OAuth applications | ||||||
|         return _('Applications you have registered'); |         return _('Applications you have registered'); | ||||||
|     } |     } | ||||||
|  |  | ||||||
|     function showContent() |     public function showContent() | ||||||
|     { |     { | ||||||
|         $offset = ($this->page - 1) * APPS_PER_PAGE; |         $offset = ($this->page - 1) * APPS_PER_PAGE; | ||||||
|         $limit  =  APPS_PER_PAGE + 1; |         $limit  =  APPS_PER_PAGE + 1; | ||||||
|  |  | ||||||
|         $application = new Oauth_application(); |         $application = new Oauth_application(); | ||||||
|         $application->owner = $this->scoped->getID(); |         $application->owner = $this->scoped->getID(); | ||||||
|         $application->whereAdd("name != 'anonymous'"); |         $application->whereAdd("name <> 'anonymous'"); | ||||||
|         $application->limit($offset, $limit); |         $application->limit($offset, $limit); | ||||||
|         $application->orderBy('created DESC'); |         $application->orderBy('created DESC'); | ||||||
|         $application->find(); |         $application->find(); | ||||||
| @@ -96,13 +92,16 @@ class OauthappssettingsAction extends SettingsAction | |||||||
|             } |             } | ||||||
|         } |         } | ||||||
|  |  | ||||||
|         $this->elementStart('p', array('id' => 'application_register')); |         $this->elementStart('p', ['id' => 'application_register']); | ||||||
|         $this->element('a', |         $this->element( | ||||||
|             array('href' => common_local_url('newapplication'), |             'a', | ||||||
|                   'class' => 'more' |             [ | ||||||
|             ), |                 'href'  => common_local_url('newapplication'), | ||||||
|  |                 'class' => 'more', | ||||||
|  |             ], | ||||||
|             // TRANS: Link description to add a new OAuth application. |             // TRANS: Link description to add a new OAuth application. | ||||||
|             'Register a new application'); |             'Register a new application' | ||||||
|  |         ); | ||||||
|         $this->elementEnd('p'); |         $this->elementEnd('p'); | ||||||
|  |  | ||||||
|         $this->pagination( |         $this->pagination( | ||||||
| @@ -113,7 +112,7 @@ class OauthappssettingsAction extends SettingsAction | |||||||
|         ); |         ); | ||||||
|     } |     } | ||||||
|  |  | ||||||
|     function showEmptyListMessage() |     public function showEmptyListMessage() | ||||||
|     { |     { | ||||||
|         // TRANS: Empty list message on page with OAuth applications. Markup allowed |         // TRANS: Empty list message on page with OAuth applications. Markup allowed | ||||||
|         $message = sprintf(_('You have not registered any applications yet.')); |         $message = sprintf(_('You have not registered any applications yet.')); | ||||||
|   | |||||||
| @@ -1,64 +1,65 @@ | |||||||
| <?php | <?php | ||||||
|  | // This file is part of GNU social - https://www.gnu.org/software/social | ||||||
|  | // | ||||||
|  | // GNU social is free software: you can redistribute it and/or modify | ||||||
|  | // it under the terms of the GNU Affero General Public License as published by | ||||||
|  | // the Free Software Foundation, either version 3 of the License, or | ||||||
|  | // (at your option) any later version. | ||||||
|  | // | ||||||
|  | // GNU social is distributed in the hope that it will be useful, | ||||||
|  | // but WITHOUT ANY WARRANTY; without even the implied warranty of | ||||||
|  | // MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the | ||||||
|  | // GNU Affero General Public License for more details. | ||||||
|  | // | ||||||
|  | // You should have received a copy of the GNU Affero General Public License | ||||||
|  | // along with GNU social.  If not, see <http://www.gnu.org/licenses/>. | ||||||
|  |  | ||||||
| /** | /** | ||||||
|  * StatusNet - the distributed open-source microblogging tool |  | ||||||
|  * Copyright (C) 2011, StatusNet, Inc. |  | ||||||
|  * |  | ||||||
|  * Stream of notices sorted by popularity |  * Stream of notices sorted by popularity | ||||||
|  * |  * | ||||||
|  * PHP version 5 |  | ||||||
|  * |  | ||||||
|  * This program is free software: you can redistribute it and/or modify |  | ||||||
|  * it under the terms of the GNU Affero General Public License as published by |  | ||||||
|  * the Free Software Foundation, either version 3 of the License, or |  | ||||||
|  * (at your option) any later version. |  | ||||||
|  * |  | ||||||
|  * This program is distributed in the hope that it will be useful, |  | ||||||
|  * but WITHOUT ANY WARRANTY; without even the implied warranty of |  | ||||||
|  * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the |  | ||||||
|  * GNU Affero General Public License for more details. |  | ||||||
|  * |  | ||||||
|  * You should have received a copy of the GNU Affero General Public License |  | ||||||
|  * along with this program.  If not, see <http://www.gnu.org/licenses/>. |  | ||||||
|  * |  | ||||||
|  * @category  Popular |  * @category  Popular | ||||||
|  * @package   StatusNet |  * @package   GNUsocial | ||||||
|  * @author    Evan Prodromou <evan@status.net> |  * @author    Evan Prodromou <evan@status.net> | ||||||
|  * @copyright 2011 StatusNet, Inc. |  * @copyright 2011 StatusNet, Inc. | ||||||
|  * @license   http://www.fsf.org/licensing/licenses/agpl-3.0.html AGPL 3.0 |  * @license   https://www.gnu.org/licenses/agpl.html GNU AGPL v3 or later | ||||||
|  * @link      http://status.net/ |  | ||||||
|  */ |  */ | ||||||
|  |  | ||||||
| if (!defined('GNUSOCIAL')) { exit(1); } | defined('GNUSOCIAL') || die(); | ||||||
|  |  | ||||||
| /** | /** | ||||||
|  * Stream of notices sorted by popularity |  * Stream of notices sorted by popularity | ||||||
|  * |  * | ||||||
|  * @category  Popular |  * @category  Popular | ||||||
|  * @package   StatusNet |  * @package   GNUsocial | ||||||
|  * @author    Evan Prodromou <evan@status.net> |  * @author    Evan Prodromou <evan@status.net> | ||||||
|  * @copyright 2011 StatusNet, Inc. |  * @copyright 2011 StatusNet, Inc. | ||||||
|  * @license   http://www.fsf.org/licensing/licenses/agpl-3.0.html AGPL 3.0 |  * @license   https://www.gnu.org/licenses/agpl.html GNU AGPL v3 or later | ||||||
|  * @link      http://status.net/ |  | ||||||
|  */ |  */ | ||||||
|  |  | ||||||
| class PopularNoticeStream extends ScopingNoticeStream | class PopularNoticeStream extends ScopingNoticeStream | ||||||
| { | { | ||||||
|     function __construct(Profile $scoped=null) |     public function __construct(Profile $scoped=null) | ||||||
|     { |     { | ||||||
|         parent::__construct(new CachingNoticeStream(new RawPopularNoticeStream(), |         parent::__construct( | ||||||
|  |             new CachingNoticeStream( | ||||||
|  |                 new RawPopularNoticeStream(), | ||||||
|                 'popular', |                 'popular', | ||||||
|                                                     false), |                 false | ||||||
|                             $scoped); |             ), | ||||||
|  |             $scoped | ||||||
|  |         ); | ||||||
|     } |     } | ||||||
| } | } | ||||||
|  |  | ||||||
| class RawPopularNoticeStream extends NoticeStream | class RawPopularNoticeStream extends NoticeStream | ||||||
| { | { | ||||||
|     function getNoticeIds($offset, $limit, $since_id, $max_id) |     public function getNoticeIds($offset, $limit, $since_id, $max_id) | ||||||
|     { |     { | ||||||
|         $weightexpr = common_sql_weight('modified', common_config('popular', 'dropoff')); |         $weightexpr = common_sql_weight('modified', common_config('popular', 'dropoff')); | ||||||
|         $cutoff = sprintf("modified > '%s'", |         $cutoff = sprintf( | ||||||
|                           common_sql_date(time() - common_config('popular', 'cutoff'))); |             "modified > TIMESTAMP '%s'", | ||||||
|  |             common_sql_date(time() - common_config('popular', 'cutoff')) | ||||||
|  |         ); | ||||||
|  |  | ||||||
|         $fave = new Fave(); |         $fave = new Fave(); | ||||||
|         $fave->selectAdd(); |         $fave->selectAdd(); | ||||||
| @@ -85,4 +86,3 @@ class RawPopularNoticeStream extends NoticeStream | |||||||
|         return $ids; |         return $ids; | ||||||
|     } |     } | ||||||
| } | } | ||||||
|  |  | ||||||
|   | |||||||
| @@ -557,7 +557,7 @@ class Activitypub_profile extends Managed_DataObject | |||||||
|         $user_table = common_database_tablename('user'); |         $user_table = common_database_tablename('user'); | ||||||
|         $sub = new Subscription(); |         $sub = new Subscription(); | ||||||
|         $sub->subscribed = $profile->id; |         $sub->subscribed = $profile->id; | ||||||
|         $sub->whereAdd('subscriber != subscribed'); |         $sub->whereAdd('subscriber <> subscribed'); | ||||||
|         $sub->whereAdd("subscriber IN (SELECT id FROM {$user_table} UNION SELECT profile_id AS id FROM activitypub_profile)"); |         $sub->whereAdd("subscriber IN (SELECT id FROM {$user_table} UNION SELECT profile_id AS id FROM activitypub_profile)"); | ||||||
|         $cnt = $sub->count('distinct subscriber'); |         $cnt = $sub->count('distinct subscriber'); | ||||||
|  |  | ||||||
| @@ -585,7 +585,7 @@ class Activitypub_profile extends Managed_DataObject | |||||||
|         $user_table = common_database_tablename('user'); |         $user_table = common_database_tablename('user'); | ||||||
|         $sub = new Subscription(); |         $sub = new Subscription(); | ||||||
|         $sub->subscriber = $profile->id; |         $sub->subscriber = $profile->id; | ||||||
|         $sub->whereAdd('subscriber != subscribed'); |         $sub->whereAdd('subscriber <> subscribed'); | ||||||
|         $sub->whereAdd("subscribed IN (SELECT id FROM {$user_table} UNION SELECT profile_id AS id FROM activitypub_profile)"); |         $sub->whereAdd("subscribed IN (SELECT id FROM {$user_table} UNION SELECT profile_id AS id FROM activitypub_profile)"); | ||||||
|         $cnt = $sub->count('distinct subscribed'); |         $cnt = $sub->count('distinct subscribed'); | ||||||
|  |  | ||||||
|   | |||||||
| @@ -1,19 +1,33 @@ | |||||||
| <?php | <?php | ||||||
|  | // This file is part of GNU social - https://www.gnu.org/software/social | ||||||
|  | // | ||||||
|  | // GNU social is free software: you can redistribute it and/or modify | ||||||
|  | // it under the terms of the GNU Affero General Public License as published by | ||||||
|  | // the Free Software Foundation, either version 3 of the License, or | ||||||
|  | // (at your option) any later version. | ||||||
|  | // | ||||||
|  | // GNU social is distributed in the hope that it will be useful, | ||||||
|  | // but WITHOUT ANY WARRANTY; without even the implied warranty of | ||||||
|  | // MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the | ||||||
|  | // GNU Affero General Public License for more details. | ||||||
|  | // | ||||||
|  | // You should have received a copy of the GNU Affero General Public License | ||||||
|  | // along with GNU social.  If not, see <http://www.gnu.org/licenses/>. | ||||||
|  |  | ||||||
| if (!defined('GNUSOCIAL')) { exit(1); } | defined('GNUSOCIAL') || die(); | ||||||
|  |  | ||||||
| class RawBookmarksNoticeStream extends NoticeStream | class RawBookmarksNoticeStream extends NoticeStream | ||||||
| { | { | ||||||
|     protected $user_id; |     protected $user_id; | ||||||
|     protected $own; |     protected $own; | ||||||
|  |  | ||||||
|     function __construct($user_id, $own) |     public function __construct($user_id, $own) | ||||||
|     { |     { | ||||||
|         $this->user_id = $user_id; |         $this->user_id = $user_id; | ||||||
|         $this->own     = $own; |         $this->own     = $own; | ||||||
|     } |     } | ||||||
|  |  | ||||||
|     function getNoticeIds($offset, $limit, $since_id, $max_id) |     public function getNoticeIds($offset, $limit, $since_id, $max_id) | ||||||
|     { |     { | ||||||
|         $notice = new Notice(); |         $notice = new Notice(); | ||||||
|         $qry = null; |         $qry = null; | ||||||
| @@ -21,7 +35,7 @@ class RawBookmarksNoticeStream extends NoticeStream | |||||||
|         $qry =  'SELECT notice.* FROM notice '; |         $qry =  'SELECT notice.* FROM notice '; | ||||||
|         $qry .= 'INNER JOIN bookmark ON bookmark.uri = notice.uri '; |         $qry .= 'INNER JOIN bookmark ON bookmark.uri = notice.uri '; | ||||||
|         $qry .= 'WHERE bookmark.profile_id = ' . $this->user_id . ' '; |         $qry .= 'WHERE bookmark.profile_id = ' . $this->user_id . ' '; | ||||||
|         $qry .= 'AND notice.is_local != ' . Notice::GATEWAY . ' '; |         $qry .= 'AND notice.is_local <> ' . Notice::GATEWAY . ' '; | ||||||
|  |  | ||||||
|         if ($since_id != 0) { |         if ($since_id != 0) { | ||||||
|             $qry .= 'AND notice.id > ' . $since_id . ' '; |             $qry .= 'AND notice.id > ' . $since_id . ' '; | ||||||
| @@ -62,7 +76,7 @@ class RawBookmarksNoticeStream extends NoticeStream | |||||||
|  |  | ||||||
| class BookmarksNoticeStream extends ScopingNoticeStream | class BookmarksNoticeStream extends ScopingNoticeStream | ||||||
| { | { | ||||||
|     function __construct($user_id, $own, Profile $scoped=null) |     public function __construct($user_id, $own, Profile $scoped = null) | ||||||
|     { |     { | ||||||
|         $stream = new RawBookmarksNoticeStream($user_id, $own); |         $stream = new RawBookmarksNoticeStream($user_id, $own); | ||||||
|  |  | ||||||
|   | |||||||
| @@ -1,17 +1,31 @@ | |||||||
| <?php | <?php | ||||||
|  | // This file is part of GNU social - https://www.gnu.org/software/social | ||||||
|  | // | ||||||
|  | // GNU social is free software: you can redistribute it and/or modify | ||||||
|  | // it under the terms of the GNU Affero General Public License as published by | ||||||
|  | // the Free Software Foundation, either version 3 of the License, or | ||||||
|  | // (at your option) any later version. | ||||||
|  | // | ||||||
|  | // GNU social is distributed in the hope that it will be useful, | ||||||
|  | // but WITHOUT ANY WARRANTY; without even the implied warranty of | ||||||
|  | // MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the | ||||||
|  | // GNU Affero General Public License for more details. | ||||||
|  | // | ||||||
|  | // You should have received a copy of the GNU Affero General Public License | ||||||
|  | // along with GNU social.  If not, see <http://www.gnu.org/licenses/>. | ||||||
|  |  | ||||||
| if (!defined('GNUSOCIAL')) { exit(1); } | defined('GNUSOCIAL') || die(); | ||||||
|  |  | ||||||
| class RawEventsNoticeStream extends NoticeStream | class RawEventsNoticeStream extends NoticeStream | ||||||
| { | { | ||||||
|     function getNoticeIds($offset, $limit, $since_id, $max_id) |     public function getNoticeIds($offset, $limit, $since_id, $max_id) | ||||||
|     { |     { | ||||||
|         $notice = new Notice(); |         $notice = new Notice(); | ||||||
|         $qry = null; |         $qry = null; | ||||||
|  |  | ||||||
|         $qry =  'SELECT notice.* FROM notice '; |         $qry =  'SELECT notice.* FROM notice '; | ||||||
|         $qry .= 'INNER JOIN happening ON happening.uri = notice.uri '; |         $qry .= 'INNER JOIN happening ON happening.uri = notice.uri '; | ||||||
|         $qry .= 'AND notice.is_local != ' . Notice::GATEWAY . ' '; |         $qry .= 'AND notice.is_local <> ' . Notice::GATEWAY . ' '; | ||||||
|  |  | ||||||
|         if ($since_id != 0) { |         if ($since_id != 0) { | ||||||
|             $qry .= 'AND notice.id > ' . $since_id . ' '; |             $qry .= 'AND notice.id > ' . $since_id . ' '; | ||||||
| @@ -45,7 +59,7 @@ class EventsNoticeStream extends ScopingNoticeStream | |||||||
|     protected $rsvp = ['Y', 'N', '?']; |     protected $rsvp = ['Y', 'N', '?']; | ||||||
|     protected $target = null; |     protected $target = null; | ||||||
|  |  | ||||||
|     function __construct(Profile $target, Profile $scoped=null, array $rsvp=array()) |     public function __construct(Profile $target, Profile $scoped = null, array $rsvp = []) | ||||||
|     { |     { | ||||||
|         $stream = new RawEventsNoticeStream(); |         $stream = new RawEventsNoticeStream(); | ||||||
|  |  | ||||||
|   | |||||||
| @@ -1,38 +1,30 @@ | |||||||
| <?php | <?php | ||||||
|  | // This file is part of GNU social - https://www.gnu.org/software/social | ||||||
|  | // | ||||||
|  | // GNU social is free software: you can redistribute it and/or modify | ||||||
|  | // it under the terms of the GNU Affero General Public License as published by | ||||||
|  | // the Free Software Foundation, either version 3 of the License, or | ||||||
|  | // (at your option) any later version. | ||||||
|  | // | ||||||
|  | // GNU social is distributed in the hope that it will be useful, | ||||||
|  | // but WITHOUT ANY WARRANTY; without even the implied warranty of | ||||||
|  | // MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the | ||||||
|  | // GNU Affero General Public License for more details. | ||||||
|  | // | ||||||
|  | // You should have received a copy of the GNU Affero General Public License | ||||||
|  | // along with GNU social.  If not, see <http://www.gnu.org/licenses/>. | ||||||
|  |  | ||||||
| /** | /** | ||||||
|  * StatusNet - the distributed open-source microblogging tool |  | ||||||
|  * Copyright (C) 2010, StatusNet, Inc. |  | ||||||
|  * |  | ||||||
|  * When a new user registers, all existing users follow them automatically. |  * When a new user registers, all existing users follow them automatically. | ||||||
|  * |  * | ||||||
|  * PHP version 5 |  | ||||||
|  * |  | ||||||
|  * This program is free software: you can redistribute it and/or modify |  | ||||||
|  * it under the terms of the GNU Affero General Public License as published by |  | ||||||
|  * the Free Software Foundation, either version 3 of the License, or |  | ||||||
|  * (at your option) any later version. |  | ||||||
|  * |  | ||||||
|  * This program is distributed in the hope that it will be useful, |  | ||||||
|  * but WITHOUT ANY WARRANTY; without even the implied warranty of |  | ||||||
|  * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the |  | ||||||
|  * GNU Affero General Public License for more details. |  | ||||||
|  * |  | ||||||
|  * You should have received a copy of the GNU Affero General Public License |  | ||||||
|  * along with this program.  If not, see <http://www.gnu.org/licenses/>. |  | ||||||
|  * |  | ||||||
|  * @category  Community |  * @category  Community | ||||||
|  * @package   StatusNet |  * @package   GNUsocial | ||||||
|  * @author    Evan Prodromou <evan@status.net> |  * @author    Evan Prodromou <evan@status.net> | ||||||
|  * @copyright 2010 StatusNet, Inc. |  * @copyright 2010 StatusNet, Inc. | ||||||
|  * @license   http://www.fsf.org/licensing/licenses/agpl-3.0.html AGPL 3.0 |  * @license   https://www.gnu.org/licenses/agpl.html GNU AGPL v3 or later | ||||||
|  * @link      http://status.net/ |  | ||||||
|  */ |  */ | ||||||
|  |  | ||||||
| if (!defined('STATUSNET')) { | defined('GNUSOCIAL') || die(); | ||||||
|     // This check helps protect against security problems; |  | ||||||
|     // your code file can't be executed directly from the web. |  | ||||||
|     exit(1); |  | ||||||
| } |  | ||||||
|  |  | ||||||
| /** | /** | ||||||
|  * Plugin to make all users follow each other at registration |  * Plugin to make all users follow each other at registration | ||||||
| @@ -40,11 +32,10 @@ if (!defined('STATUSNET')) { | |||||||
|  * Users can unfollow afterwards if they want. |  * Users can unfollow afterwards if they want. | ||||||
|  * |  * | ||||||
|  * @category  Sample |  * @category  Sample | ||||||
|  * @package   StatusNet |  * @package   GNUsocial | ||||||
|  * @author    Evan Prodromou <evan@status.net> |  * @author    Evan Prodromou <evan@status.net> | ||||||
|  * @copyright 2010 StatusNet, Inc. |  * @copyright 2010 StatusNet, Inc. | ||||||
|  * @license   http://www.fsf.org/licensing/licenses/agpl-3.0.html AGPL 3.0 |  * @license   https://www.gnu.org/licenses/agpl.html GNU AGPL v3 or later | ||||||
|  * @link      http://status.net/ |  | ||||||
|  */ |  */ | ||||||
| class FollowEveryonePlugin extends Plugin | class FollowEveryonePlugin extends Plugin | ||||||
| { | { | ||||||
| @@ -64,7 +55,7 @@ class FollowEveryonePlugin extends Plugin | |||||||
|     public function onEndUserRegister(Profile $profile) |     public function onEndUserRegister(Profile $profile) | ||||||
|     { |     { | ||||||
|         $otherUser = new User(); |         $otherUser = new User(); | ||||||
|         $otherUser->whereAdd('id != ' . $profile->id); |         $otherUser->whereAdd('id <> ' . $profile->id); | ||||||
|  |  | ||||||
|         if ($otherUser->find()) { |         if ($otherUser->find()) { | ||||||
|             while ($otherUser->fetch()) { |             while ($otherUser->fetch()) { | ||||||
| @@ -110,7 +101,7 @@ class FollowEveryonePlugin extends Plugin | |||||||
|      * |      * | ||||||
|      * @return boolean hook value; true means continue processing, false means stop. |      * @return boolean hook value; true means continue processing, false means stop. | ||||||
|      */ |      */ | ||||||
|     function onCheckSchema() |     public function onCheckSchema() | ||||||
|     { |     { | ||||||
|         $schema = Schema::get(); |         $schema = Schema::get(); | ||||||
|  |  | ||||||
| @@ -127,16 +118,17 @@ class FollowEveryonePlugin extends Plugin | |||||||
|      * |      * | ||||||
|      * @return boolean hook value |      * @return boolean hook value | ||||||
|      */ |      */ | ||||||
|     function onEndProfileFormData($action) |     public function onEndProfileFormData($action) | ||||||
|     { |     { | ||||||
|         $user = common_current_user(); |         $user = common_current_user(); | ||||||
|  |  | ||||||
|         $action->elementStart('li'); |         $action->elementStart('li'); | ||||||
|         // TRANS: Checkbox label in form for profile settings. |         // TRANS: Checkbox label in form for profile settings. | ||||||
|         $action->checkbox('followeveryone', _m('Follow everyone'), |         $action->checkbox( | ||||||
|                           ($action->arg('followeveryone')) ? |             'followeveryone', | ||||||
|                           $action->arg('followeveryone') : |             _m('Follow everyone'), | ||||||
|                           User_followeveryone_prefs::followEveryone($user->id)); |             ($action->arg('followeveryone') ?? User_followeveryone_prefs::followEveryone($user->id)) | ||||||
|  |         ); | ||||||
|         $action->elementEnd('li'); |         $action->elementEnd('li'); | ||||||
|  |  | ||||||
|         return true; |         return true; | ||||||
| @@ -149,12 +141,14 @@ class FollowEveryonePlugin extends Plugin | |||||||
|      * |      * | ||||||
|      * @return boolean hook value |      * @return boolean hook value | ||||||
|      */ |      */ | ||||||
|     function onEndProfileSaveForm($action) |     public function onEndProfileSaveForm($action) | ||||||
|     { |     { | ||||||
|         $user = common_current_user(); |         $user = common_current_user(); | ||||||
|  |  | ||||||
|         User_followeveryone_prefs::savePref($user->id, |         User_followeveryone_prefs::savePref( | ||||||
|                                             $action->boolean('followeveryone')); |             $user->id, | ||||||
|  |             $action->boolean('followeveryone') | ||||||
|  |         ); | ||||||
|  |  | ||||||
|         return true; |         return true; | ||||||
|     } |     } | ||||||
|   | |||||||
| @@ -1,32 +1,31 @@ | |||||||
| <?php | <?php | ||||||
|  | // This file is part of GNU social - https://www.gnu.org/software/social | ||||||
|  | // | ||||||
|  | // GNU social is free software: you can redistribute it and/or modify | ||||||
|  | // it under the terms of the GNU Affero General Public License as published by | ||||||
|  | // the Free Software Foundation, either version 3 of the License, or | ||||||
|  | // (at your option) any later version. | ||||||
|  | // | ||||||
|  | // GNU social is distributed in the hope that it will be useful, | ||||||
|  | // but WITHOUT ANY WARRANTY; without even the implied warranty of | ||||||
|  | // MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the | ||||||
|  | // GNU Affero General Public License for more details. | ||||||
|  | // | ||||||
|  | // You should have received a copy of the GNU Affero General Public License | ||||||
|  | // along with GNU social.  If not, see <http://www.gnu.org/licenses/>. | ||||||
|  |  | ||||||
| /** | /** | ||||||
|  * StatusNet, the distributed open-source microblogging tool |  * Plugin for sending and importing Twitter statuses | ||||||
|  * |  | ||||||
|  * PHP version 5 |  | ||||||
|  * |  | ||||||
|  * LICENCE: This program is free software: you can redistribute it and/or modify |  | ||||||
|  * it under the terms of the GNU Affero General Public License as published by |  | ||||||
|  * the Free Software Foundation, either version 3 of the License, or |  | ||||||
|  * (at your option) any later version. |  | ||||||
|  * |  | ||||||
|  * This program is distributed in the hope that it will be useful, |  | ||||||
|  * but WITHOUT ANY WARRANTY; without even the implied warranty of |  | ||||||
|  * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the |  | ||||||
|  * GNU Affero General Public License for more details. |  | ||||||
|  * |  | ||||||
|  * You should have received a copy of the GNU Affero General Public License |  | ||||||
|  * along with this program.  If not, see <http://www.gnu.org/licenses/>. |  | ||||||
|  * |  * | ||||||
|  * @category  Plugin |  * @category  Plugin | ||||||
|  * @package   StatusNet |  * @package   GNUsocial | ||||||
|  * @author    Zach Copley <zach@status.net> |  * @author    Zach Copley <zach@status.net> | ||||||
|  * @author    Julien C <chaumond@gmail.com> |  * @author    Julien C <chaumond@gmail.com> | ||||||
|  * @copyright 2009-2010 Control Yourself, Inc. |  * @copyright 2009-2010 StatusNet, Inc. | ||||||
|  * @license   http://www.fsf.org/licensing/licenses/agpl-3.0.html GNU Affero General Public License version 3.0 |  * @license   https://www.gnu.org/licenses/agpl.html GNU AGPL v3 or later | ||||||
|  * @link      http://status.net/ |  | ||||||
|  */ |  */ | ||||||
|  |  | ||||||
| if (!defined('GNUSOCIAL')) { exit(1); } | defined('GNUSOCIAL') || die(); | ||||||
|  |  | ||||||
| require_once __DIR__ . '/twitter.php'; | require_once __DIR__ . '/twitter.php'; | ||||||
|  |  | ||||||
| @@ -38,12 +37,10 @@ require_once __DIR__ . '/twitter.php'; | |||||||
|  * Depends on Favorite plugin. |  * Depends on Favorite plugin. | ||||||
|  * |  * | ||||||
|  * @category  Plugin |  * @category  Plugin | ||||||
|  * @package  StatusNet |  * @package   GNUsocial | ||||||
|  * @author    Zach Copley <zach@status.net> |  * @author    Zach Copley <zach@status.net> | ||||||
|  * @author    Julien C <chaumond@gmail.com> |  * @author    Julien C <chaumond@gmail.com> | ||||||
|  * @license  http://www.fsf.org/licensing/licenses/agpl-3.0.html GNU Affero General Public License version 3.0 |  * @license   https://www.gnu.org/licenses/agpl.html GNU AGPL v3 or later | ||||||
|  * @link     http://status.net/ |  | ||||||
|  * @link     http://twitter.com/ |  | ||||||
|  */ |  */ | ||||||
| class TwitterBridgePlugin extends Plugin | class TwitterBridgePlugin extends Plugin | ||||||
| { | { | ||||||
| @@ -53,7 +50,7 @@ class TwitterBridgePlugin extends Plugin | |||||||
|     /** |     /** | ||||||
|      * Initializer for the plugin. |      * Initializer for the plugin. | ||||||
|      */ |      */ | ||||||
|     function initialize() |     public function initialize() | ||||||
|     { |     { | ||||||
|         // Allow the key and secret to be passed in |         // Allow the key and secret to be passed in | ||||||
|         // Control panel will override |         // Control panel will override | ||||||
| @@ -83,7 +80,7 @@ class TwitterBridgePlugin extends Plugin | |||||||
|      * |      * | ||||||
|      * @return boolean result |      * @return boolean result | ||||||
|      */ |      */ | ||||||
|     static function hasKeys() |     public static function hasKeys() | ||||||
|     { |     { | ||||||
|         $ckey    = common_config('twitter', 'consumer_key'); |         $ckey    = common_config('twitter', 'consumer_key'); | ||||||
|         $csecret = common_config('twitter', 'consumer_secret'); |         $csecret = common_config('twitter', 'consumer_secret'); | ||||||
| @@ -114,14 +111,20 @@ class TwitterBridgePlugin extends Plugin | |||||||
|         $m->connect('panel/twitter', ['action' => 'twitteradminpanel']); |         $m->connect('panel/twitter', ['action' => 'twitteradminpanel']); | ||||||
|  |  | ||||||
|         if (self::hasKeys()) { |         if (self::hasKeys()) { | ||||||
|             $m->connect('twitter/authorization', |             $m->connect( | ||||||
|                         ['action' => 'twitterauthorization']); |                 'twitter/authorization', | ||||||
|             $m->connect('settings/twitter', |                 ['action' => 'twitterauthorization'] | ||||||
|                         ['action' => 'twittersettings']); |             ); | ||||||
|  |             $m->connect( | ||||||
|  |                 'settings/twitter', | ||||||
|  |                 ['action' => 'twittersettings'] | ||||||
|  |             ); | ||||||
|  |  | ||||||
|             if (common_config('twitter', 'signin')) { |             if (common_config('twitter', 'signin')) { | ||||||
|                 $m->connect('main/twitterlogin', |                 $m->connect( | ||||||
|                             ['action' => 'twitterlogin']); |                     'main/twitterlogin', | ||||||
|  |                     ['action' => 'twitterlogin'] | ||||||
|  |                 ); | ||||||
|             } |             } | ||||||
|         } |         } | ||||||
|  |  | ||||||
| @@ -135,7 +138,7 @@ class TwitterBridgePlugin extends Plugin | |||||||
|      * |      * | ||||||
|      * @return void |      * @return void | ||||||
|      */ |      */ | ||||||
|     function onEndLoginGroupNav($action) |     public function onEndLoginGroupNav($action) | ||||||
|     { |     { | ||||||
|         $action_name = $action->trimmed('action'); |         $action_name = $action->trimmed('action'); | ||||||
|  |  | ||||||
| @@ -160,7 +163,7 @@ class TwitterBridgePlugin extends Plugin | |||||||
|      * |      * | ||||||
|      * @return boolean hook return |      * @return boolean hook return | ||||||
|      */ |      */ | ||||||
|     function onEndConnectSettingsNav($action) |     public function onEndConnectSettingsNav($action) | ||||||
|     { |     { | ||||||
|         if (self::hasKeys()) { |         if (self::hasKeys()) { | ||||||
|             $action_name = $action->trimmed('action'); |             $action_name = $action->trimmed('action'); | ||||||
| @@ -185,7 +188,7 @@ class TwitterBridgePlugin extends Plugin | |||||||
|      * |      * | ||||||
|      * @return boolean hook return |      * @return boolean hook return | ||||||
|      */ |      */ | ||||||
|     function onStartEnqueueNotice($notice, &$transports) |     public function onStartEnqueueNotice($notice, &$transports) | ||||||
|     { |     { | ||||||
|         if (self::hasKeys() && $notice->isLocal() && $notice->inScope(null)) { |         if (self::hasKeys() && $notice->isLocal() && $notice->inScope(null)) { | ||||||
|             // Avoid a possible loop |             // Avoid a possible loop | ||||||
| @@ -203,7 +206,7 @@ class TwitterBridgePlugin extends Plugin | |||||||
|      * |      * | ||||||
|      * @return boolean hook return |      * @return boolean hook return | ||||||
|      */ |      */ | ||||||
|     function onGetValidDaemons(&$daemons) |     public function onGetValidDaemons(&$daemons) | ||||||
|     { |     { | ||||||
|         if (self::hasKeys()) { |         if (self::hasKeys()) { | ||||||
|             array_push( |             array_push( | ||||||
| @@ -230,7 +233,7 @@ class TwitterBridgePlugin extends Plugin | |||||||
|      * |      * | ||||||
|      * @return boolean hook return |      * @return boolean hook return | ||||||
|      */ |      */ | ||||||
|     function onEndInitializeQueueManager($manager) |     public function onEndInitializeQueueManager($manager) | ||||||
|     { |     { | ||||||
|         if (self::hasKeys()) { |         if (self::hasKeys()) { | ||||||
|             // Outgoing notices -> twitter |             // Outgoing notices -> twitter | ||||||
| @@ -245,7 +248,7 @@ class TwitterBridgePlugin extends Plugin | |||||||
|     /** |     /** | ||||||
|      * If the plugin's installed, this should be accessible to admins |      * If the plugin's installed, this should be accessible to admins | ||||||
|      */ |      */ | ||||||
|     function onAdminPanelCheck($name, &$isOK) |     public function onAdminPanelCheck($name, &$isOK) | ||||||
|     { |     { | ||||||
|         if ($name == 'twitter') { |         if ($name == 'twitter') { | ||||||
|             $isOK = true; |             $isOK = true; | ||||||
| @@ -262,10 +265,9 @@ class TwitterBridgePlugin extends Plugin | |||||||
|      * @return boolean hook value |      * @return boolean hook value | ||||||
|      */ |      */ | ||||||
|  |  | ||||||
|     function onEndAdminPanelNav($nav) |     public function onEndAdminPanelNav($nav) | ||||||
|     { |     { | ||||||
|         if (AdminPanelAction::canAdmin('twitter')) { |         if (AdminPanelAction::canAdmin('twitter')) { | ||||||
|  |  | ||||||
|             $action_name = $nav->action->trimmed('action'); |             $action_name = $nav->action->trimmed('action'); | ||||||
|  |  | ||||||
|             $nav->out->menuItem( |             $nav->out->menuItem( | ||||||
| @@ -297,7 +299,8 @@ class TwitterBridgePlugin extends Plugin | |||||||
|             'author' => 'Zach Copley, Julien C, Jean Baptiste Favre', |             'author' => 'Zach Copley, Julien C, Jean Baptiste Favre', | ||||||
|             'homepage' => GNUSOCIAL_ENGINE_REPO_URL . 'tree/master/plugins/TwitterBridge', |             'homepage' => GNUSOCIAL_ENGINE_REPO_URL . 'tree/master/plugins/TwitterBridge', | ||||||
|             // TRANS: Plugin description. |             // TRANS: Plugin description. | ||||||
|             'rawdescription' => _m('The Twitter "bridge" plugin allows integration ' . |             'rawdescription' => _m( | ||||||
|  |                 'The Twitter "bridge" plugin allows integration ' . | ||||||
|                 'of a StatusNet instance with ' . |                 'of a StatusNet instance with ' . | ||||||
|                 '<a href="http://twitter.com/">Twitter</a>.' |                 '<a href="http://twitter.com/">Twitter</a>.' | ||||||
|             ) |             ) | ||||||
| @@ -312,7 +315,7 @@ class TwitterBridgePlugin extends Plugin | |||||||
|      * |      * | ||||||
|      * @return boolean hook value; |      * @return boolean hook value; | ||||||
|      */ |      */ | ||||||
|     function onTwitterBridgeAdminImportControl() |     public function onTwitterBridgeAdminImportControl() | ||||||
|     { |     { | ||||||
|         return (bool)$this->adminImportControl; |         return (bool)$this->adminImportControl; | ||||||
|     } |     } | ||||||
| @@ -327,7 +330,7 @@ class TwitterBridgePlugin extends Plugin | |||||||
|      * |      * | ||||||
|      * @return boolean hook value; true means continue processing, false means stop. |      * @return boolean hook value; true means continue processing, false means stop. | ||||||
|      */ |      */ | ||||||
|     function onCheckSchema() |     public function onCheckSchema() | ||||||
|     { |     { | ||||||
|         $schema = Schema::get(); |         $schema = Schema::get(); | ||||||
|  |  | ||||||
| @@ -350,12 +353,11 @@ class TwitterBridgePlugin extends Plugin | |||||||
|      * |      * | ||||||
|      * @return boolean hook value |      * @return boolean hook value | ||||||
|      */ |      */ | ||||||
|     function onStartDeleteOwnNotice(User $user, Notice $notice) |     public function onStartDeleteOwnNotice(User $user, Notice $notice) | ||||||
|     { |     { | ||||||
|         $n2s = Notice_to_status::getKV('notice_id', $notice->id); |         $n2s = Notice_to_status::getKV('notice_id', $notice->id); | ||||||
|  |  | ||||||
|         if ($n2s instanceof Notice_to_status) { |         if ($n2s instanceof Notice_to_status) { | ||||||
|  |  | ||||||
|             try { |             try { | ||||||
|                 $flink = Foreign_link::getByUserID($notice->profile_id, TWITTER_SERVICE); // twitter service |                 $flink = Foreign_link::getByUserID($notice->profile_id, TWITTER_SERVICE); // twitter service | ||||||
|             } catch (NoResultException $e) { |             } catch (NoResultException $e) { | ||||||
| @@ -388,7 +390,7 @@ class TwitterBridgePlugin extends Plugin | |||||||
|      * @param Notice $notice being favored |      * @param Notice $notice being favored | ||||||
|      * @return hook return value |      * @return hook return value | ||||||
|      */ |      */ | ||||||
|     function onEndFavorNotice(Profile $profile, Notice $notice) |     public function onEndFavorNotice(Profile $profile, Notice $notice) | ||||||
|     { |     { | ||||||
|         try { |         try { | ||||||
|             $flink = Foreign_link::getByUserID($profile->getID(), TWITTER_SERVICE); // twitter service |             $flink = Foreign_link::getByUserID($profile->getID(), TWITTER_SERVICE); // twitter service | ||||||
| @@ -427,7 +429,7 @@ class TwitterBridgePlugin extends Plugin | |||||||
|      * |      * | ||||||
|      * @return hook return value |      * @return hook return value | ||||||
|      */ |      */ | ||||||
|     function onEndDisfavorNotice(Profile $profile, Notice $notice) |     public function onEndDisfavorNotice(Profile $profile, Notice $notice) | ||||||
|     { |     { | ||||||
|         try { |         try { | ||||||
|             $flink = Foreign_link::getByUserID($profile->getID(), TWITTER_SERVICE); // twitter service |             $flink = Foreign_link::getByUserID($profile->getID(), TWITTER_SERVICE); // twitter service | ||||||
| @@ -458,7 +460,7 @@ class TwitterBridgePlugin extends Plugin | |||||||
|         return true; |         return true; | ||||||
|     } |     } | ||||||
|  |  | ||||||
|     function onStartGetProfileUri($profile, &$uri) |     public function onStartGetProfileUri($profile, &$uri) | ||||||
|     { |     { | ||||||
|         if (preg_match('!^https?://twitter.com/!', $profile->profileurl)) { |         if (preg_match('!^https?://twitter.com/!', $profile->profileurl)) { | ||||||
|             $uri = $profile->profileurl; |             $uri = $profile->profileurl; | ||||||
| @@ -476,7 +478,7 @@ class TwitterBridgePlugin extends Plugin | |||||||
|      * @return boolean hook value (true) |      * @return boolean hook value (true) | ||||||
|      */ |      */ | ||||||
|  |  | ||||||
|     function onOtherAccountProfiles($profile, &$links) |     public function onOtherAccountProfiles($profile, &$links) | ||||||
|     { |     { | ||||||
|         $fuser = null; |         $fuser = null; | ||||||
|  |  | ||||||
| @@ -496,7 +498,8 @@ class TwitterBridgePlugin extends Plugin | |||||||
|  |  | ||||||
|     public function onEndShowHeadElements(Action $action) |     public function onEndShowHeadElements(Action $action) | ||||||
|     { |     { | ||||||
|         if($action instanceof ShowNoticeAction) { // Showing a notice |         // Showing a notice | ||||||
|  |         if ($action instanceof ShowNoticeAction) { | ||||||
|             $notice = Notice::getKV('id', $action->arg('notice')); |             $notice = Notice::getKV('id', $action->arg('notice')); | ||||||
|  |  | ||||||
|             try { |             try { | ||||||
| @@ -529,24 +532,48 @@ class TwitterBridgePlugin extends Plugin | |||||||
|             case 'image/jpg': |             case 'image/jpg': | ||||||
|             case 'image/png': |             case 'image/png': | ||||||
|             case 'image/gif': |             case 'image/gif': | ||||||
|                 $action->element('meta', array('name'    => 'twitter:card', |                 $action->element( | ||||||
|                                              'content' => 'photo'), |                     'meta', | ||||||
|                                        null); |                     [ | ||||||
|                 $action->element('meta', array('name'    => 'twitter:url', |                         'name'    => 'twitter:card', | ||||||
|                                              'content' => common_local_url('attachment', |                         'content' => 'photo', | ||||||
|                                                               array('attachment' => $action->attachment->id))), |                     ], | ||||||
|                                        null ); |                     null | ||||||
|                 $action->element('meta', array('name'    => 'twitter:image', |                 ); | ||||||
|                                              'content' => $action->attachment->url)); |                 $action->element( | ||||||
|                 $action->element('meta', array('name'    => 'twitter:title', |                     'meta', | ||||||
|                                              'content' => $action->attachment->title)); |                     [ | ||||||
|  |                         'name'    => 'twitter:url', | ||||||
|  |                         'content' => common_local_url( | ||||||
|  |                             'attachment', | ||||||
|  |                             ['attachment' => $action->attachment->id] | ||||||
|  |                         ) | ||||||
|  |                     ], | ||||||
|  |                     null | ||||||
|  |                 ); | ||||||
|  |                 $action->element( | ||||||
|  |                     'meta', | ||||||
|  |                     [ | ||||||
|  |                         'name'    => 'twitter:image', | ||||||
|  |                         'content' => $action->attachment->url, | ||||||
|  |                     ] | ||||||
|  |                 ); | ||||||
|  |                 $action->element( | ||||||
|  |                     'meta', | ||||||
|  |                     [ | ||||||
|  |                         'name'    => 'twitter:title', | ||||||
|  |                         'content' => $action->attachment->title, | ||||||
|  |                     ] | ||||||
|  |                 ); | ||||||
|  |  | ||||||
|                 $ns = new AttachmentNoticeSection($action); |                 $ns = new AttachmentNoticeSection($action); | ||||||
|                 $notices = $ns->getNotices(); |                 $notices = $ns->getNotices(); | ||||||
|                 $noticeArray = $notices->fetchAll(); |                 $noticeArray = $notices->fetchAll(); | ||||||
|  |  | ||||||
|                 // Should not have more than 1 notice for this attachment. |                 // Should not have more than 1 notice for this attachment. | ||||||
|                 if( count($noticeArray) != 1 ) { break; } |                 if (count($noticeArray) != 1) { | ||||||
|  |                     break; | ||||||
|  |                 } | ||||||
|                 $post = $noticeArray[0]; |                 $post = $noticeArray[0]; | ||||||
|  |  | ||||||
|                 try { |                 try { | ||||||
| @@ -572,7 +599,7 @@ class TwitterBridgePlugin extends Plugin | |||||||
|      */ |      */ | ||||||
|     public function onEndUpgrade() |     public function onEndUpgrade() | ||||||
|     { |     { | ||||||
|     	printfnq("Ensuring all Twitter notices have an object_type..."); |         printfnq('Ensuring all Twitter notices have an object_type...'); | ||||||
|  |  | ||||||
|         $notice = new Notice(); |         $notice = new Notice(); | ||||||
|         $notice->whereAdd("source = 'twitter'"); |         $notice->whereAdd("source = 'twitter'"); | ||||||
|   | |||||||
| @@ -1,44 +1,38 @@ | |||||||
| <?php | <?php | ||||||
|  | // This file is part of GNU social - https://www.gnu.org/software/social | ||||||
|  | // | ||||||
|  | // GNU social is free software: you can redistribute it and/or modify | ||||||
|  | // it under the terms of the GNU Affero General Public License as published by | ||||||
|  | // the Free Software Foundation, either version 3 of the License, or | ||||||
|  | // (at your option) any later version. | ||||||
|  | // | ||||||
|  | // GNU social is distributed in the hope that it will be useful, | ||||||
|  | // but WITHOUT ANY WARRANTY; without even the implied warranty of | ||||||
|  | // MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the | ||||||
|  | // GNU Affero General Public License for more details. | ||||||
|  | // | ||||||
|  | // You should have received a copy of the GNU Affero General Public License | ||||||
|  | // along with GNU social.  If not, see <http://www.gnu.org/licenses/>. | ||||||
|  |  | ||||||
| /** | /** | ||||||
|  * Clear all flags for a profile |  * Clear all flags for a profile | ||||||
|  * |  * | ||||||
|  * PHP version 5 |  | ||||||
|  * |  | ||||||
|  * @category  Action |  * @category  Action | ||||||
|  * @package  StatusNet |  * @package   GNUsocial | ||||||
|  * @author    Evan Prodromou <evan@status.net> |  * @author    Evan Prodromou <evan@status.net> | ||||||
|  * @license  http://www.fsf.org/licensing/licenses/agpl.html AGPLv3 |  * @copyright 2009 StatusNet, Inc. | ||||||
|  * @link     http://status.net/ |  * @license   https://www.gnu.org/licenses/agpl.html GNU AGPL v3 or later | ||||||
|  * |  | ||||||
|  * StatusNet - the distributed open-source microblogging tool |  | ||||||
|  * Copyright (C) 2009, StatusNet, Inc. |  | ||||||
|  * |  | ||||||
|  * This program is free software: you can redistribute it and/or modify |  | ||||||
|  * it under the terms of the GNU Affero General Public License as published by |  | ||||||
|  * the Free Software Foundation, either version 3 of the License, or |  | ||||||
|  * (at your option) any later version. |  | ||||||
|  * |  | ||||||
|  * This program is distributed in the hope that it will be useful, |  | ||||||
|  * but WITHOUT ANY WARRANTY; without even the implied warranty of |  | ||||||
|  * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the |  | ||||||
|  * GNU Affero General Public License for more details. |  | ||||||
|  * |  | ||||||
|  * You should have received a copy of the GNU Affero General Public License |  | ||||||
|  * along with this program.  If not, see <http://www.gnu.org/licenses/>. |  | ||||||
|  */ |  */ | ||||||
|  |  | ||||||
| if (!defined('STATUSNET')) { | defined('GNUSOCIAL') || die(); | ||||||
|     exit(1); |  | ||||||
| } |  | ||||||
|  |  | ||||||
| /** | /** | ||||||
|  * Action to clear flags for a profile |  * Action to clear flags for a profile | ||||||
|  * |  * | ||||||
|  * @category  Action |  * @category  Action | ||||||
|  * @package  StatusNet |  * @package   GNUsocial | ||||||
|  * @author    Evan Prodromou <evan@status.net> |  * @author    Evan Prodromou <evan@status.net> | ||||||
|  * @license  http://www.fsf.org/licensing/licenses/agpl.html AGPLv3 |  * @license   https://www.gnu.org/licenses/agpl.html GNU AGPL v3 or later | ||||||
|  * @link     http://status.net/ |  | ||||||
|  */ |  */ | ||||||
| class ClearflagAction extends ProfileFormAction | class ClearflagAction extends ProfileFormAction | ||||||
| { | { | ||||||
| @@ -49,7 +43,7 @@ class ClearflagAction extends ProfileFormAction | |||||||
|      * |      * | ||||||
|      * @return boolean success flag |      * @return boolean success flag | ||||||
|      */ |      */ | ||||||
|     function prepare(array $args = array()) |     public function prepare(array $args = []) | ||||||
|     { |     { | ||||||
|         if (!parent::prepare($args)) { |         if (!parent::prepare($args)) { | ||||||
|             return false; |             return false; | ||||||
| @@ -73,7 +67,7 @@ class ClearflagAction extends ProfileFormAction | |||||||
|      * |      * | ||||||
|      * @return void |      * @return void | ||||||
|      */ |      */ | ||||||
|     function handle() |     public function handle() | ||||||
|     { |     { | ||||||
|         if ($_SERVER['REQUEST_METHOD'] == 'POST') { |         if ($_SERVER['REQUEST_METHOD'] == 'POST') { | ||||||
|             $this->handlePost(); |             $this->handlePost(); | ||||||
| @@ -90,7 +84,7 @@ class ClearflagAction extends ProfileFormAction | |||||||
|      * |      * | ||||||
|      * @return void |      * @return void | ||||||
|      */ |      */ | ||||||
|     function handlePost() |     public function handlePost() | ||||||
|     { |     { | ||||||
|         $ufp = new User_flag_profile(); |         $ufp = new User_flag_profile(); | ||||||
|  |  | ||||||
| @@ -102,8 +96,10 @@ class ClearflagAction extends ProfileFormAction | |||||||
|         if ($result == false) { |         if ($result == false) { | ||||||
|             // TRANS: Server exception given when flags could not be cleared. |             // TRANS: Server exception given when flags could not be cleared. | ||||||
|             // TRANS: %s is a profile nickname. |             // TRANS: %s is a profile nickname. | ||||||
|             $msg = sprintf(_m('Could not clear flags for profile "%s".'), |             $msg = sprintf( | ||||||
|                            $this->profile->nickname); |                 _m('Could not clear flags for profile "%s".'), | ||||||
|  |                 $this->profile->nickname | ||||||
|  |             ); | ||||||
|             throw new ServerException($msg); |             throw new ServerException($msg); | ||||||
|         } |         } | ||||||
|  |  | ||||||
| @@ -119,7 +115,7 @@ class ClearflagAction extends ProfileFormAction | |||||||
|      * |      * | ||||||
|      * @return void |      * @return void | ||||||
|      */ |      */ | ||||||
|     function ajaxResults() |     public function ajaxResults() | ||||||
|     { |     { | ||||||
|         $this->startHTML('text/xml;charset=utf-8'); |         $this->startHTML('text/xml;charset=utf-8'); | ||||||
|         $this->elementStart('head'); |         $this->elementStart('head'); | ||||||
|   | |||||||
| @@ -1,21 +1,23 @@ | |||||||
| #!/usr/bin/env php | #!/usr/bin/env php | ||||||
| <?php | <?php | ||||||
| /* | // This file is part of GNU social - https://www.gnu.org/software/social | ||||||
|  * StatusNet - a distributed open-source microblogging tool | // | ||||||
|  * Copyright (C) 2008, 2009, 2010, StatusNet, Inc. | // GNU social is free software: you can redistribute it and/or modify | ||||||
|  * | // it under the terms of the GNU Affero General Public License as published by | ||||||
|  * This program is free software: you can redistribute it and/or modify | // the Free Software Foundation, either version 3 of the License, or | ||||||
|  * it under the terms of the GNU Affero General Public License as published by | // (at your option) any later version. | ||||||
|  * the Free Software Foundation, either version 3 of the License, or | // | ||||||
|  * (at your option) any later version. | // GNU social is distributed in the hope that it will be useful, | ||||||
|  * | // but WITHOUT ANY WARRANTY; without even the implied warranty of | ||||||
|  * This program is distributed in the hope that it will be useful, | // MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the | ||||||
|  * but WITHOUT ANY WARRANTY; without even the implied warranty of | // GNU Affero General Public License for more details. | ||||||
|  * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the | // | ||||||
|  * GNU Affero General Public License for more details. | // You should have received a copy of the GNU Affero General Public License | ||||||
|  * | // along with GNU social.  If not, see <http://www.gnu.org/licenses/>. | ||||||
|  * You should have received a copy of the GNU Affero General Public License |  | ||||||
|  * along with this program.  If not, see <http://www.gnu.org/licenses/>. | /** | ||||||
|  |  * @copyright 2008-2010 StatusNet, Inc. | ||||||
|  |  * @license   https://www.gnu.org/licenses/agpl.html GNU AGPL v3 or later | ||||||
|  */ |  */ | ||||||
|  |  | ||||||
| define('INSTALLDIR', dirname(__DIR__)); | define('INSTALLDIR', dirname(__DIR__)); | ||||||
| @@ -53,7 +55,7 @@ if (have_option('i', 'id')) { | |||||||
|     } |     } | ||||||
| } elseif (have_option('all')) { | } elseif (have_option('all')) { | ||||||
|     $user = new User(); |     $user = new User(); | ||||||
|     $user->whereAdd("jabber != ''"); |     $user->whereAdd("jabber <> ''"); | ||||||
|     $user->find(true); |     $user->find(true); | ||||||
|     if ($user->N == 0) { |     if ($user->N == 0) { | ||||||
|         print "No users with registered Jabber addresses in database.\n"; |         print "No users with registered Jabber addresses in database.\n"; | ||||||
|   | |||||||
| @@ -1,21 +1,23 @@ | |||||||
| #!/usr/bin/env php | #!/usr/bin/env php | ||||||
| <?php | <?php | ||||||
| /* | // This file is part of GNU social - https://www.gnu.org/software/social | ||||||
|  * StatusNet - a distributed open-source microblogging tool | // | ||||||
|  * Copyright (C) 2009-2010, StatusNet, Inc. | // GNU social is free software: you can redistribute it and/or modify | ||||||
|  * | // it under the terms of the GNU Affero General Public License as published by | ||||||
|  * This program is free software: you can redistribute it and/or modify | // the Free Software Foundation, either version 3 of the License, or | ||||||
|  * it under the terms of the GNU Affero General Public License as published by | // (at your option) any later version. | ||||||
|  * the Free Software Foundation, either version 3 of the License, or | // | ||||||
|  * (at your option) any later version. | // GNU social is distributed in the hope that it will be useful, | ||||||
|  * | // but WITHOUT ANY WARRANTY; without even the implied warranty of | ||||||
|  * This program is distributed in the hope that it will be useful, | // MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the | ||||||
|  * but WITHOUT ANY WARRANTY; without even the implied warranty of | // GNU Affero General Public License for more details. | ||||||
|  * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the | // | ||||||
|  * GNU Affero General Public License for more details. | // You should have received a copy of the GNU Affero General Public License | ||||||
|  * | // along with GNU social.  If not, see <http://www.gnu.org/licenses/>. | ||||||
|  * You should have received a copy of the GNU Affero General Public License |  | ||||||
|  * along with this program.  If not, see <http://www.gnu.org/licenses/>. | /** | ||||||
|  |  * @copyright 2009-2010 StatusNet, Inc. | ||||||
|  |  * @license   https://www.gnu.org/licenses/agpl.html GNU AGPL v3 or later | ||||||
|  */ |  */ | ||||||
|  |  | ||||||
| define('INSTALLDIR', dirname(__DIR__)); | define('INSTALLDIR', dirname(__DIR__)); | ||||||
| @@ -76,7 +78,7 @@ if (have_option('--all')) { | |||||||
|     print "Finding all notices by $profile->nickname..."; |     print "Finding all notices by $profile->nickname..."; | ||||||
| } else { | } else { | ||||||
|     print "Finding notices by $profile->nickname with geolocation data..."; |     print "Finding notices by $profile->nickname with geolocation data..."; | ||||||
|     $notice->whereAdd("lat != ''"); |     $notice->whereAdd("lat <> ''"); | ||||||
| } | } | ||||||
| $notice->find(); | $notice->find(); | ||||||
|  |  | ||||||
|   | |||||||
| @@ -362,7 +362,8 @@ function initNoticeReshare() | |||||||
|  |  | ||||||
|     $notice = new Notice(); |     $notice = new Notice(); | ||||||
|     $notice->whereAdd('repeat_of is not null'); |     $notice->whereAdd('repeat_of is not null'); | ||||||
|     $notice->whereAdd('(verb != "'.ActivityVerb::SHARE.'" OR object_type != "'.ActivityObject::ACTIVITY.'")'); |     $notice->whereAdd('(verb <> "' . ActivityVerb::SHARE | ||||||
|  |                       . '" OR object_type <> "' . ActivityObject::ACTIVITY . '")'); | ||||||
|  |  | ||||||
|     if ($notice->find()) { |     if ($notice->find()) { | ||||||
|         while ($notice->fetch()) { |         while ($notice->fetch()) { | ||||||
| @@ -580,7 +581,7 @@ function deleteMissingLocalFileThumbnails() | |||||||
|     printfnq("Removing all local File_thumbnail entries without existing files..."); |     printfnq("Removing all local File_thumbnail entries without existing files..."); | ||||||
|  |  | ||||||
|     $thumbs = new File_thumbnail(); |     $thumbs = new File_thumbnail(); | ||||||
|     $thumbs->whereAdd("filename IS NOT NULL AND filename != ''"); |     $thumbs->whereAdd("filename IS NOT NULL AND filename <> ''"); | ||||||
|     // Checking if there were any File_thumbnail entries without filename |     // Checking if there were any File_thumbnail entries without filename | ||||||
|     if ($thumbs->find()) { |     if ($thumbs->find()) { | ||||||
|         while ($thumbs->fetch()) { |         while ($thumbs->fetch()) { | ||||||
| @@ -603,7 +604,7 @@ function setFilehashOnLocalFiles() | |||||||
|     printfnq('Ensuring all local files have the filehash field set...'); |     printfnq('Ensuring all local files have the filehash field set...'); | ||||||
|  |  | ||||||
|     $file = new File(); |     $file = new File(); | ||||||
|     $file->whereAdd("filename IS NOT NULL AND filename != ''"); // local files |     $file->whereAdd("filename IS NOT NULL AND filename <> ''"); // local files | ||||||
|     $file->whereAdd('filehash IS NULL', 'AND');     // without filehash value |     $file->whereAdd('filehash IS NULL', 'AND');     // without filehash value | ||||||
|  |  | ||||||
|     if ($file->find()) { |     if ($file->find()) { | ||||||
|   | |||||||
		Reference in New Issue
	
	Block a user