X-Git-Url: https://git.mxchange.org/?a=blobdiff_plain;f=plugins%2FActivity%2FActivityPlugin.php;h=5144eb46662f3f86a4c1c25969b008aef3da4c99;hb=6267e7a9306c6e974789df56cf02b0050a9943c1;hp=cd47427e0a97dee1f06a9378e8a9d784ebb27b1e;hpb=654fdf2fa453fcb6be3df62622741e52eca4db7b;p=quix0rs-gnu-social.git diff --git a/plugins/Activity/ActivityPlugin.php b/plugins/Activity/ActivityPlugin.php index cd47427e0a..5144eb4666 100644 --- a/plugins/Activity/ActivityPlugin.php +++ b/plugins/Activity/ActivityPlugin.php @@ -44,140 +44,101 @@ if (!defined('STATUSNET')) { * @license http://www.fsf.org/licensing/licenses/agpl-3.0.html AGPL 3.0 * @link http://status.net/ */ - class ActivityPlugin extends Plugin { const VERSION = '0.1'; - const SOURCE = 'system'; + const SOURCE = 'activity'; // Flags to switch off certain activity notices public $StartFollowUser = true; - public $StopFollowUser = true; + public $StopFollowUser = false; public $JoinGroup = true; - public $LeaveGroup = true; - public $StartLike = true; - public $StopLike = true; + public $LeaveGroup = false; + public $StartLike = false; + public $StopLike = false; - function onAutoload($cls) - { - $dir = dirname(__FILE__); - - switch ($cls) - { - case 'JoinListItem': - case 'LeaveListItem': - case 'FollowListItem': - case 'UnfollowListItem': - case 'SystemListItem': - include_once $dir . '/'.strtolower($cls).'.php'; - return false; - default: - return true; - } - } - - function onEndSubscribe($subscriber, $other) + function onEndSubscribe(Profile $profile, Profile $other) { // Only do this if config is enabled if(!$this->StartFollowUser) return true; - $user = $subscriber->getUser(); - if (!empty($user)) { - $sub = Subscription::pkeyGet(array('subscriber' => $subscriber->id, - 'subscribed' => $other->id)); - $rendered = sprintf(_m('%s started following %s.'), - $subscriber->profileurl, - $subscriber->getBestName(), - $other->profileurl, - $other->getBestName()); - $content = sprintf(_m('%s (%s) started following %s (%s).'), - $subscriber->getBestName(), - $subscriber->profileurl, - $other->getBestName(), - $other->profileurl); - - $notice = Notice::saveNew($user->id, - $content, - ActivityPlugin::SOURCE, - array('rendered' => $rendered, - 'urls' => array(), - 'replies' => array($other->getUri()), - 'verb' => ActivityVerb::FOLLOW, - 'object_type' => ActivityObject::PERSON, - 'uri' => $sub->uri)); + + if (!$profile->isLocal()) { + // can't do anything with remote user anyway + return true; } + + $sub = Subscription::pkeyGet(array('subscriber' => $profile->id, + 'subscribed' => $other->id)); + // TRANS: Text for "started following" item in activity plugin. + // TRANS: %1$s is a profile URL, %2$s is a profile name, + // TRANS: %3$s is a profile URL, %4$s is a profile name. + $rendered = sprintf(_m('%2$s started following %4$s.'), + $profile->getUrl(), + $profile->getBestName(), + $other->getUrl(), + $other->getBestName()); + // TRANS: Text for "started following" item in activity plugin. + // TRANS: %1$s is a profile name, %2$s is a profile URL, + // TRANS: %3$s is a profile name, %4$s is a profile URL. + $content = sprintf(_m('%1$s (%2$s) started following %3$s (%4$s).'), + $profile->getBestName(), + $profile->getUrl(), + $other->getBestName(), + $other->getUrl()); + + $notice = Notice::saveNew($profile->id, + $content, + ActivityPlugin::SOURCE, + array('rendered' => $rendered, + 'urls' => array(), + 'replies' => array($other->getUri()), + 'verb' => ActivityVerb::FOLLOW, + 'object_type' => ActivityObject::PERSON, + 'uri' => $sub->uri)); return true; } - function onEndUnsubscribe($subscriber, $other) + function onEndUnsubscribe(Profile $profile, Profile $other) { // Only do this if config is enabled if(!$this->StopFollowUser) return true; - $user = $subscriber->getUser(); - if (!empty($user)) { - $rendered = sprintf(_m('%s stopped following %s.'), - $subscriber->profileurl, - $subscriber->getBestName(), - $other->profileurl, - $other->getBestName()); - $content = sprintf(_m('%s (%s) stopped following %s (%s).'), - $subscriber->getBestName(), - $subscriber->profileurl, - $other->getBestName(), - $other->profileurl); - - $uri = TagURI::mint('stop-following:%d:%d:%s', - $subscriber->id, - $other->id, - common_date_iso8601(common_sql_now())); - - $notice = Notice::saveNew($user->id, - $content, - ActivityPlugin::SOURCE, - array('rendered' => $rendered, - 'urls' => array(), - 'replies' => array($other->getUri()), - 'uri' => $uri, - 'verb' => ActivityVerb::UNFOLLOW, - 'object_type' => ActivityObject::PERSON)); - } - return true; - } - function onEndFavorNotice($profile, $notice) - { - // Only do this if config is enabled - if(!$this->StartLike) return true; - - $user = $profile->getUser(); - - if (!empty($user)) { - - $author = $notice->getProfile(); - $fave = Fave::pkeyGet(array('user_id' => $user->id, - 'notice_id' => $notice->id)); - - $rendered = sprintf(_m('%s liked %s\'s update.'), - $profile->profileurl, - $profile->getBestName(), - $notice->bestUrl(), - $author->getBestName()); - $content = sprintf(_m('%s (%s) liked %s\'s status (%s)'), - $profile->getBestName(), - $profile->profileurl, - $author->getBestName(), - $notice->bestUrl()); - - $notice = Notice::saveNew($user->id, - $content, - ActivityPlugin::SOURCE, - array('rendered' => $rendered, - 'urls' => array(), - 'replies' => array($author->getUri()), - 'uri' => $fave->getURI(), - 'verb' => ActivityVerb::FAVORITE, - 'object_type' => (($notice->verb == ActivityVerb::POST) ? - $notice->object_type : ActivityObject::ACTIVITY))); + if (!$profile->isLocal()) { + return true; } + + // TRANS: Text for "stopped following" item in activity plugin. + // TRANS: %1$s is a profile URL, %2$s is a profile name, + // TRANS: %3$s is a profile URL, %4$s is a profile name. + $rendered = sprintf(_m('%2$s stopped following %4$s.'), + $profile->getUrl(), + $profile->getBestName(), + $other->getUrl(), + $other->getBestName()); + // TRANS: Text for "stopped following" item in activity plugin. + // TRANS: %1$s is a profile name, %2$s is a profile URL, + // TRANS: %3$s is a profile name, %4$s is a profile URL. + $content = sprintf(_m('%1$s (%2$s) stopped following %3$s (%4$s).'), + $profile->getBestName(), + $profile->getUrl(), + $other->getBestName(), + $other->getUrl()); + + $uri = TagURI::mint('stop-following:%d:%d:%s', + $profile->id, + $other->id, + common_date_iso8601(common_sql_now())); + + $notice = Notice::saveNew($profile->id, + $content, + ActivityPlugin::SOURCE, + array('rendered' => $rendered, + 'urls' => array(), + 'replies' => array($other->getUri()), + 'uri' => $uri, + 'verb' => ActivityVerb::UNFOLLOW, + 'object_type' => ActivityObject::PERSON)); + return true; } @@ -185,37 +146,45 @@ class ActivityPlugin extends Plugin { // Only do this if config is enabled if(!$this->StopLike) return true; - $user = User::staticGet('id', $profile->id); - - if (!empty($user)) { - $author = Profile::staticGet('id', $notice->profile_id); - $rendered = sprintf(_m('%s stopped liking %s\'s update.'), - $profile->profileurl, - $profile->getBestName(), - $notice->bestUrl(), - $author->getBestName()); - $content = sprintf(_m('%s (%s) stopped liking %s\'s status (%s)'), - $profile->getBestName(), - $profile->profileurl, - $author->getBestName(), - $notice->bestUrl()); - - $uri = TagURI::mint('unlike:%d:%d:%s', - $profile->id, - $notice->id, - common_date_iso8601(common_sql_now())); - - $notice = Notice::saveNew($user->id, - $content, - ActivityPlugin::SOURCE, - array('rendered' => $rendered, - 'urls' => array(), - 'replies' => array($author->getUri()), - 'uri' => $uri, - 'verb' => ActivityVerb::UNFAVORITE, - 'object_type' => (($notice->verb == ActivityVerb::POST) ? - $notice->object_type : ActivityObject::ACTIVITY))); + + if (!$profile->isLocal()) { + return true; } + + $author = Profile::getKV('id', $notice->profile_id); + // TRANS: Text for "stopped liking" item in activity plugin. + // TRANS: %1$s is a profile URL, %2$s is a profile name, + // TRANS: %3$s is a notice URL, %4$s is an author name. + $rendered = sprintf(_m('%2$s stopped liking %4$s\'s update.'), + $profile->getUrl(), + $profile->getBestName(), + $notice->getUrl(), + $author->getBestName()); + // TRANS: Text for "stopped liking" item in activity plugin. + // TRANS: %1$s is a profile name, %2$s is a profile URL, + // TRANS: %3$s is an author name, %4$s is a notice URL. + $content = sprintf(_m('%1$s (%2$s) stopped liking %3$s\'s status (%4$s).'), + $profile->getBestName(), + $profile->getUrl(), + $author->getBestName(), + $notice->getUrl()); + + $uri = TagURI::mint('unlike:%d:%d:%s', + $profile->id, + $notice->id, + common_date_iso8601(common_sql_now())); + + $notice = Notice::saveNew($profile->id, + $content, + ActivityPlugin::SOURCE, + array('rendered' => $rendered, + 'urls' => array(), + 'replies' => array($author->getUri()), + 'uri' => $uri, + 'verb' => ActivityVerb::UNFAVORITE, + 'object_type' => (($notice->verb == ActivityVerb::POST) ? + $notice->object_type : ActivityObject::ACTIVITY))); + return true; } @@ -223,36 +192,40 @@ class ActivityPlugin extends Plugin { // Only do this if config is enabled if(!$this->JoinGroup) return true; - - $user = $profile->getUser(); - - if (empty($user)) { + + if (!$profile->isLocal()) { return true; } - - $rendered = sprintf(_m('%s joined the group %s.'), - $profile->profileurl, - $profile->getBestName(), + + // TRANS: Text for "joined group" item in activity plugin. + // TRANS: %1$s is a profile URL, %2$s is a profile name, + // TRANS: %3$s is a group URL, %4$s is a group name. + $rendered = sprintf(_m('%2$s joined the group %4$s.'), + $profile->getUrl(), + $profile->getBestName(), $group->homeUrl(), $group->getBestName()); - $content = sprintf(_m('%s (%s) joined the group %s (%s).'), - $profile->getBestName(), - $profile->profileurl, + // TRANS: Text for "joined group" item in activity plugin. + // TRANS: %1$s is a profile name, %2$s is a profile URL, + // TRANS: %3$s is a group name, %4$s is a group URL. + $content = sprintf(_m('%1$s (%2$s) joined the group %3$s (%4$s).'), + $profile->getBestName(), + $profile->getUrl(), $group->getBestName(), - $group->homeUrl()); + $group->homeUrl()); + + $mem = Group_member::pkeyGet(array('group_id' => $group->id, + 'profile_id' => $profile->id)); - $mem = Group_member::pkeyGet(array('group_id' => $group->id, - 'profile_id' => $profile->id)); - - $notice = Notice::saveNew($user->id, + $notice = Notice::saveNew($profile->id, $content, ActivityPlugin::SOURCE, array('rendered' => $rendered, 'urls' => array(), 'groups' => array($group->id), - 'uri' => $mem->getURI(), - 'verb' => ActivityVerb::JOIN, - 'object_type' => ActivityObject::GROUP)); + 'uri' => $mem->getURI(), + 'verb' => ActivityVerb::JOIN, + 'object_type' => ActivityObject::GROUP)); return true; } @@ -260,65 +233,65 @@ class ActivityPlugin extends Plugin { // Only do this if config is enabled if(!$this->LeaveGroup) return true; - - $user = $profile->getUser(); - - if (empty($user)) { + + if (!$profile->isLocal()) { return true; } - - $rendered = sprintf(_m('%s left the group %s.'), - $profile->profileurl, - $profile->getBestName(), + + // TRANS: Text for "left group" item in activity plugin. + // TRANS: %1$s is a profile URL, %2$s is a profile name, + // TRANS: %3$s is a group URL, %4$s is a group name. + $rendered = sprintf(_m('%2$s left the group %4$s.'), + $profile->getUrl(), + $profile->getBestName(), $group->homeUrl(), $group->getBestName()); - $content = sprintf(_m('%s (%s) left the group %s (%s)'), - $profile->getBestName(), - $profile->profileurl, + // TRANS: Text for "left group" item in activity plugin. + // TRANS: %1$s is a profile name, %2$s is a profile URL, + // TRANS: %3$s is a group name, %4$s is a group URL. + $content = sprintf(_m('%1$s (%2$s) left the group %3$s (%4$s).'), + $profile->getBestName(), + $profile->getUrl(), $group->getBestName(), - $group->homeUrl()); - - $uri = TagURI::mint('leave:%d:%d:%s', - $user->id, + $group->homeUrl()); + + $uri = TagURI::mint('leave:%d:%d:%s', + $profile->id, $group->id, common_date_iso8601(common_sql_now())); - $notice = Notice::saveNew($user->id, + $notice = Notice::saveNew($profile->id, $content, ActivityPlugin::SOURCE, array('rendered' => $rendered, 'urls' => array(), 'groups' => array($group->id), - 'uri' => $uri, - 'verb' => ActivityVerb::LEAVE, - 'object_type' => ActivityObject::GROUP)); + 'uri' => $uri, + 'verb' => ActivityVerb::LEAVE, + 'object_type' => ActivityObject::GROUP)); return true; } - + function onStartShowNoticeItem($nli) { - $notice = $nli->notice; - - $adapter = null; - - switch ($notice->verb) { - case ActivityVerb::FAVORITE: - case ActivityVerb::UNFAVORITE: - $adapter = new SystemListItem($nli); - break; - case ActivityVerb::JOIN: - $adapter = new JoinListItem($nli); - break; - case ActivityVerb::LEAVE: - $adapter = new JoinListItem($nli); - break; - case ActivityVerb::FOLLOW: - $adapter = new FollowListItem($nli); - break; - case ActivityVerb::UNFOLLOW: - $adapter = new UnfollowListItem($nli); - break; - } + $notice = $nli->notice; + + $adapter = null; + + switch ($notice->verb) { + case ActivityVerb::JOIN: + $adapter = new JoinListItem($nli); + break; + case ActivityVerb::LEAVE: + $adapter = new LeaveListItem($nli); + break; + case ActivityVerb::FOLLOW: + $adapter = new FollowListItem($nli); + break; + case ActivityVerb::UNFOLLOW: + $adapter = new UnfollowListItem($nli); + break; + } if (!empty($adapter)) { $adapter->showNotice(); @@ -327,66 +300,53 @@ class ActivityPlugin extends Plugin $adapter->showNoticeOptions(); return false; } - + return true; } - function onEndNoticeAsActivity($notice, &$activity) + public function onEndNoticeAsActivity(Notice $stored, Activity $act, Profile $scoped=null) { - switch ($notice->verb) { - case ActivityVerb::FAVORITE: - $fave = Fave::staticGet('uri', $notice->uri); - if (!empty($fave)) { - $notice = Notice::staticGet('id', $fave->notice_id); - if (!empty($notice)) { - $target = $notice->asActivity(); - if ($target->verb == ActivityVerb::POST) { - // "I like the thing you posted" - $activity->objects = $target->objects; - } else { - // "I like that you did whatever you did" - $activity->objects = array($target); - } - } - } - break; + switch ($stored->verb) { case ActivityVerb::UNFAVORITE: // FIXME: do something here - break; - case ActivityVerb::JOIN: - $mem = Group_member::staticGet('uri', $notice->uri); - if (!empty($mem)) { + break; + case ActivityVerb::JOIN: + $mem = Group_member::getKV('uri', $stored->getUri()); + if ($mem instanceof Group_member) { $group = $mem->getGroup(); - $activity->objects = array(ActivityObject::fromGroup($group)); + $act->title = $stored->getTitle(); + $act->objects = array(ActivityObject::fromGroup($group)); } break; - case ActivityVerb::LEAVE: + case ActivityVerb::LEAVE: // FIXME: ???? - break; - case ActivityVerb::FOLLOW: - $sub = Subscription::staticGet('uri', $notice->uri); - if (!empty($sub)) { - $profile = Profile::staticGet('id', $sub->subscribed); - if (!empty($profile)) { - $activity->objects = array(ActivityObject::fromProfile($profile)); + break; + case ActivityVerb::FOLLOW: + $sub = Subscription::getKV('uri', $stored->uri); + if ($sub instanceof Subscription) { + $profile = Profile::getKV('id', $sub->subscribed); + if ($profile instanceof Profile) { + $act->title = $stored->getTitle(); + $act->objects = array($profile->asActivityObject()); } } - break; - case ActivityVerb::UNFOLLOW: + break; + case ActivityVerb::UNFOLLOW: // FIXME: ???? - break; - } + break; + } - return true; + return true; } - function onPluginVersion(&$versions) + function onPluginVersion(array &$versions) { $versions[] = array('name' => 'Activity', 'version' => self::VERSION, 'author' => 'Evan Prodromou', 'homepage' => 'http://status.net/wiki/Plugin:Activity', 'rawdescription' => + // TRANS: Plugin description. _m('Emits notices when social activities happen.')); return true; }