!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)

/usr/local/webmail2/src/   drwxr-xr-x
Free 318.38 GB of 458.09 GB (69.5%)
Home    Back    Forward    UPDIR    Refresh    Search    Buffer    Encoder    Tools    Proc.    FTP brute    Sec.    SQL    PHP-code    Update    Feedback    Self remove    Logout    


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

/**
 * right_main.php
 *
 * This is where the mailboxes are listed. This controls most of what
 * goes on in SquirrelMail.
 *
 * @copyright &copy; 1999-2006 The SquirrelMail Project Team
 * @license http://opensource.org/licenses/gpl-license.php GNU Public License
 * @version $Id: right_main.php,v 1.146 2006/02/11 15:14:31 stekkel Exp $
 * @package squirrelmail
 */

/**
 * Path for SquirrelMail required files.
 * @ignore
 */
define('SM_PATH','../');

/* SquirrelMail required files. */
include_once(SM_PATH 'include/validate.php');
//include_once(SM_PATH . 'functions/global.php');
require_once(SM_PATH 'functions/imap.php');
require_once(
SM_PATH 'functions/date.php');
require_once(
SM_PATH 'functions/mime.php');
require_once(
SM_PATH 'functions/mailbox_display.php');
require_once(
SM_PATH 'functions/display_messages.php');
require_once(
SM_PATH 'functions/html.php');
//require_once(SM_PATH . 'functions/plugin.php');


// Trigger Developers to look at CSS ;)
// trigger_error("This layout sucks. Adapt squirrelmail.css!!!",E_USER_WARNING);
//sqm_trigger_imap_error('SQM_IMAP_NO_THREAD',"BLA1",'BAD', 'BLA2', array('test1'=>'test1'));

/* lets get the global vars we may need */
sqgetGlobalVar('key',       $key,           SQ_COOKIE);
sqgetGlobalVar('username',  $username,      SQ_SESSION);
sqgetGlobalVar('onetimepad',$onetimepad,    SQ_SESSION);
sqgetGlobalVar('delimiter'$delimiter,     SQ_SESSION);
sqgetGlobalVar('base_uri',  $base_uri,      SQ_SESSION);
sqgetGlobalVar('delayed_errors',  $delayed_errors,  SQ_SESSION);
if (
is_array($delayed_errors)) {
    
$oErrorHandler->AssignDelayedErrors($delayed_errors);
    
sqsession_unregister("delayed_errors");
}
sqgetGlobalVar('mailbox',   $mailbox);
sqgetGlobalVar('lastTargetMailbox'$lastTargetMailboxSQ_SESSION);
sqgetGlobalVar('targetMailbox'$lastTargetMailboxSQ_POST);
sqgetGlobalVar('note',              $note,              SQ_GET);
sqgetGlobalVar('mail_sent',         $mail_sent,         SQ_GET);


if ( 
sqgetGlobalVar('startMessage'$temp) ) {
    
$startMessage = (int) $temp;
} else {
    
$startMessage 1;
}
// sort => srt because of the changed behaviour which can break new behaviour
if ( sqgetGlobalVar('srt'$tempSQ_GET) ) {
    
$srt = (int) $temp;
}

if ( 
sqgetGlobalVar('showall'$tempSQ_GET) ) {
    
$showall = (int) $temp;
}

if ( 
sqgetGlobalVar('checkall'$tempSQ_GET) ) {
  
$checkall = (int) $temp;
}

/* future work */
if ( sqgetGlobalVar('account'$accountSQ_GET) ) {
  
$account = (int) $account;
} else {
  
$account 0;
}

/* end of get globals */


/* Open an imap connection */

$imapConnection sqimap_login($username$key$imapServerAddress$imapPort0);

$mailbox = (isset($mailbox) && $mailbox) ? $mailbox 'INBOX';

/* compensate for the UW vulnerability. */
if ($imap_server_type == 'uw' && (strstr($mailbox'../') ||
                                  
substr($mailbox01) == '/')) {
   
$mailbox 'INBOX';
}
/**
 * Set the global settings for a mailbox and merge them with the usersettings
 * for the mailbox. In the future we can add more mailbox specific preferences
 * preferences.
 */

$aMailboxPrefSer=getPref($data_dir$username,'pref_'.$account.'_'.$mailbox);
if (
$aMailboxPrefSer) {
    
$aMailboxPref unserialize($aMailboxPrefSer);
    
$aMailboxPref[MBX_PREF_COLUMNS] = $index_order// index_order contains the columns to show and the order of the columns
} else {
    
setUserPref($username,'pref_'.$account.'_'.$mailbox,serialize($default_mailbox_pref));
    
$aMailboxPref $default_mailbox_pref;
}
if (isset(
$srt)) {
    
$aMailboxPref[MBX_PREF_SORT] = (int) $srt;
}

$trash_folder = (isset($trash_folder)) ? $trash_folder false;
$sent_folder = (isset($sent_folder)) ? $sent_folder false;
$draft_folder = (isset($draft_folder)) ? $draft_folder false;


/**
 * until there is no per mailbox option screen to set prefs we override
 * the mailboxprefs by the default ones
 */
$aMailboxPref[MBX_PREF_LIMIT] = (int)  $show_num;
$aMailboxPref[MBX_PREF_AUTO_EXPUNGE] = (bool) $auto_expunge;
$aMailboxPref[MBX_PREF_INTERNALDATE] = (bool) getPref($data_dir$username'internal_date_sort');
$aMailboxPref[MBX_PREF_COLUMNS] = $index_order;

/**
 * Replace From => To  in case it concerns a draft or sent folder
 */
if (($mailbox == $sent_folder || $mailbox == $draft_folder) &&
    !
in_array(SQM_COL_TO,$aMailboxPref[MBX_PREF_COLUMNS])) {
    
$aNewOrder = array(); // nice var name ;)
    
foreach($aMailboxPref[MBX_PREF_COLUMNS] as $iCol) {
        if (
$iCol == SQM_COL_FROM) {
            
$iCol SQM_COL_TO;
        }
        
$aNewOrder[] = $iCol;
   }
   
$aMailboxPref[MBX_PREF_COLUMNS] = $aNewOrder;
   
setUserPref($username,'pref_'.$account.'_'.$mailbox,serialize($aMailboxPref));
}



/**
 * Set the config options for the messages list
 */
$aColumns = array(); // contains settings per column. Switch to key -> value based array, order is the order of the array keys
foreach ($aMailboxPref[MBX_PREF_COLUMNS] as $iCol) {
    
$aColumns[$iCol] = array();
    switch (
$iCol) {
        case 
SQM_COL_SUBJ:
            if (
$truncate_subject) {
                
$aColumns[$iCol]['truncate'] = $truncate_subject;
            }
            break;
        case 
SQM_COL_FROM:
        case 
SQM_COL_TO:
        case 
SQM_COL_CC:
        case 
SQM_COL_BCC:
            if (
$truncate_sender) {
                
$aColumns[$iCol]['truncate'] = $truncate_sender;
            }
            break;
   }
}

/**
 * Properties required by showMessagesForMailbox
 */
$aProps = array(
    
'columns' => $aColumns// columns bound settings
    
'config'  => array('alt_index_colors'       => $alt_index_colors,       // alternating row colors (should be a template thing)
                        
'highlight_list'        => $message_highlight_list// row highlighting rules
                        
'fancy_index_highlite'  => $fancy_index_highlite,   // highlight rows on hover or on click -> check
                        
'show_flag_buttons'     => (isset($show_flag_buttons)) ? $show_flag_buttons true,
                        
'lastTargetMailbox'     => (isset($lastTargetMailbox)) ? $lastTargetMailbox ''// last mailbox where messages are moved/copied to
                        
'trash_folder'          => $trash_folder,
                        
'sent_folder'           => $sent_folder,
                        
'draft_folder'          => $draft_folder,
                        
'color'                 => $color,
                        
'enablesort'            => true // enable sorting on columns
                
),
    
'mailbox' => $mailbox,
    
'account' => (isset($account)) ? $account 0// future usage if we support multiple imap accounts
    
'module' => 'read_body',
    
'email'  => false);


/**
 * system wide admin settings and incoming vars.
 */
$aConfig = array(
                
'user'              => $username,
                
// incoming vars
                
'offset' => $startMessage // offset in paginator
                
);
/**
 * The showall functionality is for the moment added to the config array
 * to avoid storage of the showall link in the mailbox pref. We could change
 * this behaviour later and add it to $aMailboxPref instead
 */
if (isset($showall)) {
    
$aConfig['showall'] = $showall// show all messages in a mailbox (paginator is disabled)
} else {
    
$showall false;
}


/**
 * Retrieve the mailbox cache from the session.
 */
sqgetGlobalVar('mailbox_cache',$mailbox_cache,SQ_SESSION);

/**
 * Select the mailbox and retrieve the cached info.
 */
$aMailbox sqm_api_mailbox_select($imapConnection,$account$mailbox,$aConfig,$aMailboxPref);

/**
 * MOVE THIS to a central init section !!!!
 */
if (!sqgetGlobalVar('align',$align,SQ_SESSION)) {
    
$dir = ( isset( $languages[$squirrelmail_language]['DIR']) ) ? $languages[$squirrelmail_language]['DIR'] : 'ltr';
    if ( 
$dir == 'ltr' ) {
        
$align = array('left' => 'left''right' => 'right');
    } else {
        
$align = array('left' => 'right''right' => 'left');
    }
    
sqsession_register($align'align');
}

/*
 * After initialisation of the mailbox array it's time to handle the FORM data
 */
$sError handleMessageListForm($imapConnection,$aMailbox);
if (
$sError) {
   
$note $sError;
}



/*
 * If we try to forward messages as attachment we have to open a new window
 * in case of compose in new window or redirect to compose.php
 */
if (isset($aMailbox['FORWARD_SESSION'])) {
    if (
$compose_new_win) {
        
/* add the mailbox to the cache */
        
$mailbox_cache[$account.'_'.$aMailbox['NAME']] = $aMailbox;
        
sqsession_register($mailbox_cache,'mailbox_cache');
        
// write the session in order to make sure that the compose window has
        // access to the composemessages array which is stored in the session
        
session_write_close();
        
// restart the session. Do not use sqsession_is_active because the session_id
        // isn't empty after a session_write_close
        
sqsession_start();
        if (!
preg_match("/^[0-9]{3,4}$/"$compose_width)) {
            
$compose_width '640';
        }
        if (!
preg_match("/^[0-9]{3,4}$/"$compose_height)) {
            
$compose_height '550';
        }
        
// do not use &amp;, it will break the query string and $session will not be detected!!!
        
$comp_uri SM_PATH 'src/compose.php?mailbox='urlencode($mailbox).
                    
'&session='.$aMailbox['FORWARD_SESSION'];
        
displayPageHeader($color$mailbox"comp_in_new('$comp_uri', $compose_width, $compose_height);"'');
    } else {
        
$mailbox_cache[$account.'_'.$aMailbox['NAME']] = $aMailbox;
        
sqsession_register($mailbox_cache,'mailbox_cache');

        
// save mailboxstate
        
sqsession_register($aMailbox,'aLastSelectedMailbox');
        
session_write_close();
        
// we have to redirect to the compose page
        
$location SM_PATH 'src/compose.php?mailbox='urlencode($mailbox).
                    
'&session='.$aMailbox['FORWARD_SESSION'];
        
header("Location: $location");
        exit;
    }
} else {
    
displayPageHeader($color$mailbox);
}

do_hook('right_main_after_header');

/* display a message to the user that their mail has been sent */
if (isset($mail_sent) && $mail_sent == 'yes') {
    
$note _("Your Message has been sent.");
}
if (isset(
$note)) {
    echo 
html_tag'div''<b>' htmlspecialchars($note) .'</b>''center' ) . "<br />\n";
}

if ( 
sqgetGlobalVar('just_logged_in'$just_logged_inSQ_SESSION) ) {
    if (
$just_logged_in == true) {
        
$just_logged_in false;
        
sqsession_register($just_logged_in'just_logged_in');

        if (
strlen(trim($motd)) > 0) {
            echo 
html_tag'table',
                        
html_tag'tr',
                            
html_tag'td',
                                
html_tag'table',
                                    
html_tag'tr',
                                        
html_tag'td'$motd'center' )
                                    ) ,
                                
''$color[4], 'width="100%" cellpadding="5" cellspacing="1" border="0"' )
                             )
                        ) ,
                    
'center'$color[9], 'width="70%" cellpadding="0" cellspacing="3" border="0"' );
        }
    }
}


if (
$aMailbox['EXISTS'] > 0) {
    
$aTemplateVars showMessagesForMailbox($imapConnection,$aMailbox,$aProps,$iError);
    if (
$iError) {

    }
    foreach (
$aTemplateVars as $k => $v) {
        
$oTemplate->assign($k$v);
    }

    
/*
     * TODO: To many config related vars. We should move all config related vars to
     * one single associative array and assign that to the template
     */
    
$oTemplate->assign('page_selector',  $page_selector);
    
$oTemplate->assign('page_selector_max'$page_selector_max);
    
$oTemplate->assign('compact_paginator'$compact_paginator);
    
$oTemplate->assign('javascript_on'$javascript_on);
    
$oTemplate->assign('enablesort', (isset($aProps['config']['enablesort'])) ? $aProps['config']['enablesort'] : false);
    
// Aaaaaahhhhhhh FIX ME DO NOT USE the string "none" for a var when you mean the boolean false or null
    
$oTemplate->assign('icon_theme', (isset($icon_theme) && $icon_theme !== 'none') ? $icon_theme false);
    
$oTemplate->assign('use_icons', (isset($use_icons)) ? $use_icons false);
    
$oTemplate->assign('aOrder'array_keys($aColumns));
    
$oTemplate->assign('alt_index_colors', isset($alt_index_colors) ? $alt_index_colorsfalse);
    
$oTemplate->assign('color'$color);
    
$oTemplate->assign('align'$align);

    
$oTemplate->display('message_list.tpl');

} else {
    
$string '<b>' _("THIS FOLDER IS EMPTY") . '</b>';
    echo 
'    <table width="100%" cellpadding="1" cellspacing="0" align="center" border="0" bgcolor="'.$color[9].'">';
    echo 
'     <tr><td>';
    echo 
'       <table width="100%" cellpadding="0" cellspacing="0" align="center" border="0" bgcolor="'.$color[4].'">';
    echo 
'        <tr><td><br />';
    echo 
'            <table cellpadding="1" cellspacing="5" align="center" border="0">';
    echo 
'              <tr>' html_tag'td'$string."\n"'left')
                        . 
'</tr>';
    echo 
'            </table>';
    echo 
'        <br /></td></tr>';
    echo 
'       </table></td></tr>';
    echo 
'    </table>';
}

do_hook('right_main_bottom');
sqimap_logout ($imapConnection);
$oTemplate->display('footer.tpl');


/* add the mailbox to the cache */
$mailbox_cache[$account.'_'.$aMailbox['NAME']] = $aMailbox;
sqsession_register($mailbox_cache,'mailbox_cache');
?>

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