2011-10-23 00:24:37 -07:00
|
|
|
<?php
|
2018-01-22 09:16:25 -05:00
|
|
|
/**
|
|
|
|
* @file mod/tagger.php
|
|
|
|
*/
|
2017-04-30 00:07:00 -04:00
|
|
|
use Friendica\App;
|
2018-12-26 01:06:24 -05:00
|
|
|
use Friendica\Core\Hook;
|
2018-01-22 09:16:25 -05:00
|
|
|
use Friendica\Core\L10n;
|
2018-10-29 17:20:46 -04:00
|
|
|
use Friendica\Core\Logger;
|
2017-08-26 06:04:21 +00:00
|
|
|
use Friendica\Core\System;
|
2017-11-05 12:15:53 +00:00
|
|
|
use Friendica\Core\Worker;
|
2018-07-21 08:40:21 -04:00
|
|
|
use Friendica\Database\DBA;
|
2018-01-28 11:18:08 +00:00
|
|
|
use Friendica\Model\Item;
|
2018-11-08 10:14:37 -05:00
|
|
|
use Friendica\Util\Strings;
|
2018-11-05 07:40:18 -05:00
|
|
|
use Friendica\Util\XML;
|
2019-06-10 14:19:24 +00:00
|
|
|
use Friendica\Worker\Delivery;
|
2017-04-30 00:07:00 -04:00
|
|
|
|
2017-01-09 23:14:55 +11:00
|
|
|
function tagger_content(App $a) {
|
2011-10-23 00:24:37 -07:00
|
|
|
|
2018-06-12 09:05:36 +00:00
|
|
|
if (!local_user() && !remote_user()) {
|
2011-10-23 00:24:37 -07:00
|
|
|
return;
|
|
|
|
}
|
|
|
|
|
2018-11-09 13:29:42 -05:00
|
|
|
$term = Strings::escapeTags(trim($_GET['term']));
|
2011-10-24 17:25:49 -07:00
|
|
|
// no commas allowed
|
2018-01-15 08:05:12 -05:00
|
|
|
$term = str_replace([',',' '],['','_'],$term);
|
2011-10-23 00:24:37 -07:00
|
|
|
|
2018-06-12 09:05:36 +00:00
|
|
|
if (!$term) {
|
2011-10-23 00:24:37 -07:00
|
|
|
return;
|
2018-06-12 09:05:36 +00:00
|
|
|
}
|
2011-10-23 00:24:37 -07:00
|
|
|
|
2018-11-09 13:29:42 -05:00
|
|
|
$item_id = (($a->argc > 1) ? Strings::escapeTags(trim($a->argv[1])) : 0);
|
2011-10-23 00:24:37 -07:00
|
|
|
|
2018-10-29 17:20:46 -04:00
|
|
|
Logger::log('tagger: tag ' . $term . ' item ' . $item_id);
|
2011-10-23 00:24:37 -07:00
|
|
|
|
|
|
|
|
2018-06-17 17:05:17 +00:00
|
|
|
$item = Item::selectFirst([], ['id' => $item_id]);
|
2011-10-23 00:24:37 -07:00
|
|
|
|
2018-07-21 08:46:04 -04:00
|
|
|
if (!$item_id || !DBA::isResult($item)) {
|
2018-10-29 17:20:46 -04:00
|
|
|
Logger::log('tagger: no item ' . $item_id);
|
2011-10-23 00:24:37 -07:00
|
|
|
return;
|
|
|
|
}
|
|
|
|
|
|
|
|
$owner_uid = $item['uid'];
|
2018-02-12 19:28:14 +01:00
|
|
|
$blocktags = 0;
|
2011-10-23 00:24:37 -07:00
|
|
|
|
2019-04-29 00:40:58 -04:00
|
|
|
$r = q("select `blocktags` from user where uid = %d limit 1",
|
2011-10-23 00:24:37 -07:00
|
|
|
intval($owner_uid)
|
|
|
|
);
|
2018-07-21 08:46:04 -04:00
|
|
|
if (DBA::isResult($r)) {
|
2011-10-24 04:17:46 -07:00
|
|
|
$blocktags = $r[0]['blocktags'];
|
|
|
|
}
|
2011-10-23 00:24:37 -07:00
|
|
|
|
2018-06-12 09:05:36 +00:00
|
|
|
if (local_user() != $owner_uid) {
|
2011-10-24 15:47:17 -07:00
|
|
|
return;
|
2018-06-12 09:05:36 +00:00
|
|
|
}
|
2011-10-23 00:24:37 -07:00
|
|
|
|
2012-09-04 22:50:28 -07:00
|
|
|
$r = q("select * from contact where self = 1 and uid = %d limit 1",
|
|
|
|
intval(local_user())
|
|
|
|
);
|
2018-07-21 08:46:04 -04:00
|
|
|
if (DBA::isResult($r)) {
|
2011-10-23 00:24:37 -07:00
|
|
|
$contact = $r[0];
|
2018-06-12 09:05:36 +00:00
|
|
|
} else {
|
2018-10-29 17:20:46 -04:00
|
|
|
Logger::log('tagger: no contact_id');
|
2011-10-23 00:24:37 -07:00
|
|
|
return;
|
|
|
|
}
|
|
|
|
|
2018-06-16 06:44:19 +00:00
|
|
|
$uri = Item::newURI($owner_uid);
|
2018-11-05 07:40:18 -05:00
|
|
|
$xterm = XML::escape($term);
|
2018-01-22 09:16:25 -05:00
|
|
|
$post_type = (($item['resource-id']) ? L10n::t('photo') : L10n::t('status'));
|
2016-12-20 07:10:47 +00:00
|
|
|
$targettype = (($item['resource-id']) ? ACTIVITY_OBJ_IMAGE : ACTIVITY_OBJ_NOTE );
|
2019-04-29 00:40:58 -04:00
|
|
|
$href = System::baseUrl() . '/display/' . $item['guid'];
|
2018-02-12 19:28:14 +01:00
|
|
|
|
2018-11-30 09:06:22 -05:00
|
|
|
$link = XML::escape('<link rel="alternate" type="text/html" href="'. $href . '" />' . "\n");
|
2011-10-23 00:24:37 -07:00
|
|
|
|
2018-11-05 07:40:18 -05:00
|
|
|
$body = XML::escape($item['body']);
|
2011-10-23 00:24:37 -07:00
|
|
|
|
|
|
|
$target = <<< EOT
|
|
|
|
<target>
|
|
|
|
<type>$targettype</type>
|
|
|
|
<local>1</local>
|
|
|
|
<id>{$item['uri']}</id>
|
|
|
|
<link>$link</link>
|
|
|
|
<title></title>
|
|
|
|
<content>$body</content>
|
|
|
|
</target>
|
|
|
|
EOT;
|
|
|
|
|
2018-11-22 09:23:42 -05:00
|
|
|
$tagid = System::baseUrl() . '/search?tag=' . $xterm;
|
2011-10-23 00:24:37 -07:00
|
|
|
$objtype = ACTIVITY_OBJ_TAGTERM;
|
|
|
|
|
|
|
|
$obj = <<< EOT
|
|
|
|
<object>
|
|
|
|
<type>$objtype</type>
|
|
|
|
<local>1</local>
|
|
|
|
<id>$tagid</id>
|
|
|
|
<link>$tagid</link>
|
2012-04-29 22:34:05 -07:00
|
|
|
<title>$xterm</title>
|
|
|
|
<content>$xterm</content>
|
2011-10-23 00:24:37 -07:00
|
|
|
</object>
|
|
|
|
EOT;
|
|
|
|
|
2018-01-22 09:16:25 -05:00
|
|
|
$bodyverb = L10n::t('%1$s tagged %2$s\'s %3$s with %4$s');
|
2011-10-23 00:24:37 -07:00
|
|
|
|
2018-06-12 09:05:36 +00:00
|
|
|
if (!isset($bodyverb)) {
|
2016-12-20 21:31:05 +01:00
|
|
|
return;
|
|
|
|
}
|
2011-10-23 00:24:37 -07:00
|
|
|
|
2018-11-22 09:23:42 -05:00
|
|
|
$termlink = html_entity_decode('⌗') . '[url=' . System::baseUrl() . '/search?tag=' . $term . ']'. $term . '[/url]';
|
2011-10-23 00:24:37 -07:00
|
|
|
|
2018-01-15 08:05:12 -05:00
|
|
|
$arr = [];
|
2011-10-23 00:24:37 -07:00
|
|
|
|
2018-09-27 11:52:15 +00:00
|
|
|
$arr['guid'] = System::createUUID();
|
2011-10-23 00:24:37 -07:00
|
|
|
$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['parent-uri'] = $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'];
|
2016-03-20 15:01:50 +01:00
|
|
|
|
2011-10-23 00:24:37 -07:00
|
|
|
$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;
|
2012-02-26 16:29:06 -08:00
|
|
|
$arr['private'] = $item['private'];
|
2011-10-23 00:24:37 -07:00
|
|
|
$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;
|
|
|
|
|
2018-01-28 11:18:08 +00:00
|
|
|
$post_id = Item::insert($arr);
|
2011-10-23 00:24:37 -07:00
|
|
|
|
2018-02-06 12:40:22 +00:00
|
|
|
if (!$item['visible']) {
|
|
|
|
Item::update(['visible' => true], ['id' => $item['id']]);
|
2014-03-11 23:52:32 +01:00
|
|
|
}
|
2011-10-23 00:24:37 -07:00
|
|
|
|
2018-02-06 12:40:22 +00:00
|
|
|
$term_objtype = ($item['resource-id'] ? TERM_OBJ_PHOTO : TERM_OBJ_POST);
|
2018-05-10 14:48:27 +02:00
|
|
|
|
|
|
|
$t = q("SELECT count(tid) as tcount FROM term WHERE oid=%d AND term='%s'",
|
|
|
|
intval($item['id']),
|
2018-07-21 09:10:13 -04:00
|
|
|
DBA::escape($term)
|
2018-05-10 14:48:27 +02:00
|
|
|
);
|
|
|
|
|
2018-06-12 09:05:36 +00:00
|
|
|
if (!$blocktags && $t[0]['tcount'] == 0) {
|
2013-08-03 15:12:50 -04:00
|
|
|
q("INSERT INTO term (oid, otype, type, term, url, uid) VALUE (%d, %d, %d, '%s', '%s', %d)",
|
|
|
|
intval($item['id']),
|
|
|
|
$term_objtype,
|
|
|
|
TERM_HASHTAG,
|
2018-07-21 09:10:13 -04:00
|
|
|
DBA::escape($term),
|
2018-11-22 09:33:42 -05:00
|
|
|
'',
|
2013-08-03 15:12:50 -04:00
|
|
|
intval($owner_uid)
|
2011-10-24 04:17:46 -07:00
|
|
|
);
|
|
|
|
}
|
2014-03-11 23:52:32 +01:00
|
|
|
|
2011-10-24 04:17:46 -07:00
|
|
|
// if the original post is on this site, update it.
|
2018-06-21 15:14:01 +00:00
|
|
|
$original_item = Item::selectFirst(['tag', 'id', 'uid'], ['origin' => true, 'uri' => $item['uri']]);
|
2018-07-21 08:46:04 -04:00
|
|
|
if (DBA::isResult($original_item)) {
|
2018-05-10 14:48:27 +02:00
|
|
|
$x = q("SELECT `blocktags` FROM `user` WHERE `uid`=%d LIMIT 1",
|
2018-06-21 06:21:51 +00:00
|
|
|
intval($original_item['uid'])
|
2011-10-24 04:17:46 -07:00
|
|
|
);
|
2018-05-10 14:48:27 +02:00
|
|
|
$t = q("SELECT COUNT(`tid`) AS `tcount` FROM `term` WHERE `oid`=%d AND `term`='%s'",
|
2018-06-21 06:21:51 +00:00
|
|
|
intval($original_item['id']),
|
2018-07-21 09:10:13 -04:00
|
|
|
DBA::escape($term)
|
2013-08-03 15:12:50 -04:00
|
|
|
);
|
2018-05-10 14:48:27 +02:00
|
|
|
|
2018-07-21 08:46:04 -04:00
|
|
|
if (DBA::isResult($x) && !$x[0]['blocktags'] && $t[0]['tcount'] == 0){
|
2018-05-10 14:48:27 +02:00
|
|
|
q("INSERT INTO term (`oid`, `otype`, `type`, `term`, `url`, `uid`) VALUE (%d, %d, %d, '%s', '%s', %d)",
|
2018-06-21 06:21:51 +00:00
|
|
|
intval($original_item['id']),
|
2018-05-10 14:48:27 +02:00
|
|
|
$term_objtype,
|
|
|
|
TERM_HASHTAG,
|
2018-07-21 09:10:13 -04:00
|
|
|
DBA::escape($term),
|
2018-11-22 09:33:42 -05:00
|
|
|
'',
|
2018-05-10 14:48:27 +02:00
|
|
|
intval($owner_uid)
|
|
|
|
);
|
2013-08-03 15:12:50 -04:00
|
|
|
}
|
2011-10-24 04:17:46 -07:00
|
|
|
}
|
2014-03-11 23:52:32 +01:00
|
|
|
|
2011-10-23 00:24:37 -07:00
|
|
|
|
|
|
|
$arr['id'] = $post_id;
|
|
|
|
|
2018-12-26 01:06:24 -05:00
|
|
|
Hook::callAll('post_local_end', $arr);
|
2011-10-23 00:24:37 -07:00
|
|
|
|
2019-06-10 14:19:24 +00:00
|
|
|
Worker::add(PRIORITY_HIGH, "Notifier", Delivery::POST, $post_id);
|
2011-10-23 00:24:37 -07:00
|
|
|
|
2018-12-26 00:40:12 -05:00
|
|
|
exit();
|
2013-08-03 15:12:50 -04:00
|
|
|
}
|