mirror of
https://github.com/lkddi/nexusphp.git
synced 2026-04-24 12:07:23 +08:00
job add middleware
This commit is contained in:
@@ -12,7 +12,7 @@ class TrustProxies extends Middleware
|
|||||||
*
|
*
|
||||||
* @var array<int, string>|string|null
|
* @var array<int, string>|string|null
|
||||||
*/
|
*/
|
||||||
protected $proxies;
|
protected $proxies = ['*'];
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* The headers that should be used to detect proxies.
|
* The headers that should be used to detect proxies.
|
||||||
|
|||||||
@@ -9,6 +9,7 @@ use Illuminate\Contracts\Queue\ShouldBeUnique;
|
|||||||
use Illuminate\Contracts\Queue\ShouldQueue;
|
use Illuminate\Contracts\Queue\ShouldQueue;
|
||||||
use Illuminate\Foundation\Bus\Dispatchable;
|
use Illuminate\Foundation\Bus\Dispatchable;
|
||||||
use Illuminate\Queue\InteractsWithQueue;
|
use Illuminate\Queue\InteractsWithQueue;
|
||||||
|
use Illuminate\Queue\Middleware\WithoutOverlapping;
|
||||||
use Illuminate\Queue\SerializesModels;
|
use Illuminate\Queue\SerializesModels;
|
||||||
use Nexus\Database\NexusDB;
|
use Nexus\Database\NexusDB;
|
||||||
use Nexus\Nexus;
|
use Nexus\Nexus;
|
||||||
@@ -55,6 +56,16 @@ class CalculateUserSeedBonus implements ShouldQueue
|
|||||||
|
|
||||||
public $timeout = 3600;
|
public $timeout = 3600;
|
||||||
|
|
||||||
|
/**
|
||||||
|
* 获取任务时,应该通过的中间件。
|
||||||
|
*
|
||||||
|
* @return array
|
||||||
|
*/
|
||||||
|
public function middleware()
|
||||||
|
{
|
||||||
|
return [new WithoutOverlapping($this->idRedisKey)];
|
||||||
|
}
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* Execute the job.
|
* Execute the job.
|
||||||
*
|
*
|
||||||
@@ -63,7 +74,10 @@ class CalculateUserSeedBonus implements ShouldQueue
|
|||||||
public function handle()
|
public function handle()
|
||||||
{
|
{
|
||||||
$beginTimestamp = time();
|
$beginTimestamp = time();
|
||||||
$logPrefix = sprintf("[CLEANUP_CLI_CALCULATE_SEED_BONUS_HANDLE_JOB], commonRequestId: %s, beginUid: %s, endUid: %s", $this->requestId, $this->beginUid, $this->endUid);
|
$logPrefix = sprintf(
|
||||||
|
"[CLEANUP_CLI_CALCULATE_SEED_BONUS_HANDLE_JOB], commonRequestId: %s, beginUid: %s, endUid: %s, idStr: %s, idRedisKey: %s",
|
||||||
|
$this->requestId, $this->beginUid, $this->endUid, $this->idStr, $this->idRedisKey
|
||||||
|
);
|
||||||
$haremAdditionFactor = Setting::get('bonus.harem_addition');
|
$haremAdditionFactor = Setting::get('bonus.harem_addition');
|
||||||
$officialAdditionFactor = Setting::get('bonus.official_addition');
|
$officialAdditionFactor = Setting::get('bonus.official_addition');
|
||||||
$donortimes_bonus = Setting::get('bonus.donortimes');
|
$donortimes_bonus = Setting::get('bonus.donortimes');
|
||||||
@@ -114,6 +128,7 @@ class CalculateUserSeedBonus implements ShouldQueue
|
|||||||
$all_bonus += $medalAddition;
|
$all_bonus += $medalAddition;
|
||||||
$bonusLog .= ", medalAdditionFactor: {$seedBonusResult['medal_additional_factor']}, medalBonus: {$seedBonusResult['medal_bonus']}, medalAddition: $medalAddition, all_bonus: $all_bonus";
|
$bonusLog .= ", medalAdditionFactor: {$seedBonusResult['medal_additional_factor']}, medalBonus: {$seedBonusResult['medal_bonus']}, medalAddition: $medalAddition, all_bonus: $all_bonus";
|
||||||
}
|
}
|
||||||
|
do_log($bonusLog);
|
||||||
$dividend = 3600 / $autoclean_interval_one;
|
$dividend = 3600 / $autoclean_interval_one;
|
||||||
$all_bonus = $all_bonus / $dividend;
|
$all_bonus = $all_bonus / $dividend;
|
||||||
$seed_points = $seedBonusResult['seed_points'] / $dividend;
|
$seed_points = $seedBonusResult['seed_points'] / $dividend;
|
||||||
@@ -121,9 +136,9 @@ class CalculateUserSeedBonus implements ShouldQueue
|
|||||||
// $sql = "update users set seed_points = ifnull(seed_points, 0) + $seed_points, seed_points_per_hour = {$seedBonusResult['seed_points']}, seedbonus = seedbonus + $all_bonus, seed_points_updated_at = '$updatedAt' where id = $uid limit 1";
|
// $sql = "update users set seed_points = ifnull(seed_points, 0) + $seed_points, seed_points_per_hour = {$seedBonusResult['seed_points']}, seedbonus = seedbonus + $all_bonus, seed_points_updated_at = '$updatedAt' where id = $uid limit 1";
|
||||||
// do_log("$bonusLog, query: $sql");
|
// do_log("$bonusLog, query: $sql");
|
||||||
// NexusDB::statement($sql);
|
// NexusDB::statement($sql);
|
||||||
$seedPointsUpdates[] = sprintf("when %d then ifnull(seed_points, 0) + %d", $uid, $seed_points);
|
$seedPointsUpdates[] = sprintf("when %d then ifnull(seed_points, 0) + %f", $uid, $seed_points);
|
||||||
$seedPointsPerHourUpdates[] = sprintf("when %d then %d", $uid, $seedBonusResult['seed_points']);
|
$seedPointsPerHourUpdates[] = sprintf("when %d then %f", $uid, $seedBonusResult['seed_points']);
|
||||||
$seedBonusUpdates[] = sprintf("when %d then %d", $uid, $all_bonus);
|
$seedBonusUpdates[] = sprintf("when %d then seedbonus + %f", $uid, $all_bonus);
|
||||||
if ($fd) {
|
if ($fd) {
|
||||||
$log = sprintf(
|
$log = sprintf(
|
||||||
'%s|%s|%s|%s|%s|%s|%s|%s',
|
'%s|%s|%s|%s|%s|%s|%s|%s',
|
||||||
|
|||||||
@@ -10,6 +10,7 @@ use Illuminate\Contracts\Queue\ShouldBeUnique;
|
|||||||
use Illuminate\Contracts\Queue\ShouldQueue;
|
use Illuminate\Contracts\Queue\ShouldQueue;
|
||||||
use Illuminate\Foundation\Bus\Dispatchable;
|
use Illuminate\Foundation\Bus\Dispatchable;
|
||||||
use Illuminate\Queue\InteractsWithQueue;
|
use Illuminate\Queue\InteractsWithQueue;
|
||||||
|
use Illuminate\Queue\Middleware\WithoutOverlapping;
|
||||||
use Illuminate\Queue\SerializesModels;
|
use Illuminate\Queue\SerializesModels;
|
||||||
use Nexus\Database\NexusDB;
|
use Nexus\Database\NexusDB;
|
||||||
|
|
||||||
@@ -55,6 +56,16 @@ class UpdateTorrentSeedersEtc implements ShouldQueue
|
|||||||
|
|
||||||
public $timeout = 1800;
|
public $timeout = 1800;
|
||||||
|
|
||||||
|
/**
|
||||||
|
* 获取任务时,应该通过的中间件。
|
||||||
|
*
|
||||||
|
* @return array
|
||||||
|
*/
|
||||||
|
public function middleware()
|
||||||
|
{
|
||||||
|
return [new WithoutOverlapping($this->idRedisKey)];
|
||||||
|
}
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* Execute the job.
|
* Execute the job.
|
||||||
*
|
*
|
||||||
@@ -63,7 +74,10 @@ class UpdateTorrentSeedersEtc implements ShouldQueue
|
|||||||
public function handle()
|
public function handle()
|
||||||
{
|
{
|
||||||
$beginTimestamp = time();
|
$beginTimestamp = time();
|
||||||
$logPrefix = sprintf("[CLEANUP_CLI_UPDATE_TORRENT_SEEDERS_ETC_HANDLE_JOB], commonRequestId: %s, beginTorrentId: %s, endTorrentId: %s", $this->requestId, $this->beginTorrentId, $this->endTorrentId);
|
$logPrefix = sprintf(
|
||||||
|
"[CLEANUP_CLI_UPDATE_TORRENT_SEEDERS_ETC_HANDLE_JOB], commonRequestId: %s, beginTorrentId: %s, endTorrentId: %s, idStr: %s, idRedisKey: %s",
|
||||||
|
$this->requestId, $this->beginTorrentId, $this->endTorrentId, $this->idStr, $this->idRedisKey
|
||||||
|
);
|
||||||
|
|
||||||
$idStr = $this->idStr;
|
$idStr = $this->idStr;
|
||||||
$delIdRedisKey = false;
|
$delIdRedisKey = false;
|
||||||
|
|||||||
@@ -10,6 +10,7 @@ use Illuminate\Contracts\Queue\ShouldBeUnique;
|
|||||||
use Illuminate\Contracts\Queue\ShouldQueue;
|
use Illuminate\Contracts\Queue\ShouldQueue;
|
||||||
use Illuminate\Foundation\Bus\Dispatchable;
|
use Illuminate\Foundation\Bus\Dispatchable;
|
||||||
use Illuminate\Queue\InteractsWithQueue;
|
use Illuminate\Queue\InteractsWithQueue;
|
||||||
|
use Illuminate\Queue\Middleware\WithoutOverlapping;
|
||||||
use Illuminate\Queue\SerializesModels;
|
use Illuminate\Queue\SerializesModels;
|
||||||
use Nexus\Database\NexusDB;
|
use Nexus\Database\NexusDB;
|
||||||
|
|
||||||
@@ -55,6 +56,16 @@ class UpdateUserSeedingLeechingTime implements ShouldQueue
|
|||||||
|
|
||||||
public $timeout = 3600;
|
public $timeout = 3600;
|
||||||
|
|
||||||
|
/**
|
||||||
|
* 获取任务时,应该通过的中间件。
|
||||||
|
*
|
||||||
|
* @return array
|
||||||
|
*/
|
||||||
|
public function middleware()
|
||||||
|
{
|
||||||
|
return [new WithoutOverlapping($this->idRedisKey)];
|
||||||
|
}
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* Execute the job.
|
* Execute the job.
|
||||||
*
|
*
|
||||||
@@ -63,7 +74,10 @@ class UpdateUserSeedingLeechingTime implements ShouldQueue
|
|||||||
public function handle()
|
public function handle()
|
||||||
{
|
{
|
||||||
$beginTimestamp = time();
|
$beginTimestamp = time();
|
||||||
$logPrefix = sprintf("[CLEANUP_CLI_UPDATE_SEEDING_LEECHING_TIME_HANDLE_JOB], commonRequestId: %s, beginUid: %s, endUid: %s", $this->requestId, $this->beginUid, $this->endUid);
|
$logPrefix = sprintf(
|
||||||
|
"[CLEANUP_CLI_UPDATE_SEEDING_LEECHING_TIME_HANDLE_JOB], commonRequestId: %s, beginUid: %s, endUid: %s, idStr: %s, idRedisKey: %s",
|
||||||
|
$this->requestId, $this->beginUid, $this->endUid, $this->idStr, $this->idRedisKey,
|
||||||
|
);
|
||||||
|
|
||||||
$idStr = $this->idStr;
|
$idStr = $this->idStr;
|
||||||
$delIdRedisKey = false;
|
$delIdRedisKey = false;
|
||||||
|
|||||||
Reference in New Issue
Block a user