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.
 
 
 
 
 
 

666 lines
23 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;
}
/**
*
*/
class RankLib extends TikiLib
{
/**
* @param $limit
* @param array $categ
* @param null $lang
* @return mixed
*/
public function wiki_ranking_top_pages($limit, $categ = [], $lang = null)
{
global $user, $prefs;
$pagesAdded = [];
$bindvals = [];
$mid = '';
if ($categ) {
$mid .= " INNER JOIN (`tiki_objects` as tob, `tiki_category_objects` as tco) ON (tp.`pageName` = tob.`itemId` and tob.`objectId` = tco.`catObjectId`) WHERE tob.`type` = 'wiki page' AND (tco.`categId` = ?";
$bindvals[] = $categ[0];
//FIXME
for ($i = 1, $icount_categ = count($categ); $i < $icount_categ; $i++) {
$mid .= " OR tco.`categId` = " . $categ[$i];
}
$mid .= ")";
}
$query = "select distinct tp.`pageName`, tp.`hits`, tp.`lang`, tp.`page_id` from `tiki_pages` tp $mid order by `hits` desc";
$result = $this->query($query, $bindvals);
$ret = [];
$count = 0;
while (($res = $result->fetchRow()) && $count < $limit) {
$perms = Perms::get(['type' => 'wiki page', 'object' => $res['pageName']]);
if ($perms->view) {
global $disableBestLang;
$disableBestLang = false;
if ($res['lang'] > '' && $prefs['feature_best_language'] == 'y') {
// find best language equivalent
$multilinguallib = TikiLib::lib('multilingual');
if ($multilinguallib->useBestLanguage()) {
$bestLangPageId = $multilinguallib->selectLangObj('wiki page', $res['page_id'], null, 'tiki_p_view');
if ($res['page_id'] != $bestLangPageId) {
$res['pageName'] = $this->get_page_name_from_id($bestLangPageId);
}
}
}
if ($prefs['feature_best_language'] != 'y' || ! $res['lang'] || empty($pagesAdded) || ! in_array($res['pageName'], $pagesAdded)) {
$aux['name'] = $res['pageName'];
$aux['hits'] = $res['hits'];
$aux['href'] = 'tiki-index.php?page=' . urlencode($res['pageName']);
if ($disableBestLang == true) {
$aux['href'] .= '&amp;bl=n';
}
$ret[] = $aux;
$pagesAdded[] = $res['pageName'];
++$count;
}
}
}
$retval["data"] = $ret;
$retval["title"] = tra("Wiki top pages");
$retval["y"] = tra("Hits");
$retval["type"] = "nb";
return $retval;
}
/**
* @param $limit
* @param array $categ
* @return mixed
*/
public function wiki_ranking_top_pagerank($limit, $categ = [])
{
global $user, $prefs;
$roll = mt_rand(1, (int) $prefs['wiki_ranking_reload_probability']);
if ($roll == 1) {
$this->pageRank();
}
$bindvals = [];
$mid = '';
if ($categ) {
$mid .= " INNER JOIN (`tiki_objects` as tob, `tiki_category_objects` as tco) ON (tp.`pageName` = tob.`itemId` and tob.`objectId` = tco.`catObjectId`) WHERE tob.`type` = 'wiki page' AND (tco.`categId` = ?";
//FIXME
$bindvals[] = $categ[0];
for ($i = 1, $icount_categ = count($categ); $i < $icount_categ; $i++) {
$mid .= " OR tco.`categId` = " . $categ[$i];
}
$mid .= ")";
}
$query = "select tp.`pageName`, tp.`pageRank` from `tiki_pages` tp $mid order by `pageRank` desc";
$result = $this->query($query, $bindvals);
$ret = [];
$count = 0;
while (($res = $result->fetchRow()) && $count < $limit) {
if ($this->user_has_perm_on_object($user, $res['pageName'], 'wiki page', 'tiki_p_view')) {
$aux['name'] = $res['pageName'];
$aux['hits'] = $res['pageRank'];
$aux['href'] = 'tiki-index.php?page=' . urlencode($res['pageName']);
$ret[] = $aux;
++$count;
}
}
$retval["data"] = $ret;
$retval["title"] = tra("Most-relevant pages");
$retval["y"] = tra("Relevance");
$retval["type"] = "nb";
return $retval;
}
/**
* @param $limit
* @param array $categ
* @return mixed
*/
public function wiki_ranking_last_pages($limit, $categ = [])
{
global $user, $prefs;
$bindvals = [];
$mid = '';
if ($categ) {
$mid .= " INNER JOIN (`tiki_objects` as tob, `tiki_category_objects` as tco) ON (tp.`pageName` = tob.`itemId` and tob.`objectId` = tco.`catObjectId`) WHERE tob.`type` = 'wiki page' AND (tco.`categId` = ?";
//FIXME
$bindvals[] = $categ[0];
for ($i = 1, $icount_categ = count($categ); $i < $icount_categ; $i++) {
$mid .= " OR tco.`categId` = " . $categ[$i];
}
$mid .= ")";
}
$query = "select tp.`pageName`, tp.`lastModif`, tp.`hits` from `tiki_pages` tp $mid order by `lastModif` desc";
$result = $this->query($query, $bindvals);
$ret = [];
$count = 0;
while (($res = $result->fetchRow()) && $count < $limit) {
if ($this->user_has_perm_on_object($user, $res['pageName'], 'wiki page', 'tiki_p_view')) {
$aux['name'] = $res['pageName'];
$aux['hits'] = $res['lastModif'];
$aux['href'] = 'tiki-index.php?page=' . urlencode($res['pageName']);
$ret[] = $aux;
++$count;
}
}
$retval["data"] = $ret;
$retval["title"] = tra("Wiki last pages");
$retval["y"] = tra("Modified");
$retval["type"] = "date";
return $retval;
}
/**
* @param $limit
* @param string $forumId
* @param bool $last_replied
* @return mixed
*/
public function forums_ranking_last_replied_topics($limit, $forumId = '', $last_replied = true)
{
$retval = $this->forums_ranking_last_topics($limit, $forumId, $last_replied);
return $retval;
}
public function forums_ranking_last_topics($limit, $forumId = '', $last_replied = false)
{
// $last_replied == true, means that topics shown will be based on last replied, not last created.
global $user;
if (is_array($forumId)) {
$bindvars = $forumId;
$mid = ' and a.`object` in (' . implode(',', array_fill(0, count($forumId), '?')) . ')';
} elseif (! empty($forumId)) {
$bindvars = [(int) $forumId];
$mid = ' and a.`object`=?';
} else {
$bindvars = [];
$mid = '';
}
/*if ($last_replied == false)
{ */
$query = "select * from
`tiki_comments` a,`tiki_forums` tf where
`objectType` = 'forum' and
`parentId`=0 $mid order by `commentDate` desc";
/*} else {
$query = "select a.*, tf.*, max(b.`commentDate`) as `lastPost` from
`tiki_comments` a left join `tiki_comments` b on b.`parentId`=a.`threadId` right join `tiki_forums` tf on "
.$this->cast("tf.`forumId`","string")." = a.`object`".
" where a.`objectType` = 'forum' and a.`parentId`=0 $mid group by a.`threadId` order by `lastPost` desc";
}*/
$result = $this->query($query, $bindvars);
$ret = [];
$count = 0;
while (($res = $result->fetchRow()) && $count < $limit) {
if ($this->user_has_perm_on_object($user, $res['threadId'], 'thread', 'tiki_p_forum_read')) {
if ($mid == '') { // no forumId selected
$aux['name'] = $res['name'] . ': ' . $res['title']; //forum name plus topic
} else { // forumId selected
$aux['name'] = $res['title']; // omit forum name
}
$aux['title'] = $res['title'];
$aux['href'] = 'tiki-view_forum_thread.php?comments_parentId=' . $res['threadId'];
if ($last_replied == false) {
$aux['date'] = $res['commentDate'];
// the following line is correct, the second column named hits shows date
$aux['hits'] = $res['commentDate'];
} else {
$aux['date'] = $res['lastPost'];
$aux['hits'] = $res['lastPost'];
}
$aux['user'] = $res['userName'];
$ret[] = $aux;
++$count;
}
}
$retval["data"] = $ret;
$retval["title"] = tra("Forums last topics");
$retval["y"] = tra("Topic date");
$retval["type"] = "date";
return $retval;
}
/**
* @param $limit
* @param bool $toponly
* @param string $forumId
* @return mixed
*/
public function forums_ranking_last_posts($limit, $toponly = false, $forumId = '')
{
global $user;
$offset = 0;
$count = 0;
$ret = [];
$result = TikiLib::lib('comments')->get_all_comments('forum', 0, $limit, 'commentDate_desc', '', '', '', $toponly, $forumId);
$result['data'] = Perms::filter(['type' => 'forum'], 'object', $result['data'], ['object' => 'object'], 'forum_read');
foreach ($result['data'] as $res) {
$aux['name'] = $res['title'];
$aux['title'] = $res['parentTitle'];
$tmp = $res['parentId'];
if ($tmp == 0) {
$tmp = $res['threadId'];
}
$aux['href'] = $res['href'];
$aux['hits'] = $this->get_long_datetime($res['commentDate']);
$tmp = $res['parentId'];
if ($tmp == 0) {
$tmp = $res['threadId'];
}
$aux['date'] = $res['commentDate'];
$aux['user'] = $res['userName'];
$ret[] = $aux;
}
$retval["data"] = $ret;
$retval["title"] = tra("Forums last posts");
$retval["y"] = tra("Topic date");
$retval["type"] = "date";
return $retval;
}
/**
* @param $limit
* @param string $forumId
* @return mixed
*/
public function forums_ranking_most_read_topics($limit, $forumId = '')
{
$result = TikiLib::lib('comments')->get_all_comments('forum', 0, $limit, 'hits_desc', '', '', '', true, $forumId);
$ret = [];
foreach ($result['data'] as $res) {
$aux['name'] = $forumId ? $res['title'] : $res['parentTitle'] . ': ' . $res['title'];
$aux['title'] = $res['title'];
$aux['hits'] = $res['hits'];
$aux['href'] = 'tiki-view_forum_thread.php?comments_parentId=' . $res['threadId'];
$ret[] = $aux;
}
$retval["data"] = $ret;
$retval["title"] = tra("Forums most-read topics");
$retval["y"] = tra("Reads");
$retval["type"] = "nb";
return $retval;
}
/**
* @param $qty
* @return mixed
*/
public function forums_top_posters($qty)
{
$query = "select `user`, `posts` from `tiki_user_postings` order by " . $this->convertSortMode("posts_desc");
$result = $this->query($query, [], $qty);
$ret = [];
while ($res = $result->fetchRow()) {
$aux["name"] = $res["user"];
$aux["posts"] = $res["posts"];
$ret[] = $aux;
}
$retval["data"] = $ret;
return $retval;
}
/**
* @param $limit
* @return mixed
*/
public function forums_ranking_top_topics($limit)
{
$ret = [];
$comments = TikiLib::lib('comments')->get_forum_topics(null, 0, $limit, 'average_desc');
foreach ($comments as $res) {
$aux = [];
$aux['name'] = $res['name'] . ': ' . $res['title'];
$aux['title'] = $res['title'];
$aux['hits'] = $res['average'];
$aux['href'] = 'tiki-view_forum_thread.php?comments_parentId=' . $res['threadId'];
$ret[] = $aux;
}
$retval["data"] = $ret;
$retval["title"] = tra("Forums best topics");
$retval["y"] = tra("Score");
$retval["type"] = "nb";
return $retval;
}
/**
* @param $limit
* @return mixed
*/
public function forums_ranking_most_visited_forums($limit)
{
$result = TikiLib::lib('comments')->list_forums(0, $limit, 'hits_desc');
$ret = [];
$count = 0;
foreach ($result['data'] as $res) {
$aux['name'] = $res['name'];
$aux['hits'] = $res['hits'];
$aux['href'] = 'tiki-view_forum.php?forumId=' . $res['forumId'];
$ret[] = $aux;
}
$retval["data"] = $ret;
$retval["title"] = tra("Most-visited forums");
$retval["y"] = tra("Visits");
$retval["type"] = "nb";
return $retval;
}
/**
* @param $limit
* @return mixed
*/
public function forums_ranking_most_commented_forum($limit)
{
$result = TikiLib::lib('comments')->list_forums(0, $limit, 'comments_desc');
$ret = [];
$count = 0;
foreach ($result['data'] as $res) {
$aux['name'] = $res['name'];
$aux['hits'] = $res['hits'];
$aux['href'] = 'tiki-view_forum.php?forumId=' . $res['forumId'];
$ret[] = $aux;
}
$retval["data"] = $ret;
$retval["title"] = tra("Forums with most posts");
$retval["y"] = tra("Posts");
$retval["type"] = "nb";
return $retval;
}
/**
* @param $limit
* @return mixed
*/
public function filegal_ranking_top_galleries($limit)
{
global $user;
$query = "select * from `tiki_file_galleries` where `visible`=? order by `hits` desc";
$result = $this->query($query, ['y'], $limit, 0);
$ret = [];
$count = 0;
while (($res = $result->fetchRow()) && $count < $limit) {
if ($this->user_has_perm_on_object($user, $res['galleryId'], 'file gallery', 'tiki_p_view_file_gallery')) {
$aux['name'] = $res['name'];
$aux['hits'] = $res['hits'];
$aux['href'] = 'tiki-list_file_gallery.php?galleryId=' . $res['galleryId'];
$ret[] = $aux;
++$count;
}
}
$retval["data"] = $ret;
$retval["title"] = tra("Wiki top file galleries");
$retval["y"] = tra("Visits");
$retval["type"] = "nb";
return $retval;
}
/**
* @param $limit
* @return mixed
*/
public function filegal_ranking_top_files($limit)
{
global $user;
$query = "select `fileId`,`filename`,`hits`, `galleryId` from `tiki_files` order by `hits` desc";
$result = $this->query($query, [], $limit, 0);
$ret = [];
while ($res = $result->fetchRow()) {
if ($this->user_has_perm_on_object($user, $res['fileId'], 'file', 'tiki_p_view_file_gallery')) {
$aux["name"] = $res["filename"];
$aux["hits"] = $res["hits"];
$aux["href"] = 'tiki-download_file.php?fileId=' . $res["fileId"];
$ret[] = $aux;
}
}
$retval["data"] = $ret;
$retval["title"] = tra("Wiki top files");
$retval["y"] = tra("Downloads");
$retval["type"] = "nb";
return $retval;
}
/**
* @param $limit
* @return mixed
*/
public function filegal_ranking_last_files($limit)
{
global $user;
$query = "select `fileId`,`filename`,`created`, `galleryId` from `tiki_files` order by `created` desc";
$result = $this->query($query, [], $limit, 0);
$ret = [];
while ($res = $result->fetchRow()) {
if ($this->user_has_perm_on_object($user, $res['fileId'], 'file', 'tiki_p_view_file_gallery')) {
$aux["name"] = $res["filename"];
$aux["hits"] = $res["created"];
$aux["href"] = 'tiki-download_file.php?fileId=' . $res["fileId"];
$ret[] = $aux;
}
}
$retval["data"] = $ret;
$retval["title"] = tra("Wiki most-recent files");
$retval["y"] = tra("Upload date");
$retval["type"] = "date";
return $retval;
}
/**
* @param $limit
* @return mixed
*/
public function cms_ranking_top_articles($limit)
{
global $user;
$query = "select `tiki_articles`.*, `tiki_article_types`.`show_pre_publ` from `tiki_articles` inner join `tiki_article_types` on `tiki_articles`.`type` = `tiki_article_types`.`type` order by `nbreads` desc";
$result = $this->query($query, [], $limit, 0);
$ret = [];
while ($res = $result->fetchRow()) {
if ($this->user_has_perm_on_object($user, $res['articleId'], 'article', 'tiki_p_read_article') && ($res["show_pre_publ"] == 'y' or $this->now > $res["publishDate"])) {
$aux["name"] = $res["title"];
$aux["hits"] = $res["nbreads"];
$aux["href"] = 'tiki-read_article.php?articleId=' . $res["articleId"];
$ret[] = $aux;
}
}
$retval["data"] = $ret;
$retval["title"] = tra("Top Articles");
$retval["y"] = tra("Reads");
$retval["type"] = "nb";
return $retval;
}
/**
* @param $limit
* @return mixed
*/
public function blog_ranking_top_blogs($limit)
{
global $user;
$query = "select * from `tiki_blogs` order by `hits` desc";
$result = $this->query($query, [], $limit, 0);
$ret = [];
while ($res = $result->fetchRow()) {
if ($this->user_has_perm_on_object($user, $res['blogId'], 'blog', 'tiki_p_read_blog')) {
$aux["name"] = $res["title"];
$aux["hits"] = $res["hits"];
$aux["href"] = 'tiki-view_blog.php?blogId=' . $res["blogId"];
$ret[] = $aux;
}
}
$retval["data"] = $ret;
$retval["title"] = tra("Most-visited blogs");
$retval["y"] = tra("Visits");
$retval["type"] = "nb";
return $retval;
}
/**
* @param $limit
* @return mixed
*/
public function blog_ranking_top_active_blogs($limit)
{
global $user;
$query = "select * from `tiki_blogs` order by `activity` desc";
$result = $this->query($query, [], $limit, 0);
$ret = [];
while ($res = $result->fetchRow()) {
if ($this->user_has_perm_on_object($user, $res['blogId'], 'blog', 'tiki_p_read_blog')) {
$aux["name"] = $res["title"];
$aux["hits"] = $res["activity"];
$aux["href"] = 'tiki-view_blog.php?blogId=' . $res["blogId"];
$ret[] = $aux;
}
}
$retval["data"] = $ret;
$retval["title"] = tra("Most-active blogs");
$retval["y"] = tra("Activity");
$retval["type"] = "nb";
return $retval;
}
/**
* @param $limit
* @return mixed
*/
public function blog_ranking_last_posts($limit)
{
global $user;
$query = "select * from `tiki_blog_posts` order by `created` desc";
$result = $this->query($query, [], $limit, 0);
$ret = [];
while ($res = $result->fetchRow()) {
if ($this->user_has_perm_on_object($user, $res['postId'], 'blog post', 'tiki_p_read_blog')) {
$q = "select `title` from `tiki_blogs` where `blogId`=?";
$name = $this->getOne($q, [$res["blogId"]]);
$aux["name"] = $name;
$aux["hits"] = $res["created"];
$aux["href"] = 'tiki-view_blog.php?blogId=' . $res["blogId"];
$ret[] = $aux;
}
}
$retval["data"] = $ret;
$retval["title"] = tra("Blogs last posts");
$retval["y"] = tra("Post date");
$retval["type"] = "date";
return $retval;
}
/**
* @param $limit
* @param array $categ
* @return mixed
*/
public function wiki_ranking_top_authors($limit, $categ = [])
{
global $user;
$bindvals = [];
$mid = '';
if ($categ) {
$mid .= " INNER JOIN (`tiki_objects` as tob, `tiki_category_objects` as tco) ON (tp.`pageName` = tob.`itemId` and tob.`objectId` = tco.`catObjectId`)
WHERE tob.`type` = 'wiki page'
AND (tco.`categId` = ?"
;
//FIXME
$bindvals[] = $categ[0];
for ($i = 1, $icount_categ = count($categ); $i < $icount_categ; $i++) {
$mid .= " OR tco.`categId` = " . $categ[$i];
}
$mid .= ")";
}
$query = "select distinct tp.`user`, count(*) as `numb` from `tiki_pages` tp $mid group by `user` order by " . $this->convertSortMode("numb_desc");
$result = $this->query($query, $bindvals, $limit, 0);
$ret = [];
$retu = [];
while ($res = $result->fetchRow()) {
$ret["name"] = $res["user"];
$ret["hits"] = $res["numb"];
$ret["href"] = "tiki-user_information.php?view_user=" . urlencode($res["user"]);
$retu[] = $ret;
}
$retval["data"] = $retu;
$retval["title"] = tra("Wiki top authors");
$retval["y"] = tra("Pages");
$retval["type"] = "nb";
return $retval;
}
/**
* @param $limit
* @return mixed
*/
public function cms_ranking_top_authors($limit)
{
$query = "select distinct `author`, count(*) as `numb` from `tiki_articles` group by `author` order by " . $this->convertSortMode("numb_desc");
$result = $this->query($query, [], $limit, 0);
$ret = [];
$retu = [];
while ($res = $result->fetchRow()) {
$ret["name"] = $res["author"];
$ret["hits"] = $res["numb"];
$ret["href"] = "tiki-user_information.php?view_user=" . urlencode($res["author"]);
$retu[] = $ret;
}
$retval["data"] = $retu;
$retval["title"] = tra("Top article authors");
$retval["y"] = tra("Articles");
$retval["type"] = "nb";
return $retval;
}
}
$ranklib = new RankLib();