2011-03-17 03:36:59 +01:00
|
|
|
<?php
|
2017-04-30 06:07:00 +02:00
|
|
|
|
|
|
|
use Friendica\App;
|
2017-11-08 04:57:46 +01:00
|
|
|
use Friendica\Database\DBM;
|
2017-04-30 06:07:00 +02:00
|
|
|
|
2017-01-09 13:14:55 +01:00
|
|
|
function share_init(App $a) {
|
2011-03-17 03:36:59 +01:00
|
|
|
$post_id = (($a->argc > 1) ? intval($a->argv[1]) : 0);
|
2018-05-13 14:20:15 +02:00
|
|
|
|
2017-12-20 19:18:25 +01:00
|
|
|
if (!$post_id || !local_user()) {
|
2011-03-17 03:36:59 +01:00
|
|
|
killme();
|
2017-12-20 19:18:25 +01:00
|
|
|
}
|
2011-03-17 03:36:59 +01:00
|
|
|
|
2017-01-09 13:14:55 +01:00
|
|
|
$r = q("SELECT item.*, contact.network FROM `item`
|
2017-12-20 19:18:25 +01:00
|
|
|
INNER JOIN `contact` ON `item`.`contact-id` = `contact`.`id`
|
|
|
|
WHERE `item`.`id` = %d LIMIT 1",
|
|
|
|
intval($post_id)
|
2011-03-17 03:36:59 +01:00
|
|
|
);
|
2018-05-13 14:20:15 +02:00
|
|
|
|
2017-12-20 19:18:25 +01:00
|
|
|
if (!DBM::is_result($r) || ($r[0]['private'] == 1)) {
|
2011-03-17 03:36:59 +01:00
|
|
|
killme();
|
2017-12-20 19:18:25 +01:00
|
|
|
}
|
2018-05-13 14:20:15 +02:00
|
|
|
|
2017-02-27 22:26:37 +01:00
|
|
|
if (strpos($r[0]['body'], "[/share]") !== false) {
|
|
|
|
$pos = strpos($r[0]['body'], "[share");
|
|
|
|
$o = substr($r[0]['body'], $pos);
|
2012-12-21 00:08:58 +01:00
|
|
|
} else {
|
2017-02-27 22:26:37 +01:00
|
|
|
$o = share_header($r[0]['author-name'], $r[0]['author-link'], $r[0]['author-avatar'], $r[0]['guid'], $r[0]['created'], $r[0]['plink']);
|
2012-12-21 00:08:58 +01:00
|
|
|
|
2017-01-26 15:23:30 +01:00
|
|
|
if ($r[0]['title']) {
|
2017-02-27 22:26:37 +01:00
|
|
|
$o .= '[b]'.$r[0]['title'].'[/b]'."\n";
|
2017-01-26 15:23:30 +01:00
|
|
|
}
|
2018-05-13 14:20:15 +02:00
|
|
|
|
2017-02-27 22:26:37 +01:00
|
|
|
$o .= $r[0]['body'];
|
2017-01-26 15:23:30 +01:00
|
|
|
$o .= "[/share]";
|
2012-12-21 00:08:58 +01:00
|
|
|
}
|
2017-02-27 22:26:37 +01:00
|
|
|
|
2012-03-07 00:28:27 +01:00
|
|
|
echo $o;
|
2012-12-21 00:08:58 +01:00
|
|
|
killme();
|
2011-04-10 12:36:12 +02:00
|
|
|
}
|
2015-04-05 20:43:06 +02:00
|
|
|
|
2018-05-13 14:20:15 +02:00
|
|
|
/// @TODO Rewrite to handle over whole record array
|
2015-04-05 20:43:06 +02:00
|
|
|
function share_header($author, $profile, $avatar, $guid, $posted, $link) {
|
2017-01-26 15:23:30 +01:00
|
|
|
$header = "[share author='" . str_replace(["'", "[", "]"], ["'", "[", "]"], $author).
|
|
|
|
"' profile='" . str_replace(["'", "[", "]"], ["'", "[", "]"], $profile).
|
|
|
|
"' avatar='" . str_replace(["'", "[", "]"], ["'", "[", "]"], $avatar);
|
2015-04-05 20:43:06 +02:00
|
|
|
|
2017-12-20 19:18:25 +01:00
|
|
|
if ($guid) {
|
2017-01-26 15:23:30 +01:00
|
|
|
$header .= "' guid='" . str_replace(["'", "[", "]"], ["'", "[", "]"], $guid);
|
2017-12-20 19:18:25 +01:00
|
|
|
}
|
2018-05-13 14:20:15 +02:00
|
|
|
|
2017-12-20 19:18:25 +01:00
|
|
|
if ($posted) {
|
2017-01-26 15:23:30 +01:00
|
|
|
$header .= "' posted='" . str_replace(["'", "[", "]"], ["'", "[", "]"], $posted);
|
2017-12-20 19:18:25 +01:00
|
|
|
}
|
2018-05-13 14:20:15 +02:00
|
|
|
|
2017-01-26 15:23:30 +01:00
|
|
|
$header .= "' link='" . str_replace(["'", "[", "]"], ["'", "[", "]"], $link)."']";
|
2015-04-05 20:43:06 +02:00
|
|
|
|
|
|
|
return $header;
|
|
|
|
}
|