Go Back   vb.org Archive > vBulletin Modifications > Archive > vB.org Archives > General > Member Archives
I don't know what hack messed it up Details »»
I don't know what hack messed it up
Version: , by bonnmac bonnmac is offline
Developer Last Online: Mar 2006 Show Printable Version Email this Page

Version: Unknown Rating:
Released: 05-13-2002 Last Update: Never Installs: 0
 
No support by the author.

Okay I've installed about 19 hacks so far and nothing went wrong till now.... The last hack that I had to edit this file was
"11 - vB v2.2.3- Away message for users" Now every thing works hack wise. My problem is when you send a "private message" it doesn't redirect you back to the board. It just takes you to a blank white screen. your PM gets sent but then you have to go up into explorer bar and back out of private.php.... I've included my "private.php" file hoping maybe someone can tell me what's wrong. Thanks a bunch.







PHP Code:
<?php
error_reporting
(7);

// enhanced
// received mass-forward action -> work out what to do with it
if ($action=="dostuff" && $fmulti!="") {
  if (!
is_array($HTTP_POST_VARS['privatemessage'])) {
    
// no selected messages: go to normal dostuff action and get error
    
$move="yes";
  } elseif (
count($HTTP_POST_VARS[privatemessage])==1) {
    
// only one message selected: use standard PM forwarding page
    
$action "newmessage";
    
$forward true;
    
$privatemessageid key($HTTP_POST_VARS[privatemessage]);
  } else {
    
// multiple messages selected: build URL and redirect to private2.php
    
$urlstring '';
    while (list(
$key,) = each ($HTTP_POST_VARS[privatemessage])) $urlstring .= "&m[$key]=1";
      
header("Location: private2.php?s=$s&action=fmulti".$urlstring);
    exit;
  }
}

// intercept request for read receipts page and redirect
if ($folderid=="tracking") {
  
header("Location: private2.php?s=$s");
  exit;
}
// /enhanced

$templatesused "usercpnav,privfolder_bit,privfolder_messages,privfolder_nomessages,privfolder,postbit_avatar,postbit_useremail,icq,aim,yahoo,postbit_homepage,postbit_profile,postbit_signature,privmsg,priv_reply,priv_sendprivmsg,redirect_pmthanks,redirect_pmdelete,priv_showfolders_folderbit,priv_showfolders,posticons,posticonbit";
$templatesused .= ",vbcode_smilies,vbcode_smiliebit,vbcode_smilies_getmore,vbcode_buttons,vbcode_sizebits,vbcode_fontbits,vbcode_colorbits";
// enhanced
// templates for new PM functionality
$templatesused .= ",priv_readreceiptsoption,priv_dateselect,privfolder_deletedbit,privfolder_denyreceipt,priv_senttomultiple,priv_requestreceipt,priv_buddymasspmlink,privfolder_massforward,priv_readreceiptslink,";
// /enhanced
require("./global.php");

// get decent textarea size for user's browser
$textareacols gettextareawidth();

// select correct part of FORUMJUMP menu
$frmjmpsel[pm] = "selected";

// ###################### Start pmcodeparse #######################
function pmcodeparse($bbcode) {
  global 
$privallowhtml$privallowbbimagecode$privallowsmilies$privallowbbcode;
  
$bbcode=bbcodeparse2($bbcode,$privallowhtml,$privallowbbimagecode,$privallowsmilies,$privallowbbcode1);
  return 
$bbcode;
}

if (!isset(
$action) or $action=="") {
  
$action="getfolder";
}

if (
$enablepms==0) {
  eval(
"standarderror(\"".gettemplate("error_pmadminoff")."\");");
  exit;
}

//check usergroup of user to see if they can use PMs
$permissions=getpermissions($forumid);
if (!
$permissions[canusepm]) {
  
show_nopermission();
}

//check if the user will receive PMs
if (!$bbuserinfo[receivepm]) {
  eval(
"standarderror(\"".gettemplate("error_pmturnedoff")."\");");
  exit;
}

$folderselect = array();
function 
makefolderjump() {
  global 
$bbuserinfo,$folderid,$folderselect;
  
  
$folderjump '';

  
// enhanced
  
if ($folderid==-1$folderselect[$sent] = "selected";
  
// /enhanced

  //get all folder names (for dropdown)
  //reference with $foldernames[#] .

  
if ($bbuserinfo[pmfolders]) {
    
$allfolders explode("\n"trim($bbuserinfo[pmfolders]));
    while (list(
$key,$val)=each($allfolders)) {
      
$thisfolder explode("|||"$val);
      
// enhanced
      
$thisfolderid $thisfolder[0]+1;
      
// /enhanced
      
$folderjump .= "<option value=\"$thisfolderid\" $folderselect[$thisfolderid]>$thisfolder[1]</option>";
    }
  }

  return 
$folderjump;

#end makefolderjump

// draw cp nav bar
$cpnav = array();
$cpmenu = array();
$cpnav[1]="#DFDFDF";
$cpnav[2]="#DFDFDF";
$cpnav[3]="#DFDFDF";
$cpnav[4]="#DFDFDF";
$cpnav[5]="#DFDFDF";
$cpnav[6]="#DFDFDF";
$cpnav[7]="#F1F1F1";
    
$cpmenu[7]="class=\"fjsel\" selected";
eval(
"\$cpnav = \"".gettemplate("usercpnav")."\";");

// ############################### start get folder ###############################
if ($action=="getfolder") {

    
$privatemessages '';

  
// enhanced
  // templates based on permissions
  
if ($permissions[maxbuddypm]) {
    eval(
"\$buddypmlink = \"".gettemplate("priv_buddymasspmlink")."\";");
  } else {
       
$buddypmlink '';
  }
  if (
$permissions[maxforwardpm]) {
    eval(
"\$massforwardlink = \"".gettemplate("privfolder_massforward")."\";");
  } else {
       
$massforwardlink '';
  }
  if (
$permissions[cantrackpm]) {
       eval(
"\$readreceiptsoption = \"".gettemplate("priv_readreceiptsoption")."\";");
    eval(
"\$readreceiptslink = \"".gettemplate("priv_readreceiptslink")."\";");
  } else {
       
$readreceiptsoption '';
     
$readreceiptslink '';
  }
  
// generate days prune sql condition
  
if (!$daysprune) {
    if (
$bbuserinfo[daysprune] == -1) {
      
$daysprune "all";
    } else {
      
$daysprune $bbuserinfo[daysprune];
    }
  }

  if (
$daysprune != "all") {
    
$daysprune_days $daysprune 86400;
    
$dateconds "AND dateline >= ".(time()-$daysprune_days);
  } else {
    
$daysprune_days 0;
    
$dateconds "";
    
$daysprune 1000;
  }

  
// get date select menu
  
$daysprunesel = array();
  
$daysprunesel[$daysprune] = "selected";
  eval(
"\$priv_dateselect = \"".gettemplate("priv_dateselect")."\";");
  
// /enhanced

  
if ($folderid==-1) { //Need to move out for translation
    
$sender "Sent To";
  } else {
    
$sender "Sender";
  }

  
$folderid intval($folderid);
  if (!
$folderid) {
    
$folderid 0;
  }

  
$foldernames = array();
  if (
$bbuserinfo[pmfolders]) {
    
$allfolders split("\n"trim($bbuserinfo[pmfolders]));
    while (list(
$key,$val)=each($allfolders)) {
      
$thisfolder split("\|\|\|"$val);
      
$foldernames[($thisfolder[0]+1)] = $thisfolder[1];
    }
  }

  
//get correct folder name
  
if ($folderid=="0") {
    
$foldername $inboxname;
  } elseif (
$folderid=="-1") {
    
$foldername $sentitemsname;
  } else {
    
$foldername $foldernames[$folderid];
  }

  
$messagedone=0;

  if (
trim($bbuserinfo[ignorelist])!="") {
    
$ignoreusers="AND privatemessage.fromuserid<>".implode(" AND privatemessage.fromuserid<>",explode(" ",trim($bbuserinfo[ignorelist])));
  } else {
    
$ignoreusers="";
  }

  
// enhanced - add $dateconds to query
  
$messages $DB_site->query("SELECT
  privatemessage.*,
  IF(ISNULL(touser.username),'[Deleted User]',touser.username) AS tousername,
  IF(ISNULL(fromuser.username),'[Deleted User]',fromuser.username) AS fromusername,
  icon.title AS icontitle,icon.iconpath
  FROM privatemessage
  LEFT JOIN icon ON icon.iconid=privatemessage.iconid
  LEFT JOIN user AS touser ON (touser.userid=privatemessage.touserid)
  LEFT JOIN user AS fromuser ON (fromuser.userid=privatemessage.fromuserid)
  WHERE privatemessage.userid='
$bbuserinfo[userid]'
  AND folderid='"
.intval($folderid)."'
  
$ignoreusers
  
$dateconds
  ORDER BY dateline DESC"
);
  
  
$privmsgsbit '';
  while (
$privatemessage=$DB_site->fetch_array($messages)) {

    
// get the more useful of the to/from field
    
if ($privatemessage[touserid]==$bbuserinfo[userid]) {
      
$privatemessage[displayuserid]=$privatemessage[fromuserid];
      
$privatemessage[displayusername]=$privatemessage[fromusername];
    } else {
      
$privatemessage[displayuserid]=$privatemessage[touserid];
      
$privatemessage[displayusername]=$privatemessage[tousername];
    }

    if (
$privatemessage['displayuserid']=="") {
      
$privatemessage['displayusername'] = "N/A";
    }

    
$privatemessage[datesent]=vbdate($dateformat,$privatemessage[dateline]);
    
$privatemessage[timesent]=vbdate($timeformat,$privatemessage[dateline]);

    
// enhanced
    // do multiple recipients text
    
if ($privatemessage[multiplerecipients]) {
        eval(
"\$privatemessage[displayusername] = \"".gettemplate("priv_senttomultiple")."\";");
    }
    
// blank message if deleteprompt is set
    
if ($privatemessage[deleteprompt]==1) {
      eval(
"\$privmsgsbit .= \"".gettemplate("privfolder_deletedbit")."\";");
      
$messagedone 1;
      continue;
    }
    
// add deny receipt link if group permissions allow
    
if ($permissions[cantrackpm] && $permissions[candenypmreceipts] && $privatemessage[receipt]==1) {
        eval(
"\$privatemessage[denyreceipt] = \"".gettemplate("privfolder_denyreceipt")."\";");
    }
    
// get folder icon - INCLUDING replied icon
    
switch ($privatemessage[messageread]) {
      case 
0// new message
        
$privatemessage[folder] = "https://vborg.vbsupport.ru/vbimages/newpm.gif";
        break;
      case 
1// old message
        
$privatemessage[folder] = "https://vborg.vbsupport.ru/vbimages/pm.gif";
        break;
      case 
2// replied to message
        
$privatemessage[folder] = "https://vborg.vbsupport.ru/vbimages/pmreplied.gif";
        break;
      case 
3// forwarded message
        
$privatemessage[folder] = "https://vborg.vbsupport.ru/vbimages/pmforwarded.gif";
        break;
    }
    
// /enhanced

    //get icon for this message
    
if ($privatemessage[iconid]) {
      
$privatemessage[icon]="<img src=\"$privatemessage[iconpath]\" alt=\"$privatemessage[icontitle]\" border=\"0\">";
    } else {
      
$privatemessage[icon]="&nbsp;";
    }

    
//run it through the template
    
$messagedone=1;
    eval(
"\$privmsgsbit .= \"".gettemplate("privfolder_bit")."\";");
  } 
//end while

  
if ($messagedone) {
    eval(
"\$privatemessages .= \"".gettemplate("privfolder_messages")."\";");
  } else {
    eval(
"\$privatemessages .= \"".gettemplate("privfolder_nomessages")."\";");
  }

  
$folderselect[$folderid] = "selected";
  
$folderjump makefolderjump(); //make the forum dropdown

  
makeforumjump(); //make the forum dropdown

  
eval("dooutput(\"".gettemplate("privfolder")."\");"); //and run everything through the template
#end getmsgs

// ############################### start show message ###############################
if ($action=="show") {
  
makeforumjump();

  
$privatemessageid verifyid("privatemessage",$privatemessageid);

  
$message $DB_site->query_first("SELECT privatemessage.*,icon.title as icontitle,icon.iconpath
                                    FROM privatemessage
                                    LEFT JOIN icon ON (privatemessage.iconid = icon.iconid)
                                    WHERE privatemessageid=
$privatemessageid");
  if (
$message[userid]!=$bbuserinfo[userid]) {
    
$idname="privatemessage";
    eval(
"standarderror(\"".gettemplate("error_invalidid")."\");");
    exit;
  }

  
// enhanced
  
if ($permissions[cantrackpm]) {
       eval(
"\$readreceiptsoption = \"".gettemplate("priv_readreceiptsoption")."\";");
    eval(
"\$readreceiptslink = \"".gettemplate("priv_readreceiptslink")."\";");
  } else {
    
$readreceiptsoption '';
    
$readreceiptslink '';
  }
  
$receiptSQL "";
  if (
$message[receipt]==1) {
      if ((
$permissions[candenypmreceipts]) && ($noreceipt=="yes")) {
      
$receiptSQL ", receipt=0";
    } else {
      
$receiptSQL ", receipt=2";
    }
  }
  
// show error if message has been cancelled by sender
  
if ($message[deleteprompt]) {
    
$idname="privatemessage";
    eval(
"standarderror(\"".gettemplate("error_invalidid")."\");");
    exit;
  }
  
// check for forward-to-buddylist permission
  
if ($permissions[maxbuddypm]) {
      eval(
"\$buddyforwardlink = \"".gettemplate("priv_forwardtobuddylink")."\";");
  } else {
    
$buddyforwardlink '';
  }
  
// /enhanced

  
if ($message[messageread]==0) {
  
// enhanced - added $receiptSQL
    
$DB_site->query("UPDATE privatemessage SET messageread=1, readtime='".time()."' $receiptSQL WHERE privatemessageid=$privatemessageid");
  
// /enhanced
  
}

  
$message[postdate]=vbdate($dateformat,$message[dateline]);
  
$message[posttime]=vbdate($timeformat,$message[dateline]);

  if (
$message[messageread]==0) {
    
$message[foldericon]="<img src=\"https://vborg.vbsupport.ru/vbimages/posticonnew.gif\" border=\"0\" alt=\"\">";
  } else {
    
$message[foldericon]="<img src=\"https://vborg.vbsupport.ru/vbimages/posticon.gif\" border=\"0\" alt=\"\">";
  }
  if (!
$privallowicons or $message[iconid]==0) {
    
$message[icon]="";
  } else {
    
$message[icon]="<img src=\"$message[iconpath]\" alt=\"$message[icontitle]\" border=\"0\">";
  }

  
$datecut time() - $cookietimeout;
  
$fromuserinfo = array();
  if (
$message[fromuserid]!=0) {

    
$post=$DB_site->query_first("SELECT
                                 user.*,userfield.*"
.iif($avatarenabled,",avatar.avatarpath,customavatar.dateline AS avatardateline,NOT ISNULL(customavatar.avatardata) AS hascustomavatar ","")."
                                 FROM user,userfield
                                 "
.iif ($avatarenabled,"LEFT JOIN avatar ON avatar.avatarid=user.avatarid
                                                        LEFT JOIN customavatar ON customavatar.userid=user.userid "
,"")."
                                 WHERE userfield.userid=user.userid AND user.userid=
$message[fromuserid]");
    
$userinfo=$post;

    unset(
$onlinestatus);
    if (
$post['lastactivity'] > $datecut and !$post['invisible'] and $post['lastvisit'] != $post['lastactivity']) {
       eval(
"\$onlinestatus = \"".gettemplate("postbit_online")."\";");
    } else {
       eval(
"\$onlinestatus = \"".gettemplate("postbit_offline")."\";");
    }

    if (
$bbuserinfo['showavatars']) {
        if (
$post[avatarid]!=0) {
          
$avatarurl=$post[avatarpath];
        } else {
          if (
$post[hascustomavatar] and $avatarenabled) {
            
$avatarurl="avatar.php?userid=$post[userid]&dateline=$post[avatardateline]";
          } else {
            
$avatarurl="";
          }
        }
        if (
$avatarurl=="") {
          
$post[avatar]="";
        } else {
          eval(
"\$post[avatar] = \"".gettemplate("postbit_avatar")."\";");
        }
    }

    
$post[joindate]=vbdate($registereddateformat,$post[joindate]);
    if (
$post[customtitle]==2) {
      
$post[usertitle] = htmlspecialchars($post[usertitle]);
    }
    if (
$post[showemail] and $displayemails) {
      eval(
"\$post[useremail] = \"".gettemplate("postbit_useremail")."\";");
    } else {
      
$post[useremail]="";
    }
    if (
$post[icq]!="") {
      eval(
"\$post[icqicon] = \"".gettemplate("icq")."\";");
    } else {
      
$post[icqicon]="";
    }
    if (
$post[aim]!="") {
      eval(
"\$post[aimicon] = \"".gettemplate("aim")."\";");
    } else {
      
$post[aimicon]="";
    }
    if (
$post[yahoo]!="") {
      eval(
"\$post[yahooicon] = \"".gettemplate("yahoo")."\";");
    } else {
      
$post[yahooicon]="";
    }

    if (
$post[homepage]!="" and $post[homepage]!="http://") {
      eval(
"\$post[homepage] = \"".gettemplate("postbit_homepage")."\";");
    } else {
      
$post[homepage]="";
    }

    eval(
"\$post[profile] = \"".gettemplate("postbit_profile")."\";");

    if (
$message[showsignature] and $allowsignatures and trim($post[signature])!="" && $bbuserinfo['showsignatures']) {
      
$post[signature]=bbcodeparse($post[signature],0,$allowsmilies);
      eval(
"\$post[signature] = \"".gettemplate("postbit_signature")."\";");
    } else {
      
$post[signature] = "";
    }
    
$fromuserinfo=$post;
  } else {
    
$fromuserinfo['username'] = "N/A";
  }

  
$touserinfo getuserinfo($message[touserid]);

  
$message[message]=pmcodeparse($message[message],0,$allowsmilies);
  
$message[message] .= $fromuserinfo[signature];

  if (
$getnextnewest=$DB_site->query_first("SELECT privatemessageid
                                            FROM privatemessage
                                            WHERE folderid='
$message[folderid]'
                                              AND dateline>'
$message[dateline]'
                                              AND userid='
$message[userid]'
                                            ORDER BY dateline LIMIT 1"
)) {
    
$nextnewestid=$getnextnewest[privatemessageid];
    eval(
"\$nextnewest = \"".gettemplate("privmsg_nextnewest")."\";");
  } else {
    
$nextnewest '';
  }

  if (
$getnextoldest=$DB_site->query_first("SELECT privatemessageid
                                            FROM privatemessage
                                            WHERE folderid='
$message[folderid]'
                                              AND dateline<'
$message[dateline]'
                                              AND userid='
$message[userid]'
                                            ORDER BY dateline DESC LIMIT 1"
)) {
    
$nextoldestid=$getnextoldest[privatemessageid];
    eval(
"\$nextoldest = \"".gettemplate("privmsg_nextoldest")."\";");
  } else {
    
$nextoldest '';
  }

  
// generate navbar
  
$nav_url="private.php?s=$session[sessionhash]";
  
$nav_title="Private Messages";
  
$navbits '';
  eval(
"\$navbits .= \"".gettemplate("nav_linkon")."\";");
  
$navbits.=gettemplate("nav_joiner",0);
  
$nav_url="private.php?s=$session[sessionhash]&folderid=$message[folderid]";
  
$nav_title=$foldername;
  eval(
"\$navbits .= \"".gettemplate("nav_linkon")."\";");
  eval(
"\$navbar = \"".gettemplate("navbar")."\";");
  
$nav_title=$message[title];
  eval(
"\$navbits .= \"".gettemplate("nav_linkoff")."\";");
  eval(
"\$navbar = \"".gettemplate("navbar")."\";");

  
// add folderjump
  
$folderid $message[folderid];
  
$folderselect[$folderid] = "selected";
  
$folderjump makefolderjump();

  eval(
"dooutput(\"".gettemplate("privmsg")."\");");

  } 
#end show

// ############################### start new message ###############################
if  ($action=="newmessage") {
  
//show new message form

  
if (isset($privatemessageid)) {
    
// check to see if replying or forwarding

    
$privatemesageid=verifyid("privatemessage",$privatemessageid);

    
$message $DB_site->query_first("SELECT * FROM privatemessage WHERE privatemessageid=$privatemessageid");

    
//check to make sure that this owner owns this message, and that the message has not been cancelled.
    
if ($message[userid]!=$bbuserinfo[userid] or $message[deleteprompt]==1) {
      
$idname="privatemessage";
      eval(
"standarderror(\"".gettemplate("error_invalidid")."\");");
      exit;
    }

    
$message[postdate]=vbdate($dateformat,$message[dateline]);
    
$message[posttime]=vbdate($timeformat,$message[dateline]);
    
$message[message]=htmlspecialchars($message[message]);

    
$fromuserinfo=getuserinfo($message['fromuserid']);

    
$fromusergroup=$DB_site->query_first("SELECT canusepm FROM user,usergroup WHERE user.usergroupid=usergroup.usergroupid AND user.userid='$fromuserinfo[userid]'");

    if (!
$fromuserinfo['receivepm'] or !$fromusergroup['canusepm']) {
      
$touser $fromuserinfo['username'];
      eval(
"standarderror(\"".gettemplate("error_pmrecipturnedoff")."\");");
    }

    if (
strtolower(substr($message[title],0,3))=="re:" or strtolower(substr($message[title],0,3))=="fw:") {
      
$message[title]=trim(substr($message[title],3));
    }
    if (
$forward=="true") {
      
$subject="Fw: $message[title]";
    } else {
      
$userid=$message[fromuserid];
      
$subject="Re: $message[title]";
    }
    eval(
"\$message[message] = \"".gettemplate("priv_reply",1,0)."\";");
  } else {
    
$message = array();
  }

  if (isset(
$userid)) {
    
$touserinfo=getuserinfo($userid);
    
$tousergroup=$DB_site->query_first("SELECT canusepm FROM user,usergroup WHERE user.usergroupid=usergroup.usergroupid AND user.userid='$touserinfo[userid]'");

    if (!
$touserinfo['receivepm'] or !$tousergroup['canusepm']) {
      
$touser $touserinfo['username'];
      eval(
"standarderror(\"".gettemplate("error_pmrecipturnedoff")."\");");
    }
  }

  if (
$bbuserinfo[userid]!=and !$previewpost and $bbuserinfo[signature]!="") {
    
$signaturechecked="CHECKED";
  } else {
    
$signaturechecked '';
  }

  if (
$privallowicons) {
    
$posticons=chooseicons(0);
  }  else {
    
$posticons="<input type=\"hidden\" name=\"iconid\" value=\"0\">";
  }

  
// generate navbar
  
$navbits '';
  
$nav_url="private.php?s=$session[sessionhash]";
  
$nav_title="Private Messages";
  eval(
"\$navbits .= \"".gettemplate("nav_linkon")."\";");
  eval(
"\$navbar = \"".gettemplate("navbar")."\";");
  if (
$bbuserinfo[showvbcode] && $allowvbcodebuttons) {
    
$vbcode_smilies getclickysmilies();
    
$vbcode_buttons getcodebuttons();
  } else {
    
$vbcode_smilies '';
    
$vbcode_buttons '';
  }
  
// enhanced
  
if ($permissions[cantrackpm]) {
       eval(
"\$requestreceipt = \"".gettemplate("priv_requestreceipt")."\";");
  } else {
    
$requestreceipt "";
  }
  
// /enhanced
  
eval("dooutput(\"".gettemplate("priv_sendprivmsg")."\");");

#end newmessage

// ############################### start send message ###############################
if ($HTTP_POST_VARS['action']=="dosend") {

  if (
$message=="" or $touser=="" or $title=="") {
    eval(
"standarderror(\"".gettemplate("error_requiredfields")."\");");
    exit;
  }
  
$touser htmlspecialchars($touser);

  if (
$touserinfo $DB_site->query_first("SELECT user.*, usergroup.canusepm FROM user,usergroup WHERE user.usergroupid=usergroup.usergroupid AND username='".addslashes($touser)."'")) {
    
$touserid $touserinfo[userid];
  } else {
    eval(
"standarderror(\"".gettemplate("error_pminvalidrecipient")."\");");
    exit;
  }

  if (!
$touserinfo['receivepm'] or !$touserinfo['canusepm']) {
    eval(
"standarderror(\"".gettemplate("error_pmrecipturnedoff")."\");");
    exit;
  }

  if (
strlen($message)>$pmmaxchars and $pmmaxchars!=and $bbuserinfo[usergroupid] != 6) {
    eval(
"standarderror(\"".gettemplate("error_pmtoolong")."\");");
  }

  
$prevtime=$DB_site->query_first("SELECT MAX(dateline) AS dateline FROM privatemessage WHERE fromuserid=$bbuserinfo[userid]");
  if (
time()-$prevtime[dateline]<$pmfloodtime and $pmfloodtime!=and !ismoderator()) {
    eval(
"standarderror(\"".gettemplate("error_pmfloodcheck")."\");");
    exit;
  }

  
$signature=iif($signature=="yes",1,0);
  
$parseurl=iif($parseurl=="yes",1,0);
  
$savecopy=iif($savecopy=="yes",1,0);
  
$iconid intval(trim($iconid));

  if (
$parseurl) {
    
$message=parseurl($message);
  }

  if (
$pmquota>and $touserinfo[usergroupid] != and $bbuserinfo[usergroupid] != 6) {
    
$msgcount $DB_site->query_first("SELECT COUNT(*) AS messages FROM privatemessage WHERE userid=$touserinfo[userid]");

    if (
$msgcount[messages]>=$pmquota) {
      
// mailbox full. email user and display error

      
eval("\$emailmsg = \"".gettemplate("email_pmboxfull",1,0)."\";");
      eval(
"\$emailsubject = \"".gettemplate("emailsubject_pmfullbox",1,0)."\";");
      
mail($touserinfo[email],$emailsubject,$emailmsg,"From: \"$bbtitle Mailer\" <$webmasteremail>");

      eval(
"standarderror(\"".gettemplate("error_pmfullmailbox")."\");");
      exit;
    }
  }

  
// enhanced
  
$receipt=iif($pmreceipt=="yes",1,0);
  
// /enhanced

  // enhanced - added $receipt to insert
  
$DB_site->query("INSERT INTO privatemessage (privatemessageid,userid,touserid,fromuserid,title,message,dateline,showsignature,iconid,messageread,folderid,receipt) VALUES (NULL,$touserinfo[userid],$touserinfo[userid],$bbuserinfo[userid],'".addslashes(htmlspecialchars($title))."','".addslashes($message)."',".time().",'$signature','$iconid',0,0,$receipt)");

  
// enhanced
  
if ($prevmessageid) {
    if (
$forward) {
      
$DB_site->query("UPDATE privatemessage SET messageread=3 WHERE privatemessageid=".intval($prevmessageid));
    } else {
      
$DB_site->query("UPDATE privatemessage SET messageread=2 WHERE privatemessageid=".intval($prevmessageid));
    }
  }
  
// /enhanced

  
if ($savecopy) {
    
$DB_site->query("INSERT INTO privatemessage (privatemessageid,userid,touserid,fromuserid,title,message,dateline,showsignature,iconid,messageread,folderid) VALUES (NULL,$bbuserinfo[userid],$touserinfo[userid],$bbuserinfo[userid],'".addslashes(htmlspecialchars($title))."','".addslashes($message)."',".time().",'$signature','$iconid',1,-1)");
  }

  
$touserinfo['ignorelist'] = '  '.$touserinfo['ignorelist'].' ';
  if (
strpos($touserinfo['ignorelist'],$bbuserinfo[userid] ")) {
    
$userignored 1;
  } else {
    
$userignored 0;
  }

  if (
$userignored!=1) {
    if (
$touserinfo[pmpopup]==1) {
      if (
$noshutdownfunc) {
        
$DB_site->query("UPDATE user SET pmpopup=2 WHERE userid=$touserinfo[userid]");
      } else {
        
$shutdownqueries[]="UPDATE LOW_PRIORITY user SET pmpopup=2 WHERE userid=$touserinfo[userid]";
      }
    }
    if (
$touserinfo[emailonpm]) {
      eval(
"\$emailmsg = \"".gettemplate("email_pmreceived",1,0)."\";");
      eval(
"\$emailsubject = \"".gettemplate("emailsubject_pmreceived",1,0)."\";");
      
mail($touserinfo[email],$emailsubject,$emailmsg,"From: \"$bbtitle Mailer\" <$webmasteremail>");
    }
  }

// Leave Away Message in Profile (v1.2)
  
if ($touserinfo[away]=="1") {
      
      
$sincedate vbdate($dateformat$touserinfo[awaydate]);
    if (
$touserinfo[returndate]=="0000-00-00") {
        
$returndate "(date unknown)";
    } else {
          
$returnaway explode("-"$touserinfo[returndate]);
          
$returndate "on ".vbdate($dateformatmktime(0,0,0,$returnaway[1],$returnaway[2],$returnaway[0]));
      }
      if (!
$touserinfo[awayreason]) {
          
$awayreason "No reason specified";
      } else {
          
$awayreason "$touserinfo[awayreason]";
      }
      
      eval(
"\$autoreply = \"".gettemplate("priv_autoreply",1,0)."\";"); 
      
$autotitle "Auto Reply: ".addslashes(htmlspecialchars($title));

      
$DB_site->query("INSERT INTO privatemessage (privatemessageid,userid,touserid,fromuserid,title,message,dateline,showsignature,iconid,messageread,folderid,receipt) VALUES (NULL,$bbuserinfo[userid],$bbuserinfo[userid],$touserinfo[userid],'".addslashes(htmlspecialchars($autotitle))."','".addslashes(htmlspecialchars($autoreply))."','".time()."',0,0,0,0,0)");
    if (
$bbuserinfo[emailonpm]) {
      eval(
"\$emailmsg = \"".gettemplate("email_pmautoreply",1,0)."\";");
      eval(
"\$emailsubject = \"".gettemplate("emailsubject_pmreceived",1,0)."\";");
      
mail($bbuserinfo[email],$emailsubject,$emailmsg,"From: \"$bbtitle Mailer\" <$webmasteremail>");
    }

  }
// Leave Away Message in Profile (v1.2)  eval("standardredirect(\"".gettemplate("redirect_pmthanks")."\",\"private.php?s=$session[sessionhash]\");");
#end dosend

// ############################### start do stuff (move, etc) ###############################
if ($HTTP_POST_VARS['action']=="dostuff") {
  
$what '';
  if (
$delete!="") {
    
$what="delete";
  }
  if (
$move!="") {
    
$what="move";
  }
  if (
$what=="mark") {
    
// ************************
    // mark as (un)read
  
}
  if (
$what=="move") {
    if (
is_array($privatemessage)) {
      while(list(
$key,$val)=each($privatemessage)) {
        
$DB_site->query("UPDATE privatemessage SET folderid=".intval($folderid)." WHERE privatemessageid=".intval($key)." AND userid=$bbuserinfo[userid]");
      } 
//end while
    
} else {
      eval(
"standarderror(\"".gettemplate("error_pmnoselected")."\");");
      exit;
    }
    eval(
"standardredirect(\"".gettemplate("redirect_pmmove")."\",\"private.php?s=$session[sessionhash]&folderid=".intval($folderid)."\");");
  }
  if (
$what=="delete") {
    if (
is_array($privatemessage)) {
      while(list(
$key,$val)=each($privatemessage)) {
        
$DB_site->query("DELETE FROM privatemessage WHERE privatemessageid=".intval($key)." AND userid=$bbuserinfo[userid]");
      } 
//end while
    
} else {
      eval(
"standarderror(\"".gettemplate("error_pmnoselected")."\");");
      exit;
    }
    eval(
"standardredirect(\"".gettemplate("redirect_pmdelete")."\",\"private.php?s=$session[sessionhash]&folderid=".intval($thisfolder)."\");");
  }

}

// ############################### start delete ###############################
if ($HTTP_POST_VARS['action']=="dodelete") {
  if (!
$delete) {
    eval(
"standarderror(\"".gettemplate("error_pmnotchecked")."\");");
    exit;
  }

  
$privatemessageid=verifyid("privatemessage",$privatemessageid);
  
$DB_site->query("DELETE FROM privatemessage WHERE privatemessageid=$privatemessageid AND userid=$bbuserinfo[userid]");

  eval(
"standardredirect(\"".gettemplate("redirect_pmdelete")."\",\"private.php?s=$session[sessionhash]&folderid=".intval($folderid)."\");");
#end dodelete

// ############################### start edit folders ###############################
if ($action=="editfolders") {

  
$highestnum 0;
  
$folderboxes '';
  
$newfolderboxes '';
  
$folder = array();

  if (
$bbuserinfo[pmfolders]) {
    
$allfolders split("\n"trim($bbuserinfo[pmfolders]));
    
$foldercount 0;
    while (list(
$key,$val)=each($allfolders)) {
      
$folder split("\|\|\|"$val);
      
$foldercount++;
      
$highestnum $folder[0];

      
$folder[folderid]=$folder[0]+1;
      
$folder[title]=$folder[1];
      eval(
"\$folderboxes .= \"".gettemplate("priv_showfolders_folderbit",1,0)."\";");
    }
  }

  
$foldercount=0;
  while (
$foldercount<3) {
    
$foldercount++;

    
$folder[folderid]=$foldercount+$highestnum+1;
    
$folder[title]="";
    eval(
"\$newfolderboxes .= \"".gettemplate("priv_showfolders_folderbit",1,0)."\";");
  }
  
$folderboxes .= "<INPUT TYPE=\"hidden\" name=\"highest\" value=\"".($highestnum+3)."\">";

  
// generate navbar
  
$navbits '';
  
$nav_url="private.php?s=$session[sessionhash]";
  
$nav_title="Private Messages";
  eval(
"\$navbits .= \"".gettemplate("nav_linkon")."\";");
  
$navbits.=gettemplate("nav_joiner",0);
  
$nav_url="private.php?s=$session[sessionhash]&folderid=$message[folderid]";
  
$nav_title="Edit Folders";
  eval(
"\$navbits .= \"".gettemplate("nav_linkoff")."\";");
  eval(
"\$navbar = \"".gettemplate("navbar")."\";");

  eval(
"dooutput(\"".gettemplate("priv_showfolders")."\");");

#end editfolders

// ############################### start update folders ###############################
if ($HTTP_POST_VARS['action']=="doeditfolders") {

  if (
is_array($folderlist)) {
    
$foldersql="";
    while (list(
$key,$val)=each($folderlist)) {
      if (
$val) {
        
$key intval($key)-1;
        
$val=str_replace("|||"," || | ",$val);
        
$val=str_replace("\n","nl",$val);
        if (
$foldersql) {
          
$foldersql .= "\n$key|||$val";
        } else {
          
$foldersql "$key|||$val";
        }
      } else {
        
$DB_site->query("UPDATE privatemessage SET folderid=0 WHERE folderid=".intval($key)." AND userid=$bbuserinfo[userid]");
      }
    }

    
$DB_site->query("UPDATE user SET pmfolders='".addslashes("$foldersql")."' WHERE userid=$bbuserinfo[userid]");
  }

  eval(
"standardredirect(\"".gettemplate("redirect_pmfoldersedited")."\",\"private.php?s=$session[sessionhash]\");");

#end doeditfolders


?>

Show Your Support

  • This modification may not be copied, reproduced or published elsewhere without author's permission.
Reply

Thread Tools

Posting Rules
You may not post new threads
You may not post replies
You may not post attachments
You may not edit your posts

BB code is On
Smilies are On
[IMG] code is On
HTML code is Off

Forum Jump


All times are GMT. The time now is 04:46 AM.


Powered by vBulletin® Version 3.8.12 by vBS
Copyright ©2000 - 2025, vBulletin Solutions Inc.
X vBulletin 3.8.12 by vBS Debug Information
  • Page Generation 0.04025 seconds
  • Memory Usage 2,579KB
  • Queries Executed 14 (?)
More Information
Template Usage:
  • (1)SHOWTHREAD
  • (1)ad_footer_end
  • (1)ad_footer_start
  • (1)ad_header_end
  • (1)ad_header_logo
  • (1)ad_navbar_below
  • (1)ad_showthread_beforeqr
  • (1)bbcode_php
  • (1)footer
  • (1)forumjump
  • (1)forumrules
  • (1)gobutton
  • (1)header
  • (1)headinclude
  • (1)modsystem_post
  • (1)navbar
  • (6)navbar_link
  • (120)option
  • (1)post_thanks_box
  • (1)post_thanks_button
  • (1)post_thanks_javascript
  • (1)post_thanks_navbar_search
  • (1)post_thanks_postbit_info
  • (1)postbit_onlinestatus
  • (1)postbit_wrapper
  • (1)spacer_close
  • (1)spacer_open
  • (1)tagbit_wrapper 

Phrase Groups Available:
  • global
  • inlinemod
  • postbit
  • posting
  • reputationlevel
  • showthread
Included Files:
  • ./showthread.php
  • ./global.php
  • ./includes/init.php
  • ./includes/class_core.php
  • ./includes/config.php
  • ./includes/functions.php
  • ./includes/class_hook.php
  • ./includes/modsystem_functions.php
  • ./includes/functions_bigthree.php
  • ./includes/class_postbit.php
  • ./includes/class_bbcode.php
  • ./includes/functions_reputation.php
  • ./includes/functions_post_thanks.php 

Hooks Called:
  • init_startup
  • init_startup_session_setup_start
  • init_startup_session_setup_complete
  • cache_permissions
  • fetch_threadinfo_query
  • fetch_threadinfo
  • fetch_foruminfo
  • style_fetch
  • cache_templates
  • global_start
  • parse_templates
  • global_setup_complete
  • showthread_start
  • showthread_getinfo
  • forumjump
  • showthread_post_start
  • showthread_query_postids
  • showthread_query
  • bbcode_fetch_tags
  • bbcode_create
  • showthread_postbit_create
  • postbit_factory
  • postbit_display_start
  • post_thanks_function_post_thanks_off_start
  • post_thanks_function_post_thanks_off_end
  • post_thanks_function_fetch_thanks_start
  • post_thanks_function_fetch_thanks_end
  • post_thanks_function_thanked_already_start
  • post_thanks_function_thanked_already_end
  • fetch_musername
  • postbit_imicons
  • bbcode_parse_start
  • bbcode_parse_complete_precache
  • bbcode_parse_complete
  • postbit_display_complete
  • post_thanks_function_can_thank_this_post_start
  • tag_fetchbit_complete
  • forumrules
  • navbits
  • navbits_complete
  • showthread_complete