2018-08-05 13:09:59 +02:00
|
|
|
<?php
|
|
|
|
|
|
|
|
/**
|
|
|
|
* @file src/Model/ItemURI.php
|
|
|
|
*/
|
|
|
|
|
|
|
|
namespace Friendica\Model;
|
|
|
|
|
|
|
|
use Friendica\Database\DBA;
|
|
|
|
|
2019-12-15 23:28:01 +01:00
|
|
|
class ItemURI
|
2018-08-05 13:09:59 +02:00
|
|
|
{
|
|
|
|
/**
|
|
|
|
* @brief Insert an item-uri record and return its id
|
|
|
|
*
|
|
|
|
* @param array $fields Item-uri fields
|
|
|
|
*
|
|
|
|
* @return integer item-uri id
|
2019-01-06 22:06:53 +01:00
|
|
|
* @throws \Exception
|
2018-08-05 13:09:59 +02:00
|
|
|
*/
|
|
|
|
public static function insert($fields)
|
|
|
|
{
|
2018-12-02 15:49:28 +01:00
|
|
|
// If the URI gets too long we only take the first parts and hope for best
|
|
|
|
$uri = substr($fields['uri'], 0, 255);
|
|
|
|
|
|
|
|
if (!DBA::exists('item-uri', ['uri' => $uri])) {
|
2018-08-05 13:09:59 +02:00
|
|
|
DBA::insert('item-uri', $fields, true);
|
|
|
|
}
|
|
|
|
|
2018-12-02 15:49:28 +01:00
|
|
|
$itemuri = DBA::selectFirst('item-uri', ['id'], ['uri' => $uri]);
|
2018-08-05 13:09:59 +02:00
|
|
|
|
|
|
|
if (!DBA::isResult($itemuri)) {
|
|
|
|
// This shouldn't happen
|
|
|
|
return null;
|
|
|
|
}
|
|
|
|
|
|
|
|
return $itemuri['id'];
|
|
|
|
}
|
|
|
|
|
|
|
|
/**
|
|
|
|
* @brief Searched for an id of a given uri. Adds it, if not existing yet.
|
|
|
|
*
|
|
|
|
* @param string $uri
|
|
|
|
*
|
|
|
|
* @return integer item-uri id
|
2019-01-06 22:06:53 +01:00
|
|
|
* @throws \Exception
|
2018-08-05 13:09:59 +02:00
|
|
|
*/
|
|
|
|
public static function getIdByURI($uri)
|
|
|
|
{
|
2018-12-02 15:49:28 +01:00
|
|
|
// If the URI gets too long we only take the first parts and hope for best
|
|
|
|
$uri = substr($uri, 0, 255);
|
|
|
|
|
2018-08-05 13:09:59 +02:00
|
|
|
$itemuri = DBA::selectFirst('item-uri', ['id'], ['uri' => $uri]);
|
|
|
|
|
|
|
|
if (!DBA::isResult($itemuri)) {
|
|
|
|
return self::insert(['uri' => $uri]);
|
|
|
|
}
|
|
|
|
|
|
|
|
return $itemuri['id'];
|
|
|
|
}
|
|
|
|
}
|