summaryrefslogtreecommitdiffstats
path: root/public/admin/subscriptions.php
blob: 236ac4603fada375f4892a947ebf8a0ade99640b (plain)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
<?php

require_once __DIR__ . '/../../app/app.php';
require_once __DIR__ . '/inc/auth.inc.php';

function removeSlashes(&$item, $key)
{
    $item = stripslashes($item);
}

if (!$csrf->verify($_POST['_csrf'], 'feedmanage')) {
    die('Invalid CSRF token!');
}

$opmlFile = $PlanetConfig->getOpmlFile();

if (isset($_POST['upload']) &&
    isset($_FILES['opml']) &&
    is_uploaded_file($_FILES['opml']['tmp_name']) &&
    $_FILES['opml']['size'] > 0) {
    OpmlManager::backup($opmlFile);
    $newOpml = new Opml();
    $newOpml->parse(file_get_contents($_FILES['opml']['tmp_name']));
    OpmlManager::save($newOpml, $opmlFile);

    Cache::setStore($PlanetConfig->getCacheDir() . '/');
    Cache::prune("html");
} elseif (isset($_POST['opml']) || isset($_POST['add'])) {
    // Load old OPML
    $oldOpml = OpmlManager::load($opmlFile);
    if ($PlanetConfig->getName() === '') {
        $PlanetConfig->setName($oldOpml->getTitle());
    }
    $newOpml = new Opml();
    $newOpml->title = $PlanetConfig->getName();

    // Remove slashes if needed
    if (isset($_POST['opml'])) {
        array_walk_recursive($_POST['opml'], 'removeSlashes');
    }
    // Delete/Save feeds
    if (isset($_POST['delete']) || isset($_POST['save'])) {
        foreach ($_POST['opml'] as $person) {
            if (isset($_POST['delete'])) {
                //delete mode, check if to be deleted
                if (!isset($person['delete'])) {
                    $newOpml->entries[] = $person;
                }
            } else {
                $newOpml->entries[] = $person;
            }
        }
    }

    // Add feed
    if (isset($_POST['add'])) {
        if ('http://' != $_POST['url']) {
            //autodiscover feed
            $feed = new SimplePie();
            $feed->enable_cache(false);
            $feed->set_feed_url($_POST['url']);
            if (!$PlanetConfig->checkCertificates()) {
                $feed->set_curl_options([
                    CURLOPT_SSL_VERIFYHOST => false,
                    CURLOPT_SSL_VERIFYPEER => false
                ]);
            }
            $feed->init();
            $feed->handle_content_type();
            $person['name'] = html_entity_decode($feed->get_title());
            $person['website'] = $feed->get_permalink();
            $person['feed'] = $feed->feed_url;
            $person['isDown'] = '0';

            $oldOpml->entries[] = $person;
        }
        $newOpml->entries = $oldOpml->entries;
    }

    // Backup old OPML
    OpmlManager::backup($opmlFile);

    // Save new OPML
    OpmlManager::save($newOpml, $opmlFile);

    Cache::setStore($PlanetConfig->getCacheDir() . '/');
    Cache::prune("html");
}
header("Location: index.php");
die();