Files
Siro/backend/ride/invitor/get_passenger_referrals.php
2026-06-25 01:37:23 +03:00

86 lines
2.5 KiB
PHP

<?php
require_once __DIR__ . '/../../connect.php';
// Use JWT token variables provided by connect.php
if (!$user_id || $role != 'passenger') {
jsonError("Invalid parameters or unauthorized token");
}
$country_code = $_POST['country_code'] ?? 'Jordan';
// 1. Get the passenger's referral code
$stmtCode = $con->prepare("SELECT referral_code FROM user_referral_codes WHERE user_id = ? AND user_type = 'passenger'");
$stmtCode->execute([$user_id]);
if ($stmtCode->rowCount() == 0) {
// If no code exists, return empty stats
printSuccess([
"referral_code" => null,
"total_invited_drivers" => 0,
"total_invited_passengers" => 0,
"referrals" => []
]);
exit;
}
$referralCode = $stmtCode->fetchColumn();
// 2. Fetch all referrals made by this code
$stmtRefs = $con->prepare("
SELECT id, invited_user_id, invited_user_type, status, trip_count, is_reward_claimed, created_at
FROM unified_referrals
WHERE inviter_code = ?
ORDER BY created_at DESC
");
$stmtRefs->execute([$referralCode]);
$referrals = $stmtRefs->fetchAll(PDO::FETCH_ASSOC);
$totalDrivers = 0;
$totalPassengers = 0;
// Country-specific reward thresholds
switch ($country_code) {
case 'Syria':
$driverTargetTrips = 50;
$driverReward = 500;
$passengerTargetTrips = 1;
$passengerReward = 30;
break;
case 'Egypt':
$driverTargetTrips = 30;
$driverReward = 100;
$passengerTargetTrips = 2;
$passengerReward = 20;
break;
case 'Jordan':
default:
$driverTargetTrips = 20;
$driverReward = 5;
$passengerTargetTrips = 2;
$passengerReward = 2;
break;
}
// Format data and calculate stats
foreach ($referrals as &$ref) {
if ($ref['invited_user_type'] == 'driver') {
$totalDrivers++;
$ref['target_trips'] = $driverTargetTrips;
$ref['reward_syp'] = $driverReward;
$ref['can_claim'] = ($ref['trip_count'] >= $driverTargetTrips && $ref['is_reward_claimed'] == 0) ? true : false;
} else {
$totalPassengers++;
$ref['target_trips'] = $passengerTargetTrips;
$ref['reward_syp'] = $passengerReward;
$ref['can_claim'] = ($ref['trip_count'] >= $passengerTargetTrips && $ref['is_reward_claimed'] == 0) ? true : false;
}
}
printSuccess([
"referral_code" => $referralCode,
"total_invited_drivers" => $totalDrivers,
"total_invited_passengers" => $totalPassengers,
"referrals" => $referrals
]);
?>