}
// Elements that shouldn't be parsed
- $elements = ['code', 'noparse', 'nobb', 'pre'];
+ $elements = ['code', 'noparse', 'nobb', 'pre', 'share', 'url', 'img'];
foreach ($elements as $element) {
- $request['body'] = preg_replace_callback("/\[" . $element . "\](.*?)\[\/" . $element . "\]/ism",
- function ($match) use ($element) {
- return '[base64' . $element . ']' . base64_encode($match[1]) . '[/base64' . $element . ']';
+ $request['body'] = preg_replace_callback("/\[" . $element . "(.*?)\](.*?)\[\/" . $element . "\]/ism",
+ function ($match) use ($element) {
+ return '[' . $element . '-b64' . base64_encode($match[1]) . ']' . base64_encode($match[2]) . '[/b64-' . $element . ']';
},
$request['body']
);
$request['body'] = Markdown::toBBCode($request['body']);
foreach (array_reverse($elements) as $element) {
- $request['body'] = preg_replace_callback("/\[base64" . $element . "\](.*?)\[\/base64" . $element . "\]/ism",
- function ($match) use ($element) {
- return '[' . $element . ']' . base64_decode($match[1]) . '[/' . $element . ']';
+ $request['body'] = preg_replace_callback("/\[" . $element . "-b64(.*?)\](.*?)\[\/b64-" . $element . "\]/ism",
+ function ($match) use ($element) {
+ return '[' . $element . base64_decode($match[1]) . ']' . base64_decode($match[2]) . '[/' . $element . ']';
},
$request['body']
);