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

VersionChecks   A

Complexity

Total Complexity 22

Size/Duplication

Total Lines 114
Duplicated Lines 0 %

Importance

Changes 8
Bugs 0 Features 0
Metric Value
eloc 65
c 8
b 0
f 0
dl 0
loc 114
rs 10
wmc 22

3 Methods

Rating   Name   Duplication   Size   Complexity  
A checkVerXoops() 0 21 4
A checkVerPhp() 0 20 5
C checkVerModule() 0 49 13
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