tt-rss/xml-rpc.php
2006-05-16 08:33:51 +01:00

62 lines
1.4 KiB
PHP

<?
require "xmlrpc/lib/xmlrpc.inc";
require "xmlrpc/lib/xmlrpcs.inc";
require_once "sanity_check.php";
require_once "config.php";
require_once "db.php";
require_once "db-prefs.php";
require_once "functions.php";
$link = db_connect(DB_HOST, DB_USER, DB_PASS, DB_NAME);
if (!$link) {
if (DB_TYPE == "mysql") {
print mysql_error();
}
// PG seems to display its own errors just fine by default.
return;
}
if (DB_TYPE == "pgsql") {
pg_query("set client_encoding = 'utf-8'");
}
function subscribeToFeed($msg) {
# $value = new xmlrpcval("OK");
global $link;
$login_o = $msg->getParam(0);
$pass_o = $msg->getParam(1);
$feed_url_o = $msg->getParam(2);
$login = $login_o->scalarval();
$pass = $pass_o->scalarval();
$feed_url = $feed_url_o->scalarval();
$user_id = authenticate_user($link, $login, $pass);
if (authenticate_user($link, $login, $pass)) {
if (subscribe_to_feed($link, $feed_url)) {
$reply_msg = "Subscribed successfully.";
} else {
$reply_msg = "Feed already exists in the database.";
}
} else {
$reply_msg = "Login failed.";
}
return new xmlrpcresp(new xmlrpcval($reply_msg));
}
$subscribeToFeed_sig = array(array($xmlrpcString,
$xmlrpcString, $xmlrpcString, $xmlrpcString));
$s = new xmlrpc_server(
array(
"rss.subscribeToFeed" => array("function" => "subscribeToFeed",
"signature" => $subscribeToFeed_sig))
);
?>