!C99Shell v. 2.1 [PHP 8 Update] [02.02.2022]!

Software: Apache/2.4.53 (Unix) OpenSSL/1.1.1o PHP/7.4.29 mod_perl/2.0.12 Perl/v5.34.1. PHP/7.4.29 

uname -a: Linux vps-2738122-x 4.15.0-213-generic #224-Ubuntu SMP Mon Jun 19 13:30:12 UTC 2023 x86_64 

uid=1(daemon) gid=1(daemon) grupos=1(daemon) 

Safe-mode: OFF (not secure)

/opt/lampp/phpmyadmin/libraries/classes/ConfigStorage/   drwxr-xr-x
Free 15.57 GB of 61.93 GB (25.15%)
Home    Back    Forward    UPDIR    Refresh    Search    Buffer    Encoder    Tools    Proc.    FTP brute    Sec.    SQL    PHP-code    Update    Feedback    Self remove    Logout    


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

declare(strict_types=1);

namespace 
PhpMyAdmin\ConfigStorage;

use 
PhpMyAdmin\DatabaseInterface;
use 
PhpMyAdmin\Util;

/**
 * Set of functions used for cleaning up phpMyAdmin tables
 */
class RelationCleanup
{
    
/** @var Relation */
    
public $relation;

    
/** @var DatabaseInterface */
    
public $dbi;

    
/**
     * @param DatabaseInterface $dbi      DatabaseInterface object
     * @param Relation          $relation Relation object
     */
    
public function __construct($dbiRelation $relation)
    {
        
$this->dbi $dbi;
        
$this->relation $relation;
    }

    
/**
     * Cleanup column related relation stuff
     *
     * @param string $db     database name
     * @param string $table  table name
     * @param string $column column name
     */
    
public function column($db$table$column): void
    
{
        
$relationParameters $this->relation->getRelationParameters();

        if (
$relationParameters->columnCommentsFeature !== null) {
            
$remove_query 'DELETE FROM '
                
Util::backquote($relationParameters->columnCommentsFeature->database)
                . 
'.' Util::backquote($relationParameters->columnCommentsFeature->columnInfo)
                . 
' WHERE db_name  = \'' $this->dbi->escapeString($db) . '\''
                
' AND table_name = \'' $this->dbi->escapeString($table)
                . 
'\''
                
' AND column_name = \'' $this->dbi->escapeString($column)
                . 
'\'';
            
$this->dbi->queryAsControlUser($remove_query);
        }

        if (
$relationParameters->displayFeature !== null) {
            
$remove_query 'DELETE FROM '
                
Util::backquote($relationParameters->displayFeature->database)
                . 
'.' Util::backquote($relationParameters->displayFeature->tableInfo)
                . 
' WHERE db_name  = \'' $this->dbi->escapeString($db) . '\''
                
' AND table_name = \'' $this->dbi->escapeString($table)
                . 
'\''
                
' AND display_field = \'' $this->dbi->escapeString($column)
                . 
'\'';
            
$this->dbi->queryAsControlUser($remove_query);
        }

        if (
$relationParameters->relationFeature === null) {
            return;
        }

        
$remove_query 'DELETE FROM '
            
Util::backquote($relationParameters->relationFeature->database)
            . 
'.' Util::backquote($relationParameters->relationFeature->relation)
            . 
' WHERE master_db  = \'' $this->dbi->escapeString($db)
            . 
'\''
            
' AND master_table = \'' $this->dbi->escapeString($table)
            . 
'\''
            
' AND master_field = \'' $this->dbi->escapeString($column)
            . 
'\'';
        
$this->dbi->queryAsControlUser($remove_query);

        
$remove_query 'DELETE FROM '
            
Util::backquote($relationParameters->relationFeature->database)
            . 
'.' Util::backquote($relationParameters->relationFeature->relation)
            . 
' WHERE foreign_db  = \'' $this->dbi->escapeString($db)
            . 
'\''
            
' AND foreign_table = \'' $this->dbi->escapeString($table)
            . 
'\''
            
' AND foreign_field = \'' $this->dbi->escapeString($column)
            . 
'\'';
        
$this->dbi->queryAsControlUser($remove_query);
    }

    
/**
     * Cleanup table related relation stuff
     *
     * @param string $db    database name
     * @param string $table table name
     */
    
public function table($db$table): void
    
{
        
$relationParameters $this->relation->getRelationParameters();

        if (
$relationParameters->columnCommentsFeature !== null) {
            
$remove_query 'DELETE FROM '
                
Util::backquote($relationParameters->columnCommentsFeature->database)
                . 
'.' Util::backquote($relationParameters->columnCommentsFeature->columnInfo)
                . 
' WHERE db_name  = \'' $this->dbi->escapeString($db) . '\''
                
' AND table_name = \'' $this->dbi->escapeString($table)
                . 
'\'';
            
$this->dbi->queryAsControlUser($remove_query);
        }

        if (
$relationParameters->displayFeature !== null) {
            
$remove_query 'DELETE FROM '
                
Util::backquote($relationParameters->displayFeature->database)
                . 
'.' Util::backquote($relationParameters->displayFeature->tableInfo)
                . 
' WHERE db_name  = \'' $this->dbi->escapeString($db) . '\''
                
' AND table_name = \'' $this->dbi->escapeString($table)
                . 
'\'';
            
$this->dbi->queryAsControlUser($remove_query);
        }

        if (
$relationParameters->pdfFeature !== null) {
            
$remove_query 'DELETE FROM '
                
Util::backquote($relationParameters->pdfFeature->database)
                . 
'.' Util::backquote($relationParameters->pdfFeature->tableCoords)
                . 
' WHERE db_name  = \'' $this->dbi->escapeString($db) . '\''
                
' AND table_name = \'' $this->dbi->escapeString($table)
                . 
'\'';
            
$this->dbi->queryAsControlUser($remove_query);
        }

        if (
$relationParameters->relationFeature !== null) {
            
$remove_query 'DELETE FROM '
                
Util::backquote($relationParameters->relationFeature->database)
                . 
'.' Util::backquote($relationParameters->relationFeature->relation)
                . 
' WHERE master_db  = \'' $this->dbi->escapeString($db)
                . 
'\''
                
' AND master_table = \'' $this->dbi->escapeString($table)
                . 
'\'';
            
$this->dbi->queryAsControlUser($remove_query);

            
$remove_query 'DELETE FROM '
                
Util::backquote($relationParameters->relationFeature->database)
                . 
'.' Util::backquote($relationParameters->relationFeature->relation)
                . 
' WHERE foreign_db  = \'' $this->dbi->escapeString($db)
                . 
'\''
                
' AND foreign_table = \'' $this->dbi->escapeString($table)
                . 
'\'';
            
$this->dbi->queryAsControlUser($remove_query);
        }

        if (
$relationParameters->uiPreferencesFeature !== null) {
            
$remove_query 'DELETE FROM '
                
Util::backquote($relationParameters->uiPreferencesFeature->database)
                . 
'.' Util::backquote($relationParameters->uiPreferencesFeature->tableUiPrefs)
                . 
' WHERE db_name  = \'' $this->dbi->escapeString($db) . '\''
                
' AND table_name = \'' $this->dbi->escapeString($table)
                . 
'\'';
            
$this->dbi->queryAsControlUser($remove_query);
        }

        if (
$relationParameters->navigationItemsHidingFeature === null) {
            return;
        }

        
$remove_query 'DELETE FROM '
            
Util::backquote($relationParameters->navigationItemsHidingFeature->database)
            . 
'.' Util::backquote($relationParameters->navigationItemsHidingFeature->navigationHiding)
            . 
' WHERE db_name  = \'' $this->dbi->escapeString($db) . '\''
            
' AND (table_name = \'' $this->dbi->escapeString($table)
            . 
'\''
            
' OR (item_name = \'' $this->dbi->escapeString($table)
            . 
'\''
            
' AND item_type = \'table\'))';
        
$this->dbi->queryAsControlUser($remove_query);
    }

    
/**
     * Cleanup database related relation stuff
     *
     * @param string $db database name
     */
    
public function database($db): void
    
{
        
$relationParameters $this->relation->getRelationParameters();
        if (
$relationParameters->db === null) {
            return;
        }

        if (
$relationParameters->columnCommentsFeature !== null) {
            
$remove_query 'DELETE FROM '
                
Util::backquote($relationParameters->columnCommentsFeature->database)
                . 
'.' Util::backquote($relationParameters->columnCommentsFeature->columnInfo)
                . 
' WHERE db_name  = \'' $this->dbi->escapeString($db) . '\'';
            
$this->dbi->queryAsControlUser($remove_query);
        }

        if (
$relationParameters->bookmarkFeature !== null) {
            
$remove_query 'DELETE FROM '
                
Util::backquote($relationParameters->bookmarkFeature->database)
                . 
'.' Util::backquote($relationParameters->bookmarkFeature->bookmark)
                . 
' WHERE dbase  = \'' $this->dbi->escapeString($db) . '\'';
            
$this->dbi->queryAsControlUser($remove_query);
        }

        if (
$relationParameters->displayFeature !== null) {
            
$remove_query 'DELETE FROM '
                
Util::backquote($relationParameters->displayFeature->database)
                . 
'.' Util::backquote($relationParameters->displayFeature->tableInfo)
                . 
' WHERE db_name  = \'' $this->dbi->escapeString($db) . '\'';
            
$this->dbi->queryAsControlUser($remove_query);
        }

        if (
$relationParameters->pdfFeature !== null) {
            
$remove_query 'DELETE FROM '
                
Util::backquote($relationParameters->pdfFeature->database)
                . 
'.' Util::backquote($relationParameters->pdfFeature->pdfPages)
                . 
' WHERE db_name  = \'' $this->dbi->escapeString($db) . '\'';
            
$this->dbi->queryAsControlUser($remove_query);

            
$remove_query 'DELETE FROM '
                
Util::backquote($relationParameters->pdfFeature->database)
                . 
'.' Util::backquote($relationParameters->pdfFeature->tableCoords)
                . 
' WHERE db_name  = \'' $this->dbi->escapeString($db) . '\'';
            
$this->dbi->queryAsControlUser($remove_query);
        }

        if (
$relationParameters->relationFeature !== null) {
            
$remove_query 'DELETE FROM '
                
Util::backquote($relationParameters->relationFeature->database)
                . 
'.' Util::backquote($relationParameters->relationFeature->relation)
                . 
' WHERE master_db  = \''
                
$this->dbi->escapeString($db) . '\'';
            
$this->dbi->queryAsControlUser($remove_query);

            
$remove_query 'DELETE FROM '
                
Util::backquote($relationParameters->relationFeature->database)
                . 
'.' Util::backquote($relationParameters->relationFeature->relation)
                . 
' WHERE foreign_db  = \'' $this->dbi->escapeString($db)
                . 
'\'';
            
$this->dbi->queryAsControlUser($remove_query);
        }

        if (
$relationParameters->uiPreferencesFeature !== null) {
            
$remove_query 'DELETE FROM '
                
Util::backquote($relationParameters->uiPreferencesFeature->database)
                . 
'.' Util::backquote($relationParameters->uiPreferencesFeature->tableUiPrefs)
                . 
' WHERE db_name  = \'' $this->dbi->escapeString($db) . '\'';
            
$this->dbi->queryAsControlUser($remove_query);
        }

        if (
$relationParameters->navigationItemsHidingFeature !== null) {
            
$remove_query 'DELETE FROM '
                
Util::backquote($relationParameters->navigationItemsHidingFeature->database)
                . 
'.' Util::backquote($relationParameters->navigationItemsHidingFeature->navigationHiding)
                . 
' WHERE db_name  = \'' $this->dbi->escapeString($db) . '\'';
            
$this->dbi->queryAsControlUser($remove_query);
        }

        if (
$relationParameters->savedQueryByExampleSearchesFeature !== null) {
            
$remove_query 'DELETE FROM '
                
Util::backquote($relationParameters->savedQueryByExampleSearchesFeature->database)
                . 
'.' Util::backquote($relationParameters->savedQueryByExampleSearchesFeature->savedSearches)
                . 
' WHERE db_name  = \'' $this->dbi->escapeString($db) . '\'';
            
$this->dbi->queryAsControlUser($remove_query);
        }

        if (
$relationParameters->centralColumnsFeature === null) {
            return;
        }

        
$remove_query 'DELETE FROM '
            
Util::backquote($relationParameters->centralColumnsFeature->database)
            . 
'.' Util::backquote($relationParameters->centralColumnsFeature->centralColumns)
            . 
' WHERE db_name  = \'' $this->dbi->escapeString($db) . '\'';
        
$this->dbi->queryAsControlUser($remove_query);
    }

    
/**
     * Cleanup user related relation stuff
     *
     * @param string $username username
     */
    
public function user($username): void
    
{
        
$relationParameters $this->relation->getRelationParameters();
        if (
$relationParameters->db === null) {
            return;
        }

        if (
$relationParameters->bookmarkFeature !== null) {
            
$remove_query 'DELETE FROM '
                
Util::backquote($relationParameters->bookmarkFeature->database)
                . 
'.' Util::backquote($relationParameters->bookmarkFeature->bookmark)
                . 
" WHERE `user`  = '" $this->dbi->escapeString($username)
                . 
"'";
            
$this->dbi->queryAsControlUser($remove_query);
        }

        if (
$relationParameters->sqlHistoryFeature !== null) {
            
$remove_query 'DELETE FROM '
                
Util::backquote($relationParameters->sqlHistoryFeature->database)
                . 
'.' Util::backquote($relationParameters->sqlHistoryFeature->history)
                . 
" WHERE `username`  = '" $this->dbi->escapeString($username)
                . 
"'";
            
$this->dbi->queryAsControlUser($remove_query);
        }

        if (
$relationParameters->recentlyUsedTablesFeature !== null) {
            
$remove_query 'DELETE FROM '
                
Util::backquote($relationParameters->recentlyUsedTablesFeature->database)
                . 
'.' Util::backquote($relationParameters->recentlyUsedTablesFeature->recent)
                . 
" WHERE `username`  = '" $this->dbi->escapeString($username)
                . 
"'";
            
$this->dbi->queryAsControlUser($remove_query);
        }

        if (
$relationParameters->favoriteTablesFeature !== null) {
            
$remove_query 'DELETE FROM '
                
Util::backquote($relationParameters->favoriteTablesFeature->database)
                . 
'.' Util::backquote($relationParameters->favoriteTablesFeature->favorite)
                . 
" WHERE `username`  = '" $this->dbi->escapeString($username)
                . 
"'";
            
$this->dbi->queryAsControlUser($remove_query);
        }

        if (
$relationParameters->uiPreferencesFeature !== null) {
            
$remove_query 'DELETE FROM '
                
Util::backquote($relationParameters->uiPreferencesFeature->database)
                . 
'.' Util::backquote($relationParameters->uiPreferencesFeature->tableUiPrefs)
                . 
" WHERE `username`  = '" $this->dbi->escapeString($username)
                . 
"'";
            
$this->dbi->queryAsControlUser($remove_query);
        }

        if (
$relationParameters->userPreferencesFeature !== null) {
            
$remove_query 'DELETE FROM '
                
Util::backquote($relationParameters->userPreferencesFeature->database)
                . 
'.' Util::backquote($relationParameters->userPreferencesFeature->userConfig)
                . 
" WHERE `username`  = '" $this->dbi->escapeString($username)
                . 
"'";
            
$this->dbi->queryAsControlUser($remove_query);
        }

        if (
$relationParameters->configurableMenusFeature !== null) {
            
$remove_query 'DELETE FROM '
                
Util::backquote($relationParameters->configurableMenusFeature->database)
                . 
'.' Util::backquote($relationParameters->configurableMenusFeature->users)
                . 
" WHERE `username`  = '" $this->dbi->escapeString($username)
                . 
"'";
            
$this->dbi->queryAsControlUser($remove_query);
        }

        if (
$relationParameters->navigationItemsHidingFeature !== null) {
            
$remove_query 'DELETE FROM '
                
Util::backquote($relationParameters->navigationItemsHidingFeature->database)
                . 
'.' Util::backquote($relationParameters->navigationItemsHidingFeature->navigationHiding)
                . 
" WHERE `username`  = '" $this->dbi->escapeString($username)
                . 
"'";
            
$this->dbi->queryAsControlUser($remove_query);
        }

        if (
$relationParameters->savedQueryByExampleSearchesFeature !== null) {
            
$remove_query 'DELETE FROM '
                
Util::backquote($relationParameters->savedQueryByExampleSearchesFeature->database)
                . 
'.' Util::backquote($relationParameters->savedQueryByExampleSearchesFeature->savedSearches)
                . 
" WHERE `username`  = '" $this->dbi->escapeString($username)
                . 
"'";
            
$this->dbi->queryAsControlUser($remove_query);
        }

        if (
$relationParameters->databaseDesignerSettingsFeature === null) {
            return;
        }

        
$remove_query 'DELETE FROM '
            
Util::backquote($relationParameters->databaseDesignerSettingsFeature->database)
            . 
'.' Util::backquote($relationParameters->databaseDesignerSettingsFeature->designerSettings)
            . 
" WHERE `username`  = '" $this->dbi->escapeString($username)
            . 
"'";
        
$this->dbi->queryAsControlUser($remove_query);
    }
}

:: Command execute ::

Enter:
 
Select:
 

:: Search ::
  - regexp 

:: Upload ::
 
[ Read-Only ]

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

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

--[ c99shell v. 2.1 [PHP 8 Update] [02.02.2022] maintained byC99Shell Github | Generation time: 0.2865 ]--