Update: 2026-06-22 00:31:28

This commit is contained in:
Hamza-Ayed
2026-06-22 00:31:29 +03:00
parent e73be65a72
commit efe26c95be
19 changed files with 2635 additions and 32 deletions

View File

@@ -0,0 +1,59 @@
<?php
/**
* cron_kazan_adjuster.php
* يضبط عمولة كازان ويضيف حوافز للسائقين المتواجدين في مناطق ذروة المنافسين
*
* المبدأ:
* - تقليل العمولة للمنطقة النشطة (مثال: من 15% إلى 10%)
* - يتم تشغيله كل 10 دقائق
*/
require_once __DIR__ . '/../core/bootstrap.php';
require_once __DIR__ . '/../functions.php';
try {
$con = Database::get('main');
$redis = getRedisConnection();
} catch (Exception $e) {
die("Connection failed: " . $e->getMessage() . "\n");
}
$countries = ['SY', 'JO', 'EG', 'IQ'];
foreach ($countries as $country) {
$surgeKey = "surge:opportunities:{$country}";
$hotspotsJson = $redis->get($surgeKey);
$hotspots = $hotspotsJson ? json_decode($hotspotsJson, true) : [];
// In a real scenario, Kazan configs might be stored in a `kazan_commissions` table
// or applied dynamically at the ride request time.
// Here we will save the "active discounted Kazan multiplier" in Redis so the ride logic can apply it instantly.
$kazanDiscountConfig = [];
if (!empty($hotspots)) {
foreach ($hotspots as $grid => $multiplier) {
// If competitor surge is high enough, we lower our Kazan by a factor
// Standard Kazan is let's say 15%.
if ($multiplier > 1.2) {
// Apply a 30% reduction to Kazan Commission for this grid
$kazanDiscountConfig[$grid] = 0.70; // 70% of standard commission
} elseif ($multiplier > 1.05) {
// Apply a 15% reduction
$kazanDiscountConfig[$grid] = 0.85;
}
}
}
$kazanKey = "surge:kazan_discounts:{$country}";
if (empty($kazanDiscountConfig)) {
$redis->del($kazanKey);
echo "[$country] No active Kazan discounts.\n";
} else {
$redis->setex($kazanKey, 1200, json_encode($kazanDiscountConfig));
echo "[$country] Updated Kazan discounts for " . count($kazanDiscountConfig) . " active hotspots.\n";
}
}
echo "Done.\n";