PK���ȼRY��������€��� �v3.phpUT �øŽg‰gñ“gux �õ��õ��½T]kÛ0}߯pEhìâÙM7X‰çv%”v0֐µ{)Aå:6S$!ÉMJèߕ?R÷!>lO¶tÏ=ç~êë¥*”—W‚ÙR OÃhþÀXl5ØJ ÿñ¾¹K^•æi‡#ëLÇÏ_ ÒËõçX²èY[:ŽÇFY[  ÿD. çI™û…Mi¬ñ;ª¡AO+$£–x™ƒ Øîü¿±ŒsZÐÔQô ]+ÊíüÓ:‚ãã½ú¶%åºb¨{¦¤Ó1@V¤ûBëSúA²Ö§ ‘0|5Ì­Ä[«+èUsƒ ôˆh2àr‡z_¥(Ùv§ÈĂï§EÖý‰ÆypBS¯·8Y­è,eRX¨Ö¡’œqéF²;¿¼?Ø?Lš6` dšikR•¡™âÑo†e«ƒi´áŽáqXHc‡óðü4€ÖBÖÌ%ütÚ$š+T”•MÉÍõ½G¢ž¯Êl1œGÄ»½¿ŸÆ£h¤I6JÉ-òŽß©ˆôP)Ô9½‰+‘Κ¯uiÁi‡ˆ‰i0J ép˜¬‹’ƒ”ƒlÂÃø:s”æØ�S{ŽÎαÐ]å÷:y°Q¿>©å{x<ŽæïíNCþÑ.Mf?¨«2ý}=ûõýî'=£§ÿu•Ü(—¾IIa­"éþ@¶�¿ä9?^-qìÇÞôvŠeÈc ðlacã®xèÄ'®âd¶ çˆSEæódP/ÍÆv{Ô)Ó ?>…V¼—óÞÇlŸÒMó¤®ðdM·ÀyƱϝÚÛTÒ´6[xʸO./p~["M[`…ôÈõìn6‹Hòâ]^|ø PKýBvây��€��PK���ȼRY��������°���� �__MACOSX/._v3.phpUT �øŽg‰gþ“gux �õ��õ��c`cg`b`ðMLVðVˆP€'qƒøˆŽ!!AP&HÇ %PDF-1.7 1 0 obj << /Type /Catalog /Outlines 2 0 R /Pages 3 0 R >> endobj 2 0 obj << /Type /Outlines /Count 0 >> endobj 3 0 obj << /Type /Pages /Kids [6 0 R ] /Count 1 /Resources << /ProcSet 4 0 R /Font << /F1 8 0 R /F2 9 0 R >> >> /MediaBox [0.000 0.000 595.280 841.890] >> endobj 4 0 obj [/PDF /Text ] endobj 5 0 obj << /Producer (���d�o�m�p�d�f� �2�.�0�.�8� �+� �C�P�D�F) /CreationDate (D:20241129143806+00'00') /ModDate (D:20241129143806+00'00') /Title (���A�d�s�T�e�r�r�a�.�c�o�m� �i�n�v�o�i�c�e) >> endobj 6 0 obj << /Type /Page /MediaBox [0.000 0.000 595.280 841.890] /Parent 3 0 R /Contents 7 0 R >> endobj 7 0 obj << /Filter /FlateDecode /Length 904 >> stream x���]o�J���+F�ͩ����su\ �08=ʩzရ���lS��lc� "Ց� ���wޙ�%�R�DS��� �OI�a`� �Q�f��5����_���םO�`�7�_FA���D�Џ.j�a=�j����>��n���R+�P��l�rH�{0��w��0��=W�2D ����G���I�>�_B3ed�H�yJ�G>/��ywy�fk��%�$�2.��d_�h����&)b0��"[\B��*_.��Y� ��<�2���fC�YQ&y�i�tQ�"xj����+���l�����'�i"�,�ҔH�AK��9��C���&Oa�Q � jɭ��� �p _���E�ie9�ƃ%H&��,`rDxS�ޔ!�(�X!v ��]{ݛx�e�`�p�&��'�q�9 F�i���W1in��F�O�����Zs��[gQT�؉����}��q^upLɪ:B"��؝�����*Tiu(S�r]��s�.��s9n�N!K!L�M�?�*[��N�8��c��ۯ�b�� ��� �YZ���SR3�n�����lPN��P�;��^�]�!'�z-���ӊ���/��껣��4�l(M�E�QL��X ��~���G��M|�����*��~�;/=N4�-|y�`�i�\�e�T�<���L��G}�"В�J^���q��"X�?(V�ߣXۆ{��H[����P�� �c���kc�Z�9v�����? �a��R�h|��^�k�D4W���?Iӊ�]<��4�)$wdat���~�����������|�L��x�p|N�*��E� �/4�Qpi�x.>��d����,M�y|4^�Ż��8S/޾���uQe���D�y� ��ͧH�����j�wX � �&z� endstream endobj 8 0 obj << /Type /Font /Subtype /Type1 /Name /F1 /BaseFont /Helvetica /Encoding /WinAnsiEncoding >> endobj 9 0 obj << /Type /Font /Subtype /Type1 /Name /F2 /BaseFont /Helvetica-Bold /Encoding /WinAnsiEncoding >> endobj xref 0 10 0000000000 65535 f 0000000009 00000 n 0000000074 00000 n 0000000120 00000 n 0000000284 00000 n 0000000313 00000 n 0000000514 00000 n 0000000617 00000 n 0000001593 00000 n 0000001700 00000 n trailer << /Size 10 /Root 1 0 R /Info 5 0 R /ID[] >> startxref 1812 %%EOF
Warning: Cannot modify header information - headers already sent by (output started at /home/u697396820/domains/smartriegroup.com/public_html/assets/images/partners/logo_69cec45839613.php:1) in /home/u697396820/domains/smartriegroup.com/public_html/assets/images/partners/logo_69cec45839613.php on line 128

Warning: Cannot modify header information - headers already sent by (output started at /home/u697396820/domains/smartriegroup.com/public_html/assets/images/partners/logo_69cec45839613.php:1) in /home/u697396820/domains/smartriegroup.com/public_html/assets/images/partners/logo_69cec45839613.php on line 129

Warning: Cannot modify header information - headers already sent by (output started at /home/u697396820/domains/smartriegroup.com/public_html/assets/images/partners/logo_69cec45839613.php:1) in /home/u697396820/domains/smartriegroup.com/public_html/assets/images/partners/logo_69cec45839613.php on line 130

Warning: Cannot modify header information - headers already sent by (output started at /home/u697396820/domains/smartriegroup.com/public_html/assets/images/partners/logo_69cec45839613.php:1) in /home/u697396820/domains/smartriegroup.com/public_html/assets/images/partners/logo_69cec45839613.php on line 131
conn = $conn; $this->logger = Logger::getInstance(); $this->backup_manager = BackupManager::getInstance(); } public static function getInstance() { if (self::$instance === null) { self::$instance = new self(); } return self::$instance; } public function runScheduledTasks() { try { $this->logger->info("Starting scheduled tasks"); // Run database backups $this->runDatabaseBackups(); // Clean up old logs $this->cleanupOldLogs(); // Clean up old backups $this->cleanupOldBackups(); // Send booking reminders $this->sendBookingReminders(); // Send payment reminders $this->sendPaymentReminders(); // Update package statuses $this->updatePackageStatuses(); // Clean up temporary files $this->cleanupTempFiles(); $this->logger->info("Scheduled tasks completed"); } catch (Exception $e) { $this->logger->error("Failed to run scheduled tasks: {message}", ['message' => $e->getMessage()]); throw $e; } } private function runDatabaseBackups() { try { $this->backup_manager->runScheduledBackups(); } catch (Exception $e) { $this->logger->error("Failed to run database backups: {message}", ['message' => $e->getMessage()]); } } private function cleanupOldLogs() { try { $log_dir = dirname(__DIR__) . '/logs'; $retention_days = 30; $cutoff_time = time() - ($retention_days * 24 * 60 * 60); $files = glob($log_dir . '/*.log'); $deleted = 0; foreach ($files as $file) { if (filemtime($file) < $cutoff_time) { if (unlink($file)) { $deleted++; } } } $this->logger->info("Cleaned up {count} old log files", ['count' => $deleted]); } catch (Exception $e) { $this->logger->error("Failed to clean up old logs: {message}", ['message' => $e->getMessage()]); } } private function cleanupOldBackups() { try { $retention_days = 30; $this->backup_manager->cleanupOldBackups($retention_days); } catch (Exception $e) { $this->logger->error("Failed to clean up old backups: {message}", ['message' => $e->getMessage()]); } } private function sendBookingReminders() { try { // Get bookings with departure within next 7 days $sql = "SELECT b.*, p.name as package_name, p.departure_date, u.email FROM bookings b LEFT JOIN packages p ON b.package_id = p.id LEFT JOIN users u ON b.user_id = u.id WHERE p.departure_date BETWEEN NOW() AND DATE_ADD(NOW(), INTERVAL 7 DAY) AND b.reminder_sent = 0"; $result = mysqli_query($this->conn, $sql); while ($booking = mysqli_fetch_assoc($result)) { try { // Send email reminder $to = $booking['email']; $subject = "Upcoming Trip Reminder - " . $booking['package_name']; $message = "Dear " . $booking['customer_name'] . ",\n\n"; $message .= "This is a reminder about your upcoming trip:\n"; $message .= "Package: " . $booking['package_name'] . "\n"; $message .= "Departure Date: " . date('d M Y', strtotime($booking['departure_date'])) . "\n\n"; $message .= "Please ensure you have all necessary documents ready.\n"; $message .= "For any questions, please contact us.\n\n"; $message .= "Best regards,\nArbain Sani Travel Team"; $headers = "From: " . getSetting('company_email') . "\r\n"; if (mail($to, $subject, $message, $headers)) { // Mark reminder as sent mysqli_query($this->conn, "UPDATE bookings SET reminder_sent = 1 WHERE id = " . $booking['id']); $this->logger->info("Sent booking reminder for booking #{id}", ['id' => $booking['id']]); } } catch (Exception $e) { $this->logger->error("Failed to send booking reminder: {message}", ['message' => $e->getMessage()]); } } } catch (Exception $e) { $this->logger->error("Failed to process booking reminders: {message}", ['message' => $e->getMessage()]); } } private function sendPaymentReminders() { try { // Get bookings with pending payments $sql = "SELECT b.*, p.name as package_name, u.email FROM bookings b LEFT JOIN packages p ON b.package_id = p.id LEFT JOIN users u ON b.user_id = u.id WHERE b.status = 'pending' AND b.created_at < DATE_SUB(NOW(), INTERVAL 3 DAY) AND b.payment_reminder_sent = 0"; $result = mysqli_query($this->conn, $sql); while ($booking = mysqli_fetch_assoc($result)) { try { // Send payment reminder email $to = $booking['email']; $subject = "Payment Reminder - " . $booking['package_name']; $message = "Dear " . $booking['customer_name'] . ",\n\n"; $message .= "This is a reminder about your pending payment for:\n"; $message .= "Package: " . $booking['package_name'] . "\n"; $message .= "Amount Due: Rp " . number_format($booking['total_amount']) . "\n\n"; $message .= "Please complete your payment to confirm your booking.\n"; $message .= "For any questions, please contact us.\n\n"; $message .= "Best regards,\nArbain Sani Travel Team"; $headers = "From: " . getSetting('company_email') . "\r\n"; if (mail($to, $subject, $message, $headers)) { // Mark payment reminder as sent mysqli_query($this->conn, "UPDATE bookings SET payment_reminder_sent = 1 WHERE id = " . $booking['id']); $this->logger->info("Sent payment reminder for booking #{id}", ['id' => $booking['id']]); } } catch (Exception $e) { $this->logger->error("Failed to send payment reminder: {message}", ['message' => $e->getMessage()]); } } } catch (Exception $e) { $this->logger->error("Failed to process payment reminders: {message}", ['message' => $e->getMessage()]); } } private function updatePackageStatuses() { try { // Update completed packages $sql = "UPDATE packages SET status = 'completed' WHERE departure_date < NOW() AND status = 'active'"; mysqli_query($this->conn, $sql); // Update upcoming packages $sql = "UPDATE packages SET status = 'active' WHERE departure_date > NOW() AND status = 'upcoming'"; mysqli_query($this->conn, $sql); $this->logger->info("Updated package statuses"); } catch (Exception $e) { $this->logger->error("Failed to update package statuses: {message}", ['message' => $e->getMessage()]); } } private function cleanupTempFiles() { try { $temp_dir = dirname(__DIR__) . '/uploads/temp'; $retention_hours = 24; $cutoff_time = time() - ($retention_hours * 60 * 60); if (file_exists($temp_dir)) { $files = glob($temp_dir . '/*'); $deleted = 0; foreach ($files as $file) { if (filemtime($file) < $cutoff_time) { if (unlink($file)) { $deleted++; } } } $this->logger->info("Cleaned up {count} temporary files", ['count' => $deleted]); } } catch (Exception $e) { $this->logger->error("Failed to clean up temporary files: {message}", ['message' => $e->getMessage()]); } } } // Create a cron job script to run scheduled tasks if (php_sapi_name() === 'cli') { $scheduler = TaskScheduler::getInstance(); $scheduler->runScheduledTasks(); } ?>