• Модуль: forum
  • Путь к файлу: ~/bitrix/modules/forum/classes/general/user.php
  • Класс: CAllForumRank
  • Вызов: CAllForumRank::GetList
static function GetList($arOrder = array("MIN_NUM_POSTS"=>"ASC"), $arFilter = array())
{
	global $DB;
	$arSqlSearch = array();
	$arSqlOrder = array();
	$strSqlSearch = "";
	$strSqlOrder = "";
	$arFilter = (is_array($arFilter) ? $arFilter : array());

	foreach ($arFilter as $key => $val)
	{
		$key_res = CForumNew::GetFilterOperation($key);
		$key = mb_strtoupper($key_res["FIELD"]);
		$strNegative = $key_res["NEGATIVE"];
		$strOperation = $key_res["OPERATION"];

		switch ($key)
		{
			case "ID":
			case "MIN_NUM_POSTS":
				if (intval($val)<=0)
					$arSqlSearch[] = ($strNegative=="Y"?"NOT":"")."(FR.".$key." IS NULL OR FR.".$key."<=0)";
				else
					$arSqlSearch[] = ($strNegative=="Y"?" FR.".$key." IS NULL OR NOT ":"")."(FR.".$key." ".$strOperation." ".intval($val)." )";
				break;
		}
	}

	if (count($arSqlSearch) > 0)
		$strSqlSearch = " AND (".implode(") AND (", $arSqlSearch).") ";

	foreach ($arOrder as $by=>$order)
	{
		$by = mb_strtoupper($by);
		$order = mb_strtoupper($order);
		if ($order!="ASC") $order = "DESC";

		if ($by == "ID") $arSqlOrder[] = " FR.ID ".$order." ";
		else
		{
			$arSqlOrder[] = " FR.MIN_NUM_POSTS ".$order." ";
			$by = "MIN_NUM_POSTS";
		}
	}
	DelDuplicateSort($arSqlOrder);
	if (count($arSqlOrder) > 0)
		$strSqlOrder = " ORDER BY ".implode(", ", $arSqlOrder);

	$strSql =
		"SELECT FR.ID, FR.MIN_NUM_POSTS
		FROM b_forum_rank FR
		WHERE 1 = 1
		".$strSqlSearch."
		".$strSqlOrder;

	$db_res = $DB->Query($strSql, false, "File: ".__FILE__."
Line: ".__LINE__); return $db_res; }