mirror of
https://github.com/friendica/friendica
synced 2024-11-14 05:02:54 +00:00
Some more work to make reshares work.
This commit is contained in:
parent
6dd39760ac
commit
02022b62a4
1 changed files with 44 additions and 43 deletions
|
@ -1289,13 +1289,13 @@ function ostatus_get_attachment($doc, $root, $item) {
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
function ostatus_add_author($doc, $owner, $profile) {
|
function ostatus_add_author($doc, $owner, $profile = array()) {
|
||||||
$a = get_app();
|
$a = get_app();
|
||||||
|
|
||||||
$author = $doc->createElement("author");
|
$author = $doc->createElement("author");
|
||||||
xml_add_element($doc, $author, "activity:object-type", ACTIVITY_OBJ_PERSON);
|
xml_add_element($doc, $author, "activity:object-type", ACTIVITY_OBJ_PERSON);
|
||||||
xml_add_element($doc, $author, "uri", $owner["url"]);
|
xml_add_element($doc, $author, "uri", $owner["url"]);
|
||||||
xml_add_element($doc, $author, "name", $profile["name"]);
|
xml_add_element($doc, $author, "name", $owner["name"]);
|
||||||
|
|
||||||
$attributes = array("rel" => "alternate", "type" => "text/html", "href" => $owner["url"]);
|
$attributes = array("rel" => "alternate", "type" => "text/html", "href" => $owner["url"]);
|
||||||
xml_add_element($doc, $author, "link", "", $attributes);
|
xml_add_element($doc, $author, "link", "", $attributes);
|
||||||
|
@ -1305,20 +1305,22 @@ function ostatus_add_author($doc, $owner, $profile) {
|
||||||
"type" => "image/jpeg", // To-Do?
|
"type" => "image/jpeg", // To-Do?
|
||||||
"media:width" => 175,
|
"media:width" => 175,
|
||||||
"media:height" => 175,
|
"media:height" => 175,
|
||||||
"href" => $profile["photo"]);
|
"href" => $owner["photo"]);
|
||||||
xml_add_element($doc, $author, "link", "", $attributes);
|
xml_add_element($doc, $author, "link", "", $attributes);
|
||||||
|
|
||||||
$attributes = array(
|
if (isset($owner["thumb"])) {
|
||||||
"rel" => "avatar",
|
$attributes = array(
|
||||||
"type" => "image/jpeg", // To-Do?
|
"rel" => "avatar",
|
||||||
"media:width" => 80,
|
"type" => "image/jpeg", // To-Do?
|
||||||
"media:height" => 80,
|
"media:width" => 80,
|
||||||
"href" => $profile["thumb"]);
|
"media:height" => 80,
|
||||||
xml_add_element($doc, $author, "link", "", $attributes);
|
"href" => $owner["thumb"]);
|
||||||
|
xml_add_element($doc, $author, "link", "", $attributes);
|
||||||
|
}
|
||||||
|
|
||||||
xml_add_element($doc, $author, "poco:preferredUsername", $owner["nick"]);
|
xml_add_element($doc, $author, "poco:preferredUsername", $owner["nick"]);
|
||||||
xml_add_element($doc, $author, "poco:displayName", $profile["name"]);
|
xml_add_element($doc, $author, "poco:displayName", $owner["name"]);
|
||||||
xml_add_element($doc, $author, "poco:note", $profile["about"]);
|
xml_add_element($doc, $author, "poco:note", $owner["about"]);
|
||||||
|
|
||||||
if (trim($owner["location"]) != "") {
|
if (trim($owner["location"]) != "") {
|
||||||
$element = $doc->createElement("poco:address");
|
$element = $doc->createElement("poco:address");
|
||||||
|
@ -1334,8 +1336,10 @@ function ostatus_add_author($doc, $owner, $profile) {
|
||||||
$author->appendChild($urls);
|
$author->appendChild($urls);
|
||||||
}
|
}
|
||||||
|
|
||||||
xml_add_element($doc, $author, "followers", "", array("url" => $a->get_baseurl()."/viewcontacts/".$owner["nick"]));
|
if (count($profile)) {
|
||||||
xml_add_element($doc, $author, "statusnet:profile_info", "", array("local_id" => $owner["uid"]));
|
xml_add_element($doc, $author, "followers", "", array("url" => $a->get_baseurl()."/viewcontacts/".$owner["nick"]));
|
||||||
|
xml_add_element($doc, $author, "statusnet:profile_info", "", array("local_id" => $owner["uid"]));
|
||||||
|
}
|
||||||
|
|
||||||
return $author;
|
return $author;
|
||||||
}
|
}
|
||||||
|
@ -1351,6 +1355,21 @@ class="attachment thumbnail" id="attachment-572819" rel="nofollow external">http
|
||||||
function ostatus_entry($doc, $item, $owner, $toplevel = false, $repeat = false) {
|
function ostatus_entry($doc, $item, $owner, $toplevel = false, $repeat = false) {
|
||||||
$a = get_app();
|
$a = get_app();
|
||||||
|
|
||||||
|
$is_repeat = false;
|
||||||
|
|
||||||
|
/* if (!$repeat) {
|
||||||
|
$repeated_guid = get_reshared_guid($item);
|
||||||
|
|
||||||
|
if ($repeated_guid != "") {
|
||||||
|
$r = q("SELECT * FROM `item` WHERE `uid` = %d AND `guid` = '%s' LIMIT 1",
|
||||||
|
intval($owner["uid"]), dbesc($repeated_guid));
|
||||||
|
if ($r) {
|
||||||
|
$repeated_item = $r[0];
|
||||||
|
$is_repeat = true;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
*/
|
||||||
if (!$toplevel AND !$repeat) {
|
if (!$toplevel AND !$repeat) {
|
||||||
$entry = $doc->createElement("entry");
|
$entry = $doc->createElement("entry");
|
||||||
$title = sprintf("New note by %s", $owner["nick"]);
|
$title = sprintf("New note by %s", $owner["nick"]);
|
||||||
|
@ -1368,12 +1387,15 @@ function ostatus_entry($doc, $item, $owner, $toplevel = false, $repeat = false)
|
||||||
$entry->setAttribute("xmlns:ostatus", NS_OSTATUS);
|
$entry->setAttribute("xmlns:ostatus", NS_OSTATUS);
|
||||||
$entry->setAttribute("xmlns:statusnet", NS_STATUSNET);
|
$entry->setAttribute("xmlns:statusnet", NS_STATUSNET);
|
||||||
|
|
||||||
$r = q("SELECT * FROM `profile` WHERE `uid` = %d AND `is-default`",
|
if (!$repeat) {
|
||||||
intval($owner["uid"]));
|
$r = q("SELECT * FROM `profile` WHERE `uid` = %d AND `is-default`",
|
||||||
if (!$r)
|
intval($owner["uid"]));
|
||||||
return;
|
if (!$r)
|
||||||
|
return;
|
||||||
|
|
||||||
$profile = $r[0];
|
$profile = $r[0];
|
||||||
|
}
|
||||||
|
$profile = array();
|
||||||
|
|
||||||
$author = ostatus_add_author($doc, $owner, $profile);
|
$author = ostatus_add_author($doc, $owner, $profile);
|
||||||
$entry->appendChild($author);
|
$entry->appendChild($author);
|
||||||
|
@ -1420,22 +1442,6 @@ function ostatus_entry($doc, $item, $owner, $toplevel = false, $repeat = false)
|
||||||
|
|
||||||
xml_add_element($doc, $entry, "status_net", "", array("notice_id" => $item["id"]));
|
xml_add_element($doc, $entry, "status_net", "", array("notice_id" => $item["id"]));
|
||||||
|
|
||||||
//$repeated_item = $item;
|
|
||||||
$is_repeat = false;
|
|
||||||
|
|
||||||
/* if (!$repeat) {
|
|
||||||
$repeated_guid = get_reshared_guid($item);
|
|
||||||
|
|
||||||
if ($repeated_guid != "") {
|
|
||||||
$r = q("SELECT * FROM `item` WHERE `uid` = %d AND `guid` = '%s' LIMIT 1",
|
|
||||||
intval($owner["uid"]), dbesc($repeated_guid));
|
|
||||||
if ($r) {
|
|
||||||
$repeated_item = $r[0];
|
|
||||||
$is_repeat = true;
|
|
||||||
}
|
|
||||||
}
|
|
||||||
}
|
|
||||||
*/
|
|
||||||
if (!$is_repeat)
|
if (!$is_repeat)
|
||||||
xml_add_element($doc, $entry, "activity:verb", construct_verb($item));
|
xml_add_element($doc, $entry, "activity:verb", construct_verb($item));
|
||||||
else
|
else
|
||||||
|
@ -1448,8 +1454,8 @@ function ostatus_entry($doc, $item, $owner, $toplevel = false, $repeat = false)
|
||||||
$repeated_owner = array();
|
$repeated_owner = array();
|
||||||
$repeated_owner["name"] = $repeated_item["author-name"];
|
$repeated_owner["name"] = $repeated_item["author-name"];
|
||||||
$repeated_owner["url"] = $repeated_item["author-link"];
|
$repeated_owner["url"] = $repeated_item["author-link"];
|
||||||
$repeated_owner["photo"] = normalise_link($repeated_item["author-avatar"]);
|
$repeated_owner["photo"] = $repeated_item["author-avatar"];
|
||||||
$repeated_owner["nick"] = "";
|
$repeated_owner["nick"] = $repeated_owner["name"];
|
||||||
$repeated_owner["location"] = "";
|
$repeated_owner["location"] = "";
|
||||||
$repeated_owner["about"] = "";
|
$repeated_owner["about"] = "";
|
||||||
$repeated_owner["uid"] = 0;
|
$repeated_owner["uid"] = 0;
|
||||||
|
@ -1464,12 +1470,7 @@ function ostatus_entry($doc, $item, $owner, $toplevel = false, $repeat = false)
|
||||||
$entry_repeat = ostatus_entry($doc, $repeated_item, $repeated_owner, false, true);
|
$entry_repeat = ostatus_entry($doc, $repeated_item, $repeated_owner, false, true);
|
||||||
$entry->appendChild($entry_repeat);
|
$entry->appendChild($entry_repeat);
|
||||||
} elseif ($repeat) {
|
} elseif ($repeat) {
|
||||||
$profile = array();
|
$author = ostatus_add_author($doc, $owner);
|
||||||
$profile["name"] = $owner["name"];
|
|
||||||
$profile["photo"] = $owner["photo"];
|
|
||||||
$profile["thumb"] = $owner["photo"];
|
|
||||||
$profile["about"] = $owner["about"];
|
|
||||||
$author = ostatus_add_author($doc, $owner, $profile);
|
|
||||||
$entry->appendChild($author);
|
$entry->appendChild($author);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
Loading…
Reference in a new issue