!C99Shell v. 1.0 pre-release build #16!

Software: Apache/2.0.54 (Fedora). PHP/5.0.4 

uname -a: Linux mina-info.me 2.6.17-1.2142_FC4smp #1 SMP Tue Jul 11 22:57:02 EDT 2006 i686 

uid=48(apache) gid=48(apache) groups=48(apache)
context=system_u:system_r:httpd_sys_script_t
 

Safe-mode: OFF (not secure)

/home/mnnews/public_html/login/phpmyadmin/libraries/sql-parser/src/Components/   drwxr-xr-x
Free 1.91 GB of 27.03 GB (7.05%)
Home    Back    Forward    UPDIR    Refresh    Search    Buffer    Encoder    Tools    Proc.    FTP brute    Sec.    SQL    PHP-code    Update    Feedback    Self remove    Logout    


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

/**
* `INTO` keyword parser.
*
* @package    SqlParser
* @subpackage Components
*/
namespace SqlParserComponents;

use
SqlParserComponent;
use
SqlParserParser;
use
SqlParserToken;
use
SqlParserTokensList;

/**
* `INTO` keyword parser.
*
* @category   Keywords
* @package    SqlParser
* @subpackage Components
* @author     Dan Ungureanu <udan1107@gmail.com>
* @license    http://opensource.org/licenses/GPL-2.0 GNU Public License
*/
class IntoKeyword extends Component
{

    
/**
     * Type of target (OUTFILE or SYMBOL).
     *
     * @var string
     */
    
public $type;

    
/**
     * The destination, which can be a table or a file.
     *
     * @var string|Expression
     */
    
public $dest;

    
/**
     * The name of the columns.
     *
     * @var array
     */
    
public $columns;

    
/**
     * @param Parser     $parser  The parser that serves as context.
     * @param TokensList $list    The list of tokens that are being parsed.
     * @param array      $options Parameters for parsing.
     *
     * @return IntoKeyword
     */
    
public static function parse(Parser $parser, TokensList $list, array $options = array())
    {
        
$ret = new IntoKeyword();

        
/**
         * The state of the parser.
         *
         * Below are the states of the parser.
         *
         *      0 -----------------------[ name ]----------------------> 1
         *      0 ---------------------[ OUTFILE ]---------------------> 2
         *
         *      1 ------------------------[ ( ]------------------------> (END)
         *
         *      2 ---------------------[ filename ]--------------------> 1
         *
         * @var int $state
         */
        
$state = 0;

        for (;
$list->idx < $list->count; ++$list->idx) {

            
/**
             * Token parsed at this moment.
             *
             * @var Token $token
             */
            
$token = $list->tokens[$list->idx];

            
// End of statement.
            
if ($token->type === Token::TYPE_DELIMITER) {
                break;
            }

            
// Skipping whitespaces and comments.
            
if (($token->type === Token::TYPE_WHITESPACE) || ($token->type === Token::TYPE_COMMENT)) {
                continue;
            }

            if ((
$token->type === Token::TYPE_KEYWORD) && ($token->flags & Token::FLAG_KEYWORD_RESERVED)) {
                if ((
$state === 0) && ($token->value === 'OUTFILE')) {
                    
$ret->type = 'OUTFILE';
                    
$state = 2;
                    continue;
                }

                
// No other keyword is expected.
                
break;
            }

            if (
$state === 0) {
                
$ret->dest = Expression::parse(
                    
$parser,
                    
$list,
                    array(
                        
'noAlias' => true,
                        
'noBrackets' => true,
                        
'skipColumn' => true,
                    )
                );
                
$state = 1;
            } elseif (
$state === 1) {
                if ((
$token->type === Token::TYPE_OPERATOR) && ($token->value === '(')) {
                    
$ret->columns = ArrayObj::parse($parser, $list)->values;
                    ++
$list->idx;
                }
                break;
            } elseif (
$state === 2) {
                
$ret->dest = $token->value;
                ++
$list->idx;
                break;
            }
        }

        --
$list->idx;
        return
$ret;
    }

    
/**
     * @param IntoKeyword $component The component to be built.
     * @param array       $options   Parameters for building.
     *
     * @return string
     */
    
public static function build($component, array $options = array())
    {
        if (
$component->dest instanceof Expression) {
            
$columns = !empty($component->columns) ?
                
'(' . implode(', ', $component->columns) . ')' : '';
            return
$component->dest . $columns;
        } else {
            return
'OUTFILE "' . $component->dest . '"';
        }
    }
}

:: Command execute ::

Enter:
 
Select:
 

:: Search ::
  - regexp 

:: Upload ::
 
[ Read-Only ]

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

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

--[ c99shell v. 1.0 pre-release build #16 powered by Captain Crunch Security Team | http://ccteam.ru | Generation time: 0.0039 ]--