You can not select more than 25 topics Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.
 
 
 
 
 
 

207 lines
8.2 KiB

<?php
// (c) Copyright by authors of the Tiki Wiki CMS Groupware Project
//
// All Rights Reserved. See copyright.txt for details and a complete list of authors.
// Licensed under the GNU LESSER GENERAL PUBLIC LICENSE. See license.txt for details.
// $Id$
//this script may only be included - so its better to die if called directly.
if (strpos($_SERVER["SCRIPT_NAME"], basename(__FILE__)) !== false) {
header("location: index.php");
exit;
}
require_once 'lib/socialnetworkslib.php';
class ShoutboxLib extends TikiLib
{
public function list_shoutbox($offset, $maxRecords, $sort_mode, $find)
{
global $prefs;
$parserlib = TikiLib::lib('parser');
if ($find) {
$mid = " where (`message` like ?)";
$bindvars = ['%' . $find . '%'];
} else {
$mid = "";
$bindvars = [];
}
$query = "select * from `tiki_shoutbox` $mid order by " . $this->convertSortMode($sort_mode);
$query_cant = "select count(*) from `tiki_shoutbox` $mid";
$result = $this->query($query, $bindvars, $maxRecords, $offset);
$cant = $this->getOne($query_cant, $bindvars);
$ret = [];
while ($res = $result->fetchRow()) {
if (! $res["user"]) {
$res["user"] = tra('Anonymous');
}
// convert ampersands and other stuff to xhtml compliant entities
$res["message"] = htmlspecialchars($res["message"]);
if ($prefs['shoutbox_autolink'] == 'y') {
// we replace urls starting with http(s)|ftp(s) to active links
$res["message"] = preg_replace("/((http|ftp)+(s)?:\/\/[^<>\s]+)/i", "<a href=\"\\0\">\\0</a>", $res["message"]);
// we replace also urls starting with www. only to active links
$res["message"] = preg_replace("/(?<!http|ftp)(?<!s)(?<!:\/\/)(www\.[^ )\s\r\n]+)/i", "<a href=\"http://\\0\">\\0</a>", $res["message"]);
// we replace also urls longer than 30 chars with translantable string as link description instead the URL itself to prevent breaking the layout in some browsers (e.g. Konqueror)
$res["message"] = preg_replace("/(<a href=\")((http|ftp)+(s)?:\/\/[^\"]+)(\">)([^<]){30,}<\/a>/i", "<a href=\"\\2\">[" . tra('Link') . "]</a>", $res["message"]);
}
// if not in html tag (e.g. autolink), place after every '*;' the empty span too to prevent e.g. '&amp;&amp;...'
//$res["message"] = preg_replace('/(\s*)([^>]+)(<|$)/e', "'\\1'.str_replace(';', ';<span></span>','\\2').'\\3'", $res["message"]);
$res["message"] = preg_replace_callback('/(\s*)([^>]+)(<|$)/', function ($mat) {
return $mat[1] . str_replace(';', ';<span></span>', $mat[2]) . $mat[3];
}, $res["message"]);
// if not in tag or on a space or doesn't contain a html entity we split all plain text strings longer than 25 chars using the empty span tag again
$wrap_at = 25;
// $res["message"] = preg_replace('e', "'\\1'.wordwrap('\\2', '".$wrap_at."', '<span></span>', 1).'\\3'", $res["message"]);
$res["message"] = preg_replace_callback('/(\s*)([^\;>\s]{' . $wrap_at . ',})([^&]<|$)/', function ($m, $wrap_at) {
return $m[1] . wordwrap($m[2], $wrap_at, '<span></span>', 1) . $m[3];
}, $res["message"]);
// emoticons support
$res["message"] = $parserlib->parse_smileys($res["message"]);
$ret[] = $res;
}
$retval = [];
$retval["data"] = $ret;
$retval["cant"] = $cant;
return $retval;
}
public function tweet($message, $user, $msgId)
{
global $prefs, $socialnetworkslib;
$id = $socialnetworkslib->tweet($message, $user);
if ($id > 0) {
$query = "update `tiki_shoutbox` set `tweetId`=? where `user`=? and `msgId`=?";
$bindvars = [$id,$user,$msgId];
$this->query($query, $bindvars);
}
return $id;
}
public function replace_shoutbox($msgId, $user, $message, $tweet = false, $facebook = false)
{
$message = strip_tags($message);
// Check Message for containing bad/banned words
$words = $this->get_bad_words();
$badmsg = false;
foreach ($words["data"] as $word) {
if (preg_match("/" . $word["word"] . "/i", $message)) {
$badmsg = true;
break;
}
}
//Die if badmsg with suitable error screen
if ($badmsg) {
return false;
}
// Back on track for normal shoutbox posting
$hash = md5($message); // this checks for the same message already existing
$cant = $this->getOne("select count(*) from `tiki_shoutbox` where `hash`=? and `user`=?", [$hash,$user]);
if ($cant) {
// at least update the timestamp - can be convenient if message is thanks or hello - we can see the last post
$query = "update `tiki_shoutbox` set `timestamp`=? where `user`=? and `hash`=?";
$bindvars = [(int) $this->now, $user, $hash];
} elseif ($msgId) {
$query = "update `tiki_shoutbox` set `user`=?, `message`=?, `hash`=? where `msgId`=?";
$bindvars = [$user,$message,$hash,(int) $msgId];
} else {
$query = "delete from `tiki_shoutbox` where `user`=? and `timestamp`=? and `hash`=?";
$bindvars = [$user,(int) $this->now,$hash];
$this->query($query, $bindvars);
$query = "insert into `tiki_shoutbox`(`message`,`user`,`timestamp`,`hash`) values(?,?,?,?)";
$bindvars = [$message,$user,(int) $this->now,$hash];
}
$result = $this->query($query, $bindvars);
if ($tweet) {
$msgId = $this->lastInsertId();
$this->tweet($message, $user, $msgId);
}
if ($facebook) {
global $socialnetworkslib;
require_once('lib/socialnetworkslib.php');
$fbreply = $socialnetworkslib->facebookWallPublish($user, $message);
}
return true;
}
public function remove_shoutbox($msgId)
{
global $socialnetworkslib, $user;
$tweetId = $this->getOne("select `tweetId` from `tiki_shoutbox` where `msgId`=?", [$msgId]);
if ($tweetId > 0) {
$socialnetworkslib->destroyTweet($tweetId, $user);
}
$query = "delete from `tiki_shoutbox` where `msgId`=?";
$result = $this->query($query, [(int) $msgId]);
return true;
}
public function get_shoutbox($msgId)
{
$query = "select * from `tiki_shoutbox` where `msgId`=?";
$result = $this->query($query, [(int) $msgId]);
if (! $result->numRows()) {
return false;
}
$res = $result->fetchRow();
return $res;
}
public function get_bad_words($offset = 0, $maxRecords = -1, $sort_mode = 'word_asc', $find = '')
{
if ($find) {
$findesc = "%$find%";
$mid = " where `word` like ?";
$bindvars = [$findesc];
} else {
$mid = '';
$bindvars = [];
}
$query = "select * from `tiki_shoutbox_words` $mid order by " . $this->convertSortMode($sort_mode);
$query_cant = "select count(*) from `tiki_shoutbox_words` $mid";
$result = $this->query($query, $bindvars, $maxRecords, $offset);
$cant = $this->getOne($query_cant, $bindvars);
$ret = [];
while ($res = $result->fetchRow()) {
$ret[] = $res;
}
$retval = [];
$retval["data"] = $ret;
$retval["cant"] = $cant;
return $retval;
}
public function add_bad_word($word)
{
$word = addslashes($word);
$query = "delete from `tiki_shoutbox_words` where `word`=?";
$result = $this->query($query, [$word]);
$query = "insert into `tiki_shoutbox_words` (`word`) values(?)";
$result = $this->query($query, [$word]);
return true;
}
public function remove_bad_word($word)
{
$query = "delete from `tiki_shoutbox_words` where `word`=?";
$result = $this->query($query, [$word]);
}
}
$shoutboxlib = new ShoutboxLib();