Bugfix: XML copy had problems with "&"

This commit is contained in:
Michael Vogel 2016-03-14 23:54:01 +01:00 committed by Roland Haeder
parent 2898749cc6
commit 357c48076d
No known key found for this signature in database
GPG key ID: B72F8185C6C7BD78
2 changed files with 7 additions and 7 deletions

View file

@ -291,7 +291,7 @@ class diaspora {
return self::receive_account_deletion($importer, $fields);
case "comment":
return self::receive_comment($importer, $sender, $fields);
return self::receive_comment($importer, $sender, $fields, $msg["message"]);
case "conversation":
return self::receive_conversation($importer, $msg, $fields);
@ -324,7 +324,7 @@ class diaspora {
return self::receive_retraction($importer, $sender, $fields);
case "status_message":
return self::receive_status_message($importer, $fields);
return self::receive_status_message($importer, $fields, $msg["message"]);
default:
logger("Unknown message type ".$type);
@ -841,7 +841,7 @@ class diaspora {
return true;
}
private function receive_comment($importer, $sender, $data) {
private function receive_comment($importer, $sender, $data, $xml) {
$guid = notags(unxmlify($data->guid));
$parent_guid = notags(unxmlify($data->parent_guid));
$text = unxmlify($data->text);
@ -890,7 +890,7 @@ class diaspora {
$datarray["parent-uri"] = $parent_item["uri"];
$datarray["object-type"] = ACTIVITY_OBJ_COMMENT;
$datarray["object"] = json_encode($data);
$datarray["object"] = $xml;
$datarray["body"] = diaspora2bb($text);
@ -1769,7 +1769,7 @@ class diaspora {
return true;
}
private function receive_status_message($importer, $data) {
private function receive_status_message($importer, $data, $xml) {
$raw_message = unxmlify($data->raw_message);
$guid = notags(unxmlify($data->guid));
@ -1831,7 +1831,7 @@ class diaspora {
$datarray["verb"] = ACTIVITY_POST;
$datarray["gravity"] = GRAVITY_PARENT;
$datarray["object"] = json_encode($data);
$datarray["object"] = $xml;
$datarray["body"] = $body;

View file

@ -62,7 +62,7 @@ class xml {
function copy(&$source, &$target, $elementname) {
if (count($source->children()) == 0)
$target->addChild($elementname, $source);
$target->addChild($elementname, xmlify($source));
else {
$child = $target->addChild($elementname);
foreach ($source->children() AS $childfield => $childentry)