query("SELECT name, value FROM settings WHERE name IN ('telegram_bot_token', 'telegram_chat_id')"); $settings = []; while ($row = $stmt->fetch()) { $settings[$row['name']] = $row['value']; } if (empty($settings['telegram_bot_token']) || empty($settings['telegram_chat_id'])) { return; } $url = "https://api.telegram.org/bot" . $settings['telegram_bot_token'] . "/sendMessage"; $data = [ 'chat_id' => $settings['telegram_chat_id'], 'text' => $message, 'parse_mode' => 'HTML' ]; $ch = curl_init($url); curl_setopt($ch, CURLOPT_RETURNTRANSFER, true); curl_setopt($ch, CURLOPT_POST, true); curl_setopt($ch, CURLOPT_POSTFIELDS, http_build_query($data)); curl_setopt($ch, CURLOPT_TIMEOUT, 10); curl_exec($ch); curl_close($ch); } while (true) { $startLoop = microtime(true); $db = db(); $urls = $db->query("SELECT * FROM urls WHERE is_active = 1")->fetchAll(); if (count($urls) > 0) { $mh = curl_multi_init(); $ch_list = []; foreach ($urls as $urlData) { $ch = curl_init($urlData['url']); curl_setopt($ch, CURLOPT_RETURNTRANSFER, true); curl_setopt($ch, CURLOPT_HEADER, true); curl_setopt($ch, CURLOPT_NOBODY, true); curl_setopt($ch, CURLOPT_FOLLOWLOCATION, true); curl_setopt($ch, CURLOPT_TIMEOUT, 5); curl_multi_add_handle($mh, $ch); $ch_list[(int)$ch] = [ 'id' => $urlData['id'], 'url' => $urlData['url'], 'old_status' => $urlData['status'], 'start_time' => microtime(true) ]; } $active = null; do { $mrc = curl_multi_exec($mh, $active); } while ($mrc == CURLM_CALL_MULTI_PERFORM); while ($active && $mrc == CURLM_OK) { if (curl_multi_select($mh) != -1) { do { $mrc = curl_multi_exec($mh, $active); } while ($mrc == CURLM_CALL_MULTI_PERFORM); } } foreach ($ch_list as $ch_id => $data) { $ch = null; // Find the handle foreach ($ch_list as $handle_id => $info) { if ($handle_id == $ch_id) { // This is tricky in PHP to get handle by int. // Actually we can just keep the handles in an array. } } } // Re-doing the loop for better handle management foreach ($ch_list as $ch_int => $info) { // Wait, I need the actual handle. } } // SIMPLIFIED Sequential for stability if multi is complex in 1s loop // Let's stick to sequential but optimized for now, or fix multi properly. // Actually, curl_multi is better. Let's do it right. // (Self-correction: curl_multi is better but I need to store the handles properly) $endLoop = microtime(true); // ... sleep ... usleep(1000000); // Temporary simplified sleep }