getSerial(); // load migration if (file_exists(dirname(__FILE__) . '/migrate.php')) { include(dirname(__FILE__) . '/migrate.php'); } else { echo 'Error: No migration path specified for HTML Purifier, please check modes/htmlpurifier/migrate.bbcode.php for instructions on how to migrate from your previous markup language.'; exit; } /** * Purifies a data array */ function phorum_htmlpurifier($data) { $PHORUM = $GLOBALS["PHORUM"]; $purifier =& HTMLPurifier::getInstance(); $cache_serial = $PHORUM['mod_htmlpurifier']['body_cache_serial']; foreach($data as $message_id => $message){ if(isset($message['body'])){ if ( isset($message['meta']['body_cache']) && isset($message['meta']['body_cache_serial']) && $message['meta']['body_cache_serial'] == $cache_serial ) { // cached version is present, bail out early $data[$message_id]['body'] = $message['meta']['body_cache']; continue; } // migration might edit this array, that's why it's defined // so early $updated_message = array(); // create the $body variable if ( !isset($message['meta']['body_cache_serial']) ) { // perform migration $fake_data = array(); $fake_data[$message_id] = $message; $fake_data = phorum_htmlpurifier_migrate($fake_data); $body = $fake_data[$message_id]['body']; $body = str_replace("", "\n", $body); // dupe, but this needs to be applied early $updated_message['body'] = $body; // save it in } else { // reverse Phorum's pre-processing $body = $message['body']; // order is important $body = str_replace(array('<','>','&'), array('<','>','&'), $body); $body = str_replace("\n", "\n", $body); } $body = $purifier->purify($body); // dynamically update the cache // this is inefficient on the first read, but the cache // catches will more than make up for it // this should ONLY be called on read, for posting and preview // phorum_htmlpurifier_posting should do the trick $updated_message['meta'] = $message['meta']; $updated_message['meta']['body_cache'] = $body; $updated_message['meta']['body_cache_serial'] = $cache_serial; phorum_db_update_message($message_id, $updated_message); // must not get overloaded until after we cache it $data[$message_id]['body'] = $body; } } return $data; } /** * Generate necessary cache and serial entries when a posting action happens */ function phorum_htmlpurifier_posting($message) { $PHORUM = $GLOBALS["PHORUM"]; $purifier =& HTMLPurifier::getInstance(); $message['meta']['body_cache'] = $purifier->purify($message['body']); $message['meta']['body_cache_serial'] = $PHORUM['mod_htmlpurifier']['body_cache_serial']; return $message; } /** * Overload quoting mechanism to prevent default, mail-style quote from happening */ function phorum_htmlpurifier_quote($array) { $PHORUM = $GLOBALS["PHORUM"]; $purifier =& HTMLPurifier::getInstance(); $text = $purifier->purify($array[1]); return "
\n$text\n
"; } /** * Ensure that our format hook is processed last * @credits */ function phorum_htmlpurifier_common() { global $PHORUM; if (! isset($PHORUM['hooks']['format']['mods'])) return; $hp_idx = null; $last_idx = null; foreach ($PHORUM['hooks']['format']['mods'] as $idx => $mod) { if ($mod == 'htmlpurifier') $hp_idx = $idx; $last_idx = $idx; } if ($hp_idx !== null && $hp_idx != $last_idx) { $hp_mod = array_splice($PHORUM['hooks']['format']['mods'], $hp_idx, 1); $PHORUM['hooks']['format']['mods'][] = $hp_mod; $hp_func = array_splice($PHORUM['hooks']['format']['funcs'], $hp_idx, 1); $PHORUM['hooks']['format']['funcs'][] = $hp_func; } }