mirror of
https://github.com/lkddi/nexusphp.git
synced 2026-04-23 11:27:24 +08:00
official additioin + zero bonus
This commit is contained in:
+23
-9
@@ -265,22 +265,36 @@ function docleanup($forceAll = 0, $printProgress = false) {
|
||||
if (mysql_num_rows($res) > 0)
|
||||
{
|
||||
$haremAdditionFactor = get_setting('bonus.harem_addition');
|
||||
$officialAdditionFactor = get_setting('bonus.official_addition');
|
||||
while ($arr = mysql_fetch_assoc($res)) //loop for different users
|
||||
{
|
||||
$userInfo = get_user_row($arr['userid']);
|
||||
$isDonor = is_donor($userInfo);
|
||||
$seedBonusResult = calculate_seed_bonus($arr['userid']);
|
||||
$dividend = 3600 / $autoclean_interval_one;
|
||||
$all_bonus = $seedBonusResult['all_bonus'] / $dividend;
|
||||
$seed_points = $seedBonusResult['seed_points'] / $dividend;
|
||||
$bonusLog = "[CLEANUP_CALCULATE_SEED_BONUS], user: {$arr['userid']}, seedBonusResult: " . nexus_json_encode($seedBonusResult) . ", all_bonus: $all_bonus, seed_points: $seed_points";
|
||||
if ($haremAdditionFactor > 0) {
|
||||
$haremAddition = calculate_harem_addition($arr['userid']) * $haremAdditionFactor / $dividend;
|
||||
$all_bonus += $haremAddition;
|
||||
$bonusLog .= ", haremAddition: $haremAddition, new all_bonus: $all_bonus";
|
||||
$bonusLog = "[CLEANUP_CALCULATE_SEED_BONUS], user: {$arr['userid']}, seedBonusResult: " . nexus_json_encode($seedBonusResult);
|
||||
$all_bonus = $seedBonusResult['seed_bonus'];
|
||||
$bonusLog .= ", all_bonus: $all_bonus";
|
||||
if ($isDonor) {
|
||||
$all_bonus = $all_bonus * $donortimes_bonus;
|
||||
$bonusLog .= ", isDonor, donortimes_bonus: $donortimes_bonus, all_bonus: $all_bonus";
|
||||
}
|
||||
if ($officialAdditionFactor > 0) {
|
||||
$officialAddition = $seedBonusResult['official_bonus'] * $officialAdditionFactor;
|
||||
$all_bonus += $officialAddition;
|
||||
$bonusLog .= ", officialAdditionFactor: $officialAdditionFactor, official_bonus: {$seedBonusResult['official_bonus']}, officialAddition: $officialAddition, all_bonus: $all_bonus";
|
||||
}
|
||||
if ($haremAdditionFactor > 0) {
|
||||
$haremBonus = calculate_harem_addition($arr['userid']);
|
||||
$haremAddition = $haremBonus * $haremAdditionFactor;
|
||||
$all_bonus += $haremAddition;
|
||||
$bonusLog .= ", haremAdditionFactor: $haremAdditionFactor, haremBonus: $haremBonus, haremAddition: $haremAddition, all_bonus: $all_bonus";
|
||||
}
|
||||
$dividend = 3600 / $autoclean_interval_one;
|
||||
$all_bonus = $all_bonus / $dividend;
|
||||
$seed_points = $seedBonusResult['seed_points'] / $dividend;
|
||||
$sql = "update users set seed_points = ifnull(seed_points, 0) + $seed_points, seedbonus = seedbonus + $all_bonus where id = {$arr["userid"]}";
|
||||
do_log("$bonusLog, query: $sql");
|
||||
sql_query($sql);
|
||||
|
||||
}
|
||||
}
|
||||
$log = 'calculate seeding bonus';
|
||||
|
||||
@@ -23,13 +23,14 @@ if (isset($_SERVER['argv'][1])) {
|
||||
$force = $_SERVER['argv'][1] ? 1 : 0;
|
||||
}
|
||||
$logPrefix = "[CLEANUP_CLI]";
|
||||
$begin = time();
|
||||
try {
|
||||
if ($force) {
|
||||
$result = docleanup(1, true);
|
||||
} else {
|
||||
$result = autoclean(true);
|
||||
}
|
||||
$log = "$logPrefix, DONE: $result";
|
||||
$log = "$logPrefix, DONE: $result, cost time in seconds: " . (time() - $begin);
|
||||
do_log($log);
|
||||
printProgress($log);
|
||||
} catch (\Exception $exception) {
|
||||
|
||||
@@ -1,6 +1,6 @@
|
||||
<?php
|
||||
defined('VERSION_NUMBER') || define('VERSION_NUMBER', '1.7.27');
|
||||
defined('RELEASE_DATE') || define('RELEASE_DATE', '2022-09-20');
|
||||
defined('VERSION_NUMBER') || define('VERSION_NUMBER', '1.7.28');
|
||||
defined('RELEASE_DATE') || define('RELEASE_DATE', '2022-09-25');
|
||||
defined('IN_TRACKER') || define('IN_TRACKER', false);
|
||||
defined('PROJECTNAME') || define("PROJECTNAME","NexusPHP");
|
||||
defined('NEXUSPHPURL') || define("NEXUSPHPURL","https://nexusphp.org");
|
||||
|
||||
+33
-18
@@ -5828,35 +5828,50 @@ function calculate_seed_bonus($uid, $torrentIdArr = null): array
|
||||
} else {
|
||||
$sql = "select torrents.id, torrents.added, torrents.size, torrents.seeders, peers.id as peerID from torrents LEFT JOIN peers ON peers.torrent = torrents.id WHERE peers.userid = $uid AND peers.seeder ='yes' group by peers.torrent, peers.peer_id";
|
||||
}
|
||||
$tagGrouped = [];
|
||||
$torrentResult = \Nexus\Database\NexusDB::select($sql);
|
||||
do_log("$logPrefix, sql: $sql, count: " . count($torrentResult));
|
||||
if (!empty($torrentResult)) {
|
||||
$torrentIdArrReal = array_column($torrentResult, 'id');
|
||||
$tagResult = \Nexus\Database\NexusDB::select(sprintf("select torrent_id, tag_id from torrent_tags where torrent_id in (%s)", implode(',', $torrentIdArrReal)));
|
||||
foreach ($tagResult as $tagItem) {
|
||||
$tagGrouped[$tagItem['torrent_id']][$tagItem['tag_id']] = 1;
|
||||
}
|
||||
}
|
||||
$officialTag = \App\Models\Setting::get('system.official_tag');
|
||||
$officialAdditionalFactor = \App\Models\Setting::get('bonus.official_addition');
|
||||
$zeroBonusTag = \App\Models\Setting::get('bonus.zero_bonus_tag');
|
||||
$zeroBonusFactor = \App\Models\Setting::get('bonus.zero_bonus_factor');
|
||||
do_log("$logPrefix, sql: $sql, count: " . count($torrentResult) . ", officialTag: $officialTag, officialAdditionalFactor: $officialAdditionalFactor, zeroBonusTag: $zeroBonusTag, zeroBonusFactor: $zeroBonusFactor");
|
||||
$official_a = 0;
|
||||
foreach ($torrentResult as $torrent)
|
||||
{
|
||||
$weeks_alive = ($timenow - strtotime($torrent['added'])) / $sectoweek;
|
||||
$gb_size = $torrent['size'] / 1073741824;
|
||||
$gb_size = $gb_size_raw = $torrent['size'] / 1073741824;
|
||||
if ($zeroBonusTag && isset($tagGrouped[$torrent['id']][$zeroBonusTag]) && is_numeric($zeroBonusFactor)) {
|
||||
$gb_size = $gb_size * $zeroBonusFactor;
|
||||
}
|
||||
$temp = (1 - exp($valueone * $weeks_alive)) * $gb_size * (1 + $sqrtof2 * exp($valuethree * ($torrent['seeders'] - 1)));
|
||||
do_log(sprintf(
|
||||
"$logPrefix, torrent: %s, peer ID: %s, weeks: %s, size: %s GB, increase A: %s",
|
||||
$torrent['id'], $torrent['peerID'], $weeks_alive, $gb_size, $temp
|
||||
));
|
||||
$A += $temp;
|
||||
$count++;
|
||||
$torrent_peer_count++;
|
||||
$officialAIncrease = 0;
|
||||
if ($officialTag && isset($tagGrouped[$torrent['id']][$officialTag])) {
|
||||
$officialAIncrease = $temp;
|
||||
}
|
||||
$official_a += $officialAIncrease;
|
||||
do_log(sprintf(
|
||||
"$logPrefix, torrent: %s, peer ID: %s, weeks: %s, size_raw: %s GB, size: %s GB, increase A: %s, increase official A: %s",
|
||||
$torrent['id'], $torrent['peerID'], $weeks_alive, $gb_size_raw, $gb_size, $temp, $officialAIncrease
|
||||
));
|
||||
}
|
||||
if ($count > $maxseeding_bonus)
|
||||
$count = $maxseeding_bonus;
|
||||
$all_bonus = $seed_bonus = $seed_points = $valuetwo * atan($A / $l_bonus) + ($perseeding_bonus * $count);
|
||||
$is_donor_info = \Nexus\Database\NexusDB::getOne('users', "id = $uid", "donor, donoruntil");
|
||||
$is_donor_until = $is_donor_info['donoruntil'];
|
||||
$is_donor = $is_donor_info['donor'] == 'yes' && ($is_donor_until === null || $is_donor_until == '0000-00-00 00:00:00' || $is_donor_until >= date('Y-m-d H:i:s'));
|
||||
$is_donor = intval($is_donor);
|
||||
$log = "$logPrefix, original bonus: $all_bonus, is_donor: $is_donor, donortimes_bonus: $donortimes_bonus";
|
||||
if ($is_donor && $donortimes_bonus > 0) {
|
||||
$all_bonus = $all_bonus * $donortimes_bonus;
|
||||
$log .= ", do multiple, all_bonus: $all_bonus";
|
||||
}
|
||||
$result = compact('seed_points','seed_bonus', 'all_bonus', 'A', 'count', 'torrent_peer_count');
|
||||
do_log("$log, result: " . json_encode($result));
|
||||
$seed_bonus = $seed_points = $valuetwo * atan($A / $l_bonus) + ($perseeding_bonus * $count);
|
||||
$official_bonus = $valuetwo * atan($official_a / $l_bonus) + ($perseeding_bonus * $count);
|
||||
$result = compact('seed_points','seed_bonus', 'A', 'count', 'torrent_peer_count', 'official_a', 'official_bonus');
|
||||
$result['donor_times'] = $donortimes_bonus;
|
||||
$result['official_additional_factor'] = $officialAdditionalFactor;
|
||||
do_log("$logPrefix, result: " . json_encode($result));
|
||||
return $result;
|
||||
}
|
||||
|
||||
|
||||
@@ -730,6 +730,7 @@ function get_user_row($id)
|
||||
} else {
|
||||
$arr['__is_rainbow'] = 0;
|
||||
}
|
||||
$arr['__is_donor'] = is_donor($arr);
|
||||
return apply_filter("user_row", $arr);
|
||||
});
|
||||
|
||||
@@ -1031,3 +1032,8 @@ function user_can($permission, $fail = false, $uid = 0): bool
|
||||
}
|
||||
throw new \App\Exceptions\InsufficientPermissionException();
|
||||
}
|
||||
|
||||
function is_donor(array $userInfo): bool
|
||||
{
|
||||
return $userInfo['donor'] == 'yes' && ($userInfo['donoruntil'] === null || $userInfo['donoruntil'] == '0000-00-00 00:00:00' || $userInfo['donoruntil'] >= date('Y-m-d H:i:s'));
|
||||
}
|
||||
|
||||
Reference in New Issue
Block a user