Provisional fix for ticket #3108: Facebook bridge sends "likes" as the notice's original poster instead of as the person doing the liking.
Adds optional $profile parameter for Facebookclient constructor and uses that for the foreign_link lookup if provided instead of the notice's poster.
This commit is contained in:
parent
14456cbbb2
commit
24945715d0
@ -526,7 +526,7 @@ ENDOFSCRIPT;
|
||||
*/
|
||||
function onEndFavorNotice(Profile $profile, Notice $notice)
|
||||
{
|
||||
$client = new Facebookclient($notice);
|
||||
$client = new Facebookclient($notice, $profile);
|
||||
$client->like();
|
||||
|
||||
return true;
|
||||
@ -542,7 +542,7 @@ ENDOFSCRIPT;
|
||||
*/
|
||||
function onEndDisfavorNotice(Profile $profile, Notice $notice)
|
||||
{
|
||||
$client = new Facebookclient($notice);
|
||||
$client = new Facebookclient($notice, $profile);
|
||||
$client->unLike();
|
||||
|
||||
return true;
|
||||
|
@ -48,7 +48,12 @@ class Facebookclient
|
||||
protected $notice = null; // The user's notice
|
||||
protected $user = null; // Sender of the notice
|
||||
|
||||
function __construct($notice)
|
||||
/**
|
||||
*
|
||||
* @param Notice $notice the notice to manipulate
|
||||
* @param Profile $profile local user to act as; if left empty, the notice's poster will be used.
|
||||
*/
|
||||
function __construct($notice, $profile=null)
|
||||
{
|
||||
$this->facebook = self::getFacebook();
|
||||
|
||||
@ -60,8 +65,9 @@ class Facebookclient
|
||||
|
||||
$this->notice = $notice;
|
||||
|
||||
$profile_id = $profile ? $profile->id : $notice->profile_id;
|
||||
$this->flink = Foreign_link::getByUserID(
|
||||
$notice->profile_id,
|
||||
$profile_id,
|
||||
FACEBOOK_SERVICE
|
||||
);
|
||||
|
||||
|
Loading…
Reference in New Issue
Block a user