!C99Shell v. 2.1 [PHP 8 Update] [02.02.2022]!

Software: Apache/2.4.53 (Unix) OpenSSL/1.1.1o PHP/7.4.29 mod_perl/2.0.12 Perl/v5.34.1. PHP/7.4.29 

uname -a: Linux vps-2738122-x 4.15.0-213-generic #224-Ubuntu SMP Mon Jun 19 13:30:12 UTC 2023 x86_64 

uid=1(daemon) gid=1(daemon) grupos=1(daemon) 

Safe-mode: OFF (not secure)

/opt/lampp/phpmyadmin/libraries/classes/Controllers/Server/Variables/   drwxr-xr-x
Free 15.67 GB of 61.93 GB (25.31%)
Home    Back    Forward    UPDIR    Refresh    Search    Buffer    Encoder    Tools    Proc.    FTP brute    Sec.    SQL    PHP-code    Update    Feedback    Self remove    Logout    


Viewing file:     SetVariableController.php (4.15 KB)      -rw-r--r--
Select action/file-type:
(+) | (+) | (+) | Code (+) | Session (+) | (+) | SDB (+) | (+) | (+) | (+) | (+) | (+) |
<?php

declare(strict_types=1);

namespace 
PhpMyAdmin\Controllers\Server\Variables;

use 
PhpMyAdmin\Controllers\AbstractController;
use 
PhpMyAdmin\DatabaseInterface;
use 
PhpMyAdmin\Http\ServerRequest;
use 
PhpMyAdmin\Providers\ServerVariables\ServerVariablesProvider;
use 
PhpMyAdmin\ResponseRenderer;
use 
PhpMyAdmin\Template;
use 
PhpMyAdmin\Util;

use function 
__;
use function 
htmlspecialchars;
use function 
implode;
use function 
is_numeric;
use function 
mb_strtolower;
use function 
preg_match;
use function 
trim;

final class 
SetVariableController extends AbstractController
{
    
/** @var DatabaseInterface */
    
private $dbi;

    public function 
__construct(ResponseRenderer $responseTemplate $templateDatabaseInterface $dbi)
    {
        
parent::__construct($response$template);
        
$this->dbi $dbi;
    }

    
/**
     * Handle the AJAX request for setting value for a single variable
     *
     * @param array $vars Request parameters
     */
    
public function __invoke(ServerRequest $request, array $vars): void
    
{
        if (! 
$this->response->isAjax()) {
            return;
        }

        
$value = (string) $request->getParsedBodyParam('varValue');
        
$variableName = (string) $vars['name'];
        
$matches = [];
        
$variableType ServerVariablesProvider::getImplementation()->getVariableType($variableName);

        if (
            
$variableType === 'byte' && preg_match(
                
'/^\s*(\d+(\.\d+)?)\s*(mb|kb|mib|kib|gb|gib)\s*$/i',
                
$value,
                
$matches
            
)
        ) {
            
$exp = [
                
'kb' => 1,
                
'kib' => 1,
                
'mb' => 2,
                
'mib' => 2,
                
'gb' => 3,
                
'gib' => 3,
            ];
            
$value = (float) $matches[1] * 1024 ** $exp[mb_strtolower($matches[3])];
        } else {
            
$value $this->dbi->escapeString($value);
        }

        if (! 
is_numeric($value)) {
            
$value "'" $value "'";
        }

        
$json = [];
        if (! 
preg_match('/[^a-zA-Z0-9_]+/'$variableName)) {
            
$this->dbi->query('SET GLOBAL ' $variableName ' = ' $value);
            
// Some values are rounded down etc.
            
$varValue $this->dbi->fetchSingleRow(
                
'SHOW GLOBAL VARIABLES WHERE Variable_name="'
                
$this->dbi->escapeString($variableName)
                . 
'";',
                
DatabaseInterface::FETCH_NUM
            
);
            [
$formattedValue$isHtmlFormatted] = $this->formatVariable($variableName$varValue[1]);

            if (
$isHtmlFormatted === false) {
                
$json['variable'] = htmlspecialchars($formattedValue);
            } else {
                
$json['variable'] = $formattedValue;
            }
        } else {
            
$this->response->setRequestStatus(false);
            
$json['error'] = __('Setting variable failed');
        }

        
$this->response->addJSON($json);
    }

    
/**
     * Format Variable
     *
     * @param string     $name  variable name
     * @param int|string $value variable value
     *
     * @return array formatted string and bool if string is HTML formatted
     */
    
private function formatVariable($name$value): array
    {
        
$isHtmlFormatted false;
        
$formattedValue $value;

        if (
is_numeric($value)) {
            
$variableType ServerVariablesProvider::getImplementation()->getVariableType($name);

            if (
$variableType === 'byte') {
                
$isHtmlFormatted true;
                
/** @var string[] $bytes */
                
$bytes Util::formatByteDown($value33);
                
$formattedValue trim(
                    
$this->template->render(
                        
'server/variables/format_variable',
                        [
                            
'valueTitle' => Util::formatNumber($value0),
                            
'value' => implode(' '$bytes),
                        ]
                    )
                );
            } else {
                
$formattedValue Util::formatNumber($value0);
            }
        }

        return [
            
$formattedValue,
            
$isHtmlFormatted,
        ];
    }
}

:: Command execute ::

Enter:
 
Select:
 

:: Search ::
  - regexp 

:: Upload ::
 
[ Read-Only ]

:: Make Dir ::
 
[ Read-Only ]
:: Make File ::
 
[ Read-Only ]

:: Go Dir ::
 
:: Go File ::
 

--[ c99shell v. 2.1 [PHP 8 Update] [02.02.2022] maintained byC99Shell Github | Generation time: 0.4696 ]--