Merge pull request #9046 from annando/local-followers
Fetch followers/followings locally
This commit is contained in:
commit
101daab790
1 changed files with 46 additions and 10 deletions
|
@ -28,6 +28,8 @@ use Friendica\Database\DBA;
|
||||||
use Friendica\DI;
|
use Friendica\DI;
|
||||||
use Friendica\Model\APContact;
|
use Friendica\Model\APContact;
|
||||||
use Friendica\Model\Contact;
|
use Friendica\Model\Contact;
|
||||||
|
use Friendica\Model\Profile;
|
||||||
|
use Friendica\Model\User;
|
||||||
use Friendica\Protocol\ActivityPub;
|
use Friendica\Protocol\ActivityPub;
|
||||||
use Friendica\Util\DateTimeFormat;
|
use Friendica\Util\DateTimeFormat;
|
||||||
use Friendica\Util\Strings;
|
use Friendica\Util\Strings;
|
||||||
|
@ -82,18 +84,25 @@ class Relation
|
||||||
return;
|
return;
|
||||||
}
|
}
|
||||||
|
|
||||||
$apcontact = APContact::getByURL($url, false);
|
$uid = User::getIdForURL($url);
|
||||||
|
if (!empty($uid)) {
|
||||||
if (!empty($apcontact['followers']) && is_string($apcontact['followers'])) {
|
// Fetch the followers/followings locally
|
||||||
$followers = ActivityPub::fetchItems($apcontact['followers']);
|
$followers = self::getContacts($uid, [Contact::FOLLOWER, Contact::FRIEND]);
|
||||||
|
$followings = self::getContacts($uid, [Contact::SHARING, Contact::FRIEND]);
|
||||||
} else {
|
} else {
|
||||||
$followers = [];
|
$apcontact = APContact::getByURL($url, false);
|
||||||
}
|
|
||||||
|
|
||||||
if (!empty($apcontact['following']) && is_string($apcontact['following'])) {
|
if (!empty($apcontact['followers']) && is_string($apcontact['followers'])) {
|
||||||
$followings = ActivityPub::fetchItems($apcontact['following']);
|
$followers = ActivityPub::fetchItems($apcontact['followers']);
|
||||||
} else {
|
} else {
|
||||||
$followings = [];
|
$followers = [];
|
||||||
|
}
|
||||||
|
|
||||||
|
if (!empty($apcontact['following']) && is_string($apcontact['following'])) {
|
||||||
|
$followings = ActivityPub::fetchItems($apcontact['following']);
|
||||||
|
} else {
|
||||||
|
$followings = [];
|
||||||
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
if (empty($followers) && empty($followings)) {
|
if (empty($followers) && empty($followings)) {
|
||||||
|
@ -150,6 +159,33 @@ class Relation
|
||||||
return;
|
return;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Fetch contact list from the given local user
|
||||||
|
*
|
||||||
|
* @param integer $uid
|
||||||
|
* @param array $rel
|
||||||
|
* @return void
|
||||||
|
*/
|
||||||
|
private static function getContacts(int $uid, array $rel)
|
||||||
|
{
|
||||||
|
$list = [];
|
||||||
|
$profile = Profile::getByUID($uid);
|
||||||
|
if (!empty($profile['hide-friends'])) {
|
||||||
|
return $list;
|
||||||
|
}
|
||||||
|
|
||||||
|
$condition = ['rel' => $rel, 'uid' => $uid, 'self' => false, 'deleted' => false,
|
||||||
|
'hidden' => false, 'archive' => false, 'pending' => false];
|
||||||
|
$condition = DBA::mergeConditions($condition, ["`url` IN (SELECT `url` FROM `apcontact`)"]);
|
||||||
|
$contacts = DBA::select('contact', ['url'], $condition);
|
||||||
|
while ($contact = DBA::fetch($contacts)) {
|
||||||
|
$list[] = $contact['url'];
|
||||||
|
}
|
||||||
|
DBA::close($contacts);
|
||||||
|
|
||||||
|
return $list;
|
||||||
|
}
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* Tests if a given contact url is discoverable
|
* Tests if a given contact url is discoverable
|
||||||
*
|
*
|
||||||
|
|
Loading…
Reference in a new issue