<?php
/**
- * @copyright Copyright (C) 2010-2021, the Friendica project
+ * @copyright Copyright (C) 2010-2022, the Friendica project
*
* @license GNU AGPL version 3 or any later version
*
use Friendica\Core\Worker;
use Friendica\Database\DBA;
use Friendica\DI;
+use Friendica\Model\Contact;
use Friendica\Model\Item;
use Friendica\Model\Post;
use Friendica\Model\Tag;
use Friendica\Protocol\Activity;
-use Friendica\Util\Strings;
use Friendica\Util\XML;
use Friendica\Worker\Delivery;
-function tagger_content(App $a) {
-
+function tagger_content(App $a)
+{
if (!Session::isAuthenticated()) {
return;
}
- $term = Strings::escapeTags(trim($_GET['term']));
+ $term = trim($_GET['term'] ?? '');
// no commas allowed
- $term = str_replace([',',' '],['','_'],$term);
+ $term = str_replace([',',' ', '<', '>'],['','_', '', ''], $term);
if (!$term) {
return;
}
- $item_id = ((DI::args()->getArgc() > 1) ? Strings::escapeTags(trim(DI::args()->getArgv()[1])) : 0);
+ $item_id = ((DI::args()->getArgc() > 1) ? trim(DI::args()->getArgv()[1]) : 0);
- Logger::log('tagger: tag ' . $term . ' item ' . $item_id);
+ Logger::info('tagger: tag', ['term' => $term, 'item' => $item_id]);
$item = Post::selectFirst([], ['id' => $item_id]);
if (!$item_id || !DBA::isResult($item)) {
- Logger::log('tagger: no item ' . $item_id);
+ Logger::notice('tagger: no item ' . $item_id);
return;
}
$owner_uid = $item['uid'];
- $blocktags = 0;
-
- $r = q("select `blocktags` from user where uid = %d limit 1",
- intval($owner_uid)
- );
- if (DBA::isResult($r)) {
- $blocktags = $r[0]['blocktags'];
- }
if (local_user() != $owner_uid) {
return;
}
- $r = q("select * from contact where self = 1 and uid = %d limit 1",
- intval(local_user())
- );
- if (DBA::isResult($r)) {
- $contact = $r[0];
- } else {
- Logger::log('tagger: no contact_id');
+ $contact = Contact::selectFirst([], ['self' => true, 'uid' => local_user()]);
+ if (!DBA::isResult($contact)) {
+ Logger::warning('Self contact not found.', ['uid' => local_user()]);
return;
}
- $uri = Item::newURI($owner_uid);
+ $uri = Item::newURI();
$xterm = XML::escape($term);
$post_type = (($item['resource-id']) ? DI::l10n()->t('photo') : DI::l10n()->t('status'));
$targettype = (($item['resource-id']) ? Activity\ObjectType::IMAGE : Activity\ObjectType::NOTE );
$termlink = html_entity_decode('⌗') . '[url=' . DI::baseUrl() . '/search?tag=' . $term . ']'. $term . '[/url]';
- $arr = [];
-
- $arr['guid'] = System::createUUID();
- $arr['uri'] = $uri;
- $arr['uid'] = $owner_uid;
- $arr['contact-id'] = $contact['id'];
- $arr['wall'] = $item['wall'];
- $arr['gravity'] = GRAVITY_COMMENT;
- $arr['parent'] = $item['id'];
- $arr['thr-parent'] = $item['uri'];
- $arr['owner-name'] = $item['author-name'];
- $arr['owner-link'] = $item['author-link'];
- $arr['owner-avatar'] = $item['author-avatar'];
- $arr['author-name'] = $contact['name'];
- $arr['author-link'] = $contact['url'];
- $arr['author-avatar'] = $contact['thumb'];
-
$ulink = '[url=' . $contact['url'] . ']' . $contact['name'] . '[/url]';
$alink = '[url=' . $item['author-link'] . ']' . $item['author-name'] . '[/url]';
$plink = '[url=' . $item['plink'] . ']' . $post_type . '[/url]';
- $arr['body'] = sprintf( $bodyverb, $ulink, $alink, $plink, $termlink );
-
- $arr['verb'] = Activity::TAG;
- $arr['target-type'] = $targettype;
- $arr['target'] = $target;
- $arr['object-type'] = $objtype;
- $arr['object'] = $obj;
- $arr['private'] = $item['private'];
- $arr['allow_cid'] = $item['allow_cid'];
- $arr['allow_gid'] = $item['allow_gid'];
- $arr['deny_cid'] = $item['deny_cid'];
- $arr['deny_gid'] = $item['deny_gid'];
- $arr['visible'] = 1;
- $arr['unseen'] = 1;
- $arr['origin'] = 1;
+
+ $arr = [
+ 'guid' => System::createUUID(),
+ 'uri' => $uri,
+ 'uid' => $owner_uid,
+ 'contact-id' => $contact['id'],
+ 'wall' => $item['wall'],
+ 'gravity' => Item::GRAVITY_COMMENT,
+ 'parent' => $item['id'],
+ 'thr-parent' => $item['uri'],
+ 'owner-name' => $item['author-name'],
+ 'owner-link' => $item['author-link'],
+ 'owner-avatar' => $item['author-avatar'],
+ 'author-name' => $contact['name'],
+ 'author-link' => $contact['url'],
+ 'author-avatar' => $contact['thumb'],
+ 'body' => sprintf( $bodyverb, $ulink, $alink, $plink, $termlink),
+ 'verb' => Activity::TAG,
+ 'target-type' => $targettype,
+ 'target' => $target,
+ 'object-type' => $objtype,
+ 'object' => $obj,
+ 'private' => $item['private'],
+ 'allow_cid' => $item['allow_cid'],
+ 'allow_gid' => $item['allow_gid'],
+ 'deny_cid' => $item['deny_cid'],
+ 'deny_gid' => $item['deny_gid'],
+ 'visible' => 1,
+ 'unseen' => 1,
+ 'origin' => 1,
+ ];
+
$post_id = Item::insert($arr);
$post = Post::selectFirst(['uri-id', 'uid'], ['id' => $post_id]);
- Worker::add(PRIORITY_HIGH, "Notifier", Delivery::POST, $post['uri-id'], $post['uid']);
-
- exit();
+ Worker::add(Worker::PRIORITY_HIGH, "Notifier", Delivery::POST, $post['uri-id'], $post['uid']);
+ System::exit();
}