• Модуль: forum
  • Путь к файлу: ~/bitrix/modules/forum/classes/general/points.php
  • Класс: CAllForumUserPoints
  • Вызов: CAllForumUserPoints::GetList
static function GetList($arOrder = array("TO_USER_ID"=>"ASC"), $arFilter = array())
{
	global $DB;
	$arSqlSearch = Array();
	$strSqlSearch = "";
	$arSqlOrder = Array();
	$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 "FROM_USER_ID":
			case "TO_USER_ID":
				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 (!empty($arSqlSearch))
		$strSqlSearch = " WHERE (".implode(") AND (", $arSqlSearch).") ";

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

		if ($by == "FROM_USER_ID") $arSqlOrder[] = " FR.FROM_USER_ID ".$order." ";
		elseif ($by == "POINTS") $arSqlOrder[] = " FR.POINTS ".$order." ";
		elseif ($by == "DATE_UPDATE") $arSqlOrder[] = " FR.DATE_UPDATE ".$order." ";
		else
		{
			$arSqlOrder[] = " FR.TO_USER_ID ".$order." ";
			$by = "TO_USER_ID";
		}
	}
	DelDuplicateSort($arSqlOrder);
	if (!empty($arSqlOrder))
		$strSqlOrder = " ORDER BY ".implode(", ", $arSqlOrder);

	$strSql =
		"SELECT FR.FROM_USER_ID, FR.TO_USER_ID, FR.POINTS, FR.DATE_UPDATE ".
		"FROM b_forum_user_points FR ".
		$strSqlSearch." ".
		$strSqlOrder;
	$db_res = $DB->Query($strSql, false, "File: ".__FILE__."
Line: ".__LINE__); return $db_res; }