Add backward compatibility with user contacts in Module\Group
This commit is contained in:
parent
a26322b4c2
commit
8bfe877629
2 changed files with 38 additions and 14 deletions
|
@ -25,8 +25,10 @@ use Friendica\BaseModule;
|
||||||
use Friendica\Core\Logger;
|
use Friendica\Core\Logger;
|
||||||
use Friendica\Core\Protocol;
|
use Friendica\Core\Protocol;
|
||||||
use Friendica\Core\Renderer;
|
use Friendica\Core\Renderer;
|
||||||
|
use Friendica\Database\Database;
|
||||||
use Friendica\Database\DBA;
|
use Friendica\Database\DBA;
|
||||||
use Friendica\DI;
|
use Friendica\DI;
|
||||||
|
use Friendica\Network\HTTPException;
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* functions for interacting with the group database table
|
* functions for interacting with the group database table
|
||||||
|
@ -259,21 +261,24 @@ class Group
|
||||||
* @return boolean
|
* @return boolean
|
||||||
* @throws \Exception
|
* @throws \Exception
|
||||||
*/
|
*/
|
||||||
public static function addMember($gid, $cid)
|
public static function addMember(int $gid, int $cid): bool
|
||||||
{
|
{
|
||||||
if (!$gid || !$cid) {
|
if (!$gid || !$cid) {
|
||||||
return false;
|
return false;
|
||||||
}
|
}
|
||||||
|
|
||||||
$row_exists = DBA::exists('group_member', ['gid' => $gid, 'contact-id' => $cid]);
|
// @TODO Backward compatibility with user contacts, remove by version 2022.03
|
||||||
if ($row_exists) {
|
$group = DBA::selectFirst('group', ['uid'], ['id' => $gid]);
|
||||||
// Row already existing, nothing to do
|
if (empty($group)) {
|
||||||
$return = true;
|
throw new HTTPException\NotFoundException('Group not found.');
|
||||||
} else {
|
|
||||||
$return = DBA::insert('group_member', ['gid' => $gid, 'contact-id' => $cid]);
|
|
||||||
}
|
}
|
||||||
|
|
||||||
return $return;
|
$cdata = Contact::getPublicAndUserContactID($cid, $group['uid']);
|
||||||
|
if (empty($cdata['user'])) {
|
||||||
|
throw new HTTPException\NotFoundException('Invalid contact.');
|
||||||
|
}
|
||||||
|
|
||||||
|
return DBA::insert('group_member', ['gid' => $gid, 'contact-id' => $cdata['user']], Database::INSERT_IGNORE);
|
||||||
}
|
}
|
||||||
|
|
||||||
/**
|
/**
|
||||||
|
@ -284,15 +289,24 @@ class Group
|
||||||
* @return boolean
|
* @return boolean
|
||||||
* @throws \Exception
|
* @throws \Exception
|
||||||
*/
|
*/
|
||||||
public static function removeMember($gid, $cid)
|
public static function removeMember(int $gid, int $cid): bool
|
||||||
{
|
{
|
||||||
if (!$gid || !$cid) {
|
if (!$gid || !$cid) {
|
||||||
return false;
|
return false;
|
||||||
}
|
}
|
||||||
|
|
||||||
$return = DBA::delete('group_member', ['gid' => $gid, 'contact-id' => $cid]);
|
// @TODO Backward compatibility with user contacts, remove by version 2022.03
|
||||||
|
$group = DBA::selectFirst('group', ['uid'], ['id' => $gid]);
|
||||||
|
if (empty($group)) {
|
||||||
|
throw new HTTPException\NotFoundException('Group not found.');
|
||||||
|
}
|
||||||
|
|
||||||
return $return;
|
$cdata = Contact::getPublicAndUserContactID($cid, $group['uid']);
|
||||||
|
if (empty($cdata['user'])) {
|
||||||
|
throw new HTTPException\NotFoundException('Invalid contact.');
|
||||||
|
}
|
||||||
|
|
||||||
|
return DBA::delete('group_member', ['gid' => $gid, 'contact-id' => $cid]);
|
||||||
}
|
}
|
||||||
|
|
||||||
/**
|
/**
|
||||||
|
|
|
@ -93,7 +93,17 @@ class Group extends BaseModule
|
||||||
throw new \Exception(DI::l10n()->t('Unknown group.'), 404);
|
throw new \Exception(DI::l10n()->t('Unknown group.'), 404);
|
||||||
}
|
}
|
||||||
|
|
||||||
$contact = DBA::selectFirst('contact', ['deleted'], ['id' => $contact_id, 'uid' => local_user()]);
|
// @TODO Backward compatibility with user contacts, remove by version 2022.03
|
||||||
|
$cdata = Model\Contact::getPublicAndUserContactID($contact_id, local_user());
|
||||||
|
if (empty($cdata['public'])) {
|
||||||
|
throw new \Exception(DI::l10n()->t('Contact not found.'), 404);
|
||||||
|
}
|
||||||
|
|
||||||
|
if (empty($cdata['user'])) {
|
||||||
|
throw new \Exception(DI::l10n()->t('Invalid contact.'), 404);
|
||||||
|
}
|
||||||
|
|
||||||
|
$contact = Model\Contact::getById($cdata['user'], ['deleted']);
|
||||||
if (!DBA::isResult($contact)) {
|
if (!DBA::isResult($contact)) {
|
||||||
throw new \Exception(DI::l10n()->t('Contact not found.'), 404);
|
throw new \Exception(DI::l10n()->t('Contact not found.'), 404);
|
||||||
}
|
}
|
||||||
|
@ -104,14 +114,14 @@ class Group extends BaseModule
|
||||||
|
|
||||||
switch($this->parameters['command']) {
|
switch($this->parameters['command']) {
|
||||||
case 'add':
|
case 'add':
|
||||||
if (!Model\Group::addMember($group_id, $contact_id)) {
|
if (!Model\Group::addMember($group_id, $cdata['user'])) {
|
||||||
throw new \Exception(DI::l10n()->t('Unable to add the contact to the group.'), 500);
|
throw new \Exception(DI::l10n()->t('Unable to add the contact to the group.'), 500);
|
||||||
}
|
}
|
||||||
|
|
||||||
$message = DI::l10n()->t('Contact successfully added to group.');
|
$message = DI::l10n()->t('Contact successfully added to group.');
|
||||||
break;
|
break;
|
||||||
case 'remove':
|
case 'remove':
|
||||||
if (!Model\Group::removeMember($group_id, $contact_id)) {
|
if (!Model\Group::removeMember($group_id, $cdata['user'])) {
|
||||||
throw new \Exception(DI::l10n()->t('Unable to remove the contact from the group.'), 500);
|
throw new \Exception(DI::l10n()->t('Unable to remove the contact from the group.'), 500);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
Loading…
Reference in a new issue