Update: 2026-06-15 19:39:21
This commit is contained in:
@@ -3,27 +3,73 @@ require_once __DIR__ . '/../../connect.php';
|
||||
|
||||
$driver_id = filterRequest("id");
|
||||
$phone = filterRequest("phone");
|
||||
$status = filterRequest("status");
|
||||
|
||||
// تشفير رقم الهاتف
|
||||
$encphone = $encryptionHelper->encryptData($phone);
|
||||
if (empty($driver_id)) {
|
||||
jsonError("Driver ID is required.");
|
||||
}
|
||||
|
||||
$sql = "UPDATE `driver` SET `phone` = :encphone WHERE `id` = :id";
|
||||
$updateFields = [];
|
||||
$params = [':id' => $driver_id];
|
||||
|
||||
if ($phone !== null && $phone !== '') {
|
||||
$encphone = $encryptionHelper->encryptData($phone);
|
||||
$updateFields[] = "`phone` = :phone";
|
||||
$params[':phone'] = $encphone;
|
||||
}
|
||||
|
||||
if ($status !== null && $status !== '') {
|
||||
$updateFields[] = "`status` = :status";
|
||||
$params[':status'] = $status;
|
||||
}
|
||||
|
||||
if (empty($updateFields)) {
|
||||
jsonError("No parameters provided for update.");
|
||||
}
|
||||
|
||||
$sql = "UPDATE `driver` SET " . implode(", ", $updateFields) . " WHERE `id` = :id";
|
||||
$stmt = $con->prepare($sql);
|
||||
|
||||
// Bind values
|
||||
$stmt->bindParam(':encphone', $encphone, PDO::PARAM_STR);
|
||||
$stmt->bindParam(':id', $driver_id, PDO::PARAM_STR);
|
||||
|
||||
try {
|
||||
$stmt->execute();
|
||||
$stmt->execute($params);
|
||||
|
||||
if ($stmt->rowCount() > 0) {
|
||||
// تم التحديث بنجاح
|
||||
logAudit($con, $user_id, "تعديل رقم هاتف سائق", "driver", $driver_id, ["phone" => $phone]);
|
||||
jsonSuccess(null, "Phone updated successfully.");
|
||||
logAudit($con, $user_id, "تعديل بيانات سائق من لوحة التحكم", "driver", $driver_id, [
|
||||
"phone" => $phone,
|
||||
"status" => $status
|
||||
]);
|
||||
|
||||
// إذا تم تفعيل السائق، نرسل له رسالة ترحيبية عبر الواتساب لتأكيد التفعيل
|
||||
if ($status === 'active' || $status === 'actives') {
|
||||
// جلب معلومات السائق لإرسال الرسالة
|
||||
$selectSql = "SELECT `phone`, `first_name` FROM `driver` WHERE `id` = :id";
|
||||
$selectStmt = $con->prepare($selectSql);
|
||||
$selectStmt->execute([':id' => $driver_id]);
|
||||
$driverData = $selectStmt->fetch(PDO::FETCH_ASSOC);
|
||||
|
||||
if ($driverData) {
|
||||
$decryptedPhone = $encryptionHelper->decryptData($driverData['phone']);
|
||||
$firstName = $encryptionHelper->decryptData($driverData['first_name']);
|
||||
|
||||
$supportPhones = ['0952475740', '0952475742'];
|
||||
$randomIndex = array_rand($supportPhones);
|
||||
$phoneToUse = $supportPhones[$randomIndex];
|
||||
$randomNumber = rand(1000, 999999);
|
||||
|
||||
$messageBody = "أهلاً وسهلاً كابتن $firstName 👋\n"
|
||||
. "تم تفعيل حسابك على تطبيق *سيرو*.\n"
|
||||
. "يمكنك الآن تسجيل الدخول والبدء بالعمل مباشرة.\n"
|
||||
. "للمساعدة تواصل معنا على الرقم: $phoneToUse\n"
|
||||
. "نتمنى لك عمل موفق 🚖\n\n"
|
||||
. "معرف الرسالة: $randomNumber";
|
||||
|
||||
sendWhatsAppFromServer($decryptedPhone, $messageBody);
|
||||
}
|
||||
}
|
||||
|
||||
jsonSuccess(null, "Driver updated successfully.");
|
||||
} else {
|
||||
// لم يتم العثور على أي سجل للتحديث
|
||||
jsonError("No records updated. Please check the driver ID.");
|
||||
jsonError("No records updated or driver not found.");
|
||||
}
|
||||
} catch (PDOException $e) {
|
||||
jsonError("Error updating record: " . $e->getMessage());
|
||||
|
||||
Reference in New Issue
Block a user