]> git.mxchange.org Git - friendica.git/blob - src/Model/ItemURI.php
Fix mods/README.md format
[friendica.git] / src / Model / ItemURI.php
1 <?php
2
3 /**
4  * @file src/Model/ItemURI.php
5  */
6
7 namespace Friendica\Model;
8
9 use Friendica\BaseObject;
10 use Friendica\Database\DBA;
11
12 require_once 'boot.php';
13
14 class ItemURI extends BaseObject
15 {
16         /**
17          * @brief Insert an item-uri record and return its id
18          *
19          * @param array $fields Item-uri fields
20          *
21          * @return integer item-uri id
22          */
23         public static function insert($fields)
24         {
25                 // If the URI gets too long we only take the first parts and hope for best
26                 $uri = substr($fields['uri'], 0, 255);
27
28                 if (!DBA::exists('item-uri', ['uri' => $uri])) {
29                         DBA::insert('item-uri', $fields, true);
30                 }
31
32                 $itemuri = DBA::selectFirst('item-uri', ['id'], ['uri' => $uri]);
33
34                 if (!DBA::isResult($itemuri)) {
35                         // This shouldn't happen
36                         return null;
37                 }
38
39                 return $itemuri['id'];
40         }
41
42         /**
43          * @brief Searched for an id of a given uri. Adds it, if not existing yet.
44          *
45          * @param string $uri
46          *
47          * @return integer item-uri id
48          */
49         public static function getIdByURI($uri)
50         {
51                 // If the URI gets too long we only take the first parts and hope for best
52                 $uri = substr($uri, 0, 255);
53
54                 $itemuri = DBA::selectFirst('item-uri', ['id'], ['uri' => $uri]);
55
56                 if (!DBA::isResult($itemuri)) {
57                         return self::insert(['uri' => $uri]);
58                 }
59
60                 return $itemuri['id'];
61         }
62 }