summaryrefslogtreecommitdiff
path: root/plugins
diff options
context:
space:
mode:
authorThomas Renard <[email protected]>2012-12-25 22:58:27 +0100
committerThomas Renard <[email protected]>2012-12-25 22:58:27 +0100
commite3d0198a408c1b9cd6ee75d45b3bf1657685509e (patch)
tree8971dab0e5a31735c07115a9440ee8d9ea7877a5 /plugins
parent20b86c799aa432f98aa3de7e4b1384a2c7ec21e1 (diff)
owncloud plugin: Button for creating a ReadLater bookmark in owncloud.
Needs definition of OWNCLOUD_URL to owncloud base url in config.php
Diffstat (limited to 'plugins')
-rw-r--r--plugins/owncloud/owncloud.js26
-rw-r--r--plugins/owncloud/owncloud.php55
-rw-r--r--plugins/owncloud/owncloud.pngbin0 -> 625 bytes
3 files changed, 81 insertions, 0 deletions
diff --git a/plugins/owncloud/owncloud.js b/plugins/owncloud/owncloud.js
new file mode 100644
index 000000000..6e971030b
--- /dev/null
+++ b/plugins/owncloud/owncloud.js
@@ -0,0 +1,26 @@
+function ownArticle(id) {
+ try {
+ var query = "?op=pluginhandler&plugin=owncloud&method=getOwnCloud&id=" + param_escape(id);
+
+ console.log(query);
+
+ var d = new Date();
+ var ts = d.getTime();
+
+ var w = window.open('backend.php?op=backend&method=loading', 'ttrss_tweet',
+ "status=0,toolbar=0,location=0,width=600,height=500,scrollbars=1,menubar=0");
+
+ new Ajax.Request("backend.php", {
+ parameters: query,
+ onComplete: function(transport) {
+ var ti = JSON.parse(transport.responseText);
+
+ var share_url = ti.ownurl + "?app=bookmarks&getfile=addBm.php?output=popup&url=" + param_escape(ti.link);
+
+ w.location.href = share_url;
+ } });
+ } catch (e) {
+ exception_error("ownArticle", e);
+ }
+}
+
diff --git a/plugins/owncloud/owncloud.php b/plugins/owncloud/owncloud.php
new file mode 100644
index 000000000..d00c155be
--- /dev/null
+++ b/plugins/owncloud/owncloud.php
@@ -0,0 +1,55 @@
+<?php
+require_once "config.php";
+
+class OwnCloud extends Plugin {
+ private $link;
+ private $host;
+
+ function about() {
+ return array(1.0,
+ "Adds support for OwnCloud ReadLater",
+ "cy8aer");
+ }
+
+ function init($host) {
+ $this->link = $host->get_link();
+ $this->host = $host;
+
+ $host->add_hook($host::HOOK_ARTICLE_BUTTON, $this);
+ }
+
+ function get_js() {
+ return file_get_contents(dirname(__FILE__) . "/owncloud.js");
+ }
+
+ function hook_article_button($line) {
+ return "<img src=\"".theme_image($this->link, "plugins/owncloud/owncloud.png")."\"
+ style=\"cursor : pointer\" style=\"cursor : pointer\"
+ onclick=\"ownArticle(".$line["id"].")\"
+ class='tagsPic' title='".__('Bookmark on OwnCloud ')."'>";
+ }
+
+ function getOwnCloud() {
+ $id = db_escape_string($_REQUEST['id']);
+
+ $result = db_query($this->link, "SELECT title, link
+ FROM ttrss_entries, ttrss_user_entries
+ WHERE id = '$id' AND ref_id = id AND owner_uid = " .$_SESSION['uid']);
+
+ if (db_num_rows($result) != 0) {
+ $title = truncate_string(strip_tags(db_fetch_result($result, 0, 'title')),
+ 100, '...');
+ $article_link = db_fetch_result($result, 0, 'link');
+ }
+
+ $own_url = "";
+ if (defined('OWNCLOUD_URL')) {
+ $own_url = OWNCLOUD_URL;
+ }
+ // $own_url = "https://home.g3la.de/owncloud/";
+
+ print json_encode(array("title" => $title, "link" => $article_link,
+ "id" => $id, "ownurl" => $own_url));
+ }
+}
+?>
diff --git a/plugins/owncloud/owncloud.png b/plugins/owncloud/owncloud.png
new file mode 100644
index 000000000..d31ba924b
--- /dev/null
+++ b/plugins/owncloud/owncloud.png
Binary files differ