Make common_sql_weight employ standard SQL functions for the timestamp difference in seconds. Also replace UTC_TIMESTAMP in the MariaDB-specific part with CURRENT_TIMESTAMP as it is the only occurence and GNU social sets UTC as a default timezone. In a delete_orphan_files.php script simplify the main query considerably. In clean_profiles.php stop using COUNT as if it is ANY, that is unnecessary punishment for the database. Instead implement the anti-join with a left outer join. In Autocomplete and Activitypub_profile use joins instead of a WHERE OR anti-pattern for the semi-joins. In lib/ui/galleryaction.php replace a CROSS JOIN with an INNER JOIN. In actions/sup.php remove a redundant subquery: WHERE is applied before grouping either way.
		
			
				
	
	
		
			186 lines
		
	
	
		
			5.4 KiB
		
	
	
	
		
			PHP
		
	
	
		
			Executable File
		
	
	
	
	
			
		
		
	
	
			186 lines
		
	
	
		
			5.4 KiB
		
	
	
	
		
			PHP
		
	
	
		
			Executable File
		
	
	
	
	
| #!/usr/bin/env 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/>.
 | |
| 
 | |
| /**
 | |
|  * @package   GNUsocial
 | |
|  * @copyright 2010 StatusNet, Inc.
 | |
|  * @license   https://www.gnu.org/licenses/agpl.html GNU AGPL v3 or later
 | |
|  */
 | |
| 
 | |
| define('INSTALLDIR', dirname(__DIR__, 3));
 | |
| define('PUBLICDIR', INSTALLDIR . DIRECTORY_SEPARATOR . 'public');
 | |
| 
 | |
| $helptext = <<<END_OF_HELP
 | |
| update-profile.php [options] http://example.com/profile/url
 | |
| 
 | |
| Rerun profile and feed info discovery for the given OStatus remote profile,
 | |
| and reinitialize its WebSub subscription for the given feed. This may help get
 | |
| things restarted if the hub or feed URLs have changed for the profile.
 | |
| 
 | |
| 
 | |
| END_OF_HELP;
 | |
| 
 | |
| require_once INSTALLDIR.'/scripts/commandline.inc';
 | |
| 
 | |
| $validate = new Validate();
 | |
| 
 | |
| if (empty($args[0]) || !$validate->uri($args[0])) {
 | |
|     print "$helptext";
 | |
|     exit(1);
 | |
| }
 | |
| 
 | |
| $uri = $args[0];
 | |
| 
 | |
| 
 | |
| $oprofile = Ostatus_profile::getKV('uri', $uri);
 | |
| 
 | |
| if (!$oprofile) {
 | |
|     print "No OStatus remote profile known for URI $uri\n";
 | |
|     exit(1);
 | |
| }
 | |
| 
 | |
| print "Old profile state for $oprofile->uri\n";
 | |
| showProfile($oprofile);
 | |
| 
 | |
| print "\n";
 | |
| print "Re-running feed discovery for profile URL $oprofile->uri\n";
 | |
| 
 | |
| $feedurl = null;
 | |
| $salmonuri = null;
 | |
| 
 | |
| // @fixme will bork where the URI isn't the profile URL for now
 | |
| $discover = new FeedDiscovery();
 | |
| try {
 | |
|     $feedurl = $discover->discoverFromURL($oprofile->uri);
 | |
|     $salmonuri = $discover->getAtomLink(Salmon::REL_SALMON)
 | |
|                     ?: $discover->getAtomLink(Salmon::NS_REPLIES);  // NS_REPLIES is deprecated
 | |
|     if (empty($salmonuri)) {
 | |
|         throw new FeedSubNoSalmonException('No salmon upstream URI was found');
 | |
|     }
 | |
| } catch (FeedSubException $e) {
 | |
|     $acct = $oprofile->localProfile()->getAcctUri();
 | |
|     print "Could not discover feeds HTML response, trying reconstructed acct URI: {$acct}\n";
 | |
|     $disco = new Discovery();
 | |
|     $xrd = $disco->lookup($acct);
 | |
|     $hints = DiscoveryHints::fromXRD($xrd);
 | |
| 
 | |
|     if (array_key_exists('feedurl', $hints)) {
 | |
|         // Prefer $hints['feedurl'] to current $feedurl value
 | |
|         $feedurl = $hints['feedurl'];
 | |
|     } elseif (empty($feedurl)) {
 | |
|         // if (empty($feedurl) && !array_key_exists('feedurl', $hints))
 | |
|         throw new FeedSubNoFeedException($acct);
 | |
|     }
 | |
| 
 | |
|     $salmonuri = array_key_exists('salmon', $hints) ? $hints['salmon'] : $salmonuri;
 | |
| 
 | |
|     // get the hub data too and put it in the FeedDiscovery object
 | |
|     $discover->discoverFromFeedUrl($feedurl);
 | |
| }
 | |
| 
 | |
| $huburi = $discover->getHubLink();
 | |
| 
 | |
| print "  Feed URL: $feedurl\n";
 | |
| print "  Hub URL: $huburi\n";
 | |
| print "  Salmon URL: $salmonuri\n";
 | |
| 
 | |
| if ($feedurl != $oprofile->feeduri || $salmonuri != $oprofile->salmonuri) {
 | |
|     print "\n";
 | |
|     print "Updating...\n";
 | |
|     // @fixme update keys :P
 | |
|     //$orig = clone($oprofile);
 | |
|     //$oprofile->feeduri = $feedurl;
 | |
|     //$oprofile->salmonuri = $salmonuri;
 | |
|     //$ok = $oprofile->update($orig);
 | |
|     $ok = $oprofile->query(
 | |
|         <<<END
 | |
|         UPDATE ostatus_profile
 | |
|         SET feeduri   = '{$oprofile->escape($feedurl)}',
 | |
|             salmonuri = '{$oprofile->escape($salmonuri)}'
 | |
|         WHERE uri = '{$oprofile->escape($uri)}'
 | |
|         END
 | |
|     );
 | |
| 
 | |
|     if (!$ok) {
 | |
|         print "Failed to update profile record...\n";
 | |
|         exit(1);
 | |
|     }
 | |
| 
 | |
|     $oprofile->decache();
 | |
| } else {
 | |
|     print "\n";
 | |
|     print "Ok, ostatus_profile record unchanged.\n\n";
 | |
| }
 | |
| 
 | |
| $sub = FeedSub::ensureFeed($feedurl);
 | |
| 
 | |
| if ($huburi != $sub->huburi) {
 | |
|     print "\n";
 | |
|     print "Updating hub record for feed; was $sub->huburi\n";
 | |
|     $orig = clone($sub);
 | |
|     $sub->huburi = $huburi;
 | |
|     $ok = $sub->update($orig);
 | |
| 
 | |
|     if (!$ok) {
 | |
|         print "Failed to update sub record...\n";
 | |
|         exit(1);
 | |
|     }
 | |
| } else {
 | |
|     print "\n";
 | |
|     print "Feed record ok, not changing.\n\n";
 | |
| }
 | |
| 
 | |
| echo "\n";
 | |
| echo "Pinging hub {$sub->huburi} with new subscription for {$sub->uri}\n";
 | |
| try {
 | |
|     $sub->subscribe();
 | |
|     echo "ok\n";
 | |
| } catch (Exception $e) {
 | |
|     echo 'Could not confirm. '.get_class($e).': '.$e->getMessage()."\n";
 | |
| }
 | |
| 
 | |
| $o2 = Ostatus_profile::getKV('uri', $uri);
 | |
| 
 | |
| print "\n";
 | |
| print "New profile state:\n";
 | |
| showProfile($o2);
 | |
| 
 | |
| print "\n";
 | |
| print "New feed state:\n";
 | |
| $sub2 = FeedSub::ensureFeed($feedurl);
 | |
| showSub($sub2);
 | |
| 
 | |
| function showProfile($oprofile)
 | |
| {
 | |
|     print "  Feed URL: $oprofile->feeduri\n";
 | |
|     print "  Salmon URL: $oprofile->salmonuri\n";
 | |
|     print "  Avatar URL: $oprofile->avatar\n";
 | |
|     print "  Profile ID: $oprofile->profile_id\n";
 | |
|     print "  Group ID: $oprofile->group_id\n";
 | |
|     print "  Record created: $oprofile->created\n";
 | |
|     print "  Record modified: $oprofile->modified\n";
 | |
| }
 | |
| 
 | |
| function showSub($sub)
 | |
| {
 | |
|     print "  Subscription state: $sub->sub_state\n";
 | |
|     print "  Signature secret: $sub->secret\n";
 | |
|     print "  Sub start date: $sub->sub_start\n";
 | |
|     print "  Record created: $sub->created\n";
 | |
|     print "  Record modified: $sub->modified\n";
 | |
| }
 |