Completed
Push — master ( 592643...f454c2 )
by Michael
03:05 queued 01:21
created

Helper   A

Complexity

Total Complexity 6

Size/Duplication

Total Lines 60
Duplicated Lines 0 %

Coupling/Cohesion

Components 0
Dependencies 0

Importance

Changes 0
Metric Value
dl 0
loc 60
rs 10
c 0
b 0
f 0
wmc 6
lcom 0
cbo 0

4 Methods

Rating   Name   Duplication   Size   Complexity  
A __construct() 0 6 1
A getInstance() 0 9 2
A getDirname() 0 4 1
A getHandler() 0 15 2
1
<?php
2
3
namespace XoopsModules\Xnewsletter;
4
5
/*
6
 * You may not change or alter any portion of this comment or credits
7
 * of supporting developers from this source code or any supporting source code
8
 * which is considered copyrighted (c) material of the original comment or credit authors.
9
 *
10
 * This program is distributed in the hope that it will be useful,
11
 * but WITHOUT ANY WARRANTY; without even the implied warranty of
12
 * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.
13
 */
14
15
/**
16
 * @copyright    XOOPS Project https://xoops.org/
17
 * @license      GNU GPL 2 or later (http://www.gnu.org/licenses/gpl-2.0.html)
18
 * @package
19
 * @since
20
 * @author       XOOPS Development Team
21
 */
22
//defined('XOOPS_ROOT_PATH') || die('Restricted access');
23
24
/**
25
 * Class Helper
26
 */
27
class Helper extends \Xmf\Module\Helper
28
{
29
    public $debug;
30
31
    /**
32
     * @param bool $debug
33
     */
34
    public function __construct($debug = false)
35
    {
36
        $this->debug = $debug;
37
        $moduleDirName = basename(dirname(__DIR__));
38
        parent::__construct($moduleDirName);
39
    }
40
41
    /**
42
     * @param bool $debug
43
     *
44
     * @return \XoopsModules\Xnewsletter\Helper
45
     */
46
    public static function getInstance($debug = false)
47
    {
48
        static $instance;
49
        if (null === $instance) {
50
            $instance = new static($debug);
51
        }
52
53
        return $instance;
54
    }
55
56
    /**
57
     * @return string
58
     */
59
    public function getDirname()
60
    {
61
        return $this->dirname;
62
    }
63
64
    /**
65
     * Get an Object Handler
66
     *
67
     * @param string $name name of handler to load
68
     *
69
     * @return bool|\XoopsObjectHandler|\XoopsPersistableObjectHandler
0 ignored issues
show
Documentation introduced by
Should the return type not be object?

This check compares the return type specified in the @return annotation of a function or method doc comment with the types returned by the function and raises an issue if they mismatch.

Loading history...
70
     */
71
    public function getHandler($name)
72
    {
73
        $ret   = false;
0 ignored issues
show
Unused Code introduced by
$ret is not used, you could remove the assignment.

This check looks for variable assignements that are either overwritten by other assignments or where the variable is not used subsequently.

$myVar = 'Value';
$higher = false;

if (rand(1, 6) > 3) {
    $higher = true;
} else {
    $higher = false;
}

Both the $myVar assignment in line 1 and the $higher assignment in line 2 are dead. The first because $myVar is never used and the second because $higher is always overwritten for every possible time line.

Loading history...
74
75
        $class = '\\XoopsModules\\' . ucfirst(mb_strtolower(basename(dirname(__DIR__)))) . '\\' . $name . 'Handler';
76
        if (!class_exists($class)) {
77
            throw new \RuntimeException("Class '$class' not found");
78
        }
79
        /** @var \XoopsMySQLDatabase $db */
80
        $db     = \XoopsDatabaseFactory::getDatabaseConnection();
81
        $helper = self::getInstance();
82
        $ret    = new $class($db, $helper);
83
        $this->addLog("Getting handler '{$name}'");
84
        return $ret;
85
    }
86
}
87