]> git.wh0rd.org - tt-rss.git/blob - xml-rpc.php
split headline select logic to functions.php; xml-rpc rss.getFeedHeadlines supports...
[tt-rss.git] / xml-rpc.php
1 <?
2 require "xmlrpc/lib/xmlrpc.inc";
3 require "xmlrpc/lib/xmlrpcs.inc";
4
5 require_once "sanity_check.php";
6 require_once "config.php";
7
8 require_once "db.php";
9 require_once "db-prefs.php";
10 require_once "functions.php";
11
12 $link = db_connect(DB_HOST, DB_USER, DB_PASS, DB_NAME);
13
14 if (!$link) {
15 if (DB_TYPE == "mysql") {
16 print mysql_error();
17 }
18 // PG seems to display its own errors just fine by default.
19 return;
20 }
21
22 if (DB_TYPE == "pgsql") {
23 pg_query("set client_encoding = 'utf-8'");
24 }
25
26 function getVirtualFeeds($msg) {
27 global $link;
28
29 $error_code = 0;
30
31 $login_o = $msg->getParam(0);
32 $pass_o = $msg->getParam(1);
33
34 $login = $login_o->scalarval();
35 $pass = $pass_o->scalarval();
36
37 $user_id = authenticate_user($link, $login, $pass);
38
39 $counters_ret = array();
40
41 if (authenticate_user($link, $login, $pass)) {
42
43 $counters = getLabelCounters($link, false, true);
44
45 foreach (array_keys($counters) as $id) {
46 $line_struct = new xmlrpcval(
47 array(
48 "id" => new xmlrpcval($id, "int"),
49 "description" => new xmlrpcval($counters[$id]["description"]),
50 "counter" => new xmlrpcval($counters[$id]["counter"], "int")
51 ),
52 "struct");
53
54 array_push($counters_ret, $line_struct);
55 }
56
57 $reply = new xmlrpcval($counters_ret, "array");
58
59 } else {
60 $reply_msg = "Login failed.";
61 $error_code = 1;
62 }
63
64 if ($error_code != 0) {
65 return new xmlrpcresp(0, $error_code, $reply_msg);
66 } else {
67 return new xmlrpcresp($reply);
68 }
69
70 }
71
72 function getCategories($msg) {
73 global $link;
74
75 $login_o = $msg->getParam(0);
76 $pass_o = $msg->getParam(1);
77
78 $login = $login_o->scalarval();
79 $pass = $pass_o->scalarval();
80
81 $user_id = authenticate_user($link, $login, $pass);
82
83 $error_code = 0;
84
85 if (authenticate_user($link, $login, $pass)) {
86
87 $result = db_query($link, "SELECT
88 id, title FROM ttrss_feed_categories
89 WHERE owner_uid = " .
90 $_SESSION["uid"]);
91
92 $feeds = array();
93
94 while ($line = db_fetch_assoc($result)) {
95
96 $unread = getFeedUnread($link, $line["id"]);
97
98 $line_struct = new xmlrpcval(
99 array(
100 "title" => new xmlrpcval($line["title"]),
101 "id" => new xmlrpcval($line["id"], "int")
102 ),
103 "struct");
104
105 array_push($feeds, $line_struct);
106 }
107
108 $reply = new xmlrpcval($feeds, "array");
109
110 } else {
111 $reply = "Login failed.";
112 $error_code = 1;
113 }
114
115 if ($error_code != 0) {
116 return new xmlrpcresp(0, $error_code, $reply_msg);
117 } else {
118 return new xmlrpcresp($reply);
119 }
120
121 }
122
123 function getTotalUnread($msg) {
124 global $link;
125
126 $error_code = 0;
127
128 $login_o = $msg->getParam(0);
129 $pass_o = $msg->getParam(1);
130
131 $login = $login_o->scalarval();
132 $pass = $pass_o->scalarval();
133
134 $user_id = authenticate_user($link, $login, $pass);
135
136
137 if (authenticate_user($link, $login, $pass)) {
138
139 $reply_msg = getGlobalUnread($link);
140
141 } else {
142 $reply_msg = "Login failed.";
143 $error_code = 1;
144 }
145
146 if ($error_code != 0) {
147 return new xmlrpcresp(0, $error_code, $reply_msg);
148 } else {
149 return new xmlrpcresp(new xmlrpcval($reply_msg));
150 }
151
152 }
153
154 function getVersion() {
155 return new xmlrpcval(VERSION);
156 }
157
158 function getSubscribedFeeds($msg) {
159 global $link;
160
161 $login_o = $msg->getParam(0);
162 $pass_o = $msg->getParam(1);
163
164 $login = $login_o->scalarval();
165 $pass = $pass_o->scalarval();
166
167 $user_id = authenticate_user($link, $login, $pass);
168
169 if (authenticate_user($link, $login, $pass)) {
170
171 $result = db_query($link, "SELECT
172 id, feed_url, cat_id, title, SUBSTRING(last_updated,1,19) AS last_updated
173 FROM ttrss_feeds WHERE owner_uid = " .
174 $_SESSION["uid"]);
175
176 $feeds = array();
177
178 while ($line = db_fetch_assoc($result)) {
179
180 $unread = getFeedUnread($link, $line["id"]);
181
182 $line_struct = new xmlrpcval(
183 array(
184 "feed_url" => new xmlrpcval($line["feed_url"]),
185 "title" => new xmlrpcval($line["title"]),
186 "id" => new xmlrpcval($line["id"], "int"),
187 "unread" => new xmlrpcval($unread, "int"),
188 "category_id" => new xmlrpcval($line["cat_id"], "int"),
189 "last_updated" => new xmlrpcval(strtotime($line["last_updated"]), "int")
190 ),
191 "struct");
192
193 array_push($feeds, $line_struct);
194 }
195
196 $reply = new xmlrpcval($feeds, "array");
197
198 } else {
199 $reply = new xmlrpcval("Login failed.");
200 }
201
202 return new xmlrpcresp($reply);
203 }
204
205 function subscribeToFeed($msg) {
206 global $link;
207
208 $error_code = 0;
209
210 $login_o = $msg->getParam(0);
211 $pass_o = $msg->getParam(1);
212 $feed_url_o = $msg->getParam(2);
213
214 $login = $login_o->scalarval();
215 $pass = $pass_o->scalarval();
216 $feed_url = $feed_url_o->scalarval();
217
218 if (authenticate_user($link, $login, $pass)) {
219 if (subscribe_to_feed($link, $feed_url)) {
220 $reply_msg = "Subscribed successfully.";
221 } else {
222 $reply_msg = "Feed already exists in the database.";
223 $error_code = 2;
224 }
225 } else {
226 $reply_msg = "Login failed.";
227 $error_code = 1;
228 }
229
230 if ($error_code != 0) {
231 return new xmlrpcresp(0, $error_code, $reply_msg);
232 } else {
233 return new xmlrpcresp(new xmlrpcval($reply_msg));
234 }
235 }
236
237 function getFeedHeadlines($msg) {
238 global $link;
239
240 $error_code = 0;
241
242 $login_o = $msg->getParam(0);
243 $pass_o = $msg->getParam(1);
244 $feed_id_o = $msg->getParam(2);
245 $limit_o = $msg->getParam(3);
246 $filter_o = $msg->getParam(4);
247
248 $login = $login_o->scalarval();
249 $pass = $pass_o->scalarval();
250 $feed_id = $feed_id_o->scalarval();
251 $limit = $limit_o->scalarval();
252 $filter = $filter_o->scalarval();
253
254 if (authenticate_user($link, $login, $pass)) {
255
256 if ($filter == 1) {
257 $view_mode = "unread";
258 } else if ($filter == 2) {
259 $view_mode = "marked";
260 }
261
262 $cat_view = false;
263 $search = "";
264 $search_mode = "";
265 $match_on = "";
266
267 $qfh_ret = queryFeedHeadlines($link, $feed_id, $limit,
268 $view_mode, $cat_view, $search, $search_mode, $match_on);
269
270 $result = $qfh_ret[0];
271 $feed_title = $qfh_ret[1];
272
273 $articles = array();
274
275 while ($line = db_fetch_assoc($result)) {
276
277 $headline_items = array(
278 "id" => new xmlrpcval($line["id"], "int"),
279 "unread" => new xmlrpcval(sql_bool_to_bool($line["unread"]), "boolean"),
280 "marked" => new xmlrpcval(sql_bool_to_bool($line["marked"]), "boolean"),
281 "updated" => new xmlrpcval(strtotime($line["updated"]), "int"),
282 "title" => new xmlrpcval($line["title"])
283 );
284
285 if ($feed_id < 0) {
286 $headline_items["feed_id"] = new xmlrpcval($line["feed_id"], "int");
287 }
288
289 $line_struct = new xmlrpcval($headline_items,
290 "struct");
291
292 array_push($articles, $line_struct);
293 }
294
295 $reply = new xmlrpcval(
296 array(
297 "title" => new xmlrpcval($feed_title),
298 "headlines" => new xmlrpcval($articles, "array")
299 ),
300 "struct");
301
302 } else {
303 $reply_msg = "Login failed.";
304 $error_code = 1;
305 }
306
307 if ($error_code != 0) {
308 return new xmlrpcresp(0, $error_code, $reply_msg);
309 } else {
310 return new xmlrpcresp($reply);
311 }
312
313 }
314
315 function getArticle($msg) {
316 global $link;
317
318 $error_code = 0;
319
320 $login_o = $msg->getParam(0);
321 $pass_o = $msg->getParam(1);
322 $article_id_o = $msg->getParam(2);
323
324 $login = $login_o->scalarval();
325 $pass = $pass_o->scalarval();
326 $article_id = $article_id_o->scalarval();
327
328 if (authenticate_user($link, $login, $pass)) {
329
330 $query = "SELECT title,link,content,feed_id,comments,int_id,
331 marked,unread,
332 SUBSTRING(updated,1,16) as updated,
333 author
334 FROM ttrss_entries,ttrss_user_entries
335 WHERE id = '$article_id' AND ref_id = id AND owner_uid = " . $_SESSION["uid"] ;
336
337 $result = db_query($link, $query);
338
339 if (db_num_rows($result) == 1) {
340
341 $line = db_fetch_assoc($result);
342
343 $reply = new xmlrpcval(
344 array(
345 "title" => new xmlrpcval($line["title"]),
346 "link" => new xmlrpcval($line["link"]),
347 "unread" => new xmlrpcval(sql_bool_to_bool($line["unread"]), "boolean"),
348 "marked" => new xmlrpcval(sql_bool_to_bool($line["marked"]), "boolean"),
349 "comments" => new xmlrpcval($line["comments"]),
350 "author" => new xmlrpcval($line["author"]),
351 "updated" => new xmlrpcval(strtotime($line["updated"], "int")),
352 "content" => new xmlrpcval($line["content"])
353 ),
354 "struct");
355
356 } else {
357 $reply_msg = "Article not found.";
358 $error_code = 2;
359 }
360
361 } else {
362 $reply_msg = "Login failed.";
363 $error_code = 1;
364 }
365
366 if ($error_code != 0) {
367 return new xmlrpcresp(0, $error_code, $reply_msg);
368 } else {
369 return new xmlrpcresp($reply);
370 }
371 }
372
373 function setArticleMarked($msg) {
374 global $link;
375
376 $error_code = 0;
377
378 $login_o = $msg->getParam(0);
379 $pass_o = $msg->getParam(1);
380 $article_id_o = $msg->getParam(2);
381 $marked_o = $msg->getParam(3);
382
383 $login = $login_o->scalarval();
384 $pass = $pass_o->scalarval();
385 $article_id = $article_id_o->scalarval();
386 $marked = $marked_o->scalarval();
387
388 if (authenticate_user($link, $login, $pass)) {
389
390 if ($marked == 0) {
391 $query_strategy_part = "marked = false";
392 } else if ($marked == 1) {
393 $query_strategy_part = "marked = true";
394 } else if ($marked == 2) {
395 $query_strategy_part = "marked = NOT marked";
396 }
397
398 $result = db_query($link, "UPDATE ttrss_user_entries SET
399 $query_strategy_part WHERE ref_id = '$article_id' AND
400 owner_uid = " . $_SESSION["uid"]);
401
402 if (db_affected_rows($link, $result) == 1) {
403 $reply_msg = "OK";
404 } else {
405 $error_code = 2;
406 $reply_msg = "Failed to update article.";
407 }
408
409 } else {
410 $reply_msg = "Login failed.";
411 $error_code = 1;
412 }
413
414 if ($error_code != 0) {
415 return new xmlrpcresp(0, $error_code, $reply_msg);
416 } else {
417 return new xmlrpcresp(new xmlrpcval($reply_msg));
418 }
419
420 }
421
422 function setArticleRead($msg) {
423 global $link;
424
425 $error_code = 0;
426
427 $login_o = $msg->getParam(0);
428 $pass_o = $msg->getParam(1);
429 $article_id_o = $msg->getParam(2);
430 $read_o = $msg->getParam(3);
431
432 $login = $login_o->scalarval();
433 $pass = $pass_o->scalarval();
434 $article_id = $article_id_o->scalarval();
435 $read = $read_o->scalarval();
436
437 if (authenticate_user($link, $login, $pass)) {
438
439 if ($read == 0) {
440 $query_strategy_part = "unread = true";
441 } else if ($read == 1) {
442 $query_strategy_part = "unread = false";
443 } else if ($read == 2) {
444 $query_strategy_part = "unread = NOT unread";
445 }
446
447 $result = db_query($link, "UPDATE ttrss_user_entries SET
448 $query_strategy_part WHERE ref_id = '$article_id' AND
449 owner_uid = " . $_SESSION["uid"]);
450
451 if (db_affected_rows($link, $result) == 1) {
452 $reply_msg = "OK";
453 } else {
454 $error_code = 2;
455 $reply_msg = "Failed to update article.";
456 }
457
458 } else {
459 $reply_msg = "Login failed.";
460 $error_code = 1;
461 }
462
463 if ($error_code != 0) {
464 return new xmlrpcresp(0, $error_code, $reply_msg);
465 } else {
466 return new xmlrpcresp(new xmlrpcval($reply_msg));
467 }
468
469 }
470
471 $subscribeToFeed_sig = array(array($xmlrpcString,
472 $xmlrpcString, $xmlrpcString, $xmlrpcString));
473
474 $getSubscribedFeeds_sig = array(array($xmlrpcString,
475 $xmlrpcString, $xmlrpcString));
476
477 $getFeedHeadlines_sig = array(array($xmlrpcString,
478 $xmlrpcString, $xmlrpcString, $xmlrpcInt, $xmlrpcInt, $xmlrpcInt));
479
480 $getArticle_sig = array(array($xmlrpcString,
481 $xmlrpcString, $xmlrpcString, $xmlrpcInt));
482
483 $setArticleMarked_sig = array(array($xmlrpcString,
484 $xmlrpcString, $xmlrpcString, $xmlrpcInt, $xmlrpcInt));
485
486 $setArticleUnread_sig = array(array($xmlrpcString,
487 $xmlrpcString, $xmlrpcString, $xmlrpcInt, $xmlrpcInt));
488
489 $getVersion_sig = array(array($xmlrpcString));
490
491 $getTotalUnread_sig = array(array($xmlrpcInt, $xmlrpcString,
492 $xmlrpcString));
493
494 $getCategories_sig = array(array($xmlrpcString,
495 $xmlrpcString, $xmlrpcString));
496
497 $getVirtualFeeds_sig = array(array($xmlrpcInt, $xmlrpcString,
498 $xmlrpcString));
499
500 $s = new xmlrpc_server(
501 array(
502 "rss.getVirtualFeeds" => array("function" => "getVirtualFeeds",
503 "signature" => $getVirtualFeeds_sig),
504 "rss.getCategories" => array("function" => "getCategories",
505 "signature" => $getCategories_sig),
506 "rss.getTotalUnread" => array("function" => "getTotalUnread",
507 "signature" => $getTotalUnread_sig),
508 "rss.getVersion" => array("function" => "getVersion",
509 "signature" => $getVersion_sig),
510 "rss.setArticleRead" => array("function" => "setArticleRead",
511 "signature" => $setArticleRead_sig),
512 "rss.setArticleMarked" => array("function" => "setArticleMarked",
513 "signature" => $setArticleMarked_sig),
514 "rss.getArticle" => array("function" => "getArticle",
515 "signature" => $getArticle_sig),
516 "rss.getFeedHeadlines" => array("function" => "getFeedHeadlines",
517 "signature" => $getFeedHeadlines_sig),
518 "rss.getSubscribedFeeds" => array("function" => "getSubscribedFeeds",
519 "signature" => $getSubscribedFeeds_sig),
520 "rss.subscribeToFeed" => array("function" => "subscribeToFeed",
521 "signature" => $subscribeToFeed_sig)), 0
522 );
523 $s->response_charset_encoding = "UTF-8";
524 $s->service();
525 ?>