diff options
Diffstat (limited to 'Zotlabs/Lib/Libzot.php')
-rw-r--r-- | Zotlabs/Lib/Libzot.php | 115 |
1 files changed, 20 insertions, 95 deletions
diff --git a/Zotlabs/Lib/Libzot.php b/Zotlabs/Lib/Libzot.php index 41fec64d8..05134f433 100644 --- a/Zotlabs/Lib/Libzot.php +++ b/Zotlabs/Lib/Libzot.php @@ -1134,7 +1134,6 @@ class Libzot { } $message_request = false; - $is_collection_operation = false; $has_data = array_key_exists('data', $env) && $env['data']; @@ -1142,44 +1141,26 @@ class Libzot { $AS = null; - if ($env['encoding'] === 'activitystreams') { $AS = new ActivityStreams($data); - - logger($AS->debug(), LOGGER_DATA); - if (!$AS->is_valid()) { logger('Activity rejected: ' . print_r($data, true)); return; } - // process add/remove from collection separately, as it requires a target. - // use the raw object, as it will not include actor expansion if (in_array($AS->type, ['Add', 'Remove']) && is_array($AS->obj) && array_key_exists('object', $AS->obj) && array_key_exists('actor', $AS->obj) && !empty($AS->tgt)) { - hz_syslog('relayed collection operation', LOGGER_DEBUG); - $is_collection_operation = true; - - $original_id = $AS->id; - $original_type = $AS->type; - - $raw_activity = $AS->data; - - $AS = new ActivityStreams($raw_activity['object'], portable_id: $env['sender']); - - // Store the original activity id and type for later usage - $AS->meta['original_id'] = $original_id; - $AS->meta['original_type'] = $original_type; + logger('unsupported collection operation', LOGGER_DEBUG); + return; } if (is_array($AS->obj)) { $item = Activity::decode_note($AS); - if (!$item) { logger('Could not decode activity: ' . print_r($AS, true)); return; @@ -1189,7 +1170,7 @@ class Libzot { $item = []; } - + logger($AS->debug(), LOGGER_DATA); } @@ -1332,12 +1313,7 @@ class Libzot { $relay = (($env['type'] === 'response') ? true : false); - if($is_collection_operation) - hz_syslog('col'); - else - hz_syslog('not col'); - - $result = self::process_delivery($env['sender'], $AS, $item, $deliveries, $relay, false, $message_request, false, $is_collection_operation); + $result = self::process_delivery($env['sender'], $AS, $item, $deliveries, $relay, false, $message_request); Activity::init_background_fetch($env['sender']); } @@ -1553,7 +1529,7 @@ class Libzot { * @return array */ - static function process_delivery($sender, $act, $arr, $deliveries, $relay, $public = false, $request = false, $force = false, $is_collection_operation = false) { + static function process_delivery($sender, $act, $arr, $deliveries, $relay, $public = false, $request = false, $force = false) { $result = []; // We've validated the sender. Now make sure that the sender is the owner or author @@ -1581,14 +1557,6 @@ class Libzot { $DR->set_name($channel['channel_name'] . ' <' . channel_reddress($channel) . '>'); - $conversation_operation = $is_collection_operation && isset($arr['target']['attributedTo']); - - if (str_contains($arr['tgt_type'], 'Collection') && !$relay && !$conversation_operation) { - $DR->update('not a collection activity'); - $result[] = $DR->get(); - continue; - } - if (($act) && ($act->obj) && (!is_array($act->obj))) { // The initial object fetch failed using the sys channel credentials. // Try again using the delivery channel credentials. @@ -1622,8 +1590,6 @@ class Libzot { * */ - - if ($sender === $channel['channel_hash'] && $arr['author_xchan'] === $channel['channel_hash'] && !str_starts_with($arr['mid'], z_root())) { $DR->update('self delivery ignored'); $result[] = $DR->get(); @@ -1864,12 +1830,6 @@ class Libzot { } } - if($is_collection_operation) - hz_syslog('col1'); - else - hz_syslog('not col1'); - - // This is used to fetch allow/deny rules if either the sender // or owner is a connection. post_is_importable() evaluates all of them $abook = q("select * from abook where abook_channel = %d and ( abook_xchan = '%s' OR abook_xchan = '%s' )", @@ -1878,15 +1838,11 @@ class Libzot { dbesc($arr['author_xchan']) ); - // Reactions such as like and dislike could have an mid with /activity/ in it. + // reactions such as like and dislike could have an mid with /activity/ in it. // Check for both forms in order to prevent duplicates. - - // If we process an add/remove activity, look for the original activity id instead of the object id - $sql_mid = (($is_collection_operation && $relay && $channel['channel_hash'] === $arr['owner_xchan']) ? $act->meta['original_id'] : $arr['mid']); - - $r = q("select * from item where mid in ('%s', '%s') and uid = %d limit 1", - dbesc($sql_mid), - dbesc(reverse_activity_mid($sql_mid)), + $r = q("select * from item where mid in ('%s','%s') and uid = %d limit 1", + dbesc($arr['mid']), + dbesc(str_replace(z_root() . '/activity/', z_root() . '/item/', $arr['mid'])), intval($channel['channel_id']) ); @@ -1915,29 +1871,21 @@ class Libzot { $DR->update('update ignored'); $result[] = $DR->get(); } - - if ($relay && $channel['channel_hash'] === $item_result['item']['owner_xchan'] && $item_result['item']['verb'] !== 'Add' && !$is_collection_operation) { - $approval = Activity::addToCollection($channel, $act->data, $item_result['item']['parent_mid'], $item_result['item'], deliver: false); - } - } else { $DR->update('update ignored'); $result[] = $DR->get(); - // We need this line to ensure wall-to-wall comments and add/remove activities are relayed (by falling through to the relay bit), + // We need this line to ensure wall-to-wall comments are relayed (by falling through to the relay bit), // and at the same time not relay any other relayable posts more than once, because to do so is very wasteful. if (!intval($r[0]['item_origin'])) continue; } - - } else { $arr['aid'] = $channel['channel_account_id']; $arr['uid'] = $channel['channel_id']; - // if it's a sourced post, call the post_local hooks as if it were // posted locally so that crosspost connectors will be triggered. $item_source = check_item_source($arr['uid'], $arr); @@ -1966,15 +1914,10 @@ class Libzot { } if (post_is_importable($arr['uid'], $arr, $abook)) { - $item_result = item_store($arr, addAndSync: false); - + $item_result = item_store($arr); if ($item_result['success']) { $item_id = $item_result['item_id']; - if ($relay && $channel['channel_hash'] === $item_result['item']['owner_xchan'] && $item_result['item']['verb'] !== 'Add' && !$is_collection_operation) { - $approval = Activity::addToCollection($channel, $act->data, $item_result['item']['parent_mid'], $item_result['item'], deliver: false); - } - if ($item_source && in_array($item_result['item']['obj_type'], ['Event', ACTIVITY_OBJ_EVENT])) { event_addtocal($item_id, $channel['channel_id']); } @@ -2023,10 +1966,6 @@ class Libzot { if ($relay && $item_id && $stored['item_blocked'] !== ITEM_MODERATED) { logger('Invoking relay'); Master::Summon(['Notifier', 'relay', intval($item_id)]); - if (!empty($approval) && $approval['item_id']) { - Master::Summon(['Notifier', 'relay', intval($approval['item_id'])]); - } - $DR->addto_update('relayed'); $result[] = $DR->get(); } @@ -2080,7 +2019,12 @@ class Libzot { $AS = new ActivityStreams($activity); - if ($AS->is_valid() && $AS->type === 'Announce' && is_array($AS->obj) + if (!$AS->is_valid()) { + logger('Fetched activity rejected: ' . print_r($activity, true)); + continue; + } + + if ($AS->type === 'Announce' && is_array($AS->obj) && array_key_exists('object', $AS->obj) && array_key_exists('actor', $AS->obj)) { // This is a relayed/forwarded Activity (as opposed to a shared/boosted object) // Reparse the encapsulated Activity and use that instead @@ -2088,33 +2032,14 @@ class Libzot { $AS = new ActivityStreams($AS->obj); } - // process add/remove from collection separately, as it requires a target. - // use the raw object, as it will not include actor expansion if (in_array($AS->type, ['Add', 'Remove']) && is_array($AS->obj) && array_key_exists('object', $AS->obj) && array_key_exists('actor', $AS->obj) && !empty($AS->tgt)) { - logger('relayed collection operation', LOGGER_DEBUG); - - $is_collection_operation = true; - - $original_id = $AS->id; - $original_type = $AS->type; - - $raw_activity = $AS->data; - - $AS = new ActivityStreams($raw_activity['object'], portable_id: $env['sender']); - - // Store the original activity id and type for later usage - $AS->meta['original_id'] = $original_id; - $AS->meta['original_type'] = $original_type; - } - - if (!$AS->is_valid()) { - logger('Fetched activity rejected: ' . print_r($activity, true)); - continue; + logger('unsupported collection operation', LOGGER_DEBUG); + return; } // logger($AS->debug()); @@ -2305,7 +2230,7 @@ class Libzot { } - $x = item_store_update($item, addAndSync: false); + $x = item_store_update($item); // If we're updating an event that we've saved locally, we store the item info first // because event_addtocal will parse the body to get the 'new' event details |