(originally sent to the pmwiki-users mailing list.)<br><br>I've recently gotten back to blogging on WordPress, after a gap of about 4 years where I exclusively used PmWiki for my web editing. <br>WP has some great features, but I hate both visual editor (almost any visual editor in any application) and the HTML editor. <br>
<div class="gmail_quote">
For one, the HTML is re-processed silently<br>Second, entering HTML is a damn'd nuisance.<br>Third, I'm much more used to PmWiki markup at this point.<br><br><br><br>So, I built a simple WordPress plugin to callout to PmWiki as a markup service, using the below code.<br>
Basically, the plugin checks for text enclosed by a set of tags, passes that to the markup service, which them provides HTML back to WordPress.<br><br>Despite the AuthUser and HandleAuth the markup service works on a lower level of authorization, and should any attempts at using an (:include AuthAccess.Only:) nothing is served up<br>
<br><br>Other than the simplicity and lack of nuance below (what few params currently exist are hard-coded), is this a bad idea?<br>Is there any major security hole that I'm opening up in PmWiki by doing this?<br><br>
<br>Since only text is returned, any default or themed css is not available,
nor is any JavaScript that would have been added by cookbook recipes<br>
(On a side note, the number of recipes I use that don't make use of
Unobtrusive JavaScript is annoying. I see a bunch of patching in my
future)<br>
<br>Is there any way to obtain arbitrary JavaScript that extension attempt to add to the page? (other than inline JS applied to markup) ?<br><br><br>I like being able to do markup in a consistent manner across the two platforms I use.<br>
Although the loss of plugin and extension functionality on either side is disappointing.<br><br><br><?php if(!defined('PmWiki'))exit;<br><br>## custom action for markup service<br>## 2012.05.30<br>## Michael J. Paulukonis<br>
## <a href="http://www.xradiograph.com" target="_blank">http://www.xradiograph.com</a><br>##<br>## <a href="http://www.pmwiki.org/wiki/PmWiki/CustomActions" target="_blank">http://www.pmwiki.org/wiki/PmWiki/CustomActions</a><br>
$HandleActions['wikimarkup'] = 'MarkupService'; # if url contains action=myaction call HandleMyAction timely<br>
## since this is an external call, how to handle authentication?<br>## can we pass it in via the params???<br>$AuthUser['wikimarkup'] = crypt('wikimarkup');<br>$HandleAuth['wikimarkup'] = 'admin'; # authorization level $auth for HandleMyAction<br>
<br>function MarkupService($pagename, $auth) { # parameters (signature) of handler function required by PMWiki<br><br> $wikitext = stripslashes($_GET['wikitext']);<br> $pagename = 'WordPress.Post'; // just a place-holder, evaluate<br>
<br> MarkupServiceOptions();<br><br> $markup = MarkupToHTML($pagename, $wikitext);<br><br> header('Content-type: text/html');<br> echo $markup;<br><br>}<br><br>## eventually, we should be expose these options w/in WordPress<br>
## a mechanism to SetOnce, instead of always passing, might be good<br>## OTOH, always-passing means individual sections can have different markup<br>function MarkupServiceOptions() {<br><br> global $LinkWikiWords, $SpaceWikiWords, $EnableUrlApprovalRequired;<br>
<br> $LinkWikiWords = 0; ## disable<br> $SpaceWikiWords = 0; ## turn off WikiWord spacing<br> $EnableUrlApprovalRequired = 0;<br>}<br><br><br clear="all">-Michael Paulukonis<br><a href="http://www.xradiograph.com" target="_blank">http://www.xradiograph.com</a><br>
<a href="http://goog_2112721603" target="_blank"></a><a href="http://www.xradiograph.com%5Cinterference" target="_blank">Interference Patterns (a blog)</a><br><a href="http://michaelpaulukonis.com" target="_blank">http://michaelpaulukonis.com</a><br>
<a href="http://www.BestAndroidResources.com" target="_blank"></a><br><br>Sent from somewhere in the Cloud<br>(hearthrug, by the fender)<br><br>
</div><br>