!C99Shell v. 2.5 [PHP 8 Update] [24.05.2025]!

Software: Apache. PHP/8.1.30 

uname -a: Linux server1.tuhinhossain.com 5.15.0-151-generic #161-Ubuntu SMP Tue Jul 22 14:25:40 UTC
2025 x86_64
 

uid=1002(picotech) gid=1003(picotech) groups=1003(picotech),0(root)  

Safe-mode: OFF (not secure)

/home/picotech/domains/multirest.picotech.app/public_html/vendor/vlucas/phpdotenv/src/Parser/   drwxr-xr-x
Free 28.51 GB of 117.98 GB (24.16%)
Home    Back    Forward    UPDIR    Refresh    Search    Buffer    Encoder    Tools    Proc.    FTP brute    Sec.    SQL    PHP-code    Update    Self remove    Logout    


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

declare(strict_types=1);

namespace 
Dotenv\Parser;

use 
Dotenv\Util\Regex;
use 
Dotenv\Util\Str;
use 
GrahamCampbell\ResultType\Error;
use 
GrahamCampbell\ResultType\Result;
use 
GrahamCampbell\ResultType\Success;

final class 
EntryParser
{
    private const 
INITIAL_STATE 0;
    private const 
UNQUOTED_STATE 1;
    private const 
SINGLE_QUOTED_STATE 2;
    private const 
DOUBLE_QUOTED_STATE 3;
    private const 
ESCAPE_SEQUENCE_STATE 4;
    private const 
WHITESPACE_STATE 5;
    private const 
COMMENT_STATE 6;
    private const 
REJECT_STATES = [self::SINGLE_QUOTED_STATEself::DOUBLE_QUOTED_STATEself::ESCAPE_SEQUENCE_STATE];

    
/**
     * This class is a singleton.
     *
     * @codeCoverageIgnore
     *
     * @return void
     */
    
private function __construct()
    {
        
//
    
}

    
/**
     * Parse a raw entry into a proper entry.
     *
     * That is, turn a raw environment variable entry into a name and possibly
     * a value. We wrap the answer in a result type.
     *
     * @param string $entry
     *
     * @return \GrahamCampbell\ResultType\Result<\Dotenv\Parser\Entry,string>
     */
    
public static function parse(string $entry)
    {
        return 
self::splitStringIntoParts($entry)->flatMap(static function (array $parts) {
            [
$name$value] = $parts;

            return 
self::parseName($name)->flatMap(static function (string $name) use ($value) {
                
/** @var Result<Value|null,string> */
                
$parsedValue $value === null Success::create(null) : self::parseValue($value);

                return 
$parsedValue->map(static function (?Value $value) use ($name) {
                    return new 
Entry($name$value);
                });
            });
        });
    }

    
/**
     * Split the compound string into parts.
     *
     * @param string $line
     *
     * @return \GrahamCampbell\ResultType\Result<array{string,string|null},string>
     */
    
private static function splitStringIntoParts(string $line)
    {
        
/** @var array{string,string|null} */
        
$result Str::pos($line'=')->map(static function () use ($line) {
            return 
\array_map('trim'\explode('='$line2));
        })->
getOrElse([$linenull]);

        if (
$result[0] === '') {
            return 
Error::create(self::getErrorMessage('an unexpected equals'$line));
        }

        
/** @var \GrahamCampbell\ResultType\Result<array{string,string|null},string> */
        
return Success::create($result);
    }

    
/**
     * Parse the given variable name.
     *
     * That is, strip the optional quotes and leading "export" from the
     * variable name. We wrap the answer in a result type.
     *
     * @param string $name
     *
     * @return \GrahamCampbell\ResultType\Result<string,string>
     */
    
private static function parseName(string $name)
    {
        if (
Str::len($name) > && Str::substr($name06) === 'export' && \ctype_space(Str::substr($name61))) {
            
$name \ltrim(Str::substr($name6));
        }

        if (
self::isQuotedName($name)) {
            
$name Str::substr($name1, -1);
        }

        if (!
self::isValidName($name)) {
            return 
Error::create(self::getErrorMessage('an invalid name'$name));
        }

        return 
Success::create($name);
    }

    
/**
     * Is the given variable name quoted?
     *
     * @param string $name
     *
     * @return bool
     */
    
private static function isQuotedName(string $name)
    {
        if (
Str::len($name) < 3) {
            return 
false;
        }

        
$first Str::substr($name01);
        
$last Str::substr($name, -11);

        return (
$first === '"' && $last === '"') || ($first === '\'' && $last === '\'');
    }

    
/**
     * Is the given variable name valid?
     *
     * @param string $name
     *
     * @return bool
     */
    
private static function isValidName(string $name)
    {
        return 
Regex::matches('~\A[a-zA-Z0-9_.]+\z~'$name)->success()->getOrElse(false);
    }

    
/**
     * Parse the given variable value.
     *
     * This has the effect of stripping quotes and comments, dealing with
     * special characters, and locating nested variables, but not resolving
     * them. Formally, we run a finite state automaton with an output tape: a
     * transducer. We wrap the answer in a result type.
     *
     * @param string $value
     *
     * @return \GrahamCampbell\ResultType\Result<\Dotenv\Parser\Value,string>
     */
    
private static function parseValue(string $value)
    {
        if (
\trim($value) === '') {
            return 
Success::create(Value::blank());
        }

        return 
\array_reduce(\iterator_to_array(Lexer::lex($value)), static function (Result $datastring $token) {
            return 
$data->flatMap(static function (array $data) use ($token) {
                return 
self::processToken($data[1], $token)->map(static function (array $val) use ($data) {
                    return [
$data[0]->append($val[0], $val[1]), $val[2]];
                });
            });
        }, 
Success::create([Value::blank(), self::INITIAL_STATE]))->flatMap(static function (array $result) {
            if (
in_array($result[1], self::REJECT_STATEStrue)) {
                return 
Error::create('a missing closing quote');
            }

            return 
Success::create($result[0]);
        })->
mapError(static function (string $err) use ($value) {
            return 
self::getErrorMessage($err$value);
        });
    }

    
/**
     * Process the given token.
     *
     * @param int    $state
     * @param string $token
     *
     * @return \GrahamCampbell\ResultType\Result<array{string,bool,int},string>
     */
    
private static function processToken(int $statestring $token)
    {
        switch (
$state) {
            case 
self::INITIAL_STATE:
                if (
$token === '\'') {
                    
/** @var \GrahamCampbell\ResultType\Result<array{string,bool,int},string> */
                    
return Success::create([''falseself::SINGLE_QUOTED_STATE]);
                } elseif (
$token === '"') {
                    
/** @var \GrahamCampbell\ResultType\Result<array{string,bool,int},string> */
                    
return Success::create([''falseself::DOUBLE_QUOTED_STATE]);
                } elseif (
$token === '#') {
                    
/** @var \GrahamCampbell\ResultType\Result<array{string,bool,int},string> */
                    
return Success::create([''falseself::COMMENT_STATE]);
                } elseif (
$token === '$') {
                    
/** @var \GrahamCampbell\ResultType\Result<array{string,bool,int},string> */
                    
return Success::create([$tokentrueself::UNQUOTED_STATE]);
                } else {
                    
/** @var \GrahamCampbell\ResultType\Result<array{string,bool,int},string> */
                    
return Success::create([$tokenfalseself::UNQUOTED_STATE]);
                }
            case 
self::UNQUOTED_STATE:
                if (
$token === '#') {
                    
/** @var \GrahamCampbell\ResultType\Result<array{string,bool,int},string> */
                    
return Success::create([''falseself::COMMENT_STATE]);
                } elseif (
\ctype_space($token)) {
                    
/** @var \GrahamCampbell\ResultType\Result<array{string,bool,int},string> */
                    
return Success::create([''falseself::WHITESPACE_STATE]);
                } elseif (
$token === '$') {
                    
/** @var \GrahamCampbell\ResultType\Result<array{string,bool,int},string> */
                    
return Success::create([$tokentrueself::UNQUOTED_STATE]);
                } else {
                    
/** @var \GrahamCampbell\ResultType\Result<array{string,bool,int},string> */
                    
return Success::create([$tokenfalseself::UNQUOTED_STATE]);
                }
            case 
self::SINGLE_QUOTED_STATE:
                if (
$token === '\'') {
                    
/** @var \GrahamCampbell\ResultType\Result<array{string,bool,int},string> */
                    
return Success::create([''falseself::WHITESPACE_STATE]);
                } else {
                    
/** @var \GrahamCampbell\ResultType\Result<array{string,bool,int},string> */
                    
return Success::create([$tokenfalseself::SINGLE_QUOTED_STATE]);
                }
            case 
self::DOUBLE_QUOTED_STATE:
                if (
$token === '"') {
                    
/** @var \GrahamCampbell\ResultType\Result<array{string,bool,int},string> */
                    
return Success::create([''falseself::WHITESPACE_STATE]);
                } elseif (
$token === '\\') {
                    
/** @var \GrahamCampbell\ResultType\Result<array{string,bool,int},string> */
                    
return Success::create([''falseself::ESCAPE_SEQUENCE_STATE]);
                } elseif (
$token === '$') {
                    
/** @var \GrahamCampbell\ResultType\Result<array{string,bool,int},string> */
                    
return Success::create([$tokentrueself::DOUBLE_QUOTED_STATE]);
                } else {
                    
/** @var \GrahamCampbell\ResultType\Result<array{string,bool,int},string> */
                    
return Success::create([$tokenfalseself::DOUBLE_QUOTED_STATE]);
                }
            case 
self::ESCAPE_SEQUENCE_STATE:
                if (
$token === '"' || $token === '\\') {
                    
/** @var \GrahamCampbell\ResultType\Result<array{string,bool,int},string> */
                    
return Success::create([$tokenfalseself::DOUBLE_QUOTED_STATE]);
                } elseif (
$token === '$') {
                    
/** @var \GrahamCampbell\ResultType\Result<array{string,bool,int},string> */
                    
return Success::create([$tokenfalseself::DOUBLE_QUOTED_STATE]);
                } else {
                    
$first Str::substr($token01);
                    if (
\in_array($first, ['f''n''r''t''v'], true)) {
                        
/** @var \GrahamCampbell\ResultType\Result<array{string,bool,int},string> */
                        
return Success::create([\stripcslashes('\\'.$first).Str::substr($token1), falseself::DOUBLE_QUOTED_STATE]);
                    } else {
                        
/** @var \GrahamCampbell\ResultType\Result<array{string,bool,int},string> */
                        
return Error::create('an unexpected escape sequence');
                    }
                }
            case 
self::WHITESPACE_STATE:
                if (
$token === '#') {
                    
/** @var \GrahamCampbell\ResultType\Result<array{string,bool,int},string> */
                    
return Success::create([''falseself::COMMENT_STATE]);
                } elseif (!
\ctype_space($token)) {
                    
/** @var \GrahamCampbell\ResultType\Result<array{string,bool,int},string> */
                    
return Error::create('unexpected whitespace');
                } else {
                    
/** @var \GrahamCampbell\ResultType\Result<array{string,bool,int},string> */
                    
return Success::create([''falseself::WHITESPACE_STATE]);
                }
            case 
self::COMMENT_STATE:
                
/** @var \GrahamCampbell\ResultType\Result<array{string,bool,int},string> */
                
return Success::create([''falseself::COMMENT_STATE]);
            default:
                throw new 
\Error('Parser entered invalid state.');
        }
    }

    
/**
     * Generate a friendly error message.
     *
     * @param string $cause
     * @param string $subject
     *
     * @return string
     */
    
private static function getErrorMessage(string $causestring $subject)
    {
        return 
\sprintf(
            
'Encountered %s at [%s].',
            
$cause,
            
\strtok($subject"\n")
        );
    }
}

:: Command execute ::

Enter:
 
Select:
 

:: Search ::
  - regexp 

:: Upload ::
 
[ ok ]

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

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

--[ c99shell v. 2.5 [PHP 8 Update] [24.05.2025] | Generation time: 0.0079 ]--