1) ? argv(1) : 0); if (is_numeric($type)) { $item_id = intval($type); $type = 'item'; } else { $item_id = ((argc() > 2) ? intval(argv(2)) : 0); } if (!$item_id) { killme(); } if (!in_array($type, array('item', 'photo', 'attach', 'event', 'menu_item', 'chatroom'))) { killme(); } // we have different naming in in menu_item table and chatroom table switch ($type) { case 'menu_item': $id = 'mitem_id'; break; case 'chatroom': $id = 'cr_id'; break; default: $id = 'id'; break; } $r = q( "SELECT * FROM %s WHERE $id = %d LIMIT 1", dbesc($type), intval($item_id) ); if (!$r) { killme(); } $item = $r[0]; // we have different naming in in menu_item table and chatroom table switch ($type) { case 'menu_item': $uid = $item['mitem_channel_id']; break; case 'chatroom': $uid = $item['cr_uid']; break; default: $uid = $item['uid']; break; } if ($type === 'item') { $recips = get_iconfig($item['id'], 'activitypub', 'recips'); if ($recips) { $o = ''; $l = []; if (isset($recips['to'])) { if (!is_array($recips['to'])) { $recips['to'] = [$recips['to']]; } $l = array_merge($l, $recips['to']); } if (isset($recips['cc'])) { if (!is_array($recips['cc'])) { $recips['cc'] = [$recips['cc']]; } $l = array_merge($l, $recips['cc']); } for ($x = 0; $x < count($l); $x++) { if ($l[$x] === ACTIVITY_PUBLIC_INBOX || $l[$x] === 'Public' || $l[$x] === 'as:Public') { $l[$x] = '' . t('Everybody') . ''; } else { $l[$x] = '' . $l[$x] . ''; } } echo $o . implode('
', $l); killme(); } } if ( intval($item['item_private']) && (!strlen($item['allow_cid'])) && (!strlen($item['allow_gid'])) && (!strlen($item['deny_cid'])) && (!strlen($item['deny_gid'])) ) { if ($item['mid'] === $item['parent_mid']) { echo ''; killme(); } } $allowed_users = expand_acl($item['allow_cid']); $allowed_groups = expand_acl($item['allow_gid']); $deny_users = expand_acl($item['deny_cid']); $deny_groups = expand_acl($item['deny_gid']); $o = ''; $l = []; stringify_array_elms($allowed_groups, true); stringify_array_elms($allowed_users, true); stringify_array_elms($deny_groups, true); stringify_array_elms($deny_users, true); if (count($allowed_groups)) { $r = q("SELECT gname FROM pgrp WHERE hash IN ( " . implode(', ', $allowed_groups) . " )"); if ($r) { foreach ($r as $rr) { $l[] = ''; } } } if (count($allowed_users)) { $r = q("SELECT xchan_name FROM xchan WHERE xchan_hash IN ( " . implode(', ', $allowed_users) . " )"); if ($r) { foreach ($r as $rr) { $l[] = ''; } } if ($atokens) { foreach ($atokens as $at) { if (in_array("'" . $at['xchan_hash'] . "'", $allowed_users)) { $l[] = ''; } } } } if (count($deny_groups)) { $r = q("SELECT gname FROM pgrp WHERE hash IN ( " . implode(', ', $deny_groups) . " )"); if ($r) { foreach ($r as $rr) { $l[] = ''; } } } if (count($deny_users)) { $r = q("SELECT xchan_name FROM xchan WHERE xchan_hash IN ( " . implode(', ', $deny_users) . " )"); if ($r) { foreach ($r as $rr) { $l[] = ''; } } if ($atokens) { foreach ($atokens as $at) { if (in_array("'" . $at['xchan_hash'] . "'", $deny_users)) { $l[] = ''; } } } } echo $o . implode($l); killme(); } }