Example #1
0
        foreach ($tag['attributes'] as $key => $value) {
            if (isset($setup['map'][$key])) {
                $key = $setup['map'][$key];
            }
            $vars[$key] = $value;
        }
        extract($vars, EXTR_SKIP);
        ob_start();
        include $path;
        return ob_get_clean();
    }
}
// Lets change the template path and the file extension.
$engine = new TestEngine();
$engine->setPath(__DIR__ . '/templates/');
$code = new \mjohnson\decoda\Decoda();
$code->addFilter(new \mjohnson\decoda\filters\QuoteFilter());
$code->setEngine($engine);
?>

<h2>Test Rendering</h2>

<p>Uses a different template engine, with a separate templates folder and a different file extension.</p>

<br>

<?php 
$string = '[quote]Lorem ipsum dolor sit amet, consectetur adipiscing elit. Pellentesque non sapien a eros tincidunt accumsan. Ut nisl dui, dignissim at posuere quis, facilisis eget lectus. Morbi vitae massa eu metus pharetra rhoncus. Suspendisse potenti. Phasellus laoreet dapibus dapibus. Duis faucibus lacinia diam, nec pharetra est pharetra vitae. Etiam sodales, nulla et ullamcorper mattis, augue nunc sollicitudin risus, nec imperdiet est leo vitae est. Integer ultricies, metus at scelerisque interdum, sapien lorem mollis orci, vel mattis felis augue vitae nunc. Fusce eget sem sed orci interdum commodo sit amet et metus. In ultricies feugiat eleifend. Aliquam erat volutpat.
	[quote="Miles"]Lorem ipsum dolor sit amet, consectetur adipiscing elit. Pellentesque non sapien a eros tincidunt accumsan. Ut nisl dui, dignissim at posuere quis, facilisis eget lectus. Morbi vitae massa eu metus pharetra rhoncus. Suspendisse potenti. Phasellus laoreet dapibus dapibus. Duis faucibus lacinia diam, nec pharetra est pharetra vitae. Etiam sodales, nulla et ullamcorper mattis, augue nunc sollicitudin risus, nec imperdiet est leo vitae est. Integer ultricies, metus at scelerisque interdum, sapien lorem mollis orci, vel mattis felis augue vitae nunc. Fusce eget sem sed orci interdum commodo sit amet et metus. In ultricies feugiat eleifend. Aliquam erat volutpat.[/quote]
	[quote date="1313728971"]Lorem ipsum dolor sit amet, consectetur adipiscing elit. Pellentesque non sapien a eros tincidunt accumsan. Ut nisl dui, dignissim at posuere quis, facilisis eget lectus. Morbi vitae massa eu metus pharetra rhoncus. Suspendisse potenti. Phasellus laoreet dapibus dapibus. Duis faucibus lacinia diam, nec pharetra est pharetra vitae. Etiam sodales, nulla et ullamcorper mattis, augue nunc sollicitudin risus, nec imperdiet est leo vitae est. Integer ultricies, metus at scelerisque interdum, sapien lorem mollis orci, vel mattis felis augue vitae nunc. Fusce eget sem sed orci interdum commodo sit amet et metus. In ultricies feugiat eleifend. Aliquam erat volutpat.
		[quote="Miles" date="2011-02-26 06:42:33"]Lorem ipsum dolor sit amet, consectetur adipiscing elit. Pellentesque non sapien a eros tincidunt accumsan. Ut nisl dui, dignissim at posuere quis, facilisis eget lectus. Morbi vitae massa eu metus pharetra rhoncus. Suspendisse potenti. Phasellus laoreet dapibus dapibus. Duis faucibus lacinia diam, nec pharetra est pharetra vitae. Etiam sodales, nulla et ullamcorper mattis, augue nunc sollicitudin risus, nec imperdiet est leo vitae est. Integer ultricies, metus at scelerisque interdum, sapien lorem mollis orci, vel mattis felis augue vitae nunc. Fusce eget sem sed orci interdum commodo sit amet et metus. In ultricies feugiat eleifend. Aliquam erat volutpat.
Example #2
0
<?php

$code = new \mjohnson\decoda\Decoda();
$code->addFilter(new \mjohnson\decoda\filters\UrlFilter());
$code->addHook(new \mjohnson\decoda\hooks\ClickableHook());
?>

<h2>URL</h2>

<?php 
$string = 'Valid websites:
[url]http://domain.com[/url]
[url]https://securesite.com[/url]
[url]ftp://ftpsite.com[/url]
[url]irc://ircsite.com[/url]
[url]telnet://telnetsite.com[/url]
[url="http://domain.com"]Linked URL[/url]

Valid websites (auto-linked with hook):
http://domain.com
http://sub.domain.com/?with=param
http://user:pass@domain.com:80/?with=param

Invalid websites:
[url]domain.com[/url]
[url]www.domain.com[/url]
[url]wtf://unsupportedprotocol.com/[/url]';
$code->reset($string);
echo $code->parse();
?>
Example #3
0
<h2>Censoring</h2>

<?php 
$string = 'Decoda uses a pretty awesome censoring system. It censors any word in the censored.txt blacklist file.
It tries its best not to censor words within other words, but it can happen. Here are a few examples:

f**k shit bitch asshole penis douche

And here are the same words, but with different lengths for each letter, and in different cases.

fuuCCkk shhiiiitt bITCH assHOLE peeniiss douchhe

It will also magically censor words that end with: ing, ed, er

f****r shiting bitched

Hope it works out, I tried to make it as smart as possible.';
$code = new \mjohnson\decoda\Decoda($string);
$code->addHook(new \mjohnson\decoda\hooks\CensorHook());
echo $code->parse();
Example #4
0
$string = '{b}Bold{/b}
{i}Italics{/i}
{u}Underline{/u}
{s}Strike through{/s}
{b}{i}{u}Bold, italics, underline{/u}{/i}{/b}';
$code = new \mjohnson\decoda\Decoda($string);
$code->addFilter(new \mjohnson\decoda\filters\DefaultFilter())->setBrackets('{', '}');
echo $code->parse();
?>

<h2>Shorthand emails and URLs</h2>

<?php 
$string = '[email]email@domain.com[/email]
[url]http://domain.com/[/url]';
$code = new \mjohnson\decoda\Decoda($string);
$code->addFilter(new \mjohnson\decoda\filters\EmailFilter())->addFilter(new \mjohnson\decoda\filters\UrlFilter())->setShorthand();
echo $code->parse();
?>

<h2>XHTML markup</h2>

<?php 
$string = '[b]Bold[/b]
[i]Italics[/i]
[u]Underline[/u]
[s]Strike through[/s]
[b][i][u]Bold, italics, underline[/u][/i][/b]';
$code = new \mjohnson\decoda\Decoda($string);
$code->addFilter(new \mjohnson\decoda\filters\DefaultFilter())->setXhtml();
echo $code->parse();
Example #5
0
<?php

$code = new \mjohnson\decoda\Decoda();
$code->addFilter(new \mjohnson\decoda\filters\TextFilter());
?>

<h2>Font Family</h2>

<?php 
$string = '[font="Arial"]Lorem ipsum dolor sit amet, consectetur adipiscing elit.[/font]
[font="Verdana"]Volutpat tellus vulputate dui venenatis quis euismod turpis pellentesque.[/font]
[font="Tahoma"]Suspendisse sit amet ipsum eu odio sagittis ultrices at non sapien.[/font]
[font="Monospace, \'Lucida Sans\'"]Quisque viverra feugiat purus, in luctus faucibus felis eget viverra.[/font]
[font="Times"]Suspendisse sit amet ipsum eu odio sagittis ultrices at non sapien.[/font]';
$code->reset($string);
echo $code->parse();
?>

<h2>Size <span>(10-29)</span></h2>

<?php 
$string = '[size="5"]Lorem ipsum dolor sit amet, consectetur adipiscing elit.[/size]
[size="10"]Volutpat tellus vulputate dui venenatis quis euismod turpis pellentesque.[/size]
[size="19"]Suspendisse sit amet ipsum eu odio sagittis ultrices at non sapien.[/size]
[size="27"]Quisque viverra feugiat purus, in luctus faucibus felis eget viverra.[/size]
[size="32"]Suspendisse sit amet ipsum eu odio sagittis ultrices at non sapien.[/size]';
$code->reset($string);
echo $code->parse();
?>

<h2>Color</h2>
Example #6
0
<?php

$code = new \mjohnson\decoda\Decoda();
$code->addFilter(new \mjohnson\decoda\filters\CodeFilter());
$code->addHook(new \mjohnson\decoda\hooks\EmoticonHook());
$code->addHook(new \mjohnson\decoda\hooks\CensorHook());
?>

<h2>Code</h2>

<?php 
$string = "[code]// Constants\ndefine('DECODA', __DIR__ .'/');\n\n// Includes\nspl_autoload_register();\nset_include_path(implode(PATH_SEPARATOR, array(\n\tget_include_path(),\n\tDECODA\n)));[/code]";
$code->reset($string);
echo $code->parse();
?>

<h2>Code <span>with filters and hooks</span></h2>

<?php 
$string = "[code]email@domain.com\n\n:] :) :D :/ >[ :p :o >_>\n\n:happy: :aw: :cool: :kiss: :meh: :mmf: :heart:\n\nfuuCCkk shhiiiitt bITCH assHOLE peeniiss douchhe\n\nfucker shiting bitched[/code]";
$code->reset($string);
echo $code->parse();
?>

<h2>Code <span>with language attribute</span></h2>

<?php 
$string = '[code="php"]<?php
abstract class HookAbstract implements Hook {

	/**
Example #7
0
?>

<h2>Incorrectly nested</h2>

<?php 
$string = '[b]Bold[/b]
[b][i]Bold, italics[/i][/b]
[i][u]Bold, italics, underline (wrong)[/b][/i][/u]';
$code = new \mjohnson\decoda\Decoda($string);
$code->addFilter(new \mjohnson\decoda\filters\DefaultFilter());
echo $code->parse();
?>

<h2>Incorrectly nested hierarchy</h2>

<?php 
$string = '[li]List item outside of a list or olist.[/li]

[list]
[b]Bold tag as the first descendant of list.[/b]
[li]Lorem ipsum dolor sit amet, consectetuer adipiscing elit.[/li]
[li]Aliquam laoreet pulvinar sem. Aenean at odio.[/li]
[li]Vestibulum ante [b]ipsum primis in faucibus orci luctus[/b] et ultrices posuere cubilia Curae; Donec elit.[/li]
[li]Fusce eget enim. Nullam tellus felis, sodales nec, sodales ac, commodo eu, ante.[/li]
[li]Curabitur tincidunt, lacus eget iaculis tincidunt.[/li]
[li]Curabitur sed [i]tellus[/i]. Donec id dolor.[/li]
[/list]';
$code = new \mjohnson\decoda\Decoda($string);
$code->addFilter(new \mjohnson\decoda\filters\DefaultFilter());
$code->addFilter(new \mjohnson\decoda\filters\ListFilter());
echo $code->parse();
Example #8
0
<?php

$code = new \mjohnson\decoda\Decoda();
$code->defaults();
?>

<h2>XSS Protection</h2>

<p>Any form of XSS injection will be escaped or removed from the final output; this includes any attribute beginning with javascript:.</p><br>

<?php 
$string = '<script>alert("I can use XSS");</script>
[b]<script>alert(document.cookie);</script>[/b]
[div class="javascript:alert(document);"]Attribute XSS prevention[/div]
[video="youtube" size="small"]"onload="alert(\'XSS\');" id="[/video]';
$code->reset($string);
echo $code->parse();
?>

<h2>XSS Protection <span>within an image</span></h2>

<p>If an [img] tag attempts to generate an XSS attack by placing multiple HTTP calls in one tag, the tag will not be rendered.
	For example, the following URL will fail: [img]http://example.com/delete-account?image=http://example.com/image.jpg[/img]</p><br>

<?php 
$string = '[img]http://localhost/doSomething.php?image=http://www.google.com/intl/en_ALL/images/srpr/logo1w.png[/img]';
$code->reset($string);
echo $code->parse();
Example #9
0
<?php

$code = new \mjohnson\decoda\Decoda();
$code->addFilter(new \mjohnson\decoda\filters\DefaultFilter());
?>

<h2>Bold, italics, underline, strike-through</h2>

<?php 
$string = '[b]Bold[/b]
[i]Italics[/i]
[u]Underline[/u]
[s]Strike through[/s]
[b][i][u]Bold, italics, underline[/u][/i][/b]';
$code->reset($string);
echo $code->parse();
?>

<h2>Super-script and sub-script</h2>

<?php 
$string = 'Super[sup]script[/sup]
Sub[sub]script[/sub]
[sup]Super[/sup]-[sub]sub[/sub]-script';
$code->reset($string);
echo $code->parse();
?>

<h2>Bold, italics <span>(XHTML)</span></h2>

<?php 
Example #10
0
		.decoda-quote-head { font-weight: bold; margin-bottom: 5px; }
		.decoda-quote-date { float: right; }
		.decoda-code { background: lightgray; padding: 10px; border-radius: 10px; }
		.decoda-alert { background: lightpink; padding: 10px; border-radius: 10px; }
		.decoda-note { background: powderblue; padding: 10px; border-radius: 10px; }
		.decoda-spoiler-content { background: palegreen; margin-top: 5px; padding: 10px; border-radius: 10px; }
		.decoda-spoiler-content .decoda-spoiler { margin-top: 10px; }
		.decoda-spoiler-content .decoda-spoiler-content { background: oldlace; }
	</style>
</head>
<body>
	<h1>Decoda</h1>

	<?php 
// Copyright
$code = new \mjohnson\decoda\Decoda('Copyright 2009-' . date('Y') . ' [sup]&copy;[/sup] Miles Johnson - [url]http://milesj.me[/url]');
$code->defaults();
echo $code->parse();
?>

	<dl>
		<dt>About</dt>
		<dd><?php 
buildMenu($about, $view);
?>
</dd>

		<dt>Filters</dt>
		<dd><?php 
buildMenu($filters, $view);
?>
Example #11
0
<h2>Clickable</h2>

<?php 
$string = 'Valid:
email@domain.com
http://domain.com

Invalid:
email@domain
www.domain.com';
$code = new \mjohnson\decoda\Decoda($string);
$code->addFilter(new \mjohnson\decoda\filters\EmailFilter());
$code->addFilter(new \mjohnson\decoda\filters\UrlFilter());
$code->addHook(new \mjohnson\decoda\hooks\ClickableHook());
echo $code->parse();
Example #12
0
<h2>Emoticons</h2>

<?php 
$string = 'Decoda also comes with an emoticon system. It will convert any kind of smiley from emoticons.json into a small image.
The system will not parse smilies within strings (like URLs) that resemble smilies. Here are a couple:

:] :) :D :/ >[ :p :o >_>

It also supports the word syntax:

:happy: :aw: :cool: :kiss: :meh: :mmf: :heart:';
$code = new \mjohnson\decoda\Decoda($string);
$code->addFilter(new \mjohnson\decoda\filters\ImageFilter());
$code->addHook(new \mjohnson\decoda\hooks\EmoticonHook(array('path' => '../emoticons/')));
echo $code->parse();