本文整理匯總了PHP中CRatings::GetRatingUserProp方法的典型用法代碼示例。如果您正苦於以下問題:PHP CRatings::GetRatingUserProp方法的具體用法?PHP CRatings::GetRatingUserProp怎麽用?PHP CRatings::GetRatingUserProp使用的例子?那麽, 這裏精選的方法代碼示例或許可以為您提供幫助。您也可以進一步了解該方法所在類CRatings
的用法示例。
在下文中一共展示了CRatings::GetRatingUserProp方法的2個代碼示例,這些例子默認根據受歡迎程度排序。您可以為喜歡或者感覺有用的代碼點讚,您的評價將有助於係統推薦出更棒的PHP代碼示例。
示例1: AddRatingVote
/**
* <p>Метод добавляет голос к рейтинговому голосованию. Динамичный метод.</p>
*
*
* @param array $Param Массив значений параметров. В качестве ключей данного массива
* допустимо использовать: <ul> <li> <b>ENTITY_TYPE_ID</b> – объект голосования.
* Например: FORUM_TOPIC для тем форума, FORUM_POST для сообщений форума, BLOG_POST
* для постов в блоге, BLOG_COMMENT для комментариев в блоге. Сам список
* кодов не регламентирован, можно использовать любой удобный.</li> <li>
* <b>ENTITY_ID</b> – идентификатор объекта голосования</li> <li> <b>VALUE</b> –
* выставленная оценка</li> <li> <b>USER_ID</b> – идентификатор
* пользователя</li> <li> <b>USER_IP</b> – IP-адрес пользователя</li> </ul> Все поля
* являются обязательными.
*
* @return bool
*
* <h4>Example</h4>
* <pre>
* <?
* // добавляем теме отрицательную оценку.
* $arAddVote = array(
* "ENTITY_TYPE_ID" => "FORUM_TOPIC",
* "ENTITY_ID" => 38,
* "VALUE" => -1,
* "USER_ID" => 1,
* "USER_IP" => '127.0.0.1',
* );
* CRatings::AddRatingVote($arAddVote);
* ?>
* </pre>
*
*
* @static
* @link http://dev.1c-bitrix.ru/api_help/main/reference/cratings/addratingvote.php
* @author Bitrix
*/
public static function AddRatingVote($arParam)
{
global $DB, $CACHE_MANAGER;
if (isset($_SESSION['RATING_VOTE_COUNT']) && $arParam['ENTITY_TYPE_ID'] == 'USER') {
if ($_SESSION['RATING_VOTE_COUNT'] >= $_SESSION['RATING_USER_VOTE_COUNT']) {
return false;
} else {
$_SESSION['RATING_VOTE_COUNT']++;
}
}
$arParam['ENTITY_TYPE_ID'] = substr($arParam['ENTITY_TYPE_ID'], 0, 50);
CRatings::CancelRatingVote($arParam);
$err_mess = CRatings::err_mess() . "<br>Function: AddRatingVote<br>Line: ";
$votePlus = $arParam['VALUE'] >= 0 ? true : false;
$ratingId = CRatings::GetAuthorityRating();
$arRatingUserProp = CRatings::GetRatingUserProp($ratingId, $arParam['USER_ID']);
$voteUserWeight = $arRatingUserProp['VOTE_WEIGHT'];
$sRatingWeightType = COption::GetOptionString("main", "rating_weight_type", "auto");
if ($sRatingWeightType == 'auto') {
if ($arParam['ENTITY_TYPE_ID'] == 'USER') {
$sRatingAuthrorityWeight = COption::GetOptionString("main", "rating_authority_weight_formula", 'Y');
if ($sRatingAuthrorityWeight == 'Y') {
$communitySize = COption::GetOptionString("main", "rating_community_size", 1);
$communityAuthority = COption::GetOptionString("main", "rating_community_authority", 1);
$voteWeight = COption::GetOptionString("main", "rating_vote_weight", 1);
$arParam['VALUE'] = $arParam['VALUE'] * ($communitySize * ($voteUserWeight / $voteWeight) / $communityAuthority);
}
} else {
$arParam['VALUE'] = $arParam['VALUE'] * $voteUserWeight;
}
} else {
$arParam['VALUE'] = $arParam['VALUE'] * $voteUserWeight;
}
$arFields = array('ACTIVE' => "'Y'", 'TOTAL_VOTES' => "TOTAL_VOTES+1", 'TOTAL_VALUE' => "TOTAL_VALUE" . ($votePlus ? '+' : '') . floatval($arParam['VALUE']), 'LAST_CALCULATED' => $DB->GetNowFunction());
$arFields[$votePlus ? 'TOTAL_POSITIVE_VOTES' : 'TOTAL_NEGATIVE_VOTES'] = $votePlus ? 'TOTAL_POSITIVE_VOTES+1' : 'TOTAL_NEGATIVE_VOTES+1';
// GetOwnerDocument
$arParam['OWNER_ID'] = 0;
foreach (GetModuleEvents("main", "OnGetRatingContentOwner", true) as $arEvent) {
$result = ExecuteModuleEventEx($arEvent, array($arParam));
if ($result !== false) {
$arParam['OWNER_ID'] = IntVal($result);
}
}
$rowAffected = $DB->Update("b_rating_voting", $arFields, "WHERE ENTITY_TYPE_ID='" . $DB->ForSql($arParam['ENTITY_TYPE_ID']) . "' AND ENTITY_ID='" . intval($arParam['ENTITY_ID']) . "'", $err_mess . __LINE__);
if ($rowAffected > 0) {
$rsRV = $DB->Query("SELECT ID, TOTAL_POSITIVE_VOTES FROM b_rating_voting WHERE ENTITY_TYPE_ID='" . $DB->ForSql($arParam['ENTITY_TYPE_ID']) . "' AND ENTITY_ID='" . intval($arParam['ENTITY_ID']) . "'", false, $err_mess . __LINE__);
$arRV = $rsRV->Fetch();
$arParam['RATING_VOTING_ID'] = $arRV['ID'];
$arParam['TOTAL_POSITIVE_VOTES'] = $arRV['TOTAL_POSITIVE_VOTES'];
} else {
$arFields = array("ENTITY_TYPE_ID" => "'" . $DB->ForSql($arParam["ENTITY_TYPE_ID"]) . "'", "ENTITY_ID" => intval($arParam['ENTITY_ID']), "OWNER_ID" => intval($arParam['OWNER_ID']), "ACTIVE" => "'Y'", "CREATED" => $DB->GetNowFunction(), "LAST_CALCULATED" => $DB->GetNowFunction(), "TOTAL_VOTES" => 1, "TOTAL_VALUE" => floatval($arParam['VALUE']), "TOTAL_POSITIVE_VOTES" => $votePlus ? 1 : 0, "TOTAL_NEGATIVE_VOTES" => $votePlus ? 0 : 1);
$arParam['RATING_VOTING_ID'] = $DB->Insert("b_rating_voting", $arFields, $err_mess . __LINE__);
$arParam['TOTAL_POSITIVE_VOTES'] = $votePlus ? 1 : 0;
}
$arFields = array("RATING_VOTING_ID" => intval($arParam['RATING_VOTING_ID']), "ENTITY_TYPE_ID" => "'" . $DB->ForSql($arParam["ENTITY_TYPE_ID"]) . "'", "ENTITY_ID" => intval($arParam['ENTITY_ID']), "VALUE" => floatval($arParam['VALUE']), "ACTIVE" => "'Y'", "CREATED" => $DB->GetNowFunction(), "USER_ID" => intval($arParam['USER_ID']), "USER_IP" => "'" . $DB->ForSql($arParam["USER_IP"]) . "'", "OWNER_ID" => intval($arParam['OWNER_ID']));
$ID = $DB->Insert("b_rating_vote", $arFields, $err_mess . __LINE__);
foreach (GetModuleEvents("main", "OnAddRatingVote", true) as $arEvent) {
ExecuteModuleEventEx($arEvent, array(intval($ID), $arParam));
}
if (CModule::IncludeModule('pull')) {
CPullStack::AddShared(array('module_id' => 'main', 'command' => 'rating_vote', 'params' => array("TYPE" => "ADD", "USER_ID" => intval($arParam['USER_ID']), "ENTITY_TYPE_ID" => $arParam["ENTITY_TYPE_ID"], "ENTITY_ID" => intval($arParam['ENTITY_ID']), "TOTAL_POSITIVE_VOTES" => $arParam['TOTAL_POSITIVE_VOTES'], "RESULT" => $votePlus ? 'PLUS' : 'MINUS')));
}
if (CACHED_b_rating_vote !== false) {
$bucket_size = intval(CACHED_b_rating_bucket_size);
//.........這裏部分代碼省略.........
示例2: CheckAllowVote
function CheckAllowVote($arVoteParam)
{
global $USER;
$userId = $USER->GetId();
$bUserAuth = $USER->IsAuthorized();
$bAllGroups = false;
$arInfo = array(
'RESULT' => true,
'ERROR_TYPE' => '',
'ERROR_MSG' => '',
);
$bSelfVote = COption::GetOptionString("main", "rating_self_vote", 'N');
if ($bSelfVote == 'N' && IntVal($arVoteParam['OWNER_ID']) == $userId)
{
$arInfo = array(
'RESULT' => false,
'ERROR_TYPE' => 'SELF',
'ERROR_MSG' => GetMessage('RATING_ALLOW_VOTE_SELF'),
);
}
else if (!$bUserAuth)
{
$arInfo = array(
'RESULT' => false,
'ERROR_TYPE' => 'GUEST',
'ERROR_MSG' => GetMessage('RATING_ALLOW_VOTE_GUEST'),
);
}
else
{
static $cacheAllowVote = array();
static $cacheUserVote = array();
static $cacheVoteAccess = null;
static $cacheVoteGroup = array();
static $cacheVoteSize = 0;
if(!array_key_exists($userId, $cacheAllowVote))
{
global $DB;
$arGroups = array();
$bAllGroups = false;
$sVoteType = $arVoteParam['ENTITY_TYPE_ID'] == 'USER'? 'A': 'R';
if (!isset($cacheVoteGroup[$sVoteType]))
{
$cacheVoteGroup[$sVoteType] = Array();
$rsGroups = CRatings::GetVoteGroup($sVoteType);
while ($arVoteGroup = $rsGroups->Fetch())
$cacheVoteGroup[$sVoteType][] = $arVoteGroup;
}
foreach($cacheVoteGroup[$sVoteType] as $arVoteGroup)
{
if ($arVoteGroup['GROUP_ID'] == 2)
{
$bAllGroups = true;
break;
}
$arGroups[] = $arVoteGroup['GROUP_ID'];
}
if (!$bAllGroups && !empty($arGroups) && is_null($cacheVoteAccess))
{
$strSql = '
SELECT * FROM b_user_group UG
WHERE UG.GROUP_ID IN ('.implode(',', $arGroups).')
AND UG.USER_ID = '.$userId.'
AND ((UG.DATE_ACTIVE_FROM IS NULL) OR (UG.DATE_ACTIVE_FROM <= '.$DB->CurrentTimeFunction().'))
AND ((UG.DATE_ACTIVE_TO IS NULL) OR (UG.DATE_ACTIVE_TO >= '.$DB->CurrentTimeFunction().'))';
$res = $DB->Query($strSql, false, $err_mess.__LINE__);
if ($row = $res->Fetch())
$cacheVoteAccess = true;
else
{
$cacheVoteAccess = false;
$arInfo = $cacheAllowVote[$userId] = array(
'RESULT' => false,
'ERROR_TYPE' => 'ACCESS',
'ERROR_MSG' => GetMessage('RATING_ALLOW_VOTE_ACCESS'),
);
}
}
$authorityRatingId = CRatings::GetAuthorityRating();
$arAuthorityUserProp = CRatings::GetRatingUserProp($authorityRatingId, $userId);
if ($arAuthorityUserProp['VOTE_WEIGHT'] <= 0)
{
$arInfo = $cacheAllowVote[$userId] = array(
'RESULT' => false,
'ERROR_TYPE' => 'ACCESS',
'ERROR_MSG' => GetMessage('RATING_ALLOW_VOTE_LOW_WEIGHT'),
);
}
if ($arInfo['RESULT'] && $sVoteType == 'A')
{
$strSql = '
SELECT COUNT(*) as VOTE
FROM b_rating_vote RV
WHERE RV.USER_ID = '.$userId.'
//.........這裏部分代碼省略.........