Initial commit with updated Auth and media ignored

This commit is contained in:
Hamza-Ayed
2026-04-28 13:04:27 +03:00
commit 67af97474c
477 changed files with 66444 additions and 0 deletions

30
ride/rate/add.php Normal file
View File

@@ -0,0 +1,30 @@
<?php
require_once __DIR__ . '/../../connect.php';
$passenger_id = filterRequest("passenger_id");
$driverID = filterRequest("driverID");
$rideId = filterRequest("rideId");
$rating = filterRequest("rating");
$comment = filterRequest("comment");
$sql = "INSERT INTO `ratingPassenger` (
`passenger_id`, `driverID`, `rideId`, `rating`, `comment`
) VALUES (
:passenger_id, :driverID, :rideId, :rating, :comment
)";
$stmt = $con->prepare($sql);
$stmt->bindParam(':passenger_id', $passenger_id);
$stmt->bindParam(':driverID', $driverID);
$stmt->bindParam(':rideId', $rideId);
$stmt->bindParam(':rating', $rating);
$stmt->bindParam(':comment', $comment);
$stmt->execute();
if ($stmt->rowCount() > 0) {
jsonSuccess(null, "Rate inserted successfully");
} else {
jsonError("Failed to save rating information");
}
?>

View File

@@ -0,0 +1,58 @@
<?php
require_once __DIR__ . '/../../connect.php';
// --- استقبال المتغيرات ---
$passenger_id = filterRequest("passenger_id");
$driver_id = filterRequest("driver_id");
$ride_id = filterRequest("ride_id");
$rating = filterRequest("rating");
$comment = filterRequest("comment");
try {
// التحقق من صحة البيانات الأساسية قبل البدء
if (empty($passenger_id) || empty($driver_id) || empty($ride_id)) {
throw new Exception("Required fields are missing");
}
$sql = "INSERT INTO `ratingDriver`(
`passenger_id`, `driver_id`, `ride_id`, `rating`, `comment`
) VALUES (
:passenger_id, :driver_id, :ride_id, :rating, :comment
)";
$stmt = $con->prepare($sql);
$stmt->bindParam(':passenger_id', $passenger_id);
$stmt->bindParam(':driver_id', $driver_id);
$stmt->bindParam(':ride_id', $ride_id);
$stmt->bindParam(':rating', $rating);
$stmt->bindParam(':comment', $comment);
$stmt->execute();
if ($stmt->rowCount() > 0) {
jsonSuccess(null, "Rate inserted successfully");
} else {
// في حال لم يتم الإدخال ولكن لم يحدث خطأ فني (نادرة الحدوث في Insert)
jsonError("Failed to save rating information");
}
} catch (PDOException $e) {
// --- هذا القسم خاص بأخطاء قاعدة البيانات ---
// 1. تسجيل الخطأ في ملف نصي على السيرفر (للمطور فقط)
// سيتم إنشاء ملف اسمه errors.log في نفس المجلد إذا لم يكن موجوداً
$errorMsg = "[" . date("Y-m-d H:i:s") . "] DB Error: " . $e->getMessage() . " | RideID: $ride_id \n";
file_put_contents("errors.log", $errorMsg, FILE_APPEND);
// 2. إرجاع رسالة خطأ عامة للتطبيق
jsonError("Database Error: Could not save rating");
} catch (Exception $e) {
// --- هذا القسم خاص بالأخطاء العامة الأخرى ---
$errorMsg = "[" . date("Y-m-d H:i:s") . "] General Error: " . $e->getMessage() . "\n";
file_put_contents("errors.log", $errorMsg, FILE_APPEND);
jsonError("Error: " . $e->getMessage());
}
?>

34
ride/rate/add_rate_app.php Executable file
View File

@@ -0,0 +1,34 @@
<?php
require_once __DIR__ . '/../../connect.php';
$name = filterRequest("name");
$email = filterRequest("email");
$phone = filterRequest("phone");
$userId = filterRequest("userId");
$userType = filterRequest("userType");
$rating = filterRequest("rating");
$comment = filterRequest("comment");
$email = $encryptionHelper->encryptData($email);
$phone = $encryptionHelper->encryptData($phone);
// Insert into `ratingApp` table
$sql = "INSERT INTO `ratingApp`(`id`, `name`, `email`, `phone`, `userId`, `userType`, `rating`, `comment`)
VALUES (null, :name, :email, :phone, :userId, :userType, :rating, :comment)";
$stmt = $con->prepare($sql);
$stmt->bindParam(':name', $name);
$stmt->bindParam(':email', $email);
$stmt->bindParam(':phone', $phone);
$stmt->bindParam(':userId', $userId);
$stmt->bindParam(':userType', $userType);
$stmt->bindParam(':rating', $rating);
$stmt->bindParam(':comment', $comment);
$stmt->execute();
if ($stmt->rowCount() > 0) {
jsonSuccess($message = 'Rating inserted successfully');
} else {
jsonError($message = "Failed to save rating information");
}
?>

0
ride/rate/error_log Normal file
View File

25
ride/rate/getDriverRate.php Executable file
View File

@@ -0,0 +1,25 @@
<?php
require_once __DIR__ . '/../../connect.php';
$driver_id = filterRequest("driver_id");
$sql = "SELECT
COALESCE(ROUND(AVG(ratingDriver.rating), 2), 5) as rating
FROM
ratingDriver
WHERE
ratingDriver.driver_id = :driver_id";
$stmt = $con->prepare($sql);
$stmt->bindParam(':driver_id', $driver_id);
$stmt->execute();
if ($stmt->rowCount() > 0) {
// Fetch the record
$row = $stmt->fetchAll(PDO::FETCH_ASSOC);
jsonSuccess($row);
} else {
// Print a failure message
jsonError($message = "No rating record found");
}
?>

23
ride/rate/getPassengerRate.php Executable file
View File

@@ -0,0 +1,23 @@
<?php
require_once __DIR__ . '/../../connect.php';
$passengerId = filterRequest("passenger_id");
$sql = "SELECT
COALESCE(ROUND(AVG(ratingPassenger.rating), 2), 5) as rating
FROM
ratingPassenger
WHERE
ratingPassenger.passenger_id = :passenger_id";
$stmt = $con->prepare($sql);
$stmt->bindParam(':passenger_id', $passengerId);
$stmt->execute();
if ($stmt->rowCount() > 0) {
$row = $stmt->fetch(PDO::FETCH_ASSOC);
jsonSuccess($row);
} else {
jsonError("No rating record found");
}
?>

View File

@@ -0,0 +1,77 @@
<?php
require_once __DIR__ . '/../../connect.php';
// --- الخطوة 1: استلام كافة البيانات من التطبيق ---
$email = filterRequest("email");
$name = filterRequest("name");
$rating = filterRequest("rating");
$comment = filterRequest("comment");
$phone = filterRequest("phone"); // **إضافة: استقبال رقم الهاتف**
// **تحسين: جلب أرقام الدعم من متغيرات البيئة لسهولة التعديل**
$SERVICE_PHONE1 = getenv("SERVICE_PHONE1") ?: 'الرقم الأول غير متوفر';
$SERVICE_PHONE2 = getenv("SERVICE_PHONE2") ?: 'الرقم الثاني غير متوفر';
// --- الخطوة 2: تجهيز رسالة واتساب مخصصة للكباتن بناءً على التقييم ---
$whatsappMessage = "";
if ($rating <= 4) {
$whatsappMessage = "أهلاً كابتن $name، 👋
نشكرك على تقييمك لتطبيق *انطلق* بـ $rating نجوم. نحن نقدر رأيك كثيراً ونسعى دائماً لتحسين خدماتنا.
إذا واجهتك أي مشاكل أو كان لديك أي اقتراحات، يسعدنا تواصلك معنا مباشرة عبر أرقام الدعم التالية لمساعدتك بشكل أفضل:
- $SERVICE_PHONE1
- $SERVICE_PHONE2
فريق انطلق";
} else {
$whatsappMessage = "أهلاً كابتن $name،
شكراً جزيلاً لتقييمك الرائع ($rating نجوم) لتطبيق **انطلق**! يسعدنا أنك تحظى بتجربة مميزة معنا.
نتمنى لك رحلات آمنة وموفقة دائماً.
فريق انطلق";
}
// --- الخطوة 3: إرسال رسالة الواتساب ---
if (!empty($phone)) {
if (sendWhatsAppFromServer($phone, $whatsappMessage)) {
echo "WhatsApp message sent successfully to $phone.\n";
} else {
echo "Failed to send WhatsApp message.\n";
}
} else {
echo "Phone number not provided, skipping WhatsApp.\n";
}
// --- الخطوة 4: إرسال البريد الإلكتروني (كنظام احتياطي) ---
$admin = 'support@intaleqapp.com';
$headers = "MIME-Version: 1.0" . "\r\n";
$headers .= "Content-type: text/html; charset=UTF-8" . "\r\n";
$headers .= "From: $admin" . "\r\n";
$subject = "نشكرك على تقييمك لتطبيق انطلق";
$bodyEmail = "
<html><body dir='rtl' style='text-align:right;'>
<p>أهلاً كابتن $name،</p>
<p>نشكرك جزيل الشكر على تقييمك لتطبيق <strong>انطلق</strong>!</p>
<p>لقد استلمنا تقييمك وهو <strong>$rating نجوم</strong>.</p>
<p>تعليقك: \"$comment\"</p>
<p>نحن نقدر ملاحظاتك، ونسعد دائماً بتواصلك معنا لتحسين تجربتك. إذا كان لديك أي استفسار، لا تتردد بالرد على هذا البريد.</p>
<p>مع خالص الشكر،</p>
<p>فريق انطلق.</p>
</body></html>";
if (mail($email, $subject, $bodyEmail, $headers)) {
echo "Email sent successfully to $email.";
} else {
echo "Failed to send email.";
}
?>