prepare($query);
    $usersToNotify = $stmt->execute();
    while ($userToNotify = $usersToNotify->fetchArray(SQLITE3_ASSOC)) {
        $userId = $userToNotify['id'];
        echo "For user: " . $userToNotify['username'] . "
";
        $days = 1;
        $emailNotificationsEnabled = false;
        $gotifyNotificationsEnabled = false;
        $telegramNotificationsEnabled = false;
        $webhookNotificationsEnabled = false;
        $pushoverNotificationsEnabled = false;
        $discordNotificationsEnabled = false;
        $ntfyNotificationsEnabled = false;
        // Get notification settings (how many days before the subscription ends should the notification be sent)
        $query = "SELECT days FROM notification_settings WHERE user_id = :userId";
        $stmt = $db->prepare($query);
        $stmt->bindValue(':userId', $userId, SQLITE3_INTEGER);
        $result = $stmt->execute();
        if ($row = $result->fetchArray(SQLITE3_ASSOC)) {
            $days = $row['days'];
        }
        // Check if email notifications are enabled and get the settings
        $query = "SELECT * FROM email_notifications WHERE user_id = :userId";
        $stmt = $db->prepare($query);
        $stmt->bindValue(':userId', $userId, SQLITE3_INTEGER);
        $result = $stmt->execute();
        if ($row = $result->fetchArray(SQLITE3_ASSOC)) {
            $emailNotificationsEnabled = $row['enabled'];
            $email['smtpAddress'] = $row["smtp_address"];
            $email['smtpPort'] = $row["smtp_port"];
            $email['encryption'] = $row["encryption"];
            $email['smtpUsername'] = $row["smtp_username"];
            $email['smtpPassword'] = $row["smtp_password"];
            $email['fromEmail'] = $row["from_email"] ? $row["from_email"] : "wallos@wallosapp.com";
        }
        // Check if Discord notifications are enabled and get the settings
        $query = "SELECT * FROM discord_notifications WHERE user_id = :userId";
        $stmt = $db->prepare($query);
        $stmt->bindValue(':userId', $userId, SQLITE3_INTEGER);
        $result = $stmt->execute();
        if ($row = $result->fetchArray(SQLITE3_ASSOC)) {
            $discordNotificationsEnabled = $row['enabled'];
            $discord['webhook_url'] = $row["webhook_url"];
            $discord['bot_username'] = $row["bot_username"];
            $discord['bot_avatar_url'] = $row["bot_avatar_url"];
        }
        // Check if Gotify notifications are enabled and get the settings
        $query = "SELECT * FROM gotify_notifications WHERE user_id = :userId";
        $stmt = $db->prepare($query);
        $stmt->bindValue(':userId', $userId, SQLITE3_INTEGER);
        $result = $stmt->execute();
        if ($row = $result->fetchArray(SQLITE3_ASSOC)) {
            $gotifyNotificationsEnabled = $row['enabled'];
            $gotify['serverUrl'] = $row["url"];
            $gotify['appToken'] = $row["token"];
        }
        // Check if Telegram notifications are enabled and get the settings
        $query = "SELECT * FROM telegram_notifications WHERE user_id = :userId";
        $stmt = $db->prepare($query);
        $stmt->bindValue(':userId', $userId, SQLITE3_INTEGER);
        $result = $stmt->execute();
        if ($row = $result->fetchArray(SQLITE3_ASSOC)) {
            $telegramNotificationsEnabled = $row['enabled'];
            $telegram['botToken'] = $row["bot_token"];
            $telegram['chatId'] = $row["chat_id"];
        }
        // Check if Pushover notifications are enabled and get the settings
        $query = "SELECT * FROM pushover_notifications WHERE user_id = :userId";
        $stmt = $db->prepare($query);
        $stmt->bindValue(':userId', $userId, SQLITE3_INTEGER);
        $result = $stmt->execute();
        if ($row = $result->fetchArray(SQLITE3_ASSOC)) {
            $pushoverNotificationsEnabled = $row['enabled'];
            $pushover['user_key'] = $row["user_key"];
            $pushover['token'] = $row["token"];
        }
        // Check if Nrfy notifications are enabled and get the settings
        $query = "SELECT * FROM ntfy_notifications WHERE user_id = :userId";
        $stmt = $db->prepare($query);
        $stmt->bindValue(':userId', $userId, SQLITE3_INTEGER);
        $result = $stmt->execute();
        if ($row = $result->fetchArray(SQLITE3_ASSOC)) {
            $ntfyNotificationsEnabled = $row['enabled'];
            $ntfy['host'] = $row["host"];
            $ntfy['topic'] = $row["topic"];
            $ntfy['headers'] = $row["headers"];
        }
        // Check if Webhook notifications are enabled and get the settings
        $query = "SELECT * FROM webhook_notifications WHERE user_id = :userId";
        $stmt = $db->prepare($query);
        $stmt->bindValue(':userId', $userId, SQLITE3_INTEGER);
        $result = $stmt->execute();
        if ($row = $result->fetchArray(SQLITE3_ASSOC)) {
            $webhookNotificationsEnabled = $row['enabled'];
            $webhook['url'] = $row["url"];
            $webhook['request_method'] = $row["request_method"];
            $webhook['headers'] = $row["headers"];
            $webhook['payload'] = $row["payload"];
            $webhook['iterator'] = $row["iterator"];
            if ($webhook['iterator'] === "") {
                $webhook['iterator'] = "subscriptions";
            }
        }
        $notificationsEnabled = $emailNotificationsEnabled || $gotifyNotificationsEnabled || $telegramNotificationsEnabled || 
                                $webhookNotificationsEnabled || $pushoverNotificationsEnabled || $discordNotificationsEnabled || 
                                $ntfyNotificationsEnabled;
        // If no notifications are enabled, no need to run
        if (!$notificationsEnabled) {
            echo "Notifications are disabled. No need to run.
";
            continue;
        } else {
            // Get all currencies
            $currencies = array();
            $query = "SELECT * FROM currencies WHERE user_id = :userId";
            $stmt = $db->prepare($query);
            $stmt->bindValue(':userId', $userId, SQLITE3_INTEGER);
            $result = $stmt->execute();
            while ($row = $result->fetchArray(SQLITE3_ASSOC)) {
                $currencies[$row['id']] = $row;
            }
            // Get all household members
            $query = "SELECT * FROM household WHERE user_id = :userId";
            $stmt = $db->prepare($query);
            $stmt->bindValue(':userId', $userId, SQLITE3_INTEGER);
            $resultHousehold = $stmt->execute();
            $household = [];
            while ($rowHousehold = $resultHousehold->fetchArray(SQLITE3_ASSOC)) {
                $household[$rowHousehold['id']] = $rowHousehold;
            }
            // Get all categories
            $query = "SELECT * FROM categories WHERE user_id = :userId";
            $stmt = $db->prepare($query);
            $stmt->bindValue(':userId', $userId, SQLITE3_INTEGER);
            $resultCategories = $stmt->execute();
            $categories = [];
            while ($rowCategory = $resultCategories->fetchArray(SQLITE3_ASSOC)) {
                $categories[$rowCategory['id']] = $rowCategory;
            }
            $query = "SELECT * FROM subscriptions WHERE user_id = :user_id AND notify = :notify AND inactive = :inactive ORDER BY payer_user_id ASC";
            $stmt = $db->prepare($query);
            $stmt->bindValue(':user_id', $userId, SQLITE3_INTEGER);
            $stmt->bindValue(':notify', 1, SQLITE3_INTEGER);
            $stmt->bindValue(':inactive', 0, SQLITE3_INTEGER);
            $resultSubscriptions = $stmt->execute();
            $notify = []; $i = 0;
            $currentDate = new DateTime('now');
            while ($rowSubscription = $resultSubscriptions->fetchArray(SQLITE3_ASSOC)) {
                if ($rowSubscription['notify_days_before'] !== 0) {
                    $daysToCompare = $rowSubscription['notify_days_before'];
                } else {
                    $daysToCompare = $days;
                }
                $nextPaymentDate = new DateTime($rowSubscription['next_payment']);
                $difference = $currentDate->diff($nextPaymentDate)->days + 1;
                if ($difference === $daysToCompare) {
                    $notify[$rowSubscription['payer_user_id']][$i]['name'] = $rowSubscription['name'];
                    $notify[$rowSubscription['payer_user_id']][$i]['price'] = $rowSubscription['price'] . $currencies[$rowSubscription['currency_id']]['symbol'];
                    $notify[$rowSubscription['payer_user_id']][$i]['currency'] = $currencies[$rowSubscription['currency_id']]['name'];
                    $notify[$rowSubscription['payer_user_id']][$i]['category'] = $categories[$rowSubscription['category_id']]['name'];
                    $notify[$rowSubscription['payer_user_id']][$i]['payer'] = $household[$rowSubscription['payer_user_id']]['name'];
                    $notify[$rowSubscription['payer_user_id']][$i]['date'] = $rowSubscription['next_payment'];
                    $notify[$rowSubscription['payer_user_id']][$i]['days'] = $daysToCompare;
                    $i++;
                }
            }
            if (!empty($notify)) {
                // Email notifications if enabled
                if ($emailNotificationsEnabled) {
                    $stmt = $db->prepare('SELECT * FROM user WHERE id = :user_id');
                    $stmt->bindValue(':user_id', $userId, SQLITE3_INTEGER);
                    $result = $stmt->execute();
                    $defaultUser = $result->fetchArray(SQLITE3_ASSOC);
                    $defaultEmail = $defaultUser['email'];
                    $defaultName = $defaultUser['username'];
                    foreach ($notify as $userId => $perUser) {
                        $message = "The following subscriptions are up for renewal:\n";
                        foreach ($perUser as $subscription) {
                            $dayText = $subscription['days'] == 1 ? "Tomorrow" : "In " . $subscription['days'] . " days";
                            $message .= $subscription['name'] . " for " . $subscription['price'] . " (" . $dayText . ")\n";
                        }
            
                        $mail = new PHPMailer(true);
                        $mail->CharSet="UTF-8";
                        $mail->isSMTP();
            
                        $mail->Host = $email['smtpAddress'];
                        $mail->SMTPAuth = true;
                        $mail->Username = $email['smtpUsername'];
                        $mail->Password = $email['smtpPassword'];
                        $mail->SMTPSecure = $email['encryption'];
                        $mail->Port = $email['smtpPort'];
            
                        $stmt = $db->prepare('SELECT * FROM household WHERE id = :userId');
                        $stmt->bindValue(':userId', $userId, SQLITE3_INTEGER);
                        $result = $stmt->execute();
                        $user = $result->fetchArray(SQLITE3_ASSOC);
                        $emailaddress = !empty($user['email']) ? $user['email'] : $defaultEmail;
                        $name = !empty($user['name']) ? $user['name'] : $defaultName;
            
                        $mail->setFrom($email['fromEmail'], 'Wallos App');
                        $mail->addAddress($emailaddress, $name);
            
                        $mail->Subject = 'Wallos Notification';
                        $mail->Body = $message;
            
                        if ($mail->send()) {
                            echo "Email Notifications sent
";
                        } else {
                            echo "Error sending notifications: " . $mail->ErrorInfo . "
";
                        }
                    }
                }
                // Discord notifications if enabled
                if ($discordNotificationsEnabled) {
                    foreach ($notify as $userId => $perUser) {
                        // Get name of user from household table
                        $stmt = $db->prepare('SELECT * FROM household WHERE id = :userId');
                        $stmt->bindValue(':userId', $userId, SQLITE3_INTEGER);
                        $result = $stmt->execute();
                        $user = $result->fetchArray(SQLITE3_ASSOC);
                        $title = translate('wallos_notification', $i18n);
                        if ($user['name']) {
                            $message = $user['name'] . ", the following subscriptions are up for renewal:\n";
                        } else {
                            $message = "The following subscriptions are up for renewal:\n";
                        }
                        foreach ($perUser as $subscription) {
                            $dayText = $subscription['days'] == 1 ? "Tomorrow" : "In " . $subscription['days'] . " days";
                            $message .= $subscription['name'] . " for " . $subscription['price'] . " (" . $dayText . ")\n";
                        }
                        $postfields = [
                            'content' => $message
                        ];
                        
                        if (!empty($discord['bot_username'])) {
                            $postfields['username'] = $discord['bot_username'];
                        }
                        
                        if (!empty($discord['bot_avatar_url'])) {
                            $postfields['avatar_url'] = $discord['bot_avatar_url'];
                        }
                        $ch = curl_init();
                        curl_setopt($ch, CURLOPT_URL, $discord['webhook_url']);
                        curl_setopt($ch, CURLOPT_POST, 1);
                        curl_setopt($ch, CURLOPT_POSTFIELDS, json_encode($postfields));
                        curl_setopt($ch, CURLOPT_HTTPHEADER, [
                            'Content-Type: application/json'
                        ]);
                        curl_setopt($ch, CURLOPT_RETURNTRANSFER, true);
                        $response = curl_exec($ch);
                        curl_close($ch);
                        if ($result === false) {
                            echo "Error sending notifications: " . curl_error($ch) . "
";
                        } else {
                            echo "Discord Notifications sent
";
                        }
                    }
                }
                // Gotify notifications if enabled
                if ($gotifyNotificationsEnabled) {
                    foreach ($notify as $userId => $perUser) {
                        // Get name of user from household table
                        $stmt = $db->prepare('SELECT * FROM household WHERE id = :userId');
                        $stmt->bindValue(':userId', $userId, SQLITE3_INTEGER);
                        $result = $stmt->execute();
                        $user = $result->fetchArray(SQLITE3_ASSOC);
                        if ($user['name']) {
                            $message = $user['name'] . ", the following subscriptions are up for renewal:\n";
                        } else {
                            $message = "The following subscriptions are up for renewal:\n";
                        }
                        foreach ($perUser as $subscription) {
                            $dayText = $subscription['days'] == 1 ? "Tomorrow" : "In " . $subscription['days'] . " days";
                            $message .= $subscription['name'] . " for " . $subscription['price'] . " (" . $dayText . ")\n";
                        }
                        $data = array(
                            'message' => $message,
                            'priority' => 5
                        );
                        $data_string = json_encode($data);
                        $ch = curl_init($gotify['serverUrl'] . '/message?token=' . $gotify['appToken']);
                        curl_setopt($ch, CURLOPT_CUSTOMREQUEST, "POST");
                        curl_setopt($ch, CURLOPT_POSTFIELDS, $data_string);
                        curl_setopt($ch, CURLOPT_RETURNTRANSFER, true);
                        curl_setopt($ch, CURLOPT_HTTPHEADER, array(
                            'Content-Type: application/json',
                            'Content-Length: ' . strlen($data_string))
                        );
                        $result = curl_exec($ch);
                        if ($result === false) {
                            echo "Error sending notifications: " . curl_error($ch) . "
";
                        } else {
                            echo "Gotify Notifications sent
";
                        }
                    }
                }
                // Telegram notifications if enabled
                if ($telegramNotificationsEnabled) {
                    foreach ($notify as $userId => $perUser) {
                        // Get name of user from household table
                        $stmt = $db->prepare('SELECT * FROM household WHERE id = :userId');
                        $stmt->bindValue(':userId', $userId, SQLITE3_INTEGER);
                        $result = $stmt->execute();
                        $user = $result->fetchArray(SQLITE3_ASSOC);
                        if ($user['name']) {
                            $message = $user['name'] . ", the following subscriptions are up for renewal:\n";
                        } else {
                            $message = "The following subscriptions are up for renewal:\n";
                        }
                        foreach ($perUser as $subscription) {
                            $dayText = $subscription['days'] == 1 ? "Tomorrow" : "In " . $subscription['days'] . " days";
                            $message .= $subscription['name'] . " for " . $subscription['price'] . " (" . $dayText . ")\n";
                        }
                        $data = array(
                            'chat_id' => $telegram['chatId'],
                            'text' => $message
                        );
                        $data_string = json_encode($data);
                        $ch = curl_init('https://api.telegram.org/bot' . $telegram['botToken'] . '/sendMessage');
                        curl_setopt($ch, CURLOPT_CUSTOMREQUEST, "POST");
                        curl_setopt($ch, CURLOPT_POSTFIELDS, $data_string);
                        curl_setopt($ch, CURLOPT_RETURNTRANSFER, true);
                        curl_setopt($ch, CURLOPT_HTTPHEADER, array(
                            'Content-Type: application/json',
                            'Content-Length: ' . strlen($data_string))
                        );
                        $result = curl_exec($ch);
                        if ($result === false) {
                            echo "Error sending notifications: " . curl_error($ch) . "
";
                        } else {
                            echo "Telegram Notifications sent
";
                        }
                    }
                }
                // Pushover notifications if enabled
                if ($pushoverNotificationsEnabled) {
                    foreach ($notify as $userId => $perUser) {
                        // Get name of user from household table
                        $stmt = $db->prepare('SELECT * FROM household WHERE id = :userId');
                        $stmt->bindValue(':userId', $userId, SQLITE3_INTEGER);
                        $result = $stmt->execute();
                        $user = $result->fetchArray(SQLITE3_ASSOC);
                        if ($user['name']) {
                            $message = $user['name'] . ", the following subscriptions are up for renewal:\n";
                        } else {
                            $message = "The following subscriptions are up for renewal:\n";
                        }
                        foreach ($perUser as $subscription) {
                            $dayText = $subscription['days'] == 1 ? "Tomorrow" : "In " . $subscription['days'] . " days";
                            $message .= $subscription['name'] . " for " . $subscription['price'] . " (" . $dayText . ")\n";
                        }
                        $ch = curl_init();
                        curl_setopt($ch, CURLOPT_URL, "https://api.pushover.net/1/messages.json");
                        curl_setopt($ch, CURLOPT_POST, 1);
                        curl_setopt($ch, CURLOPT_POSTFIELDS, http_build_query([
                            'token' => $pushover['token'],
                            'user' => $pushover['user_key'],
                            'message' => $message,
                        ]));
                        curl_setopt($ch, CURLOPT_RETURNTRANSFER, true);
                        $result = curl_exec($ch);
                        curl_close($ch);
                        if ($result === false) {
                            echo "Error sending notifications: " . curl_error($ch) . "
";
                        } else {
                            echo "Pushover Notifications sent
";
                        }
                    }
                }
                // Ntfy notifications if enabled
                if ($ntfyNotificationsEnabled) {
                    foreach ($notify as $userId => $perUser) {
                        // Get name of user from household table
                        $stmt = $db->prepare('SELECT * FROM household WHERE id = :userId');
                        $stmt->bindValue(':userId', $userId, SQLITE3_INTEGER);
                        $result = $stmt->execute();
                        $user = $result->fetchArray(SQLITE3_ASSOC);
                        if ($user['name']) {
                            $message = $user['name'] . ", the following subscriptions are up for renewal:\n";
                        } else {
                            $message = "The following subscriptions are up for renewal:\n";
                        }
                        foreach ($perUser as $subscription) {
                            $dayText = $subscription['days'] == 1 ? "Tomorrow" : "In " . $subscription['days'] . " days";
                            $message .= $subscription['name'] . " for " . $subscription['price'] . " (" . $dayText . ")\n";
                        }
                        $headers = json_decode($ntfy["headers"], true);
                        $customheaders = array_map(function($key, $value) {
                            return "$key: $value";
                        }, array_keys($headers), $headers);   
                        $ch = curl_init();
                        curl_setopt($ch, CURLOPT_URL, $ntfy['host'] . '/' . $ntfy['topic']);
                        curl_setopt($ch, CURLOPT_POST, 1);
                        curl_setopt($ch, CURLOPT_POSTFIELDS, $message);
                        curl_setopt($ch, CURLOPT_HTTPHEADER, $customheaders);
                        curl_setopt($ch, CURLOPT_RETURNTRANSFER, true);
                        $response = curl_exec($ch);
                        curl_close($ch);
                        if ($response === false) {
                            echo "Error sending notifications: " . curl_error($ch) . "
";
                        } else {
                            echo "Ntfy Notifications sent
";
                        }
                    }
                }
                // Webhook notifications if enabled
                if ($webhookNotificationsEnabled) {
                    // Get webhook payload and turn it into a json object
                    $payload = str_replace("{{days_until}}", $days, $webhook['payload']); // The default value for all subscriptions
                    $payload_json = json_decode($payload, true);
                    $subscription_template = $payload_json["{{subscriptions}}"];
                    $subscriptions = [];
                    foreach ($notify as $userId => $perUser) {
                        // Get name of user from household table
                        $stmt = $db->prepare('SELECT * FROM household WHERE id = :userId');
                        $stmt->bindValue(':userId', $userId, SQLITE3_INTEGER);
                        $result = $stmt->execute();
                        $user = $result->fetchArray(SQLITE3_ASSOC);
                        if ($user['name']) {
                            $payer = $user['name'];
                        }
                        foreach ($perUser as $k => $subscription) {
                            $temp_subscription = $subscription_template[0];
                            
                            foreach ($temp_subscription as $key => $value) {
                                if (is_string($value)) {
                                    $temp_subscription[$key] = str_replace("{{subscription_name}}", $subscription['name'], $value);
                                    $temp_subscription[$key] = str_replace("{{subscription_price}}", $subscription['price'], $temp_subscription[$key]);
                                    $temp_subscription[$key] = str_replace("{{subscription_currency}}", $subscription['currency'], $temp_subscription[$key]);
                                    $temp_subscription[$key] = str_replace("{{subscription_category}}", $subscription['category'], $temp_subscription[$key]);
                                    $temp_subscription[$key] = str_replace("{{subscription_payer}}", $subscription['payer'], $temp_subscription[$key]);
                                    $temp_subscription[$key] = str_replace("{{subscription_date}}", $subscription['date'], $temp_subscription[$key]);
                                    $temp_subscription[$key] = str_replace("{{subscription_days_until_payment}}", $subscription['days'], $temp_subscription[$key]); // The de facto value for this subscription
                                }
                            }
                            $subscriptions[] = $temp_subscription;
                        }
                    }
                    $payload_json["{{subscriptions}}"] = $subscriptions;
                    $payload_json[$webhook['iterator']] = $subscriptions;
                    unset($payload_json["{{subscriptions}}"]);
                    $ch = curl_init();
                    curl_setopt($ch, CURLOPT_URL, $webhook['url']);
                    curl_setopt($ch, CURLOPT_CUSTOMREQUEST, $webhook['request_method']);
                    curl_setopt($ch, CURLOPT_POSTFIELDS, json_encode($payload_json));
                    if (!empty($webhook['headers'])) {
                        $customheaders = preg_split("/\r\n|\n|\r/", $webhook['headers']);
                        curl_setopt($ch, CURLOPT_HTTPHEADER, $customheaders);
                    }
                    curl_setopt($ch, CURLOPT_RETURNTRANSFER, true);
                    $response = curl_exec($ch);
                    curl_close($ch);
                    if ($response === false) {
                        echo "Error sending notifications: " . curl_error($ch) . "
";
                    } else {
                        echo "Webhook Notifications sent
";
                    }
                }
            
        
            } else {
                echo "Nothing to notify.
";
            }
        }
    }
?>