!C99Shell v.2.1 [PHP 7 Update] [1.12.2019]!

Software: Apache/2.4.6 (CentOS) OpenSSL/1.0.2k-fips PHP/5.4.16. PHP/5.4.16 

uname -a: Linux roko-bkp 3.10.0-1160.102.1.el7.x86_64 #1 SMP Tue Oct 17 15:42:21 UTC 2023 x86_64 

uid=48(apache) gid=48(apache) groups=48(apache),1003(webmaster) 

Safe-mode: OFF (not secure)

/var/www/html/site/ipanel/app/core/doctrine/Doctrine/Pager/   drwxr-xr-x
Free 9.26 GB of 93.48 GB (9.91%)
Home    Back    Forward    UPDIR    Refresh    Search    Buffer    Encoder    Tools    Proc.    FTP brute    Sec.    SQL    PHP-code    Update    Feedback    Self remove    Logout    


Viewing file:     Layout.php (14.54 KB)      -rwxr-xr-x
Select action/file-type:
(+) | (+) | (+) | Code (+) | Session (+) | (+) | SDB (+) | (+) | (+) | (+) | (+) | (+) |
<?php
/*
 *  $Id$
 *
 * THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS
 * "AS IS" AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT
 * LIMITED TO, THE IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR
 * A PARTICULAR PURPOSE ARE DISCLAIMED. IN NO EVENT SHALL THE COPYRIGHT
 * OWNER OR CONTRIBUTORS BE LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL,
 * SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT
 * LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS OF USE,
 * DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON ANY
 * THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT
 * (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE
 * OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE.
 *
 * This software consists of voluntary contributions made by many individuals
 * and is licensed under the LGPL. For more information, see
 * <http://www.phpdoctrine.org>.
 */

/**
 * Doctrine_Pager_Layout
 *
 * @author      Guilherme Blanco <guilhermeblanco@hotmail.com>
 * @package     Doctrine
 * @subpackage  Pager
 * @license     http://www.opensource.org/licenses/lgpl-license.php LGPL
 * @version     $Revision$
 * @link        www.phpdoctrine.org
 * @since       0.9
 */
class Doctrine_Pager_Layout
{
    
/**
     * @var Doctrine_Pager $_pager      Doctrine_Pager object related to the pager layout
     */
    
private $_pager;

    
/**
     * @var Doctrine_Pager_Range $_pagerRange      Doctrine_Pager_Range object related to the pager layout
     */
    
private $_pagerRange;

    
/**
     * @var string $_template      Template to be applied for inactive pages
     *                             (and also active is selected template is not defined)
     */
    
private $_template;

    
/**
     * @var string $_selectedTemplate     Template to be applied for active page
     */
    
private $_selectedTemplate;

    
/**
     * @var string $_separatorTemplate     Separator template, applied between each page
     */
    
private $_separatorTemplate;

    
/**
     * @var string $_urlMask      URL to be assigned for each page. Masks are used as: {%var_name}
     */
    
private $_urlMask;
    
    
/**
     * @var array $_maskReplacements      Stores references of masks and their correspondent 
     *                                    (replaces defined masks with new masks or values)
     */
    
private $_maskReplacements = array();


    
/**
     * __construct
     *
     * @param Doctrine_Pager $pager     Doctrine_Pager object related to the pager layout
     * @param Doctrine_Pager_Range $pagerRange     Doctrine_Pager_Range object related to the pager layout
     * @param string $urlMask     URL to be assigned for each page
     * @return void
     */
    
public function __construct($pager$pagerRange$urlMask)
    {
        
$this->_setPager($pager);
        
$this->_setPagerRange($pagerRange);
        
$this->_setUrlMask($urlMask);

        
$this->setTemplate('[<a href="{%url}">{%page}</a>]');
        
$this->setSelectedTemplate('');
        
$this->setSeparatorTemplate('');
    }

    
/**
     * getPager
     *
     * Returns the Doctrine_Pager object related to the pager layout
     *
     * @return Doctrine_Pager        Doctrine_Pager object related to the pager range
     */
    
public function getPager()
    {
        return 
$this->_pager;
    }

    
/**
     * _setPager
     *
     * Defines the Doctrine_Pager object related to the pager layout
     *
     * @param $pager       Doctrine_Pager object related to the pager range
     * @return void
     */
    
protected function _setPager($pager)
    {
        
$this->_pager $pager;
    }

    
/**
     * execute
     *
     * Handy method to execute the query without need to retrieve the Pager instance
     *
     * @param $params               Optional parameters to Doctrine_Query::execute
     * @param $hydrationMode        Hydration Mode of Doctrine_Query::execute returned ResultSet.
     * @return Doctrine_Collection  The root collection
     */
    
public function execute($params = array(), $hydrationMode null)
    {
        return 
$this->getPager()->execute($params$hydrationMode);
    }

    
/**
     * getPagerRange
     *
     * Returns the Doctrine_Pager_Range subclass object related to the pager layout
     *
     * @return Doctrine_Pager_Range        Doctrine_Pager_Range subclass object related to the pager range
     */
    
public function getPagerRange()
    {
        return 
$this->_pagerRange;
    }

    
/**
     * _setPagerRange
     *
     * Defines the Doctrine_Pager_Range subclass object related to the pager layout
     *
     * @param $pagerRange       Doctrine_Pager_Range subclass object related to the pager range
     * @return void
     */
    
protected function _setPagerRange($pagerRange)
    {
        
$this->_pagerRange $pagerRange;
        
$this->getPagerRange()->setPager($this->getPager());
    }

    
/**
     * getUrlMask
     *
     * Returns the URL to be assigned for each page
     *
     * @return string        URL to be assigned for each page
     */
    
public function getUrlMask()
    {
        return 
$this->_urlMask;
    }

    
/**
     * _setUrlMask
     *
     * Defines the URL to be assigned for each page
     *
     * @param $urlMask       URL to be assigned for each page
     * @return void
     */
    
protected function _setUrlMask($urlMask)
    {
        
$this->_urlMask $urlMask;
    }


     
/**
     * getTemplate
     *
     * Returns the Template to be applied for inactive pages
     *
     * @return string        Template to be applied for inactive pages
     */
    
public function getTemplate()
    {
        return 
$this->_template;
    }

    
/**
     * setTemplate
     *
     * Defines the Template to be applied for inactive pages 
     * (also active page if selected template not defined)
     *
     * @param $template       Template to be applied for inactive pages
     * @return void
     */
    
public function setTemplate($template)
    {
        
$this->_template $template;
    }

    
/**
     * getSelectedTemplate
     *
     * Returns the Template to be applied for active page
     *
     * @return string        Template to be applied for active page
     */
    
public function getSelectedTemplate()
    {
        return 
$this->_selectedTemplate;
    }

    
/**
     * setSelectedTemplate
     *
     * Defines the Template to be applied for active page
     *
     * @param $selectedTemplate       Template to be applied for active page
     * @return void
     */
    
public function setSelectedTemplate($selectedTemplate)
    {
        
$this->_selectedTemplate $selectedTemplate;
    }

    
/**
     * getSeparatorTemplate
     *
     * Returns the Separator template, applied between each page
     *
     * @return string        Separator template, applied between each page
     */
    
public function getSeparatorTemplate()
    {
        return 
$this->_separatorTemplate;
    }

    
/**
     * setSeparatorTemplate
     *
     * Defines the Separator template, applied between each page
     *
     * @param $separatorTemplate       Separator template, applied between each page
     * @return void
     */ 
    
public function setSeparatorTemplate($separatorTemplate)
    {
        
$this->_separatorTemplate $separatorTemplate;
    }

    
/**
     * addMaskReplacement
     *
     * Defines a mask replacement. When parsing template, it converts replacement
     * masks into new ones (or values), allowing to change masks behavior on the fly
     *
     * @param $oldMask       Mask to be replaced
     * @param $newMask       Mask or Value that will be defined after replacement
     * @param $asValue       Optional value (default false) that if defined as true,
     *                       changes the bahavior of replacement mask to replacement
     *                       value
     * @return void
     */ 
    
public function addMaskReplacement($oldMask$newMask$asValue false)
    {
        if ((
$oldMask trim($oldMask)) != 'page_number') {
            
$this->_maskReplacements[$oldMask] = array(
                
'newMask' => $newMask,
                
'asValue' => ($asValue === false) ? false true
            
);
        }
    }

    
/**
     * removeMaskReplacement
     *
     * Remove a mask replacement
     *
     * @param $oldMask       Replacement Mask to be removed
     * @return void
     */ 
    
public function removeMaskReplacement($oldMask)
    {
        if (isset(
$this->_maskReplacements[$oldMask])) {
            
$this->_maskReplacements[$oldMask] = null;
            unset(
$this->_maskReplacements[$oldMask]);
        }
    }
    
    
    
/**
     * cleanMaskReplacements
     *
     * Remove all mask replacements
     *
     * @return void
     */ 
    
public function cleanMaskReplacements()
    {
        
$this->_maskReplacements null;
        
$this->_maskReplacements = array();
    }

    
/**
     * display
     *
     * Displays the pager on screen based on templates and options defined
     *
     * @param $options    Optional parameters to be applied in template and url mask
     * @param $return     Optional parameter if you want to capture the output of this method call 
     *                    (Default value is false), instead of printing it
     * @return void       If you would like to capture the output of Doctrine_Pager_Layout::display(),
     *                    use the $return  parameter. If this parameter is set to TRUE, this method 
     *                    will return its output, instead of printing it (which it does by default)
     */
    
public function display($options = array(), $return false)
    {
        
$range $this->getPagerRange()->rangeAroundPage();
        
$str '';

        
// For each page in range
        
for ($i 0$l count($range); $i $l$i++) {
            
// Define some optional mask values
            
$options['page_number'] = $range[$i];

            
$str .= $this->processPage($options);

            
// Apply separator between pages
            
if ($i $l 1) {
                
$str .= $this->getSeparatorTemplate();
            }
        }

        
// Possible wish to return value instead of print it on screen
        
if ($return) {
            return 
$str;
        }

        echo 
$str;
    }

    
/**
     * processPage
     *
     * Parses the template and returns the string of a processed page
     *
     * @param array    Optional parameters to be applied in template and url mask
     * @return string  Processed template for the given page
     */
    
public function processPage($options = array())
    {
        
// Check if at least basic options are defined
        
if ( !isset($options['page_number'])) {
            throw new 
Doctrine_Pager_Exception(
                
'Cannot process template of the given page. ' .
                
'Missing at least one of needed parameters: \'page\' or \'page_number\''
            
);

            
// Should never reach here
            
return '';
        }

        
// Assign "page" options index if not defined yet
        
if ( !isset($this->_maskReplacements['page']) && !isset($options['page'])) {
            
$options['page'] = $options['page_number'];
        }

        return 
$this->_parseTemplate($options);
    }

    
/**
     * Simply calls display, and returns the output.
     */
    
public function __toString()
    {
      return 
$this->display(array(), true);
    }

    
/**
     * _parseTemplate
     *
     * Parse the template of a given page and return the processed template
     *
     * @param array    Optional parameters to be applied in template and url mask
     * @return string  
     */
    
protected function _parseTemplate($options = array())
    {
        
$str $this->_parseUrlTemplate($options);
        
$replacements $this->_parseReplacementsTemplate($options);

        return 
strtr($str$replacements);
    }

    
/**
     * _parseUrlTemplate
     *
     * Parse the url mask to return the correct template depending of the options sent.
     * Already process the mask replacements assigned.
     *
     * @param $options    Optional parameters to be applied in template and url mask
     * @return string
     */
    
protected function _parseUrlTemplate($options = array())
    {
        
$str '';

        
// If given page is the current active one
        
if ($options['page_number'] == $this->getPager()->getPage()) {
            
$str $this->_parseMaskReplacements($this->getSelectedTemplate());
        }

        
// Possible attempt where Selected == Template
        
if ($str == '') {
            
$str $this->_parseMaskReplacements($this->getTemplate());
        }

        return 
$str;
    }

    
/**
     * _parseUrl
     *
     * Parse the mask replacements of a given page
     *
     * @param $options    Optional parameters to be applied in template and url mask
     * @return string
     */
    
protected function _parseReplacementsTemplate($options = array())
    {
        
// Defining "url" options index to allow {%url} mask
        
$options['url'] = $this->_parseUrl($options);

        
$replacements = array();

        foreach (
$options as $k => $v) {
            
$replacements['{%'.$k.'}'] = $v;
        }

        return 
$replacements;
    }

    
/**
     * _parseUrl
     *
     * Parse the url mask of a given page and return the processed url
     *
     * @param $options    Optional parameters to be applied in template and url mask
     * @return string
     */
    
protected function _parseUrl($options = array())
    {
        
$str $this->_parseMaskReplacements($this->getUrlMask());

        
$replacements = array();

        foreach (
$options as $k => $v) {
            
$replacements['{%'.$k.'}'] = $v;
        }

        return 
strtr($str$replacements);
    }

    
/**
     * _parseMaskReplacements
     *
     * Parse the mask replacements, changing from to-be replaced mask with new masks/values
     *
     * @param $str    String to have masks replaced
     * @return string  
     */
    
protected function _parseMaskReplacements($str)
    {
        
$replacements = array();

        foreach (
$this->_maskReplacements as $k => $v) {
            
$replacements['{%'.$k.'}'] = ($v['asValue'] === true) ? $v['newMask'] : '{%'.$v['newMask'].'}';
        }

        return 
strtr($str$replacements);
    }
}

:: 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 7 Update] [1.12.2019] maintained by KaizenLouie and updated by cermmik | C99Shell Github (MySQL update) | Generation time: 0.0046 ]--