X-Git-Url: https://git.mxchange.org/?a=blobdiff_plain;f=src%2FModel%2FItemURI.php;h=3194097f31ad0e5bbad4680b1c2580793267db4f;hb=dfcfae6bcca54a27b1bf5099d96d54f2bba997d3;hp=452f7e57c8e3838d3da43e97878a8e12734c27ed;hpb=3d14977b73c5d42e3cc8bb8c6f0ca94435ab5a61;p=friendica.git diff --git a/src/Model/ItemURI.php b/src/Model/ItemURI.php index 452f7e57c8..3194097f31 100644 --- a/src/Model/ItemURI.php +++ b/src/Model/ItemURI.php @@ -1,62 +1,84 @@ . + * */ namespace Friendica\Model; -use Friendica\BaseObject; +use Friendica\Core\Logger; +use Friendica\Database\Database; use Friendica\Database\DBA; +use Friendica\DI; -require_once 'boot.php'; - -class ItemURI extends BaseObject +class ItemURI { /** - * @brief Insert an item-uri record and return its id + * Insert an item-uri record and return its id * * @param array $fields Item-uri fields - * - * @return integer item-uri id + * @return int|null item-uri id + * @throws \Exception */ - public static function insert($fields) + public static function insert(array $fields) { - // If the URI gets too long we only take the first parts and hope for best - $uri = substr($fields['uri'], 0, 255); + $fields = DI::dbaDefinition()->truncateFieldsForTable('item-uri', $fields); - if (!DBA::exists('item-uri', ['uri' => $uri])) { - DBA::insert('item-uri', $fields, true); + if (!DBA::exists('item-uri', ['uri' => $fields['uri']])) { + DBA::insert('item-uri', $fields, Database::INSERT_IGNORE); } - $itemuri = DBA::selectFirst('item-uri', ['id'], ['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; } + if (empty($itemuri['guid']) && !empty($fields['guid'])) { + DBA::update('item-uri', ['guid' => $fields['guid']], ['id' => $itemuri['id']]); + } + return $itemuri['id']; } /** - * @brief Searched for an id of a given uri. Adds it, if not existing yet. + * 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; } }