!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)

/home/ccl/vendor/illuminate/database/Query/Grammars/   drwxrwxr-x
Free 12.99 GB of 57.97 GB (22.42%)
Home    Back    Forward    UPDIR    Refresh    Search    Buffer    Encoder    Tools    Proc.    FTP brute    Sec.    SQL    PHP-code    Update    Self remove    Logout    


Viewing file:     MySqlGrammar.php (9.08 KB)      -rwxr-xr-x
Select action/file-type:
(+) | (+) | (+) | Code (+) | Session (+) | (+) | SDB (+) | (+) | (+) | (+) | (+) | (+) |
<?php

namespace Illuminate\Database\Query\Grammars;

use 
Illuminate\Support\Arr;
use 
Illuminate\Support\Str;
use 
Illuminate\Database\Query\Builder;
use 
Illuminate\Database\Query\JsonExpression;

class 
MySqlGrammar extends Grammar
{
    
/**
     * The components that make up a select clause.
     *
     * @var array
     */
    
protected $selectComponents = [
        
'aggregate',
        
'columns',
        
'from',
        
'joins',
        
'wheres',
        
'groups',
        
'havings',
        
'orders',
        
'limit',
        
'offset',
        
'lock',
    ];

    
/**
     * Compile a select query into SQL.
     *
     * @param  \Illuminate\Database\Query\Builder  $query
     * @return string
     */
    
public function compileSelect(Builder $query)
    {
        
$sql parent::compileSelect($query);

        if (
$query->unions) {
            
$sql '('.$sql.') '.$this->compileUnions($query);
        }

        return 
$sql;
    }

    
/**
     * Compile a single union statement.
     *
     * @param  array  $union
     * @return string
     */
    
protected function compileUnion(array $union)
    {
        
$conjuction $union['all'] ? ' union all ' ' union ';

        return 
$conjuction.'('.$union['query']->toSql().')';
    }

    
/**
     * Compile the random statement into SQL.
     *
     * @param  string  $seed
     * @return string
     */
    
public function compileRandom($seed)
    {
        return 
'RAND('.$seed.')';
    }

    
/**
     * Compile the lock into SQL.
     *
     * @param  \Illuminate\Database\Query\Builder  $query
     * @param  bool|string  $value
     * @return string
     */
    
protected function compileLock(Builder $query$value)
    {
        if (! 
is_string($value)) {
            return 
$value 'for update' 'lock in share mode';
        }

        return 
$value;
    }

    
/**
     * Compile an update statement into SQL.
     *
     * @param  \Illuminate\Database\Query\Builder  $query
     * @param  array  $values
     * @return string
     */
    
public function compileUpdate(Builder $query$values)
    {
        
$table $this->wrapTable($query->from);

        
// Each one of the columns in the update statements needs to be wrapped in the
        // keyword identifiers, also a place-holder needs to be created for each of
        // the values in the list of bindings so we can make the sets statements.
        
$columns $this->compileUpdateColumns($values);

        
// If the query has any "join" clauses, we will setup the joins on the builder
        // and compile them so we can attach them to this update, as update queries
        // can get join statements to attach to other tables when they're needed.
        
$joins '';

        if (isset(
$query->joins)) {
            
$joins ' '.$this->compileJoins($query$query->joins);
        }

        
// Of course, update queries may also be constrained by where clauses so we'll
        // need to compile the where clauses and attach it to the query so only the
        // intended records are updated by the SQL statements we generate to run.
        
$where $this->compileWheres($query);

        
$sql rtrim("update {$table}{$joins} set $columns $where");

        
// If the query has an order by clause we will compile it since MySQL supports
        // order bys on update statements. We'll compile them using the typical way
        // of compiling order bys. Then they will be appended to the SQL queries.
        
if (! empty($query->orders)) {
            
$sql .= ' '.$this->compileOrders($query$query->orders);
        }

        
// Updates on MySQL also supports "limits", which allow you to easily update a
        // single record very easily. This is not supported by all database engines
        // so we have customized this update compiler here in order to add it in.
        
if (isset($query->limit)) {
            
$sql .= ' '.$this->compileLimit($query$query->limit);
        }

        return 
rtrim($sql);
    }

    
/**
     * Compile all of the columns for an update statement.
     *
     * @param  array  $values
     * @return string
     */
    
protected function compileUpdateColumns($values)
    {
        return 
collect($values)->map(function ($value$key) {
            if (
$this->isJsonSelector($key)) {
                return 
$this->compileJsonUpdateColumn($key, new JsonExpression($value));
            }

            return 
$this->wrap($key).' = '.$this->parameter($value);
        })->
implode(', ');
    }

    
/**
     * Prepares a JSON column being updated using the JSON_SET function.
     *
     * @param  string  $key
     * @param  \Illuminate\Database\Query\JsonExpression  $value
     * @return string
     */
    
protected function compileJsonUpdateColumn($keyJsonExpression $value)
    {
        
$path explode('->'$key);

        
$field $this->wrapValue(array_shift($path));

        
$accessor "'$.\"".implode('"."'$path)."\"'";

        return 
"{$field} = json_set({$field}{$accessor}{$value->getValue()})";
    }

    
/**
     * Prepare the bindings for an update statement.
     *
     * Booleans, integers, and doubles are inserted into JSON updates as raw values.
     *
     * @param  array  $bindings
     * @param  array  $values
     * @return array
     */
    
public function prepareBindingsForUpdate(array $bindings, array $values)
    {
        
$values collect($values)->reject(function ($value$column) {
            return 
$this->isJsonSelector($column) &&
                
in_array(gettype($value), ['boolean''integer''double']);
        })->
all();

        return 
parent::prepareBindingsForUpdate($bindings$values);
    }

    
/**
     * Compile a delete statement into SQL.
     *
     * @param  \Illuminate\Database\Query\Builder  $query
     * @return string
     */
    
public function compileDelete(Builder $query)
    {
        
$table $this->wrapTable($query->from);

        
$where is_array($query->wheres) ? $this->compileWheres($query) : '';

        return isset(
$query->joins)
                    ? 
$this->compileDeleteWithJoins($query$table$where)
                    : 
$this->compileDeleteWithoutJoins($query$table$where);
    }

    
/**
     * Prepare the bindings for a delete statement.
     *
     * @param  array  $bindings
     * @return array
     */
    
public function prepareBindingsForDelete(array $bindings)
    {
        
$cleanBindings Arr::except($bindings, ['join''select']);

        return 
array_values(
            
array_merge($bindings['join'], Arr::flatten($cleanBindings))
        );
    }

    
/**
     * Compile a delete query that does not use joins.
     *
     * @param  \Illuminate\Database\Query\Builder  $query
     * @param  string  $table
     * @param  array  $where
     * @return string
     */
    
protected function compileDeleteWithoutJoins($query$table$where)
    {
        
$sql trim("delete from {$table} {$where}");

        
// When using MySQL, delete statements may contain order by statements and limits
        // so we will compile both of those here. Once we have finished compiling this
        // we will return the completed SQL statement so it will be executed for us.
        
if (! empty($query->orders)) {
            
$sql .= ' '.$this->compileOrders($query$query->orders);
        }

        if (isset(
$query->limit)) {
            
$sql .= ' '.$this->compileLimit($query$query->limit);
        }

        return 
$sql;
    }

    
/**
     * Compile a delete query that uses joins.
     *
     * @param  \Illuminate\Database\Query\Builder  $query
     * @param  string  $table
     * @param  array  $where
     * @return string
     */
    
protected function compileDeleteWithJoins($query$table$where)
    {
        
$joins ' '.$this->compileJoins($query$query->joins);

        
$alias strpos(strtolower($table), ' as ') !== false
                
explode(' as '$table)[1] : $table;

        return 
trim("delete {$alias} from {$table}{$joins} {$where}");
    }

    
/**
     * Wrap a single string in keyword identifiers.
     *
     * @param  string  $value
     * @return string
     */
    
protected function wrapValue($value)
    {
        if (
$value === '*') {
            return 
$value;
        }

        
// If the given value is a JSON selector we will wrap it differently than a
        // traditional value. We will need to split this path and wrap each part
        // wrapped, etc. Otherwise, we will simply wrap the value as a string.
        
if ($this->isJsonSelector($value)) {
            return 
$this->wrapJsonSelector($value);
        }

        return 
'`'.str_replace('`''``'$value).'`';
    }

    
/**
     * Wrap the given JSON selector.
     *
     * @param  string  $value
     * @return string
     */
    
protected function wrapJsonSelector($value)
    {
        
$path explode('->'$value);

        
$field $this->wrapValue(array_shift($path));

        return 
sprintf('%s->\'$.%s\''$fieldcollect($path)->map(function ($part) {
            return 
'"'.$part.'"';
        })->
implode('.'));
    }

    
/**
     * Determine if the given string is a JSON selector.
     *
     * @param  string  $value
     * @return bool
     */
    
protected function isJsonSelector($value)
    {
        return 
Str::contains($value'->');
    }
}

:: Command execute ::

Enter:
 
Select:
 

:: Search ::
  - regexp 

:: Upload ::
 
[ Read-Only ]

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

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

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