-- ------------------------------------------
-- Friendica 2022.05-dev (Siberian Iris)
--- DB_UPDATE_VERSION 1454
+-- DB_UPDATE_VERSION 1455
-- ------------------------------------------
`ignored` boolean COMMENT 'Posts from this contact are ignored',
`collapsed` boolean COMMENT 'Posts from this contact are collapsed',
`hidden` boolean COMMENT 'This contact is hidden from the others',
+ `is-blocked` boolean COMMENT 'User is blocked by this contact',
`pending` boolean COMMENT '',
`rel` tinyint unsigned COMMENT 'The kind of the relation between the user and the contact',
`info` mediumtext COMMENT '',
| ignored | Posts from this contact are ignored | boolean | YES | | NULL | |
| collapsed | Posts from this contact are collapsed | boolean | YES | | NULL | |
| hidden | This contact is hidden from the others | boolean | YES | | NULL | |
+| is-blocked | User is blocked by this contact | boolean | YES | | NULL | |
| pending | | boolean | YES | | NULL | |
| rel | The kind of the relation between the user and the contact | tinyint unsigned | YES | | NULL | |
| info | | mediumtext | YES | | NULL | |
return $collapsed;
}
+
+ /**
+ * Set/Release that the user is blocked by the contact
+ *
+ * @param int $cid Either public contact id or user's contact id
+ * @param int $uid User ID
+ * @param boolean $blocked Is the user blocked or unblocked by the contact?
+ * @throws \Exception
+ */
+ public static function setIsBlocked($cid, $uid, $blocked)
+ {
+ $cdata = Contact::getPublicAndUserContactID($cid, $uid);
+ if (empty($cdata)) {
+ return;
+ }
+
+ DBA::update('user-contact', ['is-blocked' => $blocked], ['cid' => $cdata['public'], 'uid' => $uid], true);
+ }
+
+ /**
+ * Returns if the user is blocked by the contact
+ *
+ * @param int $cid Either public contact id or user's contact id
+ * @param int $uid User ID
+ *
+ * @return boolean Is the user blocked or unblocked by the contact?
+ * @throws \Exception
+ */
+ public static function isIsBlocked($cid, $uid)
+ {
+ $cdata = Contact::getPublicAndUserContactID($cid, $uid);
+ if (empty($cdata)) {
+ return false;
+ }
+
+ if (!empty($cdata['public'])) {
+ $public_contact = DBA::selectFirst('user-contact', ['is-blocked'], ['cid' => $cdata['public'], 'uid' => $uid]);
+ if (DBA::isResult($public_contact)) {
+ return $public_contact['is-blocked'];
+ }
+ }
+
+ return false;
+ }
}
Logger::info('Deleted contact', ['object' => $activity['object_id']]);
}
+ /**
+ * Blocks the user by the contact
+ *
+ * @param array $activity
+ * @throws \Exception
+ */
+ public static function blockPerson($activity)
+ {
+ $cid = Contact::getIdForURL($activity['actor']);
+ if (empty($cid)) {
+ return;
+ }
+
+ $uid = User::getIdForURL($activity['object_id']);
+ if (empty($uid)) {
+ return;
+ }
+
+ Contact\User::setIsBlocked($cid, $uid, true);
+
+ Logger::info('Contact blocked user', ['contact' => $cid, 'user' => $uid]);
+ }
+
+ /**
+ * Unblocks the user by the contact
+ *
+ * @param array $activity
+ * @throws \Exception
+ */
+ public static function unblockPerson($activity)
+ {
+ $cid = Contact::getIdForURL($activity['actor']);
+ if (empty($cid)) {
+ return;
+ }
+
+ $uid = User::getIdForURL($activity['object_object']);
+ if (empty($uid)) {
+ return;
+ }
+
+ Contact\User::setIsBlocked($cid, $uid, false);
+
+ Logger::info('Contact unblocked user', ['contact' => $cid, 'user' => $uid]);
+ }
+
/**
* Accept a follow request
*
case 'as:Block':
if (in_array($object_data['object_type'], self::ACCOUNT_TYPES)) {
- // Used by Mastodon to announce that the sender has blocked the account
- self::storeUnhandledActivity(false, $type, $object_data, $activity, $body, $uid, $trust_source, $push, $signer);
+ ActivityPub\Processor::blockPerson($object_data);
} else {
self::storeUnhandledActivity(true, $type, $object_data, $activity, $body, $uid, $trust_source, $push, $signer);
}
} elseif (($object_data['object_type'] == 'as:Accept') &&
in_array($object_data['object_object_type'], self::ACCOUNT_TYPES)) {
ActivityPub\Processor::rejectFollowUser($object_data);
+ } elseif (($object_data['object_type'] == 'as:Block') &&
+ in_array($object_data['object_object_type'], self::ACCOUNT_TYPES)) {
+ ActivityPub\Processor::unblockPerson($object_data);
} elseif (in_array($object_data['object_type'], array_merge(self::ACTIVITY_TYPES, ['as:Announce'])) &&
in_array($object_data['object_object_type'], array_merge(['as:Tombstone'], self::CONTENT_TYPES))) {
ActivityPub\Processor::undoActivity($object_data);
use Friendica\Database\DBA;
if (!defined('DB_UPDATE_VERSION')) {
- define('DB_UPDATE_VERSION', 1454);
+ define('DB_UPDATE_VERSION', 1455);
}
return [
"ignored" => ["type" => "boolean", "comment" => "Posts from this contact are ignored"],
"collapsed" => ["type" => "boolean", "comment" => "Posts from this contact are collapsed"],
"hidden" => ["type" => "boolean", "comment" => "This contact is hidden from the others"],
+ "is-blocked" => ["type" => "boolean", "comment" => "User is blocked by this contact"],
"pending" => ["type" => "boolean", "comment" => ""],
"rel" => ["type" => "tinyint unsigned", "comment" => "The kind of the relation between the user and the contact"],
"info" => ["type" => "mediumtext", "comment" => ""],