X-Git-Url: https://git.mxchange.org/?a=blobdiff_plain;f=src%2FModel%2FItemURI.php;h=1755552299741b6884060ea8e4452c75b4aac13d;hb=70674f2ecc9d34ba7eabbd15c06f85b469b27d0e;hp=6421b2dbd9a5007cafd463ff04d62bc7a0c43043;hpb=e4228c6218db70d600641430f4895f76cc049c5b;p=friendica.git diff --git a/src/Model/ItemURI.php b/src/Model/ItemURI.php index 6421b2dbd9..1755552299 100644 --- a/src/Model/ItemURI.php +++ b/src/Model/ItemURI.php @@ -1,6 +1,6 @@ truncateFieldsForTable('item-uri', $fields); - if (!DBA::exists('item-uri', ['uri' => $uri])) { - DBA::insert('item-uri', $fields, Database::INSERT_UPDATE); + if (!DBA::exists('item-uri', ['uri' => $fields['uri']])) { + DBA::insert('item-uri', $fields, Database::INSERT_IGNORE); } - $itemuri = DBA::selectFirst('item-uri', ['id', 'guid'], ['uri' => $uri]); - + $itemuri = DBA::selectFirst('item-uri', ['id', 'guid'], ['uri' => $fields['uri']]); if (!DBA::isResult($itemuri)) { // This shouldn't happen + Logger::warning('Item-uri not found', $fields); return null; } @@ -61,21 +61,34 @@ class ItemURI * Searched for an id of a given uri. Adds it, if not existing yet. * * @param string $uri + * @param bool $insert * * @return integer item-uri id + * * @throws \Exception */ - public static function getIdByURI($uri) + public static function getIdByURI(string $uri, bool $insert = true): int { - // If the URI gets too long we only take the first parts and hope for best - $uri = substr($uri, 0, 255); + if (empty($uri)) { + return 0; + } $itemuri = DBA::selectFirst('item-uri', ['id'], ['uri' => $uri]); - if (!DBA::isResult($itemuri)) { + if (!DBA::isResult($itemuri) && $insert) { return self::insert(['uri' => $uri]); } - return $itemuri['id']; + return $itemuri['id'] ?? 0; + } + + /** + * @param int $uriId + * @return bool + * @throws \Exception + */ + public static function exists(int $uriId): bool + { + return DBA::exists('item-uri', ['id' => $uriId]); } }