VersionChecks::checkVerPhp()   A
last analyzed

Complexity

Conditions 6
Paths 6

Size

Total Lines 31
Code Lines 14

Duplication

Lines 0
Ratio 0 %

Importance

Changes 0
Metric Value
cc 6
eloc 14
nc 6
nop 1
dl 0
loc 31
rs 9.2222
c 0
b 0
f 0
1
<?php
2
3
namespace XoopsModules\Chess\Common;
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     http://www.fsf.org/copyleft/gpl.html GNU public license
18
 * @author      mamba <[email protected]>
19
 */
20
trait VersionChecks
21
{
22
    /**
23
     * Verifies XOOPS version meets minimum requirements for this module
24
     * @static
25
     *
26
     * @param \XoopsModule|null $module
27
     * @param null|string       $requiredVer
28
     * @return bool true if meets requirements, false if not
29
     */
30
    public static function checkVerXoops(?\XoopsModule $module = null, $requiredVer = null)
31
    {
32
        $moduleDirName = \basename(\dirname(__DIR__, 2));
33
34
        $moduleDirNameUpper = mb_strtoupper($moduleDirName);
35
36
        if (null === $module) {
37
            $module = \XoopsModule::getByDirname($moduleDirName);
38
        }
39
40
        \xoops_loadLanguage('admin', $moduleDirName);
41
42
        \xoops_loadLanguage('common', $moduleDirName);
43
44
        //check for minimum XOOPS version
45
        $currentVer = mb_substr(\XOOPS_VERSION, 6); // get the numeric part of string
46
        if (null === $requiredVer) {
47
            $requiredVer = '' . $module->getInfo('min_xoops'); //making sure it's a string
0 ignored issues
show
Bug introduced by
Are you sure $module->getInfo('min_xoops') 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

47
            $requiredVer = '' . /** @scrutinizer ignore-type */ $module->getInfo('min_xoops'); //making sure it's a string
Loading history...
48
        }
49
50
        $success = true;
51
52
        if (\version_compare($currentVer, $requiredVer, '<')) {
53
            $success = false;
54
55
            $module->setErrors(\sprintf(\constant('CO_' . $moduleDirNameUpper . '_ERROR_BAD_XOOPS'), $requiredVer, $currentVer));
56
        }
57
58
        return $success;
59
    }
60
61
    /**
62
     * Verifies PHP version meets minimum requirements for this module
63
     * @static
64
     *
65
     * @param \XoopsModule|null $module
66
     * @return bool true if meets requirements, false if not
67
     */
68
    public static function checkVerPhp(?\XoopsModule $module = null)
69
    {
70
        $moduleDirName = \basename(\dirname(__DIR__, 2));
71
72
        $moduleDirNameUpper = mb_strtoupper($moduleDirName);
73
74
        if (null === $module) {
75
            $module = \XoopsModule::getByDirname($moduleDirName);
76
        }
77
78
        \xoops_loadLanguage('admin', $moduleDirName);
79
80
        \xoops_loadLanguage('common', $moduleDirName);
81
82
        // check for minimum PHP version
83
84
        $success = true;
85
86
        $verNum = \PHP_VERSION;
87
88
        $reqVer = &$module->getInfo('min_php');
89
90
        if (false !== $reqVer && '' !== $reqVer && !\is_array($reqVer)) {
91
            if (\version_compare($verNum, $reqVer, '<')) {
92
                $module->setErrors(\sprintf(\constant('CO_' . $moduleDirNameUpper . '_ERROR_BAD_PHP'), $reqVer, $verNum));
93
94
                $success = false;
95
            }
96
        }
97
98
        return $success;
99
    }
100
101
    /**
102
     * compares current module version with latest GitHub release
103
     * @static
104
     * @param \Xmf\Module\Helper $helper
105
     * @param string|null        $source
106
     * @param string|null        $default
107
     *
108
     * @return string|array info about the latest module version, if newer
109
     */
110
    public static function checkVerModule($helper, $source = 'github', $default = 'master')
111
    {
112
        $moduleDirName = \basename(\dirname(__DIR__, 2));
113
114
        $moduleDirNameUpper = mb_strtoupper($moduleDirName);
115
116
        $update = '';
117
118
        $repository = 'XoopsModules25x/' . $moduleDirName;
119
120
        //        $repository         = 'XoopsModules25x/publisher'; //for testing only
121
122
        $ret = '';
123
124
        $infoReleasesUrl = "https://api.github.com/repos/$repository/releases";
125
126
        if ('github' === $source) {
127
            if (\function_exists('curl_init') && false !== ($curlHandle = \curl_init())) {
128
                \curl_setopt($curlHandle, \CURLOPT_URL, $infoReleasesUrl);
129
130
                \curl_setopt($curlHandle, \CURLOPT_RETURNTRANSFER, true);
131
132
                \curl_setopt($curlHandle, \CURLOPT_SSL_VERIFYPEER, true);
133
134
                \curl_setopt($curlHandle, \CURLOPT_HTTPHEADER, ["User-Agent:Publisher\r\n"]);
135
136
                $curlReturn = \curl_exec($curlHandle);
137
138
                if (false === $curlReturn) {
139
                    \trigger_error(\curl_error($curlHandle));
140
                } elseif (false !== \mb_strpos($curlReturn, 'Not Found')) {
0 ignored issues
show
Bug introduced by
It seems like $curlReturn can also be of type true; however, parameter $haystack of mb_strpos() 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

140
                } elseif (false !== \mb_strpos(/** @scrutinizer ignore-type */ $curlReturn, 'Not Found')) {
Loading history...
141
                    \trigger_error('Repository Not Found: ' . $infoReleasesUrl);
142
                } else {
143
                    $file = \json_decode($curlReturn, false);
0 ignored issues
show
Bug introduced by
It seems like $curlReturn can also be of type true; however, parameter $json of json_decode() 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

143
                    $file = \json_decode(/** @scrutinizer ignore-type */ $curlReturn, false);
Loading history...
144
145
                    $latestVersionLink = \sprintf("https://github.com/$repository/archive/%s.zip", $file ? \reset($file)->tag_name : $default);
146
147
                    $latestVersion = $file[0]->tag_name;
148
149
                    $prerelease = $file[0]->prerelease;
150
151
                    if ('master' !== $latestVersionLink) {
152
                        $update = \constant('CO_' . $moduleDirNameUpper . '_' . 'NEW_VERSION') . $latestVersion;
153
                    }
154
155
                    //"PHP-standardized" version
156
157
                    $latestVersion = mb_strtolower($latestVersion);
158
159
                    if (false !== mb_strpos($latestVersion, 'final')) {
160
                        $latestVersion = \str_replace('_', '', mb_strtolower($latestVersion));
161
162
                        $latestVersion = \str_replace('final', '', mb_strtolower($latestVersion));
163
                    }
164
165
                    $moduleVersion = $helper->getModule()->getInfo('version') . '_' . $helper->getModule()->getInfo('module_status');
0 ignored issues
show
Bug introduced by
Are you sure $helper->getModule()->getInfo('module_status') 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

165
                    $moduleVersion = $helper->getModule()->getInfo('version') . '_' . /** @scrutinizer ignore-type */ $helper->getModule()->getInfo('module_status');
Loading history...
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

165
                    $moduleVersion = /** @scrutinizer ignore-type */ $helper->getModule()->getInfo('version') . '_' . $helper->getModule()->getInfo('module_status');
Loading history...
166
167
                    //"PHP-standardized" version
168
169
                    $moduleVersion = \str_replace(' ', '', mb_strtolower($moduleVersion));
170
171
                    //                    $moduleVersion = '1.0'; //for testing only
172
173
                    //                    $moduleDirName = 'publisher'; //for testing only
174
175
                    if (!$prerelease && \version_compare($moduleVersion, $latestVersion, '<')) {
176
                        $ret = [];
177
178
                        $ret[] = $update;
179
180
                        $ret[] = $latestVersionLink;
181
                    }
182
                }
183
184
                \curl_close($curlHandle);
185
            }
186
        }
187
188
        return $ret;
189
    }
190
}
191