diff options
Diffstat (limited to 'wizard')
-rw-r--r-- | wizard/alarm.png | bin | 0 -> 1907 bytes | |||
-rw-r--r-- | wizard/index.php | 410 | ||||
-rw-r--r-- | wizard/info.png | bin | 0 -> 1817 bytes | |||
-rw-r--r-- | wizard/notice.png | bin | 0 -> 1770 bytes | |||
-rw-r--r-- | wizard/question.png | bin | 0 -> 1854 bytes |
5 files changed, 285 insertions, 125 deletions
diff --git a/wizard/alarm.png b/wizard/alarm.png Binary files differnew file mode 100644 index 00000000..e57cccb0 --- /dev/null +++ b/wizard/alarm.png diff --git a/wizard/index.php b/wizard/index.php index 04252234..59fa1776 100644 --- a/wizard/index.php +++ b/wizard/index.php @@ -8,68 +8,105 @@ <link rel="shortcut icon" href="/favicon.ico" /> </head> <?php -define('FC_EOL', 29); -define('FC_DEV', 32); -define('EL_EOL', 5); -define('EL_DEV', 9); +define('FC_EOL', 38); +define('FC_DEV', 42); +define('EL_EOL', 7); +define('EL_DEV', 10); +define('PHP_SEC', '8.1'); +define('EPEL_DEV', 2); // 0 missing, 1 partially populated, 2 mostly full define('COUNTER', __DIR__ . "/counter.txt"); $osvers = [ - 'RHEL 8' => ['7.2','7.3'], - 'RHEL 7' => '5.4', - 'RHEL 6' => '5.3', - 'CentOS 8' => '7.2', - 'CentOS 7' => '5.4', - 'CentOS 6' => '5.3', - 'Fedora 32' => '7.4', - 'Fedora 31' => '7.3', - 'Fedora 30' => '7.3', + 'RHEL 9' => ['8.0', '8.1', '8.2'], + 'RHEL 8' => ['7.4', '8.0', '8.2'], +// 'RHEL 7' => '5.4', + 'CentOS 9' => ['8.0', '8.1', '8.2'], +// 'CentOS 8' => ['7.4', '8.0', '8.2'], +// 'CentOS 7' => '5.4', + 'EL 9' => ['8.0', '8.1', '8.2'], + 'EL 8' => ['7.4', '8.0', '8.2'], +// 'EL 7' => '5.4', + 'Fedora 41' => '8.3', + 'Fedora 40' => '8.3', + 'Fedora 39' => '8.2', ]; $osmin = [ + 'RHEL 9' => '7.4', + 'RHEL 8' => '5.6', +// 'RHEL 7' => '5.4', + 'CentOS 9' => '7.4', +// 'CentOS 8' => '5.6', +// 'CentOS 7' => '5.4', + 'EL 9' => '7.4', + 'EL 8' => '5.6', +// 'EL 7' => '5.4', + 'Fedora 41' => '7.4', + 'Fedora 40' => '7.4', + 'Fedora 39' => '7.4', +]; +$osminbase = [ + 'RHEL 9' => '7.4', 'RHEL 8' => '7.2', - 'RHEL 7' => '5.4', - 'RHEL 6' => '5.4', - 'CentOS 8' => '7.2', - 'CentOS 7' => '5.4', - 'CentOS 6' => '5.4', - 'Fedora 32' => '5.6', - 'Fedora 31' => '5.6', - 'Fedora 30' => '5.6', +// 'RHEL 7' => '5.4', + 'CentOS 9' => '7.4', +// 'CentOS 8' => '7.2', +// 'CentOS 7' => '5.4', + 'EL 9' => '7.4', + 'EL 8' => '7.2', +// 'EL 7' => '5.4', + 'Fedora 41' => '7.4', + 'Fedora 40' => '7.4', + 'Fedora 39' => '7.4', ]; $osmax = [ - 'RHEL 8' => '7.4', - 'RHEL 7' => '7.4', - 'RHEL 6' => '7.3', - 'CentOS 8' => '7.4', - 'CentOS 7' => '7.4', - 'CentOS 6' => '7.3', - 'Fedora 32' => '7.4', - 'Fedora 31' => '7.4', - 'Fedora 30' => '7.4', + 'RHEL 9' => '8.4', + 'RHEL 8' => '8.4', +// 'RHEL 7' => '8.3', + 'CentOS 9' => '8.4', +// 'CentOS 8' => '8.3', +// 'CentOS 7' => '8.3', + 'EL 9' => '8.4', + 'EL 8' => '8.4', +// 'EL 7' => '8.3', + 'Fedora 41' => '8.4', + 'Fedora 40' => '8.4', + 'Fedora 39' => '8.4', ]; $osname = [ - 'RHEL 8' => 'RHEL-8', - 'RHEL 7' => 'RHEL-7 (maintained until June 2024)', - 'RHEL 6' => 'RHEL-6 (maintained until November 2020)', - 'CentOS 8' => 'CentOS 8', - 'CentOS 7' => 'CentOS 7 (maintained until June 2024)', - 'CentOS 6' => 'CentOS 6 (maintained until November 2020)', - 'Fedora 32' => 'Fedora 32 (development version)', - 'Fedora 31' => 'Fedora 31', - 'Fedora 30' => 'Fedora 30', -// 'Fedora 29' => 'Fedora 29 (EOL since November 2019)', -]; -$grpname = [ - 'RHEL' => 'Red Hat Enterprise Linux', - 'CentOS' => 'CentOS', - 'Fedora' => 'Fedora', + ':rhel' => 'Red Hat Enterprise Linux', + 'RHEL 9' => 'RHEL 9.4', // (maintained until May 31, 2032) + 'RHEL 8' => 'RHEL 8.9', // (maintained until May 31, 2029) +// 'RHEL 7' => 'RHEL 7.9 (maintained until June 30, 2024)', + ':centos' => 'CentOS Stream, CentOS Linux', + 'CentOS 9' => 'CentOS Stream 9', // (maintained until May 31, 2027) +// 'CentOS 8' => 'CentOS Stream 8 (maintained until May 31, 2024)', +// 'CentOS 7' => 'CentOS 7 (maintained until June 30, 2024)', + ':clone' => 'Alma Linux, Rocky Linux and other clones', + 'EL 9' => 'EL 9', + 'EL 8' => 'EL 8', +// 'EL 7' => 'EL 7 (maintained until June 30, 2024)', + ':fedora' => 'Fedora Linux', + 'Fedora 41' => 'Fedora 41', + 'Fedora 40' => 'Fedora 40', + 'Fedora 39' => 'Fedora 39 (maintained until November 29, 2024)', ]; $types = [ 'base' => 'Default / Single version (simplest way)', 'scl' => 'Multiple versions simultaneously', ]; +$arches = [ + 'x86_64' => 'x86_64', + 'aarch64' => 'aarch64', + 'ppc64le' => 'ppc64le', + 's390x' => 's390x', +]; $phpvers = [ // use false when only SCL + '8.4' => 'remi-php84', + '8.3' => 'remi-php83', + '8.2' => 'remi-php82', + '8.1' => 'remi-php81', + '8.0' => 'remi-php80', '7.4' => 'remi-php74', '7.3' => 'remi-php73', '7.2' => 'remi-php72', @@ -80,22 +117,31 @@ $phpvers = [ '5.4' => 'remi-php54', ]; $phpname = [ -// ':devel' => 'Development version, not ready for production', + ':devel' => 'Development version, not ready for production', + '8.4' => '8.4.0RC4', ':stable' => 'Stable versions - usage recommended', - '7.4' => '7.4.4 (active support until November 2021)', - '7.3' => '7.3.16 (active support until December 2020)', + '8.3' => '8.3.13 (active support until December 2025)', + '8.2' => '8.2.25 (active support until December 2024)', ':secure' => 'Security only versions', - '7.2' => '7.2.29 (security only support until November 2020)', + '8.1' => '8.1.30 (security only support until December 2025)', ':eol' => 'Deprecated versions - usage discouraged', + '8.0' => '8.0.30 (no upstream support since November 2023)', + '7.4' => '7.4.33 (no upstream support since November 2022)', + '7.3' => '7.3.33 (no upstream support since December 2021)', + '7.2' => '7.2.34 (no upstream support since November 2020)', '7.1' => '7.1.33 (no upstream support since December 2019)', '7.0' => '7.0.33 (no upstream support since December 2018)', '5.6' => '5.6.40 (no upstream support since January 2019)', - '5.5' => '5.5.38 (no upstream support since July 2016)', - '5.4' => '5.4.45 (no upstream support since September 2015)', ]; +$phptest = [ + '8.3' => '8.3.14RC1', + '8.2' => '8.2.26RC1', +]; + $php = (isset($_POST['php']) && isset($phpvers[$_POST['php']]) ? $_POST['php'] : false); $os = (isset($_POST['os']) && isset($osvers[$_POST['os']]) ? $_POST['os'] : false); $type = (isset($_POST['type']) && isset($types[$_POST['type']]) ? $_POST['type'] : false); +$arch = (isset($_POST['arch']) && isset($arches[$_POST['arch']]) ? $_POST['arch'] : 'x86_64'); ?> <body> @@ -105,13 +151,19 @@ $type = (isset($_POST['type']) && isset($types[$_POST['type']]) ? $_POST['type' </div> <p id="prelude"> <a href="https://blog.remirepo.net/">Blog</a> | - <a href="https://forum.remirepo.net/">Forum</a> | + <a href="https://github.com/remicollet/remirepo/issues">Support</a> | <a href="https://rpms.remirepo.net/">Repository</a> | <a href="https://rpms.remirepo.net/wizard/">Wizard</a> </p> <div id="wrapper"> <div id="main"> <div id="content"> +<?php + if (count($_POST) == 0) { + echo '<h2>Please STOP WAR NOW!</h2><p><a href="https://blog.remirepo.net/post/2022/03/03/Please-STOP-war">'; + echo '<img alt="" class="media" src="https://blog.remirepo.net/public/icons/dove.svg" width="256" /></a></p>'; + } +?> <h2>Operating system and version selection</h2> <form method='post'> <ul class="pkglist"> @@ -120,13 +172,14 @@ $type = (isset($_POST['type']) && isset($types[$_POST['type']]) ? $_POST['type' <option value=''>--</option> <?php $prev = false; - foreach($osvers as $osver => $phpver) { - list($dist, $ver) = explode(' ', $osver, 2); - if ($dist != $prev) { + foreach($osname as $osver => $name) { + if ($osver[0] == ':') { if ($prev) echo "</optgroup>"; - printf("<optgroup label='%s'>", $grpname[$prev=$dist]); - } - printf("<option value='%s' %s> %s</option>", $osver, ($osver===$os ? 'selected' : ''), $osname[$osver]); + printf("<optgroup label='%s'>", $name); + $prev = true; + } else { + printf("<option value='%s' %s> %s</option>", $osver, ($osver===$os ? 'selected' : ''), $name); + } } ?> </optgroup></select> @@ -153,6 +206,13 @@ $type = (isset($_POST['type']) && isset($types[$_POST['type']]) ? $_POST['type' ?> </select> </p></li> + <li><p>Architecture: + <select name='arch' onChange='submit()'> +<?php + foreach($arches as $archref => $name) printf("<option value='%s' %s>%s</option>", $archref, ($archref===$arch ? 'selected' : ''), $name); +?> + </select> + </p></li> </ul> </form> <h2>Wizard answer</h2> @@ -165,10 +225,27 @@ $err = false; if ($os) { list($dist, $ver) = explode(' ', $os, 2); if (($dist == 'Fedora' && $ver<=FC_EOL) || ($dist != 'Fedora' && $ver<=EL_EOL)) { - printf("<li><b>%s</b> have reached its <b>end of life</b>, upgrade is strongly recommended.</li><br />", $os); - } - if (($dist == 'Fedora' && $ver>=FC_DEV) || ($dist != 'Fedora' && $ver>=EL_DEV)) { - printf("<li><b>WARNING: %s</b> is a <b>development</b> version, not ready for production.</li><br />", $os); + printf("<li><img src='alarm.png'> <b>%s</b> has reached its <b>end of life</b>, upgrade is strongly recommended.</li><br />", $os); + + } else if (($dist == 'Fedora' && $ver>=FC_DEV) || ($dist != 'Fedora' && $ver>=EL_DEV)) { + printf("<li><img src='notice.png'> <b>WARNING: %s</b> is a <b>development</b> version, not ready for production.</li><br />", $os); + + } else if ($ver == 7 || $ver == 39 || ($dist=="CentOS" && $ver == 8)) { + if ($ver == 39) $days = mktime(0, 0, 0, 11, 29, 2024); + else if ($ver == 9) $days = mktime(0, 0, 0, 5, 31, $dist=="CentOS" ? 2027 : 2032); + else if ($ver == 8) $days = mktime(0, 0, 0, 5, 31, $dist=="CentOS" ? 2024 : 2029); + else if ($ver == 7) $days = mktime(0, 0, 0, 6, 30, 2024); + $eol = date("F Y", $days); + $days = (int)(($days - time()) / (60 * 60 * 24)); + $weeks = round($days/7); + $months = round($days/30); + if ($months >= 6) { + printf("<li><img src='notice.png'> <b>WARNING: %s</b> will reach its <b>end of life</b> in $eol, in <b>$months months</b>, upgrade is heartily recommended.</li><br />", $os); + } else if ($weeks >= 8) { + printf("<li><img src='alarm.png'> <b>WARNING: %s</b> will reach its <b>end of life</b> in $eol, in <b>$weeks weeks</b>, upgrade is strongly recommended.</li><br />", $os); + } else { + printf("<li><img src='alarm.png'> <b>WARNING: %s</b> will reach its <b>end of life</b> in $eol, in <b>$days days</b>, upgrade is urgently recommended.</li><br />", $os); + } } } if ($php && $os) { @@ -176,33 +253,79 @@ if ($php && $os) { $os, is_array($osvers[$os]) ? implode(', ', $osvers[$os]) : $osvers[$os] ); - if (version_compare($php, '5.6', '<')) { - printf("<li><b>WARNING</b>, PHP version <b>%s</b> have reached its eod of life, despite packages have security fix, you should consider a maintained version.</li><br />", $php); + if (version_compare($php, PHP_SEC, '<')) { + printf("<li><img src='notice.png'> <b>WARNING</b>, PHP version <b>%s</b> have reached its end of life, despite packages have security fixes, you should consider a maintained version.</li><br />", $php); } + // else printf("<li>PHP %s is a maintained version (> %s).</li><br />", $php, PHP_SEC); +} + +if ($arch == 'ppc64le' || $arch == 's390x') { + printf("<li><b>$arch</b> is not planed for now</li><br />"); + $err =true; + +} else if ($arch == 'aarch64') { + if ($os && $dist === 'Fedora') { + if ($ver < 39) { + printf("<li><b>aarch64</b> for Fedora $ver is not planed for now</li><br />"); + $err =true; + } + } else if ($os && $ver < 8) { + printf("<li><b>aarch64</b> for Enterprise Linux $ver is not planed for now</li><br />"); + $err =true; + } else if ($os && $ver == 8) { + // no older SCLs + $osmin['RHEL 8'] = $osmin['CentOS 8'] = '7.2'; + } } + if ($php && $os && $type && !$err) { + $disp = explode(' ', $phpname[$php], 2)[0]; if ($dist == 'Fedora') { - $mod = ($ver >= 29); + $mod = ($ver >= 29); + $dnf5 = ($ver >= 41); $yum = 'dnf'; printf("<li>Command to install the Remi repository configuration package:"); printf("<pre> $yum install https://rpms.remirepo.net/fedora/remi-release-%d.rpm</pre>", $ver); printf("</li><br />"); } else { - $mod = ($ver >= 8); + $mod = ($ver >= 8); + $dnf5 = false; if ($ver >= 8) { $yum = 'dnf'; } else { $yum = 'yum'; } - printf("<li>Command to install the EPEL repository configuration package:"); - printf("<pre> $yum install https://dl.fedoraproject.org/pub/epel/epel-release-latest-%d.noarch.rpm</pre></li><br />", $ver); - printf("<li>Command to install the Remi repository configuration package:"); + switch ($os) { + case 'RHEL 8': + case 'RHEL 9': + printf("<li>Command to enabled the <b>CRB</b> repository:"); + printf("<pre> subscription-manager repos --enable codeready-builder-for-rhel-%d-%s-rpms</pre></li><br />", $ver, $arch); + break; + case 'CentOS 8': + case 'CentOS 9': + printf("<li>Command to enabled the <b>CRB</b> repository:"); + printf("<pre> dnf config-manager --set-enabled %s</pre></li><br />", $ver < 9 ? 'powertools' : 'crb'); + break; + } + if ($ver < EL_DEV || EPEL_DEV > 0) { + printf("<li>Command to install the <b>EPEL</b> repository configuration package:"); + printf("<pre> $yum install https://dl.fedoraproject.org/pub/epel/epel-release-latest-%d.noarch.rpm</pre></li><br />", $ver); + } + printf("<li>Command to install the <b>Remi</b> repository configuration package:"); printf("<pre> $yum install https://rpms.remirepo.net/enterprise/remi-release-%d.rpm</pre>", $ver); printf("</li><br />"); - printf("<li>Command to install the yum-utils package (for the yum-config-manager command):"); - printf("<pre> $yum install yum-utils</pre>"); + if ($yum === "yum") { + printf("<li>Command to install the yum-utils package (for the yum-config-manager command):"); + printf("<pre> $yum install yum-utils</pre>"); + } + + if ($ver == EL_DEV && EPEL_DEV < 2) { + printf("<li>As EPEL is not yet fully populated, you probably have to enable the main repository:"); + printf("<pre> dnf config-manager --enable remi</pre></li><br />", $ver); + } + printf("</li><br />"); if ($dist == 'RHEL' && $ver < 8) { printf("<li>On <b>RHEL</b> you (probably) need to enable the <b>optional channel</b> for some dependencies.</li><br />"); @@ -218,6 +341,8 @@ if ($php && $os && $type && !$err) { if ($type == 'base') { printf("<li>You want a <b>single version </b> which means replacing base packages from the distribution</li><br />"); + $min = $osminbase[$os]; + printf("<li>Packages have the <b>same name</b> than the base repository, ie php-*</li><br />"); if (version_compare($php, $osmax[$os], '>')) { @@ -226,12 +351,12 @@ if ($php && $os && $type && !$err) { } else if (!$phpvers[$php]) { printf("<li>Sorry, but PHP version <b>%s</b> are not yet available for <b>%s</b> as single version, try multiple versions.</li><br />", $php, $os); - } else if (version_compare($php, $tmp=(is_array($osvers[$os]) ? $osvers[$os][0] : $osvers[$os]), '<')) { - printf("<li>Sorry, but PHP version older than <b>%s</b> are not available for <b>%s</b>, try multiple versions.</li><br />", $tmp, $os); + } else if (version_compare($php, $min, '<')) { + printf("<li>Sorry, but PHP version older than <b>%s</b> are not available for <b>%s</b>, try multiple versions.</li><br />", $min, $os); } else { - if ($dist == 'Fedora' && version_compare($php, $tmp=(is_array($osvers[$os]) ? $osvers[$os][0] : $osvers[$os]), '=')) { - $repo = 'remi'; + if ($mod) { + $repo = 'remi-modular'; } else { $repo = $phpvers[$php]; } @@ -242,47 +367,67 @@ if ($php && $os && $type && !$err) { printf("<pre> dnf config-manager --set-enabled remi</pre></li><br />"); } - if ($dist == 'Fedora' || $yum == 'yum') { - printf("<li>PHP version <b>%s</b> packages are available for <b>%s</b> in <b>%s</b> repository</li><br />", $php, $os, $repo); + if ($mod) { + printf("<li>PHP version <b>%s</b> packages are available for <b>%s</b> in <b>remi-modular</b> repository</li><br />", $disp, $os); + + if ($dnf5) { // dnf v5 have minimal support for modularity https://bugzilla.redhat.com/2305955 + printf("<li>You have to enable the module stream for $php:"); + printf("<pre> dnf module reset php</pre>"); + printf("<pre> dnf module enable php:remi-%s</pre>", $php); + printf("</li><br />"); + + printf("<li>If no version is installed, command to <b>install</b> the php stream default profile:"); + printf("<pre> dnf install php-cli php-fpm php-mbstring php-xml</pre>"); + printf("</li><br />"); + + printf("<li>If an older version is installed, command to <b>upgrade</b> the php stack:"); + printf("<pre> dnf update</pre>"); + printf("</li><br />"); + + printf("<li>If an newer version is installed, command to <b>downgrade</b> the php stack:"); + printf("<pre> dnf downgrade php-common</pre>"); + printf("</li><br />"); + } else { + printf("<li>Command to enable the module stream for $php, if a version is already installed this will also upgrade/downgrade it:"); + printf("<pre> dnf module switch-to php:remi-%s</pre>", $php); + printf("</li><br />"); + + printf("<li>If no version is installed, command to <b>install</b> the php stream default profile:"); + printf("<pre> dnf module install php:remi-%s</pre>", $php); + printf("</li><br />"); + } + } else { + printf("<li>PHP version <b>%s</b> packages are available for <b>%s</b> in <b>%s</b> repository</li><br />", $disp, $os, $repo); printf("<li>Command to enable the repository:"); - } - if ($dist == 'Fedora') { - printf("<pre> dnf config-manager --set-enabled %s</pre></li><br />", $repo); - if ($mod) { - printf("<li>Command to disable the modular repository:"); - printf("<pre> dnf config-manager --set-disabled remi-modular</pre></li><br />"); - printf("<li>Alternatively, you may prefer the modern way, by to enabling the module stream for $php:"); - } - } else if ($yum == 'yum') { // EL-6, 7 - printf("<pre> yum-config-manager --enable %s</pre></li><br />", $repo); - printf("<li>If the <b>priorities</b> plugin is enabled, ensure %s have higher priority (a lower value) than %s</li><br />", $repo, ($dist == 'Fedora' ? 'fedora' : 'base and updates')); - } else { // EL-8, module only - printf("<li>You have to enable the module stream for $php:"); - } - if ($mod) { - printf("<pre> dnf module reset php"); - printf( "\n dnf module install php:remi-%s</pre>", $php); - printf("</li><br />"); - } + printf("<pre> yum-config-manager --disable 'remi-php*'"); + printf( "\n yum-config-manager --enable %s</pre></li><br />", $repo); - printf("<li>Command to upgrade (the repository only provides PHP):"); - printf("<pre> $yum update</pre>"); - printf("</li><br />"); + printf("<li>You can check the list of the enabled repositories:"); + printf("<pre> yum repolist</pre></li><br />"); + printf("<li>If the <b>priorities</b> plugin is enabled, ensure %s have higher priority (a lower value) than %s</li><br />", $repo, ($dist == 'Fedora' ? 'fedora' : 'base and updates')); + + printf("<li>If an old version is installed, command to <b>upgrade</b>:"); + printf("<pre> $yum update</pre>"); + printf("</li><br />"); - printf("<li>Command to install <b>additional</b> packages:"); + printf("<li>If no version is installed, command to <b>install</b> the php command:"); + printf("<pre> $yum install php-cli</pre>"); + printf("</li><br />"); + } + printf("<li>Command to install <b>additional</b> packages (xxx for SAPI or extension name):"); printf("<pre> $yum install php-xxx</pre>"); printf("</li><br />"); if (version_compare($php, '7.0', '>=')) { printf("<li>Command to install <b>testing</b> packages:"); - if ($dist != 'Fedora' && $mod) { - printf("<pre> $yum --enablerepo=remi-modular-test install php-xxx</pre>", $repo); - } else { - printf("<pre> $yum --enablerepo=%s-test install php-xxx</pre>", $repo); - } + printf("<pre> $yum --enablerepo=%s-test install php-xxx</pre>", $repo); printf("</li><br />"); } + if (isset($phptest[$php])) { + printf("<li>PHP version <b>%s</b> packages are available in the testing repository.", $phptest[$php]); + printf("</li><br />"); + } printf("<li>Command to check the installed version and available extensions:"); printf("<pre> php --version\n php --modules</pre>"); @@ -294,27 +439,32 @@ if ($php && $os && $type && !$err) { } else { printf("<li>You want <b>multiple versions </b> which means using a <a href='https://www.softwarecollections.org/en/'>Software Collection</a></li><br />"); $scl='php'.str_replace('.', '', $php); + + echo "<li><p><img src='info.png'> <b>Tips</b>: For Software Collection usage read: "; + echo "<a href='https://blog.remirepo.net/post/2022/02/17/My-PHP-Workstation'>My PHP Workstation</a></p><br /></li>"; if (version_compare($php, $osmax[$os], '>')) { - printf("<li>Sorry, but PHP version greater than <b>%s</b> are not available for <b>%s</b>.</li><br />", $osmax[$os], $os); + printf("<li>Sorry, but PHP version greater than <b>%s</b> are not available for <b>%s</b> (%s).</li><br />", $osmax[$os], $os, $arch); } else if (version_compare($php, $osmin[$os], '<')) { - printf("<li>Sorry, but PHP version older than <b>%s</b> are not available for <b>%s</b>.</li><br />", $osmin[$os], $os); + printf("<li>Sorry, but PHP version older than <b>%s</b> are not available for <b>%s</b> (%s).</li><br />", $osmin[$os], $os, $arch); } else { if (!$phpvers[$php]) { - printf("<li><b>WARNING</b>: PHP version <b>%s</b> is a <b>development</b> version, not ready for production.</li><br />", $php); + printf("<li><img src='alarm.png'> <b>WARNING</b>: PHP version <b>%s</b> is a <b>development</b> version, not ready for production.</li><br />", $php); } if ($dist=='Fedora') { - $repo = ($phpvers[$php] ? 'remi' : 'remi-test'); // Dev version + $repo = 'remi'; //($phpvers[$php] ? 'remi' : 'remi-test'); // Dev version - printf("<li>The <b>%s</b> collection is available in the <b>$repo</b> repository</li><br />", $scl); + printf("<li>Some common <b>dependencies</b> are available in <b>remi</b> repository, which need to be enabled"); + printf("<pre> dnf config-manager --set-enabled remi</pre></li><br />"); + printf("<li>The <b>%s</b> collection is available in the <b>$repo</b> repository, and provides PHP version <b>%s</b></li><br />", $scl, $disp); printf("<li>Command to install:"); - printf("<pre> $yum --enablerepo=$repo install %s</pre>", $scl); + printf("<pre> $yum install %s</pre>", $scl); printf("</li><br />"); printf("<li>Command to install additional packages:"); - printf("<pre> $yum --enablerepo=$repo install %s-php-xxx</pre>", $scl); + printf("<pre> $yum install %s-php-xxx</pre>", $scl); } else { - $repo = ($phpvers[$php] ? 'remi-safe' : 'remi-test'); // Dev version - $opt = ($phpvers[$php] ? '' : '--enablerepo=remi-test'); // Dev version + $repo = 'remi-safe'; //($phpvers[$php] ? 'remi-safe' : 'remi-test'); // Dev version + $opt = ""; //($phpvers[$php] ? '' : '--enablerepo=remi-test'); // Dev version printf("<li>The <b>%s</b> collection is available in the <b>$repo</b> repository</li><br />", $scl); printf("<li>Command to install:"); @@ -329,25 +479,33 @@ if ($php && $os && $type && !$err) { printf("<pre> $yum --enablerepo=remi-test install %s-php-xxx</pre>", $scl); printf("</li><br />"); } + if (isset($phptest[$php])) { + printf("<li>PHP version <b>%s</b> packages are available in the testing repository.", $phptest[$php]); + printf("</li><br />"); + } printf("<li>Command to check the installed version and available extensions:"); printf("<pre> %s --version\n %s --modules</pre>", $scl, $scl); printf("</li><br />"); + + printf("<li>When a single version is installed, command in default path (/usr/bin/php) can be installed:"); + printf("<pre> $yum install %s-syspaths</pre>", $scl); + printf("</li><br />"); } $counter++; @file_put_contents(COUNTER, "$counter\n"); } } else if (!$os) { - echo "<li><p>Please select the operating system you are running.</p></li>"; - echo "<li><p><b>Tips</b>: check the content of /etc/redhat-release.</p></li>"; + echo "<li><p><img src='question.png'> Please select the operating system you are running.</p></li>"; + echo "<li><p><img src='info.png'> <b>Tips</b>: check the content of /etc/redhat-release.</p></li>"; } else if (!$php) { - echo "<li><p>Please select PHP version you want to use.</p></li>"; - echo "<li><p><b>Tips</b>: read: <a href='https://www.php.net/supported-versions.php'>PHP Supported Versions</a></li>"; + echo "<li><p><img src='question.png'> Please select PHP version you want to use.</p></li>"; + echo "<li><p><img src='info.png'> <b>Tips</b>: read: <a href='https://www.php.net/supported-versions.php'>PHP Supported Versions</a></li>"; } else if (!$err) { - echo "<li><p>Please select installation type</p></li>"; - echo "<li><p><b>Tips</b>: read the <a href='https://blog.remirepo.net/pages/English-FAQ#scl'>FAQ</a></p></li>"; + echo "<li><p><img src='question.png'> Please select installation type</p></li>"; + echo "<li><p><img src='info.png'> <b>Tips</b>: read the <a href='https://blog.remirepo.net/pages/English-FAQ#scl'>FAQ</a></p></li>"; } ?> </ul> @@ -358,14 +516,16 @@ if ($php && $os && $type && !$err) { <ul class="levbarlist"> <li><a href="https://blog.remirepo.net/pages/Config-en" class="nlink" title="Repository configuration">Repository configuration</a></li> <li><a href="https://blog.remirepo.net/pages/English-FAQ" class="nlink" title="F.A.Q.">F.A.Q.</a></li> - <li><a href="https://forum.remirepo.net/" class="nlink" title="Forum">Forum</a></li> <li><a href="https://github.com/remicollet/remirepo/issues" class="nlink" title="Bug tracker">Bug tracker</a></li> - <li><a href="https://blog.remirepo.net/post/2012/09/03/remirepo-IRC-channel-on-freenode-network" class="nlink" title="IRC channel">IRC channel</a></li> + <li><a href="https://blog.remirepo.net/post/2021/05/20/remirepo-IRC-channel-on-Libera-network" class="nlink" title="IRC channel">IRC channel</a></li> <li><a href='https://twitter.com/RemiRepository'>Repository twitter account</a></li> - <li><?php - printf("<b>%d answers</b> given", $counter); + <li><a href='https://discord.gg/qwC6kM2dcE'>Discord server</a></li> +<!-- <li><?php + $day = (time() - mktime(0,0,0,12,8,2015)) / 86400; + $rate = $counter / $day; + printf("<b>%d answers</b> given since Dec 2015<br><b>%d answers</b> per day", $counter, $rate); ?></li> - </ul><br /><br /><br /> +--> </ul><br /><br /><br /> <form action="https://www.paypal.com/cgi-bin/webscr" method="post"><div> <input type="hidden" name="cmd" value="_s-xclick" /> <input type="hidden" name="encrypted" value="-----BEGIN PKCS7-----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-----END PKCS7----- diff --git a/wizard/info.png b/wizard/info.png Binary files differnew file mode 100644 index 00000000..6f2911d1 --- /dev/null +++ b/wizard/info.png diff --git a/wizard/notice.png b/wizard/notice.png Binary files differnew file mode 100644 index 00000000..44262883 --- /dev/null +++ b/wizard/notice.png diff --git a/wizard/question.png b/wizard/question.png Binary files differnew file mode 100644 index 00000000..69929d0b --- /dev/null +++ b/wizard/question.png |