From 7252abe3ea5703b3cf75a3745e560499cfde500a Mon Sep 17 00:00:00 2001
From: Andrew Dolgov <fox@madoka.volgo-balt.ru>
Date: Sun, 23 Dec 2012 15:18:41 +0400
Subject: [PATCH] add contributed plugins; load note plugin by default

---
 config.php-dist                   |   2 +-
 include/functions.php             |   2 +-
 plugins/flattr/flattr.php         |  46 ++++++++++++++++++++++++++++
 plugins/flattr/flattr.png         | Bin 0 -> 693 bytes
 plugins/googleplus/googleplus.js  |  29 ++++++++++++++++++
 plugins/googleplus/googleplus.php |  47 +++++++++++++++++++++++++++++
 plugins/googleplus/googleplus.png | Bin 0 -> 827 bytes
 plugins/identica/identica.js      |  31 +++++++++++++++++++
 plugins/identica/identica.php     |  47 +++++++++++++++++++++++++++++
 plugins/identica/identica.png     | Bin 0 -> 121 bytes
 plugins/pinterest/pinterest.js    |  31 +++++++++++++++++++
 plugins/pinterest/pinterest.php   |  47 +++++++++++++++++++++++++++++
 plugins/pinterest/pinterest.png   | Bin 0 -> 3829 bytes
 plugins/pocket/pocket.js          |  31 +++++++++++++++++++
 plugins/pocket/pocket.php         |  48 ++++++++++++++++++++++++++++++
 plugins/pocket/pocket.png         | Bin 0 -> 471 bytes
 16 files changed, 359 insertions(+), 2 deletions(-)
 create mode 100644 plugins/flattr/flattr.php
 create mode 100644 plugins/flattr/flattr.png
 create mode 100644 plugins/googleplus/googleplus.js
 create mode 100644 plugins/googleplus/googleplus.php
 create mode 100644 plugins/googleplus/googleplus.png
 create mode 100644 plugins/identica/identica.js
 create mode 100644 plugins/identica/identica.php
 create mode 100644 plugins/identica/identica.png
 create mode 100644 plugins/pinterest/pinterest.js
 create mode 100644 plugins/pinterest/pinterest.php
 create mode 100644 plugins/pinterest/pinterest.png
 create mode 100644 plugins/pocket/pocket.js
 create mode 100644 plugins/pocket/pocket.php
 create mode 100644 plugins/pocket/pocket.png

diff --git a/config.php-dist b/config.php-dist
index 2975d680a..12e472905 100644
--- a/config.php-dist
+++ b/config.php-dist
@@ -176,7 +176,7 @@
 	// if you experience weird errors and tt-rss failing to start, blank pages
 	// after login, or content encoding errors, disable it.
 
-	define('PLUGINS', '');
+	define('PLUGINS', 'note');
 	// Plugins to load. Check plugins/ directory for additional information.
 
 	define('FEEDBACK_URL', '');
diff --git a/include/functions.php b/include/functions.php
index da6767986..a4caf9fde 100644
--- a/include/functions.php
+++ b/include/functions.php
@@ -3141,7 +3141,7 @@
 			ccache_update($link, $feed_id, $owner_uid);
 		}
 
-		$result = db_query($link, "SELECT title,link,content,feed_id,comments,int_id,
+		$result = db_query($link, "SELECT id,title,link,content,feed_id,comments,int_id,
 			".SUBSTRING_FOR_DATE."(updated,1,16) as updated,
 			(SELECT icon_url FROM ttrss_feeds WHERE id = feed_id) as icon_url,
 			(SELECT site_url FROM ttrss_feeds WHERE id = feed_id) as site_url,
diff --git a/plugins/flattr/flattr.php b/plugins/flattr/flattr.php
new file mode 100644
index 000000000..6af6cb9c3
--- /dev/null
+++ b/plugins/flattr/flattr.php
@@ -0,0 +1,46 @@
+<?php
+class Flattr {
+	private $link;
+	private $host;
+
+	function __construct($host) {
+		$this->link = $host->get_link();
+		$this->host = $host;
+
+		$host->add_hook($host::HOOK_ARTICLE_BUTTON, $this);
+	}
+
+  function hook_article_button($line) {
+
+	$article_id = $line["id"];
+
+    $result = db_query($this->link, "SELECT link
+      FROM ttrss_entries, ttrss_user_entries
+      WHERE id = '$article_id' AND ref_id = id AND owner_uid = " .$_SESSION['uid']);
+
+    if (db_num_rows($result) != 0) {
+      $article_link = db_fetch_result($result, 0, 'link');
+    }
+
+    $response = null;
+    if ($article_link) {
+      $encoded = urlencode($article_link);
+      $r = file_get_contents("https://api.flattr.com/rest/v2/things/lookup/?url=$encoded");
+      $response = json_decode($r, true);
+    }
+
+    $rv = null;
+    if ($response and array_key_exists('link', $response)) {
+      $rv = "<a id='flattr' href='" . $response['link'] . "'>
+        <img src=\"".theme_image($this->link, 'plugins/flattr/flattr.png')."\"
+        class='tagsPic' style=\"cursor : pointer\"
+        title='".__('Flattr article')."'>
+        </a>";
+    } else {
+      $rv = "";
+    }
+
+    return $rv;
+  }
+}
+?>
diff --git a/plugins/flattr/flattr.png b/plugins/flattr/flattr.png
new file mode 100644
index 0000000000000000000000000000000000000000..4933ffc21187b212de7a52509806adb1bbad1d32
GIT binary patch
literal 693
zcmV;m0!safP)<h;3K|Lk000e1NJLTq000mG000mO1^@s6AM^iV00001b5ch_0Itp)
z=>Px#24YJ`L;(K){{a7>y{D4^000SaNLh0L01FcU01FcV0GgZ_00007bV*G`2iyV>
z5D^DbYG=p*00K2hL_t(I%Z-yyNR&|&#eesGpIXx&D_u;G?ILQ`G9jWC6`@&_U?2p!
zh)7D495E~kO>`uSAZihjND;Y+(jp_sj3jG_HbD_Yty_p$;C%DmyDj`TV_2Qd<2~*@
z=W@<{LKc4XZLh*e8L$Z`0favxMtz<aX<L5adAk6N-`Td7KyCm#Kv@`qQI8k7R9H3C
zaQoe<78&o|8pFslpp<`Lx;a@`J>1ljs=t`;eO-v72Ct>F%2UTA@DbrVuvw91qKY-r
zwerw#)6F->I|CavIG704YFVz1zQ9N=!e>0-c@KU=p7&j`BO{6HqsLkU8ztP7kPp@R
zby?lNB#@dFH7~yaj9uGOfanqfS7S#<61_u*!*moKv^wWgs8)-!2)<(V+svgPV<j@C
zJ~a9OU_6i@-`UCRc|&ZD>s}!Q96;>E>q+4LYzEHad~QlP1PT)TB}H#D_<3)k+Ifs_
zs^r4cO0(EgZjB5kcJ`$KoU?Y`YDvhnoeG3r7yS&41IY9KiYj}IWBp8Z<T9%RF(p|9
zW3v+k9-QHBym{2NJ>Hj8=WDI<!K3N+{t6?)8dbe)y)T^8*H58lFrk7MO%|O`ooRVg
zkrd||tpY+E<sL#@m5p9?RgPgoe;7nQ=8SX~cchw{2g*D1Gp^AADu7ZXP?@`=fGPrS
zMNCf^!MS)xs;%+i?(V$Ep0xZIUIoTfpWQn!Apmv#yG}2Sd<&3a;qN#Bq<|+z%&pe_
bgK2=@+RFrzSUAM600000NkvXXu0mjfgW@Ur

literal 0
HcmV?d00001

diff --git a/plugins/googleplus/googleplus.js b/plugins/googleplus/googleplus.js
new file mode 100644
index 000000000..027d9b40e
--- /dev/null
+++ b/plugins/googleplus/googleplus.js
@@ -0,0 +1,29 @@
+	function shareArticleToGooglePlus(id) {
+	try {
+		var query = "?op=pluginhandler&plugin=googleplus&method=getInfo&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=500,height=450,scrollbars=1,menubar=0");
+
+		new Ajax.Request("backend.php",	{
+			parameters: query,
+			onComplete: function(transport) {
+				var ti = JSON.parse(transport.responseText);
+
+				var share_url = "https://plus.google.com/share?url=" + param_escape(ti.link);
+
+				w.location.href = share_url;
+
+			} });
+
+
+	} catch (e) {
+		exception_error("tweetArticle", e);
+	}
+	}
+
diff --git a/plugins/googleplus/googleplus.php b/plugins/googleplus/googleplus.php
new file mode 100644
index 000000000..1c5128eed
--- /dev/null
+++ b/plugins/googleplus/googleplus.php
@@ -0,0 +1,47 @@
+<?php
+class GooglePlus {
+	private $link;
+	private $host;
+
+	function __construct($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__) . "/googleplus.js");
+	}
+
+	function hook_article_button($line) {
+		$article_id = $line["id"];
+
+		$rv = "<img src=\"".theme_image($this->link, 'plugins/googleplus/googleplus.png')."\"
+			class='tagsPic' style=\"cursor : pointer\"
+			onclick=\"shareArticleToGooglePlus($article_id)\"
+			title='".__('Share on Google+')."'>";
+
+		return $rv;
+	}
+
+	function getInfo() {
+		$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');
+		}
+
+		print json_encode(array("title" => $title, "link" => $article_link,
+				"id" => $id));
+	}
+
+
+}
+?>
diff --git a/plugins/googleplus/googleplus.png b/plugins/googleplus/googleplus.png
new file mode 100644
index 0000000000000000000000000000000000000000..8c64b81a208bcca3c419190d70874ec684266840
GIT binary patch
literal 827
zcmV-B1H}A^P)<h;3K|Lk000e1NJLTq000mG000mO1^@s6AM^iV00004XF*Lt006O%
z3;baP00006VoOIv0RI600RN!9r;`8x010qNS#tmY3ljhU3ljkVnw%H_000McNliru
z+yx5<G8f$?xwZfR0=P*;K~y-)os(OLm1Pu$pY<R1p6$q{@i2!5D;OiOpe{m5gT@dk
zyQqtZ3Bf~$i<|<Rg7QuwNWAoLQG%rr23|HWs1cJvYKYFoAe2e&rp93s54iXK_rJgI
zTdRxt$HQ$4UicQQ_3^HEy-PlLW;y#O{s534-rVq5B~AqtkOF`zhyjqP+WKQBuLAb|
zvn%H+j%-|8dcJ?@RG;{6%s`4p00ZI}%!=H&X7TLL*KRD^I(oXD01WgjIo&h7vpb)>
zU{O!MbgbKmI)`37iyt3FCeH&#zWgZ`zBOV!9}ab|=;#~=)+7KA?>?~FAKq)x#5u7@
zXkMRT!O*+3rfbN=IV=RwK*-ye1_@baUFMzxNB}g?(CNR#(lVgP*ZXL$e~onT74qX>
zA+K*n7WYxAR?+GrbjN36H*dj-ZA1Xh2ZBVX2Gk%_I&l}y;LK1Fvf5SZmoL%yr-sim
z8oy1_{PQw*8H5mU11pK9ryxl{70sGhqmFt{eC8CfLiYHR_$Qtw9X&=8=7cU7c;uar
z$d~ldCZgTZiLD-_wR;D?-Nu>V0I!B`WjJEIL@>YTU*6kfy{``8`X8ZEN}+2hZe$Db
z&3_+Qsfi#-30%%>y~(QaNl5_wo!i*nPl+TVd~*`t%8(ngc;@|6cmRQr0T2pbL;yZ`
zTw2DbWg36i2(1?Ru7mjU0$d2VpatgMJ{TeBy$^KF2J+7jS$N}Z+>c}ASAK`;L%3c0
z2$hAX8mbg9f~w6kNC4`yGg<G*){1#g636iUceG!43E47C{>dK7A8&(lr5HsJkUM#3
z++}e7=$G3YYG{(6B4}D7{%H*N?H5E{iwULjoJUkq4K%#x?5+AR_s$J@d0FqO!GT9N
zr%@cutFF~5e(j5tMvp_B0^l_0_?6nxv8kC~?^E~x$A890XO`^wexLvV002ovPDHLk
FV1iUJeKG(5

literal 0
HcmV?d00001

diff --git a/plugins/identica/identica.js b/plugins/identica/identica.js
new file mode 100644
index 000000000..d31fc55f4
--- /dev/null
+++ b/plugins/identica/identica.js
@@ -0,0 +1,31 @@
+	function shareArticleToIdentica(id) {
+	try {
+		var query = "?op=pluginhandler&plugin=identica&method=getInfo&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 = "http://identi.ca/index.php?action=bookmarkpopup&_=" + ts +
+					"&title=" + param_escape(ti.title) +
+					"&url=" + param_escape(ti.link);
+
+				w.location.href = share_url;
+
+			} });
+
+
+	} catch (e) {
+		exception_error("shareArticleIdentica", e);
+	}
+	}
+
diff --git a/plugins/identica/identica.php b/plugins/identica/identica.php
new file mode 100644
index 000000000..e7a5b3573
--- /dev/null
+++ b/plugins/identica/identica.php
@@ -0,0 +1,47 @@
+<?php
+class Identica {
+	private $link;
+	private $host;
+
+	function __construct($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__) . "/identica.js");
+	}
+
+	function hook_article_button($line) {
+		$article_id = $line["id"];
+
+		$rv = "<img src=\"".theme_image($this->link, 'plugins/identica/identica.png')."\"
+			class='tagsPic' style=\"cursor : pointer\"
+			onclick=\"shareArticleToIdentica($article_id)\"
+			title='".__('Share on identi.ca')."'>";
+
+		return $rv;
+	}
+
+	function getInfo() {
+		$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');
+		}
+
+		print json_encode(array("title" => $title, "link" => $article_link,
+				"id" => $id));
+	}
+
+
+}
+?>
diff --git a/plugins/identica/identica.png b/plugins/identica/identica.png
new file mode 100644
index 0000000000000000000000000000000000000000..ee3cb61ea83e774986cf51e66984d80dc1deff4c
GIT binary patch
literal 121
zcmeAS@N?(olHy`uVBq!ia0vp^0wB!D3?x-;bCrM;OS+@4BLl<6e(pbstUx|nfKP}k
zkp7jxQorOuIgrIz666=m;PC858jvIC>Eal|aXmSKf%&(6i=YGpL!2Ss(Stpa>wuCB
Mp00i_>zopr0FTrhAOHXW

literal 0
HcmV?d00001

diff --git a/plugins/pinterest/pinterest.js b/plugins/pinterest/pinterest.js
new file mode 100644
index 000000000..01c525f55
--- /dev/null
+++ b/plugins/pinterest/pinterest.js
@@ -0,0 +1,31 @@
+	function pinterest(id) {
+	try {
+		var query = "?op=pluginhandler&plugin=pinterest&method=getInfo&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=650,height=600,scrollbars=1,menubar=0");
+
+		new Ajax.Request("backend.php",	{
+			parameters: query,
+			onComplete: function(transport) {
+				var ti = JSON.parse(transport.responseText);
+
+				var share_url = "http://pinterest.com/pin/create/button/?" +
+					"url=" + param_escape(ti.link) +
+					"&description=" + param_escape(ti.title);
+
+				w.location.href = share_url;
+
+			} });
+
+
+	} catch (e) {
+		exception_error("tweetArticle", e);
+	}
+	}
+
diff --git a/plugins/pinterest/pinterest.php b/plugins/pinterest/pinterest.php
new file mode 100644
index 000000000..83a95a449
--- /dev/null
+++ b/plugins/pinterest/pinterest.php
@@ -0,0 +1,47 @@
+<?php
+class Pinterest {
+	private $link;
+	private $host;
+
+	function __construct($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__) . "/pinterest.js");
+	}
+
+	function hook_article_button($line) {
+		$article_id = $line["id"];
+
+		$rv = "<img src=\"".theme_image($this->link, 'plugins/pinterest/pinterest.png')."\"
+			class='tagsPic' style=\"cursor : pointer\"
+			onclick=\"pinterest($article_id)\"
+			title='".__('Pinterest')."'>";
+
+		return $rv;
+	}
+
+	function getInfo() {
+		$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');
+		}
+
+		print json_encode(array("title" => $title, "link" => $article_link,
+				"id" => $id));
+	}
+
+
+}
+?>
diff --git a/plugins/pinterest/pinterest.png b/plugins/pinterest/pinterest.png
new file mode 100644
index 0000000000000000000000000000000000000000..b85aed3cd6be0c16eb3b4c3c83eb3f9f2ca5abd3
GIT binary patch
literal 3829
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

literal 0
HcmV?d00001

diff --git a/plugins/pocket/pocket.js b/plugins/pocket/pocket.js
new file mode 100644
index 000000000..021d5bb05
--- /dev/null
+++ b/plugins/pocket/pocket.js
@@ -0,0 +1,31 @@
+	function shareArticleToPocket(id) {
+	try {
+		var query = "?op=pluginhandler&plugin=pocket&method=getInfo&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=500,height=400,scrollbars=1,menubar=0");
+
+		new Ajax.Request("backend.php",	{
+			parameters: query,
+			onComplete: function(transport) {
+				var ti = JSON.parse(transport.responseText);
+
+				var share_url = "https://getpocket.com/save?" +
+					"&title=" + param_escape(ti.title) +
+					"&url=" + param_escape(ti.link);
+
+				w.location.href = share_url;
+
+			} });
+
+
+	} catch (e) {
+		exception_error("tweetArticle", e);
+	}
+	}
+
diff --git a/plugins/pocket/pocket.php b/plugins/pocket/pocket.php
new file mode 100644
index 000000000..56592a526
--- /dev/null
+++ b/plugins/pocket/pocket.php
@@ -0,0 +1,48 @@
+<?php
+class Pocket {
+
+	private $link;
+	private $host;
+
+	function __construct($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__) . "/pocket.js");
+	}
+
+	function hook_article_button($line) {
+		$article_id = $line["id"];
+
+		$rv = "<img src=\"".theme_image($this->link, 'plugins/pocket/pocket.png')."\"
+			class='tagsPic' style=\"cursor : pointer\"
+			onclick=\"shareArticleToPocket($article_id)\"
+			title='".__('Pocket')."'>";
+
+		return $rv;
+	}
+
+	function getInfo() {
+		$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');
+		}
+
+		print json_encode(array("title" => $title, "link" => $article_link,
+				"id" => $id));
+	}
+
+
+}
+?>
diff --git a/plugins/pocket/pocket.png b/plugins/pocket/pocket.png
new file mode 100644
index 0000000000000000000000000000000000000000..ff6bc85a450c35cc26fb912538bfc38ce88c0fe0
GIT binary patch
literal 471
zcmV;|0Vw{7P)<h;3K|Lk000e1NJLTq000mG000mO1^@s6AM^iV00006VoOIv0RI60
z0RN!9r;`8x010qNS#tmY3ljhU3ljkVnw%H_000McNliru+zJ;695;TCsF?r&0c1%;
zK~y-)&5|)sR6!JlzjNQl0Ht{pqLfqw6GIDur6)#_{T0UA&{$evXn??PU@Hq-fkYD{
zPzYGiP@x79DkBCm?^y5_SRM&>daKEuIp3XgX5e3!T8pE4;||g-z&C2_liSNn-vDZt
zHg<uIza0D<=mdxht~#)NqtrIi`JlLZJ;Sl>uZDE4fmHU6FWasHBy3M_{ruDme$`TA
zUT*)|?6p0O+VpK1v{D@(UE6s9JI{ZNPVNEDSDNzxhxPm8SI=JnOtKtE4-V^%^;8s(
z@|ETs!2ZaSd$owSNPWhZRa5}Rt3qRCkb_yoo9`nN4*{}>*Mhz>KpC%A0EuF%=J;Tp
znUp<{MfS0@mAh=qCQ(dPLW~p}hDF&3uw+TOq}-Bq2DM=!QfyRyBEbIe<E|`=XNv5p
z;BMRV!xtB6_T*GEJ@1>R*8*B~P;YeGMSn&NmG<6A@wt0>>45*P{s5oJlkTTY`F{Wa
N002ovPDHLkV1k&R%)$Tw

literal 0
HcmV?d00001

-- 
GitLab