Passed
Push — master ( 796a84...196098 )
by Goffy
38s queued 13s
created

VersionChecks::checkVerModule()   C

Complexity

Conditions 13
Paths 13

Size

Total Lines 49
Code Lines 36

Duplication

Lines 0
Ratio 0 %

Importance

Changes 3
Bugs 0 Features 0
Metric Value
cc 13
eloc 36
c 3
b 0
f 0
nc 13
nop 3
dl 0
loc 49
rs 6.6166

How to fix   Complexity   

Long Method

Small methods make your code easier to understand, in particular if combined with a good name. Besides, if your method is small, finding a good name is usually much easier.

For example, if you find yourself adding comments to a method's body, this is usually a good sign to extract the commented part to a new method, and use the comment as a starting point when coming up with a good name for this new method.

Commonly applied refactorings include:

1
<?php
2
3
declare(strict_types=1);
4
5
namespace XoopsModules\Tdmdownloads\Common;
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     http://www.fsf.org/copyleft/gpl.html GNU public license
20
 * @author      mamba <[email protected]>
21
 */
22
23
use Xmf\Module\Helper;
24
25
trait VersionChecks
26
{
27
    /**
28
     * Verifies XOOPS version meets minimum requirements for this module
29
     * @static
30
     *
31
     */
32
    public static function checkVerXoops(?\XoopsModule $module = null, ?string $requiredVer = null): bool
33
    {
34
        $moduleDirName      = \basename(\dirname(__DIR__, 2));
35
        $moduleDirNameUpper = \mb_strtoupper($moduleDirName);
36
        if (null === $module) {
37
            $module = \XoopsModule::getByDirname($moduleDirName);
38
        }
39
        \xoops_loadLanguage('admin', $moduleDirName);
40
        \xoops_loadLanguage('common', $moduleDirName);
41
42
        //check for minimum XOOPS version
43
        $currentVer = \mb_substr(\XOOPS_VERSION, 6); // get the numeric part of string
44
        if (null === $requiredVer) {
45
            $requiredVer = (string)$module->getInfo('min_xoops'); //making sure it's a string
46
        }
47
        $success = true;
48
        if (\version_compare($currentVer, $requiredVer, '<')) {
49
            $success = false;
50
            $module->setErrors(\sprintf(\constant('CO_' . $moduleDirNameUpper . '_ERROR_BAD_XOOPS'), $requiredVer, $currentVer));
51
        }
52
        return $success;
53
    }
54
55
    /**
56
     * Verifies PHP version meets minimum requirements for this module
57
     * @static
58
     *
59
     * @return bool true if meets requirements, false if not
60
     */
61
    public static function checkVerPhp(?\XoopsModule $module = null): bool
62
    {
63
        $moduleDirName      = \basename(\dirname(__DIR__, 2));
64
        $moduleDirNameUpper = \mb_strtoupper($moduleDirName);
65
        if (null === $module) {
66
            $module = \XoopsModule::getByDirname($moduleDirName);
67
        }
68
        \xoops_loadLanguage('admin', $moduleDirName);
69
        \xoops_loadLanguage('common', $moduleDirName);
70
        // check for minimum PHP version
71
        $success = true;
72
        $verNum  = \PHP_VERSION;
73
        $reqVer  = &$module->getInfo('min_php');
74
        if (false !== $reqVer && '' !== $reqVer) {
75
            if (\version_compare($verNum, $reqVer, '<')) {
0 ignored issues
show
Bug introduced by
It seems like $reqVer can also be of type array; however, parameter $version2 of version_compare() does only seem to accept string, maybe add an additional type check? ( Ignorable by Annotation )

If this is a false-positive, you can also ignore this issue in your code via the ignore-type  annotation

75
            if (\version_compare($verNum, /** @scrutinizer ignore-type */ $reqVer, '<')) {
Loading history...
76
                $module->setErrors(\sprintf(\constant('CO_' . $moduleDirNameUpper . '_ERROR_BAD_PHP'), $reqVer, $verNum));
0 ignored issues
show
Bug introduced by
It seems like $reqVer can also be of type array; however, parameter $values of sprintf() does only seem to accept double|integer|string, maybe add an additional type check? ( Ignorable by Annotation )

If this is a false-positive, you can also ignore this issue in your code via the ignore-type  annotation

76
                $module->setErrors(\sprintf(\constant('CO_' . $moduleDirNameUpper . '_ERROR_BAD_PHP'), /** @scrutinizer ignore-type */ $reqVer, $verNum));
Loading history...
77
                $success = false;
78
            }
79
        }
80
        return $success;
81
    }
82
83
    /**
84
     *
85
     * compares current module version with the latest GitHub release
86
     * @static
87
     *
88
     */
89
90
    public static function checkVerModule(Helper $helper, ?string $source = 'github', ?string $default = 'master'): ?array
91
    {
92
        $moduleDirName      = \basename(\dirname(__DIR__, 2));
93
        $moduleDirNameUpper = \mb_strtoupper($moduleDirName);
94
        $update             = '';
95
        $repository         = 'XoopsModules25x/' . $moduleDirName;
96
        //        $repository         = 'XoopsModules25x/publisher'; //for testing only
97
        $ret             = null;
98
        $infoReleasesUrl = "https://api.github.com/repos/$repository/releases";
99
        if ('github' === $source) {
100
            if (\function_exists('curl_init') && false !== ($curlHandle = \curl_init())) {
101
                \curl_setopt($curlHandle, \CURLOPT_URL, $infoReleasesUrl);
102
                \curl_setopt($curlHandle, \CURLOPT_RETURNTRANSFER, true);
103
                \curl_setopt($curlHandle, \CURLOPT_SSL_VERIFYPEER, true); //TODO: how to avoid an error when 'Peer's Certificate issuer is not recognized'
104
                \curl_setopt($curlHandle, \CURLOPT_HTTPHEADER, ["User-Agent:Publisher\r\n"]);
105
                $curlReturn = \curl_exec($curlHandle);
106
                if (false === $curlReturn) {
107
                    \trigger_error(\curl_error($curlHandle));
108
                } elseif (\is_string($curlReturn) && false !== \strpos($curlReturn, 'Not Found')) {
109
                    \trigger_error('Repository Not Found: ' . $infoReleasesUrl);
110
                } elseif (\is_string($curlReturn)) {
111
                    $file              = json_decode($curlReturn, false);
112
                    $latestVersionLink = \sprintf("https://github.com/$repository/archive/%s.zip", $file ? \reset($file)->tag_name : $default);
113
                    $latestVersion     = $file[0]->tag_name;
114
                    $prerelease        = $file[0]->prerelease;
115
                    if ('master' !== $latestVersionLink) {
116
                        $update = \constant('CO_' . $moduleDirNameUpper . '_' . 'NEW_VERSION') . $latestVersion;
117
                    }
118
                    //"PHP-standardized" version
119
                    $latestVersion = \mb_strtolower($latestVersion);
120
                    if (false !== mb_strpos($latestVersion, 'final')) {
121
                        $latestVersion = \str_replace('_', '', \mb_strtolower($latestVersion));
122
                        $latestVersion = \str_replace('final', '', \mb_strtolower($latestVersion));
123
                    }
124
                    $moduleVersion = ($helper->getModule()->getInfo('version') . '_' . $helper->getModule()->getInfo('module_status'));
0 ignored issues
show
Bug introduced by
Are you sure $helper->getModule()->getInfo('version') of type array|string can be used in concatenation? ( Ignorable by Annotation )

If this is a false-positive, you can also ignore this issue in your code via the ignore-type  annotation

124
                    $moduleVersion = (/** @scrutinizer ignore-type */ $helper->getModule()->getInfo('version') . '_' . $helper->getModule()->getInfo('module_status'));
Loading history...
125
                    //"PHP-standardized" version
126
                    $moduleVersion = \str_replace(' ', '', \mb_strtolower($moduleVersion));
127
                    //                    $moduleVersion = '1.0'; //for testing only
128
                    //                    $moduleDirName = 'publisher'; //for testing only
129
                    if (!$prerelease && \version_compare($moduleVersion, $latestVersion, '<')) {
130
                        $ret   = [];
131
                        $ret[] = $update;
132
                        $ret[] = $latestVersionLink;
133
                    }
134
                }
135
                \curl_close($curlHandle);
136
            }
137
        }
138
        return $ret;
139
    }
140
}
141