mirror of
https://github.com/ezyang/htmlpurifier.git
synced 2025-01-20 12:31:53 +00:00
[Phorum] Fix cross-platform mutilation of cache data, remove excess newlines.
git-svn-id: http://htmlpurifier.org/svnroot/htmlpurifier/trunk@1277 48356398-32a2-884e-a903-53898d9a118a
This commit is contained in:
parent
d7157d0ccd
commit
1765a7537a
@ -21,6 +21,11 @@
|
|||||||
* to be upgraded when Phorum 6 rolls around.
|
* to be upgraded when Phorum 6 rolls around.
|
||||||
*/
|
*/
|
||||||
|
|
||||||
|
// Note: Cache data is base64 encoded because Phorum insists on flinging
|
||||||
|
// to the user and expecting it to come back unharmed, newlines and
|
||||||
|
// all, which ain't happening. It's slower, it takes up more space, but
|
||||||
|
// at least it won't get mutilated
|
||||||
|
|
||||||
if(!defined('PHORUM')) exit;
|
if(!defined('PHORUM')) exit;
|
||||||
|
|
||||||
/**
|
/**
|
||||||
@ -48,7 +53,7 @@ function phorum_htmlpurifier_format($data)
|
|||||||
$message['meta']['body_cache_serial'] == $cache_serial
|
$message['meta']['body_cache_serial'] == $cache_serial
|
||||||
) {
|
) {
|
||||||
// cached version is present, bail out early
|
// cached version is present, bail out early
|
||||||
$data[$message_id]['body'] = $message['meta']['body_cache'];
|
$data[$message_id]['body'] = base64_decode($message['meta']['body_cache']);
|
||||||
continue;
|
continue;
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -65,7 +70,7 @@ function phorum_htmlpurifier_format($data)
|
|||||||
$fake_data[$message_id] = $message;
|
$fake_data[$message_id] = $message;
|
||||||
$fake_data = phorum_htmlpurifier_migrate($fake_data);
|
$fake_data = phorum_htmlpurifier_migrate($fake_data);
|
||||||
$body = $fake_data[$message_id]['body'];
|
$body = $fake_data[$message_id]['body'];
|
||||||
$body = str_replace("<phorum break>", "\n", $body); // dupe, but this needs to be applied early
|
$body = str_replace("<phorum break>", '', $body);
|
||||||
$updated_message['body'] = $body; // save it in
|
$updated_message['body'] = $body; // save it in
|
||||||
} else {
|
} else {
|
||||||
// reverse Phorum's pre-processing
|
// reverse Phorum's pre-processing
|
||||||
@ -84,7 +89,7 @@ function phorum_htmlpurifier_format($data)
|
|||||||
// this should ONLY be called on read, for posting and preview
|
// this should ONLY be called on read, for posting and preview
|
||||||
// phorum_htmlpurifier_posting should do the trick
|
// phorum_htmlpurifier_posting should do the trick
|
||||||
$updated_message['meta'] = $message['meta'];
|
$updated_message['meta'] = $message['meta'];
|
||||||
$updated_message['meta']['body_cache'] = $body;
|
$updated_message['meta']['body_cache'] = base64_encode($body);
|
||||||
$updated_message['meta']['body_cache_serial'] = $cache_serial;
|
$updated_message['meta']['body_cache_serial'] = $cache_serial;
|
||||||
phorum_db_update_message($message_id, $updated_message);
|
phorum_db_update_message($message_id, $updated_message);
|
||||||
|
|
||||||
@ -106,7 +111,7 @@ function phorum_htmlpurifier_posting($message) {
|
|||||||
// this is a temporary attribute
|
// this is a temporary attribute
|
||||||
$fake_data[0]['meta']['htmlpurifier_light'] = true; // only purify, please
|
$fake_data[0]['meta']['htmlpurifier_light'] = true; // only purify, please
|
||||||
list($changed_message) = phorum_hook('format', $fake_data);
|
list($changed_message) = phorum_hook('format', $fake_data);
|
||||||
$message['meta']['body_cache'] = $changed_message['body'];
|
$message['meta']['body_cache'] = base64_encode($changed_message['body']);
|
||||||
$message['meta']['body_cache_serial'] = $PHORUM['mod_htmlpurifier']['body_cache_serial'];
|
$message['meta']['body_cache_serial'] = $PHORUM['mod_htmlpurifier']['body_cache_serial'];
|
||||||
return $message;
|
return $message;
|
||||||
}
|
}
|
||||||
|
Loading…
Reference in New Issue
Block a user