mirror of
https://github.com/e107inc/e107.git
synced 2025-10-24 19:26:21 +02:00
944 lines
23 KiB
PHP
Executable File
944 lines
23 KiB
PHP
Executable File
<?php
|
|
/*
|
|
* e107 website system
|
|
*
|
|
* Copyright (C) 2008-2014 e107 Inc (e107.org)
|
|
* Released under the terms and conditions of the
|
|
* GNU General Public License (http://www.gnu.org/licenses/gpl.txt)
|
|
*
|
|
* PM plugin - base class API
|
|
*
|
|
*/
|
|
|
|
|
|
|
|
if (!defined('e107_INIT')) { exit; }
|
|
|
|
class private_message
|
|
{
|
|
protected $e107;
|
|
protected $pmPrefs;
|
|
|
|
|
|
public function prefs()
|
|
{
|
|
return $this->pmPrefs;
|
|
}
|
|
|
|
|
|
/**
|
|
* Constructor
|
|
*
|
|
* @param array $prefs - pref settings for PM plugin
|
|
* @return none
|
|
*/
|
|
public function __construct($prefs=null)
|
|
{
|
|
$this->e107 = e107::getInstance();
|
|
$this->pmPrefs = e107::pref('pm');
|
|
}
|
|
|
|
|
|
/**
|
|
* Mark a PM as read
|
|
* If flag set, send read receipt to sender
|
|
*
|
|
* @param int $pm_id - ID of PM
|
|
* @param array $pm_info - PM details
|
|
*
|
|
* @return none
|
|
*
|
|
* @todo - 'read_delete' pref doesn't exist - remove code? Or support?
|
|
*/
|
|
function pm_mark_read($pm_id, $pm_info)
|
|
{
|
|
$now = time();
|
|
if($this->pmPrefs['read_delete'])
|
|
{
|
|
$this->del($pm_id);
|
|
}
|
|
else
|
|
{
|
|
e107::getDb()->gen("UPDATE `#private_msg` SET `pm_read` = {$now} WHERE `pm_id`=".intval($pm_id)); // TODO does this work properly?
|
|
if(strpos($pm_info['pm_option'], '+rr') !== FALSE)
|
|
{
|
|
$this->pm_send_receipt($pm_info);
|
|
}
|
|
e107::getEvent()->trigger('user_pm_read', $pm_id);
|
|
}
|
|
}
|
|
|
|
|
|
/*
|
|
* Get an existing PM
|
|
*
|
|
* @param int $pmid - ID of PM in DB
|
|
*
|
|
* @return boolean|array - FALSE on error, array of PM info on success
|
|
*/
|
|
function pm_get($pmid)
|
|
{
|
|
$qry = "
|
|
SELECT pm.*, ut.user_image AS sent_image, ut.user_name AS sent_name, uf.user_image AS from_image, uf.user_name AS from_name, uf.user_email as from_email, ut.user_email as to_email FROM #private_msg AS pm
|
|
LEFT JOIN #user AS ut ON ut.user_id = pm.pm_to
|
|
LEFT JOIN #user AS uf ON uf.user_id = pm.pm_from
|
|
WHERE pm.pm_id='".intval($pmid)."'
|
|
";
|
|
if (e107::getDb()->gen($qry))
|
|
{
|
|
$row = e107::getDb()->fetch();
|
|
return $row;
|
|
}
|
|
return FALSE;
|
|
}
|
|
|
|
|
|
/*
|
|
* Send a PM
|
|
*
|
|
* @param array $vars - PM information
|
|
* ['receipt'] - set TRUE if read receipt required
|
|
* ['uploaded'] - list of attachments (if any) - each is an array('size', 'name')
|
|
* ['to_userclass'] - set TRUE if sending to a user class
|
|
* ['to_array'] = array of recipients
|
|
* ['pm_userclass'] = target user class
|
|
* ['to_info'] = recipients array of array('user_id', 'user_class')
|
|
*
|
|
* May also be an array as received from the generic table, if sending via a cron job
|
|
* identified by the existence of $vars['pm_from']
|
|
*
|
|
* @return string - text detailing result
|
|
*/
|
|
function add($vars)
|
|
{
|
|
|
|
$tp = e107::getParser();
|
|
$sql = e107::getDb();
|
|
$pmsize = 0;
|
|
$attachlist = '';
|
|
$pm_options = '';
|
|
$ret = '';
|
|
$addOutbox = TRUE;
|
|
$timestamp = time();
|
|
|
|
$maxSendNow = varset($this->pmPrefs['pm_max_send'],100); // Maximum number of PMs to send without queueing them
|
|
if (isset($vars['pm_from']))
|
|
{ // Doing bulk send off cron task
|
|
$info = array();
|
|
foreach ($vars as $k => $v)
|
|
{
|
|
if (strpos($k, 'pm_') === 0)
|
|
{
|
|
$info[$k] = $v;
|
|
unset($vars[$k]);
|
|
}
|
|
}
|
|
$addOutbox = FALSE; // Don't add to outbox - was done earlier
|
|
}
|
|
else
|
|
{ // Send triggered by user - may be immediate or bulk dependent on number of recipients
|
|
$vars['options'] = '';
|
|
if(isset($vars['receipt']) && $vars['receipt']) {$pm_options .= '+rr+'; }
|
|
|
|
if(isset($vars['uploaded']))
|
|
{
|
|
foreach($vars['uploaded'] as $u)
|
|
{
|
|
if (!isset($u['error']) || !$u['error'])
|
|
{
|
|
$pmsize += $u['size'];
|
|
$a_list[] = $u['name'];
|
|
}
|
|
}
|
|
$attachlist = implode(chr(0), $a_list);
|
|
}
|
|
$pmsize += strlen($vars['pm_message']);
|
|
|
|
$pm_subject = trim($tp->toDB($vars['pm_subject']));
|
|
$pm_message = trim($tp->toDB($vars['pm_message']));
|
|
|
|
if (!$pm_subject && !$pm_message && !$attachlist)
|
|
{ // Error - no subject, no message body and no uploaded files
|
|
return LAN_PM_65;
|
|
}
|
|
|
|
// Most of the pm info is fixed - just need to set the 'to' user on each send
|
|
$info = array(
|
|
'pm_from' => $vars['from_id'],
|
|
'pm_sent' => $timestamp, /* Date sent */
|
|
'pm_read' => 0, /* Date read */
|
|
'pm_subject' => $pm_subject,
|
|
'pm_text' => $pm_message,
|
|
'pm_sent_del' => 0, /* Set when can delete */
|
|
'pm_read_del' => 0, /* set when can delete */
|
|
'pm_attachments' => $attachlist,
|
|
'pm_option' => $pm_options, /* Options associated with PM - '+rr' for read receipt */
|
|
'pm_size' => $pmsize
|
|
);
|
|
|
|
// print_a($info);
|
|
// print_a($vars);
|
|
}
|
|
|
|
if(!empty($vars['pm_userclass']) || isset($vars['to_array']))
|
|
{
|
|
if(!empty($vars['pm_userclass']))
|
|
{
|
|
$toclass = e107::getUserClass()->getName($vars['pm_userclass']);
|
|
$tolist = $this->get_users_inclass($vars['pm_userclass']);
|
|
$ret .= LAN_PM_38.": {$toclass}<br />";
|
|
$class = TRUE;
|
|
$info['pm_sent_del'] = 1; // keep the outbox clean and limited to 1 entry when sending to an entire class.
|
|
}
|
|
else
|
|
{
|
|
$tolist = $vars['to_array'];
|
|
$class = FALSE;
|
|
}
|
|
// Sending multiple PMs here. If more than some number ($maxSendNow), need to split into blocks.
|
|
if (count($tolist) > $maxSendNow)
|
|
{
|
|
$totalSend = count($tolist);
|
|
$targets = array_chunk($tolist, $maxSendNow); // Split into a number of lists, each with the maximum number of elements (apart from the last block, of course)
|
|
unset($tolist);
|
|
|
|
$pmInfo = $info;
|
|
$genInfo = array(
|
|
'gen_type' => 'pm_bulk',
|
|
'gen_datestamp' => time(),
|
|
'gen_user_id' => USERID,
|
|
'gen_ip' => ''
|
|
);
|
|
for ($i = 0; $i < count($targets) - 1; $i++)
|
|
{ // Save the list in the 'generic' table
|
|
$pmInfo['to_array'] = $targets[$i]; // Should be in exactly the right format
|
|
$genInfo['gen_intdata'] = count($targets[$i]);
|
|
$genInfo['gen_chardata'] = e107::serialize($pmInfo,TRUE);
|
|
$sql->insert('generic', array('data' => $genInfo, '_FIELD_TYPES' => array('gen_chardata' => 'string'))); // Don't want any of the clever sanitising now
|
|
}
|
|
$toclass .= ' ['.$totalSend.']';
|
|
$tolist = $targets[count($targets) - 1]; // Send the residue now (means user probably isn't kept hanging around too long if sending lots)
|
|
unset($targets);
|
|
}
|
|
foreach($tolist as $u)
|
|
{
|
|
set_time_limit(30);
|
|
$info['pm_to'] = intval($u['user_id']); // Sending to a single user now
|
|
|
|
if($pmid = $sql->insert('private_msg', $info))
|
|
{
|
|
$info['pm_id'] = $pmid;
|
|
e107::getEvent()->trigger('user_pm_sent', $info);
|
|
|
|
unset($info['pm_id']); // prevent it from being used on the next record.
|
|
|
|
if($class == FALSE)
|
|
{
|
|
$toclass .= $u['user_name'].', ';
|
|
}
|
|
if(check_class($this->pmPrefs['notify_class'], null, $u['user_id']))
|
|
{
|
|
$vars['to_info'] = $u;
|
|
$vars['pm_sent'] = $timestamp;
|
|
$this->pm_send_notify($u['user_id'], $vars, $pmid, count($a_list));
|
|
}
|
|
}
|
|
else
|
|
{
|
|
$ret .= LAN_PM_39.": {$u['user_name']} <br />";
|
|
e107::getMessage()->addDebug($sql->getLastErrorText());
|
|
}
|
|
}
|
|
if ($addOutbox)
|
|
{
|
|
$info['pm_to'] = $toclass; // Class info to put into outbox
|
|
$info['pm_sent_del'] = 0;
|
|
$info['pm_read_del'] = 1;
|
|
if(!$pmid = $sql->insert('private_msg', $info))
|
|
{
|
|
$ret .= LAN_PM_41.'<br />';
|
|
}
|
|
}
|
|
|
|
}
|
|
else
|
|
{ // Sending to a single person
|
|
$info['pm_to'] = intval($vars['to_info']['user_id']); // Sending to a single user now
|
|
|
|
|
|
|
|
|
|
if($pmid = $sql->insert('private_msg', $info))
|
|
{
|
|
$info['pm_id'] = $pmid;
|
|
$info['pm_sent'] = $timestamp;
|
|
e107::getEvent()->trigger('user_pm_sent', $info);
|
|
|
|
|
|
if(check_class($this->pmPrefs['notify_class'], null, $vars['to_info']['user_id']))
|
|
{
|
|
set_time_limit(20);
|
|
$vars['pm_sent'] = $timestamp;
|
|
$this->pm_send_notify($vars['to_info']['user_id'], $vars, $pmid, count($a_list));
|
|
}
|
|
$ret .= LAN_PM_40.": {$vars['to_info']['user_name']}<br />";
|
|
}
|
|
}
|
|
return $ret;
|
|
}
|
|
|
|
|
|
|
|
/**
|
|
* Delete a PM from a user's inbox/outbox.
|
|
* PM is only actually deleted from DB once both sender and recipient have marked it as deleted
|
|
* When physically deleted, any attachments are deleted as well
|
|
*
|
|
* @param integer $pmid - ID of the PM
|
|
* @param boolean $force - set to TRUE to force deletion of unread PMs
|
|
* @return boolean|string - FALSE if PM not found, or other DB error. String if successful
|
|
*/
|
|
function del($pmid, $force = FALSE)
|
|
{
|
|
$sql = e107::getDb();
|
|
$pmid = (int)$pmid;
|
|
$ret = '';
|
|
$newvals = '';
|
|
if($sql->select('private_msg', '*', 'pm_id = '.$pmid.' AND (pm_from = '.USERID.' OR pm_to = '.USERID.')'))
|
|
{
|
|
$row = $sql->fetch();
|
|
|
|
// if user is the receiver of the PM
|
|
if (!$force && ($row['pm_to'] == USERID))
|
|
{
|
|
$newvals = 'pm_read_del = 1';
|
|
$ret .= LAN_PM_42.'<br />';
|
|
if($row['pm_sent_del'] == 1) { $force = TRUE; } // sender has deleted as well, set force to true so the DB record can be deleted
|
|
}
|
|
|
|
// if user is the sender of the PM
|
|
if (!$force && ($row['pm_from'] == USERID))
|
|
{
|
|
if($newvals != '') { $force = TRUE; }
|
|
$newvals = 'pm_sent_del = 1';
|
|
$ret .= LAN_PM_43."<br />";
|
|
if($row['pm_read_del'] == 1) { $force = TRUE; } // receiver has deleted as well, set force to true so the DB record can be deleted
|
|
}
|
|
|
|
if($force == TRUE)
|
|
{
|
|
// Delete any attachments and remove PM from db
|
|
$attachments = explode(chr(0), $row['pm_attachments']);
|
|
$aCount = array(0,0);
|
|
foreach($attachments as $a)
|
|
{
|
|
$a = trim($a);
|
|
if ($a)
|
|
{
|
|
$filename = e_PLUGIN.'pm/attachments/'.$a;
|
|
if (unlink($filename)) $aCount[0]++; else $aCount[1]++;
|
|
}
|
|
}
|
|
if ($aCount[0] || $aCount[1])
|
|
{
|
|
|
|
// $ret .= str_replace(array('--GOOD--', '--FAIL--'), $aCount, LAN_PM_71).'<br />';
|
|
$ret .= e107::getParser()->lanVars(LAN_PM_71, $aCount);
|
|
}
|
|
$sql->delete('private_msg', 'pm_id = '.$pmid);
|
|
}
|
|
else
|
|
{
|
|
$sql->update('private_msg', $newvals.' WHERE pm_id = '.$pmid);
|
|
}
|
|
return $ret;
|
|
}
|
|
return FALSE;
|
|
}
|
|
|
|
/**
|
|
* Convinient url assembling shortcut
|
|
*//*
|
|
public function url($action, $params = array(), $options = array())
|
|
{
|
|
if(strpos($action, '/') === false) $action = 'view/'.$action;
|
|
e107::getUrl()->create('pm/'.$action, $params, $options);
|
|
}*/
|
|
|
|
/**
|
|
* Send an email to notify of a PM
|
|
*
|
|
* @param int $uid - not used
|
|
* @param array $pmInfo - PM details
|
|
* @param int $pmid - ID of PM in database
|
|
* @param int $attach_count - number of attachments
|
|
*
|
|
* @return none
|
|
*/
|
|
function pm_send_notify($uid, $pmInfo, $pmid, $attach_count = 0)
|
|
{
|
|
// require_once(e_HANDLER.'mail.php');
|
|
/*
|
|
$tpl_file = THEME.'pm_template.php';
|
|
|
|
$PM_NOTIFY = null; // loaded in template below.
|
|
|
|
include(is_readable($tpl_file) ? $tpl_file : e_PLUGIN.'pm/pm_template.php');
|
|
|
|
$template = $PM_NOTIFY;
|
|
*/
|
|
if(THEME_LEGACY)
|
|
{
|
|
include_once(THEME.'pm_template.php');
|
|
}
|
|
|
|
if(empty($PM_NOTIFY))
|
|
{
|
|
$PM_NOTIFY = e107::getTemplate('pm', 'pm', 'notify');
|
|
}
|
|
|
|
if(empty($PM_NOTIFY)) // BC Fallback.
|
|
{
|
|
|
|
$PM_NOTIFY =
|
|
"<div>
|
|
<h4>".LAN_PM_101."{SITENAME}</h4>
|
|
<table class='table table-striped'>
|
|
<tr><td>".LAN_PM_102."</td><td>{USERNAME}</td></tr>
|
|
<tr><td>".LAN_PM_103."</td><td>{PM_SUBJECT}</td></tr>
|
|
<tr><td>".LAN_PM_108."</td><td>{PM_DATE}</td></tr>
|
|
<tr><td>".LAN_PM_104."</td><td>{PM_ATTACHMENTS}</td></tr>
|
|
|
|
</table><br />
|
|
<div>".LAN_PM_105.": {PM_URL}</div>
|
|
</div>
|
|
";
|
|
|
|
}
|
|
|
|
$url = e107::url('pm','index', null, array('mode'=>'full')).'?show.'.$pmid;
|
|
|
|
$data = array();
|
|
$data['PM_SUBJECT'] = $pmInfo['pm_subject'];
|
|
$data['PM_ATTACHMENTS'] = intval($attach_count);
|
|
$data['PM_DATE'] = e107::getParser()->toDate($pmInfo['pm_sent'], 'long');
|
|
$data['SITENAME'] = SITENAME;
|
|
$data['USERNAME'] = USERNAME;
|
|
$data['PM_URL'] = $url;// e107::url('pm','index', null, array('mode'=>'full')).'?show.'.$pmid;
|
|
$data['PM_BUTTON'] = "<a class='btn btn-primary' href='".$url."'>".LAN_PM_113."</a>";// e107::url('pm','index', null, array('mode'=>'full')).'?show.'.$pmid;
|
|
|
|
$text = e107::getParser()->simpleParse($PM_NOTIFY, $data);
|
|
|
|
$eml = array();
|
|
$eml['email_subject'] = LAN_PM_100.USERNAME;
|
|
$eml['send_html'] = true;
|
|
$eml['email_body'] = $text;
|
|
$eml['template'] = 'default';
|
|
$eml['e107_header'] = $pmInfo['to_info']['user_id'];
|
|
|
|
if(e107::getEmail()->sendEmail($pmInfo['to_info']['user_email'], $pmInfo['to_info']['user_name'], $eml))
|
|
{
|
|
return true;
|
|
}
|
|
else
|
|
{
|
|
return false;
|
|
}
|
|
|
|
}
|
|
|
|
|
|
/**
|
|
* Send PM read receipt
|
|
*
|
|
* @param array $pmInfo - PM details
|
|
* @return boolean
|
|
*/
|
|
function pm_send_receipt($pmInfo) //TODO Add Template and combine with method above..
|
|
{
|
|
require_once(e_HANDLER.'mail.php');
|
|
$subject = LAN_PM_106.$pmInfo['sent_name'];
|
|
|
|
$pmlink = e107::url('pm','index', null, array('mode'=>'full')).'?show.'.$pmInfo['pm_id'];
|
|
|
|
$txt = str_replace("{UNAME}", $pmInfo['sent_name'], LAN_PM_107).date('l F dS Y h:i:s A')."\n\n";
|
|
$txt .= LAN_PM_108.date('l F dS Y h:i:s A', $pmInfo['pm_sent'])."\n";
|
|
$txt .= LAN_PM_103.$pmInfo['pm_subject']."\n";
|
|
$txt .= LAN_PM_105."\n".$pmlink."\n";
|
|
|
|
if(sendemail($pmInfo['from_email'], $subject, $txt, $pmInfo['from_name']))
|
|
{
|
|
return true;
|
|
}
|
|
|
|
return false;
|
|
}
|
|
|
|
|
|
/**
|
|
* Get list of users blocked from sending to a specific user ID.
|
|
*
|
|
* @param int|mixed $to - user ID
|
|
* @return array of blocked users as user IDs
|
|
*/
|
|
function block_get($to = USERID)
|
|
{
|
|
$sql = e107::getDb();
|
|
$ret = array();
|
|
$to = intval($to); // Precautionary
|
|
if ($sql->select('private_msg_block', 'pm_block_from', 'pm_block_to = '.$to))
|
|
{
|
|
while($row = $sql->fetch())
|
|
{
|
|
$ret[] = $row['pm_block_from'];
|
|
}
|
|
}
|
|
return $ret;
|
|
}
|
|
|
|
|
|
/**
|
|
* Get list of users blocked from sending to a specific user ID.
|
|
*
|
|
* @param integer $to - user ID
|
|
*
|
|
* @return array of blocked users, including specific user info
|
|
*/
|
|
function block_get_user($to = USERID)
|
|
{
|
|
$sql = e107::getDb();
|
|
$ret = array();
|
|
$to = intval($to); // Precautionary
|
|
if ($sql->gen('SELECT pm.*, u.user_name FROM `#private_msg_block` AS pm LEFT JOIN `#user` AS u ON `pm`.`pm_block_from` = `u`.`user_id` WHERE pm_block_to = '.$to))
|
|
{
|
|
while($row = $sql->fetch())
|
|
{
|
|
$ret[] = $row;
|
|
}
|
|
}
|
|
return $ret;
|
|
}
|
|
|
|
|
|
/**
|
|
* Add a user block
|
|
*
|
|
* @param int $from - sender to block
|
|
* @param int $to - user doing the blocking
|
|
*
|
|
* @return string result message
|
|
*/
|
|
function block_add($from, $to = USERID)
|
|
{
|
|
$sql = e107::getDb();
|
|
$from = intval($from);
|
|
if($sql->select('user', 'user_name, user_perms', 'user_id = '.$from))
|
|
{
|
|
$uinfo = $sql->fetch();
|
|
if (($uinfo['user_perms'] == '0') || ($uinfo['user_perms'] == '0.'))
|
|
{ // Don't allow block of main admin
|
|
return LAN_PM_64;
|
|
}
|
|
|
|
if(!$sql->count('private_msg_block', '(*)', 'WHERE pm_block_from = '.$from." AND pm_block_to = '".e107::getParser()->toDB($to)."'"))
|
|
{
|
|
if($sql->insert('private_msg_block', array(
|
|
'pm_block_from' => $from,
|
|
'pm_block_to' => $to,
|
|
'pm_block_datestamp' => time()
|
|
)))
|
|
{
|
|
return str_replace('{UNAME}', $uinfo['user_name'], LAN_PM_47);
|
|
}
|
|
else
|
|
{
|
|
return LAN_PM_48;
|
|
}
|
|
}
|
|
else
|
|
{
|
|
return str_replace('{UNAME}', $uinfo['user_name'], LAN_PM_49);
|
|
}
|
|
}
|
|
else
|
|
{
|
|
return LAN_PM_17;
|
|
}
|
|
}
|
|
|
|
|
|
|
|
/**
|
|
* Delete user block
|
|
*
|
|
* @param int $from - sender to block
|
|
* @param int $to - user doing the blocking
|
|
*
|
|
* @return string result message
|
|
*/
|
|
function block_del($from, $to = USERID)
|
|
{
|
|
$sql = e107::getDb();
|
|
$from = intval($from);
|
|
if($sql->select('user', 'user_name', 'user_id = '.$from))
|
|
{
|
|
$uinfo = $sql->fetch();
|
|
if($sql->select('private_msg_block', 'pm_block_id', 'pm_block_from = '.$from.' AND pm_block_to = '.intval($to)))
|
|
{
|
|
$row = $sql->fetch();
|
|
if($sql->delete('private_msg_block', 'pm_block_id = '.intval($row['pm_block_id'])))
|
|
{
|
|
return str_replace('{UNAME}', $uinfo['user_name'], LAN_PM_44);
|
|
}
|
|
else
|
|
{
|
|
return LAN_PM_45;
|
|
}
|
|
}
|
|
else
|
|
{
|
|
return str_replace('{UNAME}', $uinfo['user_name'], LAN_PM_46);
|
|
}
|
|
}
|
|
else
|
|
{
|
|
return LAN_PM_17;
|
|
}
|
|
}
|
|
|
|
|
|
/**
|
|
* Get user ID matching a name
|
|
*
|
|
* @param string var - name to match
|
|
*
|
|
* @return boolean|array - FALSE if no match, array of user info if found
|
|
*/
|
|
function pm_getuid($var)
|
|
{
|
|
$sql = e107::getDb();
|
|
|
|
if(is_numeric($var))
|
|
{
|
|
$where = "user_id = ".intval($var);
|
|
}
|
|
else
|
|
{
|
|
// $var = strip_if_magic($var);
|
|
$var = str_replace("'", ''', trim($var)); // Display name uses entities for apostrophe
|
|
$where = "user_name LIKE '".$sql->escape($var, FALSE)."'";
|
|
}
|
|
|
|
if($sql->select('user', 'user_id, user_name, user_class, user_email', $where))
|
|
{
|
|
$row = $sql->fetch();
|
|
return $row;
|
|
}
|
|
|
|
return false;
|
|
|
|
}
|
|
|
|
|
|
/**
|
|
* Get list of users in class
|
|
*
|
|
* @param int $class - class ID
|
|
*
|
|
* @return boolean|array - FALSE on error/none found, else array of user information arrays
|
|
*/
|
|
function get_users_inclass($class)
|
|
{
|
|
|
|
return e107::getUserClass()->getUsersInClass($class, 'user_name, user_email, user_class');
|
|
|
|
|
|
/*$sql = e107::getDb();
|
|
|
|
if($class == e_UC_MEMBER)
|
|
{
|
|
$qry = "SELECT user_id, user_name, user_email, user_class FROM `#user` WHERE 1";
|
|
}
|
|
elseif($class == e_UC_ADMIN)
|
|
{
|
|
$qry = "SELECT user_id, user_name, user_email, user_class FROM `#user` WHERE user_admin = 1";
|
|
}
|
|
elseif($class)
|
|
{
|
|
$regex = "(^|,)(".e107::getParser()->toDB($class).")(,|$)";
|
|
$qry = "SELECT user_id, user_name, user_email, user_class FROM `#user` WHERE user_class REGEXP '{$regex}'";
|
|
}
|
|
|
|
|
|
if(!empty($qry) && $sql->gen($qry))
|
|
{
|
|
$ret = $sql->db_getList();
|
|
return $ret;
|
|
}
|
|
return FALSE;*/
|
|
}
|
|
|
|
|
|
/**
|
|
* Check permission to send a PM to someone.
|
|
* @param int $uid user_id of the person to send to
|
|
* @return bool
|
|
*/
|
|
function canSendTo($uid)
|
|
{
|
|
if(empty($uid))
|
|
{
|
|
return false;
|
|
}
|
|
|
|
if(!empty($this->pmPrefs['vip_class']))
|
|
{
|
|
if(check_class($this->pmPrefs['vip_class'],null,$uid) && !check_class($this->pmPrefs['vip_class']))
|
|
{
|
|
return false;
|
|
}
|
|
|
|
}
|
|
|
|
$user = e107::user($uid);
|
|
|
|
$uclass = explode(",", $user['user_class']);
|
|
|
|
if($this->pmPrefs['send_to_class'] == 'matchclass')
|
|
{
|
|
$tmp = explode(",", USERCLASS);
|
|
$result = array_intersect($uclass, $tmp);
|
|
|
|
return !empty($result);
|
|
}
|
|
|
|
return in_array($this->pmPrefs['send_to_class'], $uclass);
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
/**
|
|
* Get inbox - up to $limit messages from $from
|
|
*
|
|
* @param int $uid - user ID
|
|
* @param int $from - first message
|
|
* @param int $limit - number of messages
|
|
*
|
|
* @return boolean|array - FALSE if none found or error, array of PMs if available
|
|
*/
|
|
function pm_get_inbox($uid = USERID, $from = 0, $limit = 10)
|
|
{
|
|
$sql = e107::getDb();
|
|
$ret = array();
|
|
$total_messages = 0;
|
|
$uid = intval($uid);
|
|
$limit = intval($limit);
|
|
if ($limit < 2) { $limit = 10; }
|
|
$from = intval($from);
|
|
$qry = "
|
|
SELECT SQL_CALC_FOUND_ROWS pm.*, u.user_image, u.user_name FROM `#private_msg` AS pm
|
|
LEFT JOIN `#user` AS u ON u.user_id = pm.pm_from
|
|
WHERE pm.pm_to='{$uid}' AND pm.pm_read_del=0
|
|
ORDER BY pm.pm_sent DESC
|
|
LIMIT ".$from.", ".$limit."
|
|
";
|
|
|
|
if($sql->gen($qry))
|
|
{
|
|
$total_messages = $sql->foundRows(); // Total number of messages
|
|
$ret['messages'] = $sql->db_getList();
|
|
}
|
|
|
|
$ret['total_messages'] = $total_messages; // Should always be defined
|
|
return $ret;
|
|
}
|
|
|
|
|
|
/**
|
|
* Get outbox - up to $limit messages from $from
|
|
*
|
|
* @param int $uid - user ID
|
|
* @param int $from - first message
|
|
* @param int $limit - number of messages
|
|
*
|
|
* @return boolean|array - FALSE if none found or error, array of PMs if available
|
|
*/
|
|
function pm_get_outbox($uid = USERID, $from = 0, $limit = 10)
|
|
{
|
|
$sql = e107::getDb();
|
|
$ret = array();
|
|
$total_messages = 0;
|
|
$uid = intval($uid);
|
|
$limit = intval($limit);
|
|
if ($limit < 2) { $limit = 10; }
|
|
$from = intval($from);
|
|
$qry = "
|
|
SELECT SQL_CALC_FOUND_ROWS pm.*, u.user_image, u.user_name FROM #private_msg AS pm
|
|
LEFT JOIN #user AS u ON u.user_id = pm.pm_to
|
|
WHERE pm.pm_from='{$uid}' AND pm.pm_sent_del = '0'
|
|
|
|
ORDER BY pm.pm_sent DESC
|
|
LIMIT ".$from.', '.$limit;
|
|
|
|
if($sql->gen($qry))
|
|
{
|
|
$total_messages = $sql->total_results; // Total number of messages
|
|
$ret['messages'] = $sql->db_getList();
|
|
}
|
|
$ret['total_messages'] = $total_messages;
|
|
return $ret;
|
|
}
|
|
|
|
|
|
/**
|
|
* Send a file down to the user
|
|
*
|
|
* @param int $pmid - PM ID
|
|
* @param string $filenum - attachment number within the list associated with the PM
|
|
*
|
|
* @return none
|
|
*
|
|
*/
|
|
function send_file($pmid, $filenum)
|
|
{
|
|
$pm_info = $this->pm_get($pmid);
|
|
|
|
$attachments = explode(chr(0), $pm_info['pm_attachments']);
|
|
|
|
if(!isset($attachments[$filenum]))
|
|
{
|
|
return false;
|
|
}
|
|
|
|
$fname = $attachments[$filenum];
|
|
list($timestamp, $fromid, $rand, $file) = explode("_", $fname, 4);
|
|
|
|
|
|
$filename = false; // getcwd()."/attachments/{$fname}";
|
|
|
|
$pathList = array();
|
|
$pathList[] = e_PLUGIN."pm/attachments/"; // getcwd()."/attachments/"; // legacy path.
|
|
$pathList[] = e107::getFile()->getUserDir($fromid, false, 'attachments'); // new media path.
|
|
|
|
foreach($pathList as $path)
|
|
{
|
|
$tPath = $path.$fname;
|
|
|
|
if(is_file($tPath))
|
|
{
|
|
$filename = $tPath;
|
|
break;
|
|
}
|
|
|
|
}
|
|
|
|
if(empty($filename) || !is_file($filename))
|
|
{
|
|
return false;
|
|
}
|
|
|
|
|
|
if($fromid != $pm_info['pm_from'])
|
|
{
|
|
return false;
|
|
}
|
|
|
|
// e107::getFile()->send($filename); // limited to Media and system folders. Won't work for legacy plugin path.
|
|
// exit;
|
|
|
|
|
|
|
|
@set_time_limit(10 * 60);
|
|
@ini_set("max_execution_time", 10 * 60);
|
|
while (ob_get_length() !== false) // destroy all ouput buffering
|
|
{
|
|
ob_end_clean();
|
|
}
|
|
|
|
if (connection_status() == 0)
|
|
{
|
|
if (strpos($_SERVER['HTTP_USER_AGENT'], "MSIE") !== false) {
|
|
$file = preg_replace('/\./', '%2e', $file, substr_count($file, '.') - 1);
|
|
}
|
|
if (isset($_SERVER['HTTP_RANGE']))
|
|
{
|
|
$seek = intval(substr($_SERVER['HTTP_RANGE'] , strlen('bytes=')));
|
|
}
|
|
$bufsize = 2048;
|
|
ignore_user_abort(true);
|
|
$data_len = filesize($filename);
|
|
if ($seek > ($data_len - 1)) $seek = 0;
|
|
$res = fopen($filename, 'rb');
|
|
if ($seek)
|
|
{
|
|
fseek($res , $seek);
|
|
}
|
|
$data_len -= $seek;
|
|
header("Expires: 0");
|
|
header("Cache-Control: max-age=30" );
|
|
header("Content-Type: application/force-download");
|
|
header("Content-Disposition: attachment; filename={$file}");
|
|
header("Content-Length: {$data_len}");
|
|
header("Pragma: public");
|
|
if ($seek)
|
|
{
|
|
header("Accept-Ranges: bytes");
|
|
header("HTTP/1.0 206 Partial Content");
|
|
header("status: 206 Partial Content");
|
|
header("Content-Range: bytes {$seek}-".($data_len - 1)."/{$data_len}");
|
|
}
|
|
while (!connection_aborted() && $data_len > 0)
|
|
{
|
|
echo fread($res , $bufsize);
|
|
$data_len -= $bufsize;
|
|
}
|
|
fclose($res);
|
|
}
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
function updateTemplate($template)
|
|
{
|
|
$array = array(
|
|
'FORM_TOUSER' => 'PM_FORM_TOUSER',
|
|
'FORM_TOCLASS' => 'PM_FORM_TOCLASS',
|
|
'FORM_SUBJECT' => 'PM_FORM_SUBJECT',
|
|
'FORM_MESSAGE' => 'PM_FORM_MESSAGE',
|
|
'EMOTES' => 'PM_EMOTES',
|
|
'ATTACHMENT' => 'PM_ATTACHMENT',
|
|
'RECEIPT' => 'PM_RECEIPT',
|
|
'INBOX_TOTAL' => 'PM_INBOX_TOTAL',
|
|
'INBOX_UNREAD' => 'PM_INBOX_UNREAD',
|
|
'INBOX_FILLED' => 'PM_INBOX_FILLED',
|
|
'OUTBOX_TOTAL' => 'PM_OUTBOX_TOTAL',
|
|
'OUTBOX_UNREAD' => 'PM_OUTBOX_UNREAD',
|
|
'OUTBOX_FILLED' => 'PM_OUTBOX_FILLED',
|
|
|
|
'SEND_PM_LINK' => 'PM_SEND_PM_LINK',
|
|
'NEWPM_ANIMATE' => 'PM_NEWPM_ANIMATE',
|
|
|
|
'BLOCKED_SENDERS_MANAGE' => 'PM_BLOCKED_SENDERS_MANAGE',
|
|
'DELETE_BLOCKED_SELECTED' => 'DELETE_BLOCKED_SELECTED'
|
|
);
|
|
|
|
|
|
foreach($array as $old => $new)
|
|
{
|
|
$template = str_replace("{".$old."}", "{".$new."}", $template);
|
|
}
|
|
|
|
return $template;
|
|
|
|
}
|
|
|
|
}
|