mirror of
				https://git.tt-rss.org/fox/tt-rss.git
				synced 2025-11-04 13:51:26 +01:00 
			
		
		
		
	
		
			
				
	
	
		
			228 lines
		
	
	
		
			6.5 KiB
		
	
	
	
		
			PHP
		
	
	
	
	
	
			
		
		
	
	
			228 lines
		
	
	
		
			6.5 KiB
		
	
	
	
		
			PHP
		
	
	
	
	
	
<?php
 | 
						|
class Mail extends Plugin {
 | 
						|
 | 
						|
	private $host;
 | 
						|
 | 
						|
	function about() {
 | 
						|
		return array(1.0,
 | 
						|
			"Share article via email",
 | 
						|
			"fox");
 | 
						|
	}
 | 
						|
 | 
						|
	function init($host) {
 | 
						|
		$this->host = $host;
 | 
						|
 | 
						|
		$host->add_hook($host::HOOK_ARTICLE_BUTTON, $this);
 | 
						|
		$host->add_hook($host::HOOK_PREFS_TAB, $this);
 | 
						|
	}
 | 
						|
 | 
						|
	function get_js() {
 | 
						|
		return file_get_contents(dirname(__FILE__) . "/mail.js");
 | 
						|
	}
 | 
						|
 | 
						|
	function save() {
 | 
						|
		$addresslist = db_escape_string($_POST["addresslist"]);
 | 
						|
 | 
						|
		$this->host->set($this, "addresslist", $addresslist);
 | 
						|
 | 
						|
		echo __("Mail addresses saved.");
 | 
						|
	}
 | 
						|
 | 
						|
	function hook_prefs_tab($args) {
 | 
						|
		if ($args != "prefPrefs") return;
 | 
						|
 | 
						|
		print "<div dojoType=\"dijit.layout.AccordionPane\" title=\"".__('Mail plugin')."\">";
 | 
						|
 | 
						|
		print "<p>" . __("You can set predefined email addressed here (comma-separated list):") . "</p>";
 | 
						|
 | 
						|
		print "<form dojoType=\"dijit.form.Form\">";
 | 
						|
 | 
						|
		print "<script type=\"dojo/method\" event=\"onSubmit\" args=\"evt\">
 | 
						|
			evt.preventDefault();
 | 
						|
			if (this.validate()) {
 | 
						|
				console.log(dojo.objectToQuery(this.getValues()));
 | 
						|
				new Ajax.Request('backend.php', {
 | 
						|
					parameters: dojo.objectToQuery(this.getValues()),
 | 
						|
					onComplete: function(transport) {
 | 
						|
						notify_info(transport.responseText);
 | 
						|
					}
 | 
						|
				});
 | 
						|
				//this.reset();
 | 
						|
			}
 | 
						|
			</script>";
 | 
						|
 | 
						|
			print "<input dojoType=\"dijit.form.TextBox\" style=\"display : none\" name=\"op\" value=\"pluginhandler\">";
 | 
						|
			print "<input dojoType=\"dijit.form.TextBox\" style=\"display : none\" name=\"method\" value=\"save\">";
 | 
						|
			print "<input dojoType=\"dijit.form.TextBox\" style=\"display : none\" name=\"plugin\" value=\"mail\">";
 | 
						|
 | 
						|
			$addresslist = $this->host->get($this, "addresslist");
 | 
						|
 | 
						|
			print "<textarea dojoType=\"dijit.form.SimpleTextarea\" style='font-size : 12px; width : 50%' rows=\"3\"
 | 
						|
				name='addresslist'>$addresslist</textarea>";
 | 
						|
 | 
						|
			print "<p><button dojoType=\"dijit.form.Button\" type=\"submit\">".
 | 
						|
				__("Save")."</button>";
 | 
						|
 | 
						|
			print "</form>";
 | 
						|
 | 
						|
		print "</div>";
 | 
						|
	}
 | 
						|
 | 
						|
	function hook_article_button($line) {
 | 
						|
		return "<img src=\"plugins/mail/mail.png\"
 | 
						|
					class='tagsPic' style=\"cursor : pointer\"
 | 
						|
					onclick=\"emailArticle(".$line["id"].")\"
 | 
						|
					alt='Zoom' title='".__('Forward by email')."'>";
 | 
						|
	}
 | 
						|
 | 
						|
	function emailArticle() {
 | 
						|
 | 
						|
		$param = db_escape_string($_REQUEST['param']);
 | 
						|
 | 
						|
		print "<input dojoType=\"dijit.form.TextBox\" style=\"display : none\" name=\"op\" value=\"pluginhandler\">";
 | 
						|
		print "<input dojoType=\"dijit.form.TextBox\" style=\"display : none\" name=\"plugin\" value=\"mail\">";
 | 
						|
		print "<input dojoType=\"dijit.form.TextBox\" style=\"display : none\" name=\"method\" value=\"sendEmail\">";
 | 
						|
 | 
						|
		$result = db_query("SELECT email, full_name FROM ttrss_users WHERE
 | 
						|
			id = " . $_SESSION["uid"]);
 | 
						|
 | 
						|
		$user_email = htmlspecialchars(db_fetch_result($result, 0, "email"));
 | 
						|
		$user_name = htmlspecialchars(db_fetch_result($result, 0, "full_name"));
 | 
						|
 | 
						|
		if (!$user_name) $user_name = $_SESSION['name'];
 | 
						|
 | 
						|
		print "<input dojoType=\"dijit.form.TextBox\" style=\"display : none\" name=\"from_email\" value=\"$user_email\">";
 | 
						|
		print "<input dojoType=\"dijit.form.TextBox\" style=\"display : none\" name=\"from_name\" value=\"$user_name\">";
 | 
						|
 | 
						|
		require_once "lib/MiniTemplator.class.php";
 | 
						|
 | 
						|
		$tpl = new MiniTemplator;
 | 
						|
 | 
						|
		$tpl->readTemplateFromFile("templates/email_article_template.txt");
 | 
						|
 | 
						|
		$tpl->setVariable('USER_NAME', $_SESSION["name"], true);
 | 
						|
		$tpl->setVariable('USER_EMAIL', $user_email, true);
 | 
						|
		$tpl->setVariable('TTRSS_HOST', $_SERVER["HTTP_HOST"], true);
 | 
						|
 | 
						|
		$result = db_query("SELECT DISTINCT link, content, title, note
 | 
						|
			FROM ttrss_user_entries, ttrss_entries WHERE id = ref_id AND
 | 
						|
			id IN ($param) AND owner_uid = " . $_SESSION["uid"]);
 | 
						|
 | 
						|
		if (db_num_rows($result) > 1) {
 | 
						|
			$subject = __("[Forwarded]") . " " . __("Multiple articles");
 | 
						|
		}
 | 
						|
 | 
						|
		while ($line = db_fetch_assoc($result)) {
 | 
						|
 | 
						|
			if (!$subject)
 | 
						|
				$subject = __("[Forwarded]") . " " . htmlspecialchars($line["title"]);
 | 
						|
 | 
						|
			$tpl->setVariable('ARTICLE_TITLE', strip_tags($line["title"]));
 | 
						|
			$tnote = strip_tags($line["note"]);
 | 
						|
			if( $tnote != ''){
 | 
						|
				$tpl->setVariable('ARTICLE_NOTE', $tnote, true);
 | 
						|
				$tpl->addBlock('note');
 | 
						|
			}
 | 
						|
			$tpl->setVariable('ARTICLE_URL', strip_tags($line["link"]));
 | 
						|
 | 
						|
			$tpl->addBlock('article');
 | 
						|
		}
 | 
						|
 | 
						|
		$tpl->addBlock('email');
 | 
						|
 | 
						|
		$content = "";
 | 
						|
		$tpl->generateOutputToString($content);
 | 
						|
 | 
						|
		print "<table width='100%'><tr><td>";
 | 
						|
 | 
						|
		$addresslist = explode(",", $this->host->get($this, "addresslist"));
 | 
						|
 | 
						|
		print __('To:');
 | 
						|
 | 
						|
		print "</td><td>";
 | 
						|
 | 
						|
/*		print "<input dojoType=\"dijit.form.ValidationTextBox\" required=\"true\"
 | 
						|
				style=\"width : 30em;\"
 | 
						|
				name=\"destination\" id=\"emailArticleDlg_destination\">"; */
 | 
						|
 | 
						|
		print_select("destination", "", $addresslist, 'style="width: 30em" dojoType="dijit.form.ComboBox"');
 | 
						|
 | 
						|
/*		print "<div class=\"autocomplete\" id=\"emailArticleDlg_dst_choices\"
 | 
						|
	style=\"z-index: 30; display : none\"></div>"; */
 | 
						|
 | 
						|
		print "</td></tr><tr><td>";
 | 
						|
 | 
						|
		print __('Subject:');
 | 
						|
 | 
						|
		print "</td><td>";
 | 
						|
 | 
						|
		print "<input dojoType=\"dijit.form.ValidationTextBox\" required=\"true\"
 | 
						|
				style=\"width : 30em;\"
 | 
						|
				name=\"subject\" value=\"$subject\" id=\"subject\">";
 | 
						|
 | 
						|
		print "</td></tr>";
 | 
						|
 | 
						|
		print "<tr><td colspan='2'><textarea dojoType=\"dijit.form.SimpleTextarea\" style='font-size : 12px; width : 100%' rows=\"20\"
 | 
						|
			name='content'>$content</textarea>";
 | 
						|
 | 
						|
		print "</td></tr></table>";
 | 
						|
 | 
						|
		print "<div class='dlgButtons'>";
 | 
						|
		print "<button dojoType=\"dijit.form.Button\" onclick=\"dijit.byId('emailArticleDlg').execute()\">".__('Send e-mail')."</button> ";
 | 
						|
		print "<button dojoType=\"dijit.form.Button\" onclick=\"dijit.byId('emailArticleDlg').hide()\">".__('Cancel')."</button>";
 | 
						|
		print "</div>";
 | 
						|
 | 
						|
		//return;
 | 
						|
	}
 | 
						|
 | 
						|
	function sendEmail() {
 | 
						|
		require_once 'classes/ttrssmailer.php';
 | 
						|
 | 
						|
		$reply = array();
 | 
						|
 | 
						|
		$mail = new ttrssMailer();
 | 
						|
 | 
						|
		$mail->AddReplyTo(strip_tags($_REQUEST['from_email']),
 | 
						|
			strip_tags($_REQUEST['from_name']));
 | 
						|
		//$mail->AddAddress($_REQUEST['destination']);
 | 
						|
		$addresses = explode(';', $_REQUEST['destination']);
 | 
						|
		foreach($addresses as $nextaddr)
 | 
						|
			$mail->AddAddress($nextaddr);
 | 
						|
 | 
						|
		$mail->IsHTML(false);
 | 
						|
		$mail->Subject = $_REQUEST['subject'];
 | 
						|
		$mail->Body = $_REQUEST['content'];
 | 
						|
 | 
						|
		$rc = $mail->Send();
 | 
						|
 | 
						|
		if (!$rc) {
 | 
						|
			$reply['error'] =  $mail->ErrorInfo;
 | 
						|
		} else {
 | 
						|
			//save_email_address(db_escape_string($destination));
 | 
						|
			$reply['message'] = "UPDATE_COUNTERS";
 | 
						|
		}
 | 
						|
 | 
						|
		print json_encode($reply);
 | 
						|
	}
 | 
						|
 | 
						|
	/* function completeEmails() {
 | 
						|
		$search = db_escape_string($_REQUEST["search"]);
 | 
						|
 | 
						|
		print "<ul>";
 | 
						|
 | 
						|
		foreach ($_SESSION['stored_emails'] as $email) {
 | 
						|
			if (strpos($email, $search) !== false) {
 | 
						|
				print "<li>$email</li>";
 | 
						|
			}
 | 
						|
		}
 | 
						|
 | 
						|
		print "</ul>";
 | 
						|
	} */
 | 
						|
 | 
						|
	function api_version() {
 | 
						|
		return 2;
 | 
						|
	}
 | 
						|
 | 
						|
}
 | 
						|
?>
 |