first commit
This commit is contained in:
30
backend/ride/rate/add.php
Normal file
30
backend/ride/rate/add.php
Normal 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");
|
||||
}
|
||||
?>
|
||||
58
backend/ride/rate/addRateToDriver.php
Normal file
58
backend/ride/rate/addRateToDriver.php
Normal 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
backend/ride/rate/add_rate_app.php
Executable file
34
backend/ride/rate/add_rate_app.php
Executable 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
backend/ride/rate/error_log
Normal file
0
backend/ride/rate/error_log
Normal file
25
backend/ride/rate/getDriverRate.php
Executable file
25
backend/ride/rate/getDriverRate.php
Executable 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
backend/ride/rate/getPassengerRate.php
Executable file
23
backend/ride/rate/getPassengerRate.php
Executable 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");
|
||||
}
|
||||
?>
|
||||
77
backend/ride/rate/sendEmailRateingApp.php
Executable file
77
backend/ride/rate/sendEmailRateingApp.php
Executable 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.";
|
||||
}
|
||||
?>
|
||||
|
||||
Reference in New Issue
Block a user