d01f44ee99
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";
|
|
}
|