X-Git-Url: https://git.mxchange.org/?a=blobdiff_plain;f=mod%2Ftagrm.php;h=1683bf1d6f4df22e3ec8cc8b8481923fa732d07a;hb=23b10cf2ae5fe10ba21a4b43e1aae17818647661;hp=2a829932ea1fe07d6225d2b97a81443d01eec43c;hpb=e609de295742fa1de70279206d6bea91900350ba;p=friendica.git diff --git a/mod/tagrm.php b/mod/tagrm.php index 2a829932ea..32cb19e691 100644 --- a/mod/tagrm.php +++ b/mod/tagrm.php @@ -1,104 +1,131 @@ . + * */ -use Friendica\App; -use Friendica\Core\L10n; -use Friendica\Core\System; -use Friendica\Database\DBM; -use Friendica\Model\Item; - -require_once 'include/bbcode.php'; - -function tagrm_post(App $a) { +use Friendica\App; +use Friendica\Content\Text\BBCode; +use Friendica\Database\DBA; +use Friendica\DI; +use Friendica\Model\Post; +use Friendica\Model\Tag; + +function tagrm_post(App $a) +{ if (!local_user()) { - goaway(System::baseUrl() . '/' . $_SESSION['photo_return']); - } - - if ((x($_POST,'submit')) && ($_POST['submit'] === L10n::t('Cancel'))) { - goaway(System::baseUrl() . '/' . $_SESSION['photo_return']); + DI::baseUrl()->redirect($_SESSION['photo_return']); } - $tag = ((x($_POST,'tag')) ? hex2bin(notags(trim($_POST['tag']))) : ''); - $item = ((x($_POST,'item')) ? intval($_POST['item']) : 0 ); - - $r = q("SELECT * FROM `item` WHERE `id` = %d AND `uid` = %d LIMIT 1", - intval($item), - intval(local_user()) - ); - - if (!DBM::is_result($r)) { - goaway(System::baseUrl() . '/' . $_SESSION['photo_return']); + if (!empty($_POST['submit']) && ($_POST['submit'] === DI::l10n()->t('Cancel'))) { + DI::baseUrl()->redirect($_SESSION['photo_return']); } - $arr = explode(',', $r[0]['tag']); - for ($x = 0; $x < count($arr); $x ++) { - if ($arr[$x] === $tag) { - unset($arr[$x]); - break; - } + $tags = []; + foreach ($_POST['tag'] ?? [] as $tag) { + $tags[] = hex2bin(trim($tag)); } - $tag_str = implode(',',$arr); - - Item::update(['tag' => $tag_str], ['id' => $item]); - - info(L10n::t('Tag removed') . EOL ); - goaway(System::baseUrl() . '/' . $_SESSION['photo_return']); + $item_id = $_POST['item'] ?? 0; + update_tags($item_id, $tags); + DI::baseUrl()->redirect($_SESSION['photo_return']); // NOTREACHED } +/** + * Updates tags from an item + * + * @param $item_id + * @param $tags array + * @throws Exception + */ +function update_tags($item_id, $tags) +{ + if (empty($item_id) || empty($tags)) { + return; + } + $item = Post::selectFirst(['uri-id'], ['id' => $item_id, 'uid' => local_user()]); + if (!DBA::isResult($item)) { + return; + } -function tagrm_content(App $a) { + foreach ($tags as $new_tag) { + if (preg_match_all('/([#@!])\[url\=([^\[\]]*)\]([^\[\]]*)\[\/url\]/ism', $new_tag, $results, PREG_SET_ORDER)) { + foreach ($results as $tag) { + Tag::removeByHash($item['uri-id'], $tag[1], $tag[3], $tag[2]); + } + } + } +} +function tagrm_content(App $a) +{ $o = ''; + $photo_return = $_SESSION['photo_return'] ?? ''; + if (!local_user()) { - goaway(System::baseUrl() . '/' . $_SESSION['photo_return']); + DI::baseUrl()->redirect($photo_return); // NOTREACHED } - $item = (($a->argc > 1) ? intval($a->argv[1]) : 0); - if (!$item) { - goaway(System::baseUrl() . '/' . $_SESSION['photo_return']); - // NOTREACHED + if (DI::args()->getArgc()== 3) { + update_tags(DI::args()->getArgv()[1], [trim(hex2bin(DI::args()->getArgv()[2]))]); + DI::baseUrl()->redirect($photo_return); } - $r = q("SELECT * FROM `item` WHERE `id` = %d AND `uid` = %d LIMIT 1", - intval($item), - intval(local_user()) - ); + $item_id = ((DI::args()->getArgc()> 1) ? intval(DI::args()->getArgv()[1]) : 0); + if (!$item_id) { + DI::baseUrl()->redirect($photo_return); + // NOTREACHED + } - if (!DBM::is_result($r)) { - goaway(System::baseUrl() . '/' . $_SESSION['photo_return']); + $item = Post::selectFirst(['uri-id'], ['id' => $item_id, 'uid' => local_user()]); + if (!DBA::isResult($item)) { + DI::baseUrl()->redirect($photo_return); } - $arr = explode(',', $r[0]['tag']); + $tag_text = Tag::getCSVByURIId($item['uri-id']); + + $arr = explode(',', $tag_text); - if (!count($arr)) { - goaway(System::baseUrl() . '/' . $_SESSION['photo_return']); + if (empty($arr)) { + DI::baseUrl()->redirect($photo_return); } - $o .= '

' . L10n::t('Remove Item Tag') . '

'; + $o .= '

' . DI::l10n()->t('Remove Item Tag') . '

'; - $o .= '

' . L10n::t('Select a tag to remove: ') . '

'; + $o .= '

' . DI::l10n()->t('Select a tag to remove: ') . '

'; $o .= '
'; - $o .= ''; + $o .= ''; $o .= ''; - $o .= ''; - $o .= ''; + $o .= ''; + $o .= ''; $o .= '
'; return $o; - }