Xoopstube::grabEntries()   A
last analyzed

Complexity

Conditions 3
Paths 2

Size

Total Lines 22
Code Lines 17

Duplication

Lines 0
Ratio 0 %

Importance

Changes 2
Bugs 0 Features 0
Metric Value
cc 3
eloc 17
c 2
b 0
f 0
nc 2
nop 1
dl 0
loc 22
rs 9.7
1
<?php
2
3
declare(strict_types=1);
4
5
namespace XoopsModules\Rssfit\Plugins;
6
7
/*
8
 * You may not change or alter any portion of this comment or credits
9
 * of supporting developers from this source code or any supporting source code
10
 * which is considered copyrighted (c) material of the original comment or credit authors.
11
 *
12
 * This program is distributed in the hope that it will be useful,
13
 * but WITHOUT ANY WARRANTY; without even the implied warranty of
14
 * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.
15
 */
16
17
/**
18
 * @copyright    XOOPS Project (https://xoops.org)
19
 * @license      GNU GPL 2 or later (https://www.gnu.org/licenses/gpl-2.0.html)
20
 * @package      RSSFit - Extendable XML news feed generator
21
 * @author       NS Tai (aka tuff) <http://www.brandycoke.com>
22
 * @author       XOOPS Development Team
23
 */
24
25
/**
26
 * About this RSSFit plug-in
27
 * Author: jayjay <http://www.sint-niklaas.be>
28
 * Requirements (Tested with):
29
 *  Module: Xoopstube <https://xoops.org>
30
 *  Version: 1.0
31
 *  RSSFit version: 1.21
32
 *  XOOPS version: 2.0.18.1
33
 */
34
35
use XoopsModules\Rssfit\{
36
    AbstractPlugin
37
};
38
use XoopsModules\Xoopstube\Helper as PluginHelper;
39
40
if (!\defined('RSSFIT_ROOT_PATH')) {
41
    exit();
42
}
43
44
/**
45
 * Class Xoopstube
46
 */
47
final class Xoopstube extends AbstractPlugin
48
{
49
50
    public function __construct() {
51
        if (\class_exists(PluginHelper::class)) {
52
            $this->helper = PluginHelper::getInstance();
53
            $this->dirname = $this->helper->dirname();
54
        }
55
    }
56
57
58
    public function grabEntries(\XoopsMySQLDatabase $xoopsDB): ?array
59
    {
60
        $myts = \MyTextSanitizer::getInstance();
61
        $ret  = null;
62
        $i    = 0;
63
        $sql  = 'SELECT l.lid, l.title as ltitle, l.date, l.cid, l.hits, l.description, c.title as ctitle FROM ' . $xoopsDB->prefix('xoopstube_videos') . ' l, ' . $xoopsDB->prefix('xoopstube_cat') . ' c WHERE l.cid=c.cid AND l.status>0 ORDER BY l.date DESC';
64
65
        $result = $xoopsDB->query($sql, $this->grab, 0);
66
        if ($result instanceof \mysqli_result) {
67
            $ret = [];
68
            while (false !== ($row = $xoopsDB->fetchArray($result))) {
69
                $ret[$i]['title']       = $row['ltitle'];
70
                $link                   = XOOPS_URL . '/modules/' . $this->dirname . '/singlevideo.php?cid=' . $row['cid'] . '&amp;lid=' . $row['lid'];
71
                $ret[$i]['link']        = $ret[$i]['guid'] = $link;
72
                $ret[$i]['timestamp']   = $row['date'];
73
                $ret[$i]['description'] = $myts->displayTarea($row['description']);
74
                $ret[$i]['category']    = $this->modname;
75
                $ret[$i]['domain']      = XOOPS_URL . '/modules/' . $this->dirname . '/';
76
                $i++;
77
            }
78
        }
79
        return $ret;
80
    }
81
}
82