<?php
session_start();
require_once '../config/config.php';

$xml_content = '';
$parsed_data = null;
$error = null;

if ($_SERVER['REQUEST_METHOD'] === 'POST' && isset($_POST['xml_content'])) {
    $xml_content = $_POST['xml_content'];
    
    
    // This allows external entity injection
    
    try {
        
        libxml_use_internal_errors(true);
        
        $dom = new DOMDocument();
        // CRITICAL: Load XML without disabling external entities
        $dom->loadXML($xml_content, LIBXML_DTDLOAD | LIBXML_DTDATTR | LIBXML_NOENT);
        
        $parsed_data = [];
        
        // Extract channel title first (this is where XXE entities are typically placed)
        $channels = $dom->getElementsByTagName('channel');
        if ($channels->length > 0) {
            $channel = $channels->item(0);
            $channelTitle = $channel->getElementsByTagName('title')->item(0);
            if ($channelTitle && $channelTitle->nodeValue) {
                $parsed_data[] = [
                    'title' => '[Channel] ' . $channelTitle->nodeValue,
                    'link' => '#',
                    'description' => 'RSS Feed Channel Information'
                ];
            }
        }
        
        $items = $dom->getElementsByTagName('item');
        
        foreach ($items as $item) {
            $title = $item->getElementsByTagName('title')->item(0);
            $link = $item->getElementsByTagName('link')->item(0);
            $description = $item->getElementsByTagName('description')->item(0);
            
            $parsed_data[] = [
                'title' => $title ? $title->nodeValue : 'N/A',
                'link' => $link ? $link->nodeValue : '#',
                'description' => $description ? $description->nodeValue : ''
            ];
        }
        
    } catch (Exception $e) {
        $error = $e->getMessage();
    }
}
?>

<!DOCTYPE html>
<html lang="en">
<head>
    <meta charset="UTF-8">
    <meta name="viewport" content="width=device-width, initial-scale=1.0">
    <title>RSS Feed Parser - QuickShop</title>
    <link href="https://cdn.jsdelivr.net/npm/bootstrap@5.3.0/dist/css/bootstrap.min.css" rel="stylesheet">
    <link rel="stylesheet" href="https://cdnjs.cloudflare.com/ajax/libs/font-awesome/6.4.0/css/all.min.css">
    <link href="https://fonts.googleapis.com/css2?family=Inter:wght@300;400;500;600;700;800&display=swap" rel="stylesheet">
    <style>
        body {
            font-family: 'Inter', sans-serif;
            background: #f8fafc;
        }
        
        .navbar {
            background: #ffffff !important;
            box-shadow: 0 1px 3px rgba(0, 0, 0, 0.1);
        }
        
        .navbar-brand {
            font-weight: 800;
            color: #6366f1 !important;
        }
        
        .parser-section {
            background: white;
            border-radius: 12px;
            padding: 2rem;
            margin: 2rem 0;
            box-shadow: 0 1px 3px rgba(0, 0, 0, 0.1);
        }
        
        textarea {
            font-family: 'Courier New', monospace;
        }
    </style>
</head>
<body>
    <nav class="navbar navbar-expand-lg">
        <div class="container">
            <a class="navbar-brand" href="index.php">
                <i class="fas fa-bolt"></i> QuickShop
            </a>
        </div>
    </nav>

    <div class="container">
        <div class="parser-section">
            <h2><i class="fas fa-rss"></i> RSS Feed Parser</h2>
            <p class="text-muted">Parse RSS feeds from other retailers to compare prices</p>
            
            <form method="POST" action="rss_parser.php">
                <div class="mb-3">
                    <label class="form-label">XML/RSS Content</label>
                    <textarea name="xml_content" class="form-control" rows="12" placeholder="Paste RSS feed XML content here..."><?php echo htmlspecialchars($xml_content); ?></textarea>
                </div>
                <button type="submit" class="btn btn-primary">
                    <i class="fas fa-play"></i> Parse Feed
                </button>
                <button type="button" class="btn btn-outline-secondary" onclick="loadSample()">
                    Load Sample Feed
                </button>
            </form>
        </div>
        
        <?php if ($parsed_data): ?>
        <div class="parser-section">
            <h3><i class="fas fa-list"></i> Parsed Feed Items</h3>
            <hr>
            <?php foreach ($parsed_data as $item): ?>
                <div class="card mb-3">
                    <div class="card-body">
                        <h5 class="card-title"><?php echo htmlspecialchars($item['title']); ?></h5>
                        <p class="card-text"><?php echo htmlspecialchars($item['description']); ?></p>
                        <?php if ($item['link'] !== '#'): ?>
                            <a href="<?php echo htmlspecialchars($item['link']); ?>" class="btn btn-sm btn-primary" target="_blank">
                                <i class="fas fa-external-link-alt"></i> Visit Link
                            </a>
                        <?php endif; ?>
                    </div>
                </div>
            <?php endforeach; ?>
        </div>
        <?php elseif ($error): ?>
        <div class="alert alert-danger mt-4">
            <i class="fas fa-exclamation-triangle"></i> Error: <?php echo htmlspecialchars($error); ?>
        </div>
        <?php endif; ?>
    </div>

    <script src="https://cdn.jsdelivr.net/npm/bootstrap@5.3.0/dist/js/bootstrap.bundle.min.js"></script>
    <script>
        function loadSample() {
            const sample = '<' + '?xml version="1.0" encoding="UTF-8"?' + '>\n' +
'<rss version="2.0">\n' +
'  <channel>\n' +
'    <title>Sample Product Feed</title>\n' +
'    <item>\n' +
'      <title>Laptop Pro 2024</title>\n' +
'      <link>https://example.com/laptop</link>\n' +
'      <description>High-performance laptop with latest specs</description>\n' +
'    </item>\n' +
'    <item>\n' +
'      <title>Wireless Mouse</title>\n' +
'      <link>https://example.com/mouse</link>\n' +
'      <description>Ergonomic wireless mouse with long battery life</description>\n' +
'    </item>\n' +
'  </channel>\n' +
'</rss>';
            document.querySelector('textarea[name="xml_content"]').value = sample;
        }
    </script>
</body>
</html>


| Category | Test |
| Product ID | #146 |
| Price | $99.99 |
| Availability | Out of Stock |
| Average Rating | No ratings yet |
| Total Reviews | 0 customer reviews |
No reviews yet for this product. Be the first to review!