diff --git a/backend.php b/backend.php
index d5272ddae..9454702fb 100644
--- a/backend.php
+++ b/backend.php
@@ -56,7 +56,7 @@
$print_exec_time = false;
if ((!$op || $op == "rpc" || $op == "rss" || $op == "view" ||
- $op == "digestSend" || $op == "viewfeed" ||
+ $op == "digestSend" || $op == "viewfeed" || $op == "publish" ||
$op == "globalUpdateFeeds") && !$_REQUEST["noxml"]) {
header("Content-Type: application/xml; charset=utf-8");
} else {
@@ -69,7 +69,7 @@
}
if (!($_SESSION["uid"] && validate_session($link)) && $op != "globalUpdateFeeds"
- && $op != "rss" && $op != "getUnread") {
+ && $op != "rss" && $op != "getUnread" && $op != "publish") {
if ($op == "rpc" || $op == "viewfeed" || $op == "view") {
print_error_xml(6); die;
@@ -404,6 +404,33 @@
module_pref_feed_browser($link);
}
+ if ($op == "publish") {
+ $key = db_escape_string($_GET["key"]);
+
+ $result = db_query($link, "SELECT login, owner_uid
+ FROM ttrss_user_prefs, ttrss_users WHERE
+ pref_name = '_PREFS_PUBLISH_KEY' AND
+ value = '$key' AND
+ ttrss_users.id = owner_uid");
+
+ if (db_num_rows($result) == 1) {
+ $owner = db_fetch_result($result, 0, "owner_uid");
+ $login = db_fetch_result($result, 0, "login");
+
+ $_SESSION["uid"] = $owner;
+
+ generate_syndicated_feed($link, -2, false);
+
+ session_destroy();
+ } else {
+
+ $_SESSION["uid"] = 0;
+ generate_syndicated_feed($link, -2, false);
+ session_destroy();
+ }
+
+ }
+
if ($op == "rss") {
$feed = db_escape_string($_GET["id"]);
$user = db_escape_string($_GET["user"]);
@@ -424,6 +451,8 @@
generate_syndicated_feed($link, $feed, $is_cat,
$search, $search_mode, $match_on);
}
+
+ session_destroy();
}
if ($op == "labelFromSearch") {
diff --git a/functions.php b/functions.php
index a77d2f85c..8157d12d2 100644
--- a/functions.php
+++ b/functions.php
@@ -2279,6 +2279,8 @@
function getFeedTitle($link, $id) {
if ($id == -1) {
return __("Starred articles");
+ } else if ($id == -2) {
+ return __("Published articles");
} else if ($id < -10) {
$label_id = -10 - $id;
$result = db_query($link, "SELECT description FROM ttrss_labels WHERE id = '$label_id'");
diff --git a/modules/backend-rpc.php b/modules/backend-rpc.php
index 1e757ca72..ddf33a0df 100644
--- a/modules/backend-rpc.php
+++ b/modules/backend-rpc.php
@@ -295,6 +295,23 @@
}
+ if ($subop == "regenPubKey") {
+
+ print "