friendica-github/mod/repair_ostatus.php

65 lines
1.6 KiB
PHP
Raw Normal View History

2015-09-03 22:18:25 +02:00
<?php
/**
* @file mod/repair_ostatus.php
*/
use Friendica\App;
2018-01-21 13:33:59 -05:00
use Friendica\Core\L10n;
use Friendica\Core\Protocol;
2017-08-26 06:04:21 +00:00
use Friendica\Core\System;
use Friendica\Database\DBA;
use Friendica\Model\Contact;
2015-09-03 22:18:25 +02:00
function repair_ostatus_content(App $a) {
2015-09-03 22:18:25 +02:00
if (! local_user()) {
2018-01-21 13:33:59 -05:00
notice(L10n::t('Permission denied.') . EOL);
2015-09-03 22:18:25 +02:00
goaway($_SESSION['return_url']);
// NOTREACHED
}
$o = "<h2>".L10n::t("Resubscribing to OStatus contacts")."</h2>";
2015-09-03 22:18:25 +02:00
$uid = local_user();
$a = get_app();
$counter = intval($_REQUEST['counter']);
$r = q("SELECT COUNT(*) AS `total` FROM `contact` WHERE
`uid` = %d AND `network` = '%s' AND `rel` IN (%d, %d)",
intval($uid),
DBA::escape(Protocol::OSTATUS),
intval(Contact::FRIEND),
intval(Contact::SHARING));
2015-09-03 22:18:25 +02:00
if (!$r)
return($o.L10n::t("Error"));
2015-09-03 22:18:25 +02:00
$total = $r[0]["total"];
$r = q("SELECT `url` FROM `contact` WHERE
`uid` = %d AND `network` = '%s' AND `rel` IN (%d, %d)
ORDER BY `url`
LIMIT %d, 1",
intval($uid),
DBA::escape(Protocol::OSTATUS),
intval(Contact::FRIEND),
intval(Contact::SHARING), $counter++);
2015-09-03 22:18:25 +02:00
if (!$r) {
2018-01-22 07:29:50 -05:00
$o .= L10n::t("Done");
2015-09-03 22:18:25 +02:00
return $o;
}
$o .= "<p>".$counter."/".$total.": ".$r[0]["url"]."</p>";
$o .= "<p>".L10n::t("Keep this window open until done.")."</p>";
2015-09-03 22:18:25 +02:00
2018-01-22 07:29:50 -05:00
$result = Contact::createFromProbe($uid, $r[0]["url"], true);
2015-09-03 22:18:25 +02:00
$a->page['htmlhead'] = '<meta http-equiv="refresh" content="1; URL='.System::baseUrl().'/repair_ostatus?counter='.$counter.'">';
2015-09-03 22:18:25 +02:00
return $o;
}