mirror of
https://github.com/friendica/friendica
synced 2025-01-18 17:04:28 +00:00
Issue 14349: Fix profile page for unrelated contacts
This commit is contained in:
parent
66e9807876
commit
131e330e61
8 changed files with 440 additions and 476 deletions
|
@ -281,12 +281,12 @@ class User
|
||||||
*/
|
*/
|
||||||
public static function setCollapsed(int $cid, int $uid, bool $collapsed)
|
public static function setCollapsed(int $cid, int $uid, bool $collapsed)
|
||||||
{
|
{
|
||||||
$cdata = Contact::getPublicAndUserContactID($cid, $uid);
|
$pcid = Contact::getPublicContactId($cid, $uid);
|
||||||
if (empty($cdata)) {
|
if (!$pcid) {
|
||||||
return;
|
return;
|
||||||
}
|
}
|
||||||
|
|
||||||
DBA::update('user-contact', ['collapsed' => $collapsed], ['cid' => $cdata['public'], 'uid' => $uid], true);
|
DBA::update('user-contact', ['collapsed' => $collapsed], ['cid' => $pcid, 'uid' => $uid], true);
|
||||||
}
|
}
|
||||||
|
|
||||||
/**
|
/**
|
||||||
|
@ -300,21 +300,13 @@ class User
|
||||||
*/
|
*/
|
||||||
public static function isCollapsed(int $cid, int $uid): bool
|
public static function isCollapsed(int $cid, int $uid): bool
|
||||||
{
|
{
|
||||||
$cdata = Contact::getPublicAndUserContactID($cid, $uid);
|
$pcid = Contact::getPublicContactId($cid, $uid);
|
||||||
if (empty($cdata)) {
|
if (!$pcid) {
|
||||||
return false;
|
return false;
|
||||||
}
|
}
|
||||||
|
|
||||||
$collapsed = false;
|
$public_contact = DBA::selectFirst('user-contact', ['collapsed'], ['cid' => $pcid, 'uid' => $uid]);
|
||||||
|
return $public_contact['collapsed'] ?? false;
|
||||||
if (!empty($cdata['public'])) {
|
|
||||||
$public_contact = DBA::selectFirst('user-contact', ['collapsed'], ['cid' => $cdata['public'], 'uid' => $uid]);
|
|
||||||
if (DBA::isResult($public_contact)) {
|
|
||||||
$collapsed = (bool) $public_contact['collapsed'];
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
return $collapsed;
|
|
||||||
}
|
}
|
||||||
|
|
||||||
/**
|
/**
|
||||||
|
@ -328,12 +320,12 @@ class User
|
||||||
*/
|
*/
|
||||||
public static function setChannelFrequency(int $cid, int $uid, int $frequency)
|
public static function setChannelFrequency(int $cid, int $uid, int $frequency)
|
||||||
{
|
{
|
||||||
$cdata = Contact::getPublicAndUserContactID($cid, $uid);
|
$pcid = Contact::getPublicContactId($cid, $uid);
|
||||||
if (empty($cdata)) {
|
if (!$pcid) {
|
||||||
return;
|
return;
|
||||||
}
|
}
|
||||||
|
|
||||||
DBA::update('user-contact', ['channel-frequency' => $frequency], ['cid' => $cdata['public'], 'uid' => $uid], true);
|
DBA::update('user-contact', ['channel-frequency' => $frequency], ['cid' => $pcid, 'uid' => $uid], true);
|
||||||
}
|
}
|
||||||
|
|
||||||
/**
|
/**
|
||||||
|
@ -347,21 +339,13 @@ class User
|
||||||
*/
|
*/
|
||||||
public static function getChannelFrequency(int $cid, int $uid): int
|
public static function getChannelFrequency(int $cid, int $uid): int
|
||||||
{
|
{
|
||||||
$cdata = Contact::getPublicAndUserContactID($cid, $uid);
|
$pcid = Contact::getPublicContactId($cid, $uid);
|
||||||
if (empty($cdata)) {
|
if (!$pcid) {
|
||||||
return false;
|
return false;
|
||||||
}
|
}
|
||||||
|
|
||||||
$frequency = self::FREQUENCY_DEFAULT;
|
$public_contact = DBA::selectFirst('user-contact', ['channel-frequency'], ['cid' => $pcid, 'uid' => $uid]);
|
||||||
|
return $public_contact['channel-frequency'] ?? self::FREQUENCY_DEFAULT;
|
||||||
if (!empty($cdata['public'])) {
|
|
||||||
$public_contact = DBA::selectFirst('user-contact', ['channel-frequency'], ['cid' => $cdata['public'], 'uid' => $uid]);
|
|
||||||
if (DBA::isResult($public_contact)) {
|
|
||||||
$frequency = $public_contact['channel-frequency'] ?? self::FREQUENCY_DEFAULT;
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
return $frequency;
|
|
||||||
}
|
}
|
||||||
|
|
||||||
/**
|
/**
|
||||||
|
@ -375,12 +359,12 @@ class User
|
||||||
*/
|
*/
|
||||||
public static function setChannelOnly(int $cid, int $uid, bool $isChannelOnly)
|
public static function setChannelOnly(int $cid, int $uid, bool $isChannelOnly)
|
||||||
{
|
{
|
||||||
$cdata = Contact::getPublicAndUserContactID($cid, $uid);
|
$pcid = Contact::getPublicContactId($cid, $uid);
|
||||||
if (empty($cdata)) {
|
if (!$pcid) {
|
||||||
return;
|
return;
|
||||||
}
|
}
|
||||||
|
|
||||||
DBA::update('user-contact', ['channel-only' => $isChannelOnly], ['cid' => $cdata['public'], 'uid' => $uid], true);
|
DBA::update('user-contact', ['channel-only' => $isChannelOnly], ['cid' => $pcid, 'uid' => $uid], true);
|
||||||
}
|
}
|
||||||
|
|
||||||
/**
|
/**
|
||||||
|
@ -394,21 +378,13 @@ class User
|
||||||
*/
|
*/
|
||||||
public static function getChannelOnly(int $cid, int $uid): bool
|
public static function getChannelOnly(int $cid, int $uid): bool
|
||||||
{
|
{
|
||||||
$cdata = Contact::getPublicAndUserContactID($cid, $uid);
|
$pcid = Contact::getPublicContactId($cid, $uid);
|
||||||
if (empty($cdata)) {
|
if (!$pcid) {
|
||||||
return false;
|
return false;
|
||||||
}
|
}
|
||||||
|
|
||||||
$isChannelOnly = false;
|
$public_contact = DBA::selectFirst('user-contact', ['channel-only'], ['cid' => $pcid, 'uid' => $uid]);
|
||||||
|
return $public_contact['channel-only'] ?? false;
|
||||||
if (!empty($cdata['public'])) {
|
|
||||||
$public_contact = DBA::selectFirst('user-contact', ['channel-only'], ['cid' => $cdata['public'], 'uid' => $uid]);
|
|
||||||
if (DBA::isResult($public_contact)) {
|
|
||||||
$isChannelOnly = $public_contact['channel-only'] ?? false;
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
return $isChannelOnly;
|
|
||||||
}
|
}
|
||||||
|
|
||||||
/**
|
/**
|
||||||
|
@ -422,12 +398,12 @@ class User
|
||||||
*/
|
*/
|
||||||
public static function setIsBlocked(int $cid, int $uid, bool $blocked)
|
public static function setIsBlocked(int $cid, int $uid, bool $blocked)
|
||||||
{
|
{
|
||||||
$cdata = Contact::getPublicAndUserContactID($cid, $uid);
|
$pcid = Contact::getPublicContactId($cid, $uid);
|
||||||
if (empty($cdata)) {
|
if (!$pcid) {
|
||||||
return;
|
return;
|
||||||
}
|
}
|
||||||
|
|
||||||
DBA::update('user-contact', ['is-blocked' => $blocked], ['cid' => $cdata['public'], 'uid' => $uid], true);
|
DBA::update('user-contact', ['is-blocked' => $blocked], ['cid' => $pcid, 'uid' => $uid], true);
|
||||||
}
|
}
|
||||||
|
|
||||||
/**
|
/**
|
||||||
|
@ -440,18 +416,12 @@ class User
|
||||||
*/
|
*/
|
||||||
public static function isIsBlocked(int $cid, int $uid): bool
|
public static function isIsBlocked(int $cid, int $uid): bool
|
||||||
{
|
{
|
||||||
$cdata = Contact::getPublicAndUserContactID($cid, $uid);
|
$pcid = Contact::getPublicContactId($cid, $uid);
|
||||||
if (empty($cdata)) {
|
if (!$pcid) {
|
||||||
return false;
|
return false;
|
||||||
}
|
}
|
||||||
|
|
||||||
if (!empty($cdata['public'])) {
|
$public_contact = DBA::selectFirst('user-contact', ['is-blocked'], ['cid' => $pcid, 'uid' => $uid]);
|
||||||
$public_contact = DBA::selectFirst('user-contact', ['is-blocked'], ['cid' => $cdata['public'], 'uid' => $uid]);
|
return $public_contact['is-blocked'] ?? false;
|
||||||
if (DBA::isResult($public_contact)) {
|
|
||||||
return $public_contact['is-blocked'];
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
return false;
|
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
|
@ -100,12 +100,12 @@ class UpdateCredentials extends BaseApi
|
||||||
User::update($user, $uid);
|
User::update($user, $uid);
|
||||||
Profile::update($profile, $uid);
|
Profile::update($profile, $uid);
|
||||||
|
|
||||||
$cdata = Contact::getPublicAndUserContactID($owner['id'], $uid);
|
$ucid = Contact::getUserContactId($owner['id'], $uid);
|
||||||
if (empty($cdata)) {
|
if (!$ucid) {
|
||||||
DI::mstdnError()->InternalError();
|
DI::mstdnError()->InternalError();
|
||||||
}
|
}
|
||||||
|
|
||||||
$account = DI::mstdnAccount()->createFromContactId($cdata['user'], $uid);
|
$account = DI::mstdnAccount()->createFromContactId($ucid, $uid);
|
||||||
$this->response->addJsonContent($account->toArray());
|
$this->response->addJsonContent($account->toArray());
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
|
@ -45,13 +45,13 @@ class VerifyCredentials extends BaseApi
|
||||||
DI::mstdnError()->InternalError();
|
DI::mstdnError()->InternalError();
|
||||||
}
|
}
|
||||||
|
|
||||||
$cdata = Contact::getPublicAndUserContactID($self['id'], $uid);
|
$ucid = Contact::getUserContactId($self['id'], $uid);
|
||||||
if (empty($cdata)) {
|
if (!$ucid) {
|
||||||
DI::mstdnError()->InternalError();
|
DI::mstdnError()->InternalError();
|
||||||
}
|
}
|
||||||
|
|
||||||
// @todo Support the source property,
|
// @todo Support the source property,
|
||||||
$account = DI::mstdnAccount()->createFromContactId($cdata['user'], $uid);
|
$account = DI::mstdnAccount()->createFromContactId($ucid, $uid);
|
||||||
$this->response->addJsonContent($account->toArray());
|
$this->response->addJsonContent($account->toArray());
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
|
@ -81,18 +81,18 @@ class Conversations extends BaseModule
|
||||||
|
|
||||||
// Backward compatibility: Ensure to use the public contact when the user contact is provided
|
// Backward compatibility: Ensure to use the public contact when the user contact is provided
|
||||||
// Remove by version 2022.03
|
// Remove by version 2022.03
|
||||||
$data = Model\Contact::getPublicAndUserContactID(intval($this->parameters['id']), $this->userSession->getLocalUserId());
|
$pcid = Model\Contact::getPublicContactId(intval($this->parameters['id']), $this->userSession->getLocalUserId());
|
||||||
if (empty($data)) {
|
if (!$pcid) {
|
||||||
throw new NotFoundException($this->t('Contact not found.'));
|
throw new NotFoundException($this->t('Contact not found.'));
|
||||||
}
|
}
|
||||||
|
|
||||||
$contact = Model\Contact::getById($data['public']);
|
$contact = Model\Contact::getById($pcid);
|
||||||
if (empty($contact)) {
|
if (empty($contact)) {
|
||||||
throw new NotFoundException($this->t('Contact not found.'));
|
throw new NotFoundException($this->t('Contact not found.'));
|
||||||
}
|
}
|
||||||
|
|
||||||
// Don't display contacts that are about to be deleted
|
// Don't display contacts that are about to be deleted
|
||||||
if (!empty($contact['deleted']) || !empty($contact['network']) && $contact['network'] == Protocol::PHANTOM) {
|
if ($contact['deleted'] || $contact['network'] == Protocol::PHANTOM) {
|
||||||
throw new NotFoundException($this->t('Contact not found.'));
|
throw new NotFoundException($this->t('Contact not found.'));
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
|
@ -73,18 +73,18 @@ class Posts extends BaseModule
|
||||||
|
|
||||||
// Backward compatibility: Ensure to use the public contact when the user contact is provided
|
// Backward compatibility: Ensure to use the public contact when the user contact is provided
|
||||||
// Remove by version 2022.03
|
// Remove by version 2022.03
|
||||||
$data = Model\Contact::getPublicAndUserContactID(intval($this->parameters['id']), $this->userSession->getLocalUserId());
|
$pcid = Model\Contact::getPublicContactId(intval($this->parameters['id']), $this->userSession->getLocalUserId());
|
||||||
if (empty($data)) {
|
if (!$pcid) {
|
||||||
throw new NotFoundException($this->t('Contact not found.'));
|
throw new NotFoundException($this->t('Contact not found.'));
|
||||||
}
|
}
|
||||||
|
|
||||||
$contact = Model\Contact::getById($data['public']);
|
$contact = Model\Contact::getById($pcid);
|
||||||
if (!DBA::isResult($contact)) {
|
if (!DBA::isResult($contact)) {
|
||||||
throw new NotFoundException($this->t('Contact not found.'));
|
throw new NotFoundException($this->t('Contact not found.'));
|
||||||
}
|
}
|
||||||
|
|
||||||
// Don't display contacts that are about to be deleted
|
// Don't display contacts that are about to be deleted
|
||||||
if (DBA::isResult($contact) && (!empty($contact['deleted']) || !empty($contact['network']) && $contact['network'] == Protocol::PHANTOM)) {
|
if ($contact['deleted'] || $contact['network'] == Protocol::PHANTOM) {
|
||||||
throw new NotFoundException($this->t('Contact not found.'));
|
throw new NotFoundException($this->t('Contact not found.'));
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
|
@ -165,11 +165,13 @@ class Profile extends BaseModule
|
||||||
}
|
}
|
||||||
|
|
||||||
// Fetch the protocol from the user's contact.
|
// Fetch the protocol from the user's contact.
|
||||||
|
if ($data['user']) {
|
||||||
$usercontact = Contact::getById($data['user'], ['network', 'protocol']);
|
$usercontact = Contact::getById($data['user'], ['network', 'protocol']);
|
||||||
if ($this->db->isResult($usercontact)) {
|
if ($this->db->isResult($usercontact)) {
|
||||||
$contact['network'] = $usercontact['network'];
|
$contact['network'] = $usercontact['network'];
|
||||||
$contact['protocol'] = $usercontact['protocol'];
|
$contact['protocol'] = $usercontact['protocol'];
|
||||||
}
|
}
|
||||||
|
}
|
||||||
|
|
||||||
if (empty($contact['network']) && Contact::isLocal($contact['url']) ) {
|
if (empty($contact['network']) && Contact::isLocal($contact['url']) ) {
|
||||||
$contact['network'] = Protocol::DFRN;
|
$contact['network'] = Protocol::DFRN;
|
||||||
|
@ -177,7 +179,7 @@ class Profile extends BaseModule
|
||||||
}
|
}
|
||||||
|
|
||||||
// Don't display contacts that are about to be deleted
|
// Don't display contacts that are about to be deleted
|
||||||
if ($this->db->isResult($contact) && (!empty($contact['deleted']) || !empty($contact['network']) && $contact['network'] == Protocol::PHANTOM)) {
|
if ($contact['deleted'] || $contact['network'] == Protocol::PHANTOM) {
|
||||||
throw new HTTPException\NotFoundException($this->t('Contact not found.'));
|
throw new HTTPException\NotFoundException($this->t('Contact not found.'));
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
|
@ -59,16 +59,12 @@ class Revoke extends BaseModule
|
||||||
return;
|
return;
|
||||||
}
|
}
|
||||||
|
|
||||||
$data = Model\Contact::getPublicAndUserContactID($this->parameters['id'], DI::userSession()->getLocalUserId());
|
$ucid = Model\Contact::getUserContactId($this->parameters['id'], DI::userSession()->getLocalUserId());
|
||||||
if (!$this->dba->isResult($data)) {
|
if (!$ucid) {
|
||||||
throw new HTTPException\NotFoundException($this->t('Unknown contact.'));
|
|
||||||
}
|
|
||||||
|
|
||||||
if (empty($data['user'])) {
|
|
||||||
throw new HTTPException\ForbiddenException();
|
throw new HTTPException\ForbiddenException();
|
||||||
}
|
}
|
||||||
|
|
||||||
$this->contact = Model\Contact::getById($data['user']);
|
$this->contact = Model\Contact::getById($ucid);
|
||||||
|
|
||||||
if ($this->contact['deleted']) {
|
if ($this->contact['deleted']) {
|
||||||
throw new HTTPException\NotFoundException($this->t('Contact is deleted.'));
|
throw new HTTPException\NotFoundException($this->t('Contact is deleted.'));
|
||||||
|
|
File diff suppressed because it is too large
Load diff
Loading…
Reference in a new issue