Difference between revisions of "Extension:EmailPage"

From Organic Design wiki
(relative to absolute - better way)
(wrap message in html tags and embed css article)
Line 11: Line 11:
 
define('EMAILARTICLE_VERSION','0.0.0, 2007-05-25');
 
define('EMAILARTICLE_VERSION','0.0.0, 2007-05-25');
  
$wgEmailArticleGroup      = 'postmaster'; # Users must belong to this group to send emails (empty string means anyone can send)
+
$wgEmailArticleGroup      = 'postmaster';       # Users must belong to this group to send emails (empty string means anyone can send)
$wgEmailArticleContactsCat = 'Contacts';   # This specifies the name of a category containing categories of contact articles
+
$wgEmailArticleContactsCat = 'Contacts';         # This specifies the name of a category containing categories of contact articles
 +
$wgEmailArticleCss        = 'EmailArticle.css'; # A minimal CSS article to embed in the email (eg. monobook/main.css without portlets, actions etc)
 
$wgPhpMailerClass          = dirname(__FILE__).'/phpmailer/class.phpmailer.php'; # From http://phpmailer.sourceforge.net/
 
$wgPhpMailerClass          = dirname(__FILE__).'/phpmailer/class.phpmailer.php'; # From http://phpmailer.sourceforge.net/
  
Line 74: Line 75:
 
# Send the message to the recipients
 
# Send the message to the recipients
 
function send($title) {
 
function send($title) {
global $wgOut,$wgUser,$wgServer,$wgScript;
+
global $wgOut,$wgUser,$wgServer,$wgScript,$wgEmailArticleCss;
  
 
# get the info from the posted form
 
# get the info from the posted form
Line 102: Line 103:
 
$message = preg_replace("|\\W$wgScript|i",$wgServer.$wgScript,$message);
 
$message = preg_replace("|\\W$wgScript|i",$wgServer.$wgScript,$message);
  
# Add CSS and add margin:8px to body tag
+
# Create a simple html wrapper with embedded CSS for the message content
xwReplaceTokens($article, true);
+
$article = new Article(Title::newFromText($wgEmailArticleCss));
 +
$css = $article->getContent();
 +
$message = "<html><head><style type=\"text/css\">$css</style></head><body>$message</body></html>";
  
 
}
 
}

Revision as of 03:24, 31 May 2007

<?php

  1. Extension:EmailArticle
Info.svg These are the MediaWiki extensions we're using and/or developing. Please refer to the information on the mediawiki.org wiki for installation and usage details. Extensions here which have no corresponding mediawiki article are either not ready for use or have been superseded. You can also browse our extension code in our local Subversion repository or our GitHub mirror.

Template:Php

  1. - Licenced under LGPL (http://www.gnu.org/copyleft/lesser.html)
  2. - Author: User:NadCategory:Extensions created with Template:SpecialPage
  3. - See http://www.mediawiki.org/wiki/Extension:EmailArticle for installation and usage details

$wgShowExceptionDetails = true;

if (!defined('MEDIAWIKI')) die('Not an entry point.');

define('EMAILARTICLE_VERSION','0.0.0, 2007-05-25');

$wgEmailArticleGroup = 'postmaster'; # Users must belong to this group to send emails (empty string means anyone can send) $wgEmailArticleContactsCat = 'Contacts'; # This specifies the name of a category containing categories of contact articles $wgEmailArticleCss = 'EmailArticle.css'; # A minimal CSS article to embed in the email (eg. monobook/main.css without portlets, actions etc) $wgPhpMailerClass = dirname(__FILE__).'/phpmailer/class.phpmailer.php'; # From http://phpmailer.sourceforge.net/

if ($wgEmailArticleGroup) $wgGroupPermissions['sysop'][$wgEmailArticleGroup] = true;

$wgExtensionFunctions[] = 'wfSetupEmailArticle';

$wgExtensionCredits['specialpage'][] = array( 'name' => 'Special:EmailArticle', 'author' => 'User:Nad', 'description' => 'Send rendered article to an email address or list of addresses', 'url' => 'http://www.mediawiki.org/wiki/Extension:EmailArticle', 'version' => EMAILARTICLE_VERSION );

  1. If form has been posted, include the phpmailer class

if (isset($_REQUEST['sf_cat'])) require_once($wgPhpMailerClass);

  1. Define a new class based on the SpecialPage class

require_once("$IP/includes/SpecialPage.php"); class SpecialEmailArticle extends SpecialPage {

# Constructor function SpecialEmailArticle() { global $wgEmailArticleGroup; SpecialPage::SpecialPage('EmailArticle',$wgEmailArticleGroup); }

# Override SpecialPage::execute($param = ) function execute($param) { global $wgOut,$wgUser,$wgEmailArticleContactsCat; $title = Title::makeTitle(NS_SPECIAL,'EmailArticle');

# If the form has been posted, attempt to send the message if (isset($_REQUEST['sf_cat'])) $this->send($param); elseif ($param == ) return $wgOut->addWikiText(wfMsg('ea_noarticle'));

$wgOut->addWikiText(wfMsg('ea_selectrecipients')); $wgOut->addHTML(wfElement('form',array('action' => $title->getLocalURL('action=submit'),'method' => 'POST'),null));

# If $wgEmailArticleContactsCat is set, create a select list of all categories if ($wgEmailArticleContactsCat) { $db =& wfGetDB(DB_SLAVE); $cl = $db->tableName('categorylinks'); $cats = ; $result = $db->query("SELECT cl_from FROM $cl WHERE cl_to = '$wgEmailArticleContactsCat' ORDER BY cl_sortkey"); while ($row = mysql_fetch_row($result)) { $t = Title::newFromID($row[0]); if ($t->getNamespace() == NS_CATEGORY) $cats .= "<option>{$t->getText()}</option>"; } if ($cats) $wgOut->addHTML("From category: <select name=\"sf_cat\">$cats</select>"); }

$wgOut->addHTML( '<textarea name="sf_list" cols=25 rows=10></textarea>' . wfElement('input',array('type' => 'submit')) . '</form>' ); }

# Send the message to the recipients function send($title) { global $wgOut,$wgUser,$wgServer,$wgScript,$wgEmailArticleCss;

# get the info from the posted form $subject = $_REQUEST['sf_subject']; $header = $_REQUEST['sf_header']; $cat = $_REQUEST['sf_cat']; $group = $_REQUEST['sf_group']; $list = $_REQUEST['sf_list']; $textonly = $_REQUEST['sf_textonly'];

# get the wikitext content of the article to send $title = Title::newFromText($title); $article = new Article($title); $message = $article->getContent();

if ($header) $message = "$header\n\n$message";

# Convert the message text to html unless textonly if ($textonly == ) {

# Parse the wikitext $parser = new Parser; $opt = new ParserOptions; $message = $parser->parse($message,$title,$opt,true,true)->getText();

# Convert any relative URL's to absolute $message = preg_replace("|\\W$wgScript|i",$wgServer.$wgScript,$message);

# Create a simple html wrapper with embedded CSS for the message content $article = new Article(Title::newFromText($wgEmailArticleCss)); $css = $article->getContent(); $message = "$message";

}

# Set up new mailer instance $mail = new PHPMailer(); $mail->From = $wgUser->isValidEmailAddr() ? $wgUser->getEmail() : "wiki@$wgServer"; $mail->FromName = $GLOBALS['xwUserName']; $mail->IsHTML(!$textonly); foreach ( $GLOBALS['sa-email'] as $i ) $mail->AddAddress( trim($i) ); $mail->Subject = $title; $mail->Body = $article;

# Send message and redirect client back to article or raise error $title = preg_replace('/^(?=Category:)/i',':',$title); if ($mail->Send()) { global $xwUserName; $msg = count($GLOBALS['sa-email']).' recipient(s)'; xwLog("$title sent to $msg by $xwUserName"); } else xwLog($msg = "Error sending $title for $xwUserName: ".$mail->ErrorInfo); }

}

  1. Called from $wgExtensionFunctions array when initialising extensions

function wfSetupEmailArticle() { global $wgLanguageCode,$wgMessageCache;

# Add the messages used by the specialpage if ($wgLanguageCode == 'en') { $wgMessageCache->addMessages(array( 'emailarticle' => 'EmailArticle', 'ea_noarticle' => "Please specify an article to send, for example Special:EmailArticle/Main Page.", 'ea_error' => "Error: $1", 'ea_ok' => "Article $1 sent successfully to $2 recipient$3", 'ea_selectrecipients' => "Select the recipients" 'ea_selectrecipients' => "Select the recipients" )); }

# Add the specialpage to the environment SpecialPage::addPage(new SpecialEmailArticle()); } ?>