Browse Source

Follow/Unfollow now works from OStatus.

pull/1758/head
Michael Vogel 6 years ago
parent
commit
2b3ebb9c3e
3 changed files with 15 additions and 7 deletions
  1. +6
    -3
      include/items.php
  2. +8
    -4
      include/ostatus.php
  3. +1
    -0
      mod/wall_upload.php

+ 6
- 3
include/items.php View File

@ -4159,9 +4159,12 @@ function new_follower($importer,$contact,$datarray,$item,$sharing = false) {
$name = notags(trim($datarray['author-name']));
$photo = notags(trim($datarray['author-avatar']));
$rawtag = $item->get_item_tags(NAMESPACE_ACTIVITY,'actor');
if($rawtag && $rawtag[0]['child'][NAMESPACE_POCO]['preferredUsername'][0]['data'])
$nick = $rawtag[0]['child'][NAMESPACE_POCO]['preferredUsername'][0]['data'];
if (is_object($item)) {
$rawtag = $item->get_item_tags(NAMESPACE_ACTIVITY,'actor');
if($rawtag && $rawtag[0]['child'][NAMESPACE_POCO]['preferredUsername'][0]['data'])
$nick = $rawtag[0]['child'][NAMESPACE_POCO]['preferredUsername'][0]['data'];
} else
$nick = $item;
if(is_array($contact)) {
if(($contact['network'] == NETWORK_OSTATUS && $contact['rel'] == CONTACT_IS_SHARING)


+ 8
- 4
include/ostatus.php View File

@ -205,6 +205,12 @@ function ostatus_import($xml,$importer,&$contact, &$hub) {
else
$author = ostatus_fetchauthor($xpath, $entry, $importer, $contact, false);
$value = $xpath->evaluate('atom:author/poco:preferredUsername/text()', $context)->item(0)->nodeValue;
if ($value != "")
$nickname = $value;
else
$nickname = $author["author-name"];
$item = array_merge($header, $author);
// Now get the item
@ -242,14 +248,12 @@ function ostatus_import($xml,$importer,&$contact, &$hub) {
}
if ($item["verb"] == ACTIVITY_FOLLOW) {
// ignore "Follow" messages
// new_follower($importer,$contact,$datarray,$item);
new_follower($importer, $contact, $item, $nickname);
continue;
}
if ($item["verb"] == NAMESPACE_OSTATUS."/unfollow") {
// ignore "Unfollow" messages
// lose_follower($importer,$contact,$datarray,$item);
lose_follower($importer, $contact, $item, $dummy);
continue;
}


+ 1
- 0
mod/wall_upload.php View File

@ -119,6 +119,7 @@ function wall_upload_post(&$a, $desktopmode = true) {
$maximagesize = get_config('system','maximagesize');
if(($maximagesize) && ($filesize > $maximagesize)) {
logger("Image exceeds size limit of ".$maximagesize);
echo sprintf( t('Image exceeds size limit of %s'), formatBytes($maximagesize)) . EOL;
@unlink($src);
killme();


Loading…
Cancel
Save