X-Git-Url: https://git.mxchange.org/?a=blobdiff_plain;f=plugins%2FActivity%2FActivityPlugin.php;h=aa718d079e6d044ae4907f7cea942f29c803d1ec;hb=97099e08c5a932a95cab55a3142edb361bd3a9a1;hp=cd47427e0a97dee1f06a9378e8a9d784ebb27b1e;hpb=654fdf2fa453fcb6be3df62622741e52eca4db7b;p=quix0rs-gnu-social.git diff --git a/plugins/Activity/ActivityPlugin.php b/plugins/Activity/ActivityPlugin.php index cd47427e0a..aa718d079e 100644 --- a/plugins/Activity/ActivityPlugin.php +++ b/plugins/Activity/ActivityPlugin.php @@ -44,19 +44,18 @@ 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) { @@ -82,18 +81,24 @@ class ActivityPlugin extends Plugin 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(), + $sub = Subscription::pkeyGet(array('subscriber' => $subscriber->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.'), + $subscriber->profileurl, + $subscriber->getBestName(), $other->profileurl, $other->getBestName()); - $content = sprintf(_m('%s (%s) started following %s (%s).'), - $subscriber->getBestName(), - $subscriber->profileurl, + // 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).'), + $subscriber->getBestName(), + $subscriber->profileurl, $other->getBestName(), - $other->profileurl); + $other->profileurl); $notice = Notice::saveNew($user->id, $content, @@ -101,9 +106,9 @@ class ActivityPlugin extends Plugin array('rendered' => $rendered, 'urls' => array(), 'replies' => array($other->getUri()), - 'verb' => ActivityVerb::FOLLOW, - 'object_type' => ActivityObject::PERSON, - 'uri' => $sub->uri)); + 'verb' => ActivityVerb::FOLLOW, + 'object_type' => ActivityObject::PERSON, + 'uri' => $sub->uri)); } return true; } @@ -114,31 +119,37 @@ class ActivityPlugin extends Plugin if(!$this->StopFollowUser) return true; $user = $subscriber->getUser(); if (!empty($user)) { - $rendered = sprintf(_m('%s stopped following %s.'), - $subscriber->profileurl, - $subscriber->getBestName(), + // 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.'), + $subscriber->profileurl, + $subscriber->getBestName(), $other->profileurl, $other->getBestName()); - $content = sprintf(_m('%s (%s) stopped following %s (%s).'), - $subscriber->getBestName(), - $subscriber->profileurl, + // 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).'), + $subscriber->getBestName(), + $subscriber->profileurl, $other->getBestName(), - $other->profileurl); + $other->profileurl); + + $uri = TagURI::mint('stop-following:%d:%d:%s', + $subscriber->id, + $other->id, + common_date_iso8601(common_sql_now())); - $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)); + 'uri' => $uri, + 'verb' => ActivityVerb::UNFOLLOW, + 'object_type' => ActivityObject::PERSON)); } return true; } @@ -147,25 +158,31 @@ class ActivityPlugin extends Plugin { // 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_id' => $notice->id)); + + // TRANS: Text for "liked" 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 liked %4$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()); + // TRANS: Text for "liked" 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) liked %3$s\'s status (%4$s).'), + $profile->getBestName(), + $profile->profileurl, + $author->getBestName(), + $notice->bestUrl()); $notice = Notice::saveNew($user->id, $content, @@ -173,10 +190,10 @@ class ActivityPlugin extends Plugin 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))); + 'uri' => $fave->getURI(), + 'verb' => ActivityVerb::FAVORITE, + 'object_type' => (($notice->verb == ActivityVerb::POST) ? + $notice->object_type : ActivityObject::ACTIVITY))); } return true; } @@ -189,32 +206,38 @@ class ActivityPlugin extends Plugin if (!empty($user)) { $author = Profile::staticGet('id', $notice->profile_id); - $rendered = sprintf(_m('%s stopped liking %s\'s update.'), - $profile->profileurl, - $profile->getBestName(), + // 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->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())); - + // 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->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))); + 'uri' => $uri, + 'verb' => ActivityVerb::UNFAVORITE, + 'object_type' => (($notice->verb == ActivityVerb::POST) ? + $notice->object_type : ActivityObject::ACTIVITY))); } return true; } @@ -223,36 +246,42 @@ class ActivityPlugin extends Plugin { // Only do this if config is enabled if(!$this->JoinGroup) return true; - + $user = $profile->getUser(); - + if (empty($user)) { 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->profileurl, + $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->profileurl, $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, $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,25 +289,31 @@ class ActivityPlugin extends Plugin { // Only do this if config is enabled if(!$this->LeaveGroup) return true; - + $user = $profile->getUser(); - + if (empty($user)) { 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->profileurl, + $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->profileurl, $group->getBestName(), - $group->homeUrl()); - - $uri = TagURI::mint('leave:%d:%d:%s', + $group->homeUrl()); + + $uri = TagURI::mint('leave:%d:%d:%s', $user->id, $group->id, common_date_iso8601(common_sql_now())); @@ -289,36 +324,36 @@ class ActivityPlugin extends Plugin 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) { + $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; - } + $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; + } if (!empty($adapter)) { $adapter->showNotice(); @@ -327,19 +362,20 @@ class ActivityPlugin extends Plugin $adapter->showNoticeOptions(); return false; } - + return true; } function onEndNoticeAsActivity($notice, &$activity) { - switch ($notice->verb) { + 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(); + $cur = common_current_user(); + $target = $notice->asActivity($cur); if ($target->verb == ActivityVerb::POST) { // "I like the thing you posted" $activity->objects = $target->objects; @@ -352,18 +388,18 @@ class ActivityPlugin extends Plugin break; case ActivityVerb::UNFAVORITE: // FIXME: do something here - break; - case ActivityVerb::JOIN: + break; + case ActivityVerb::JOIN: $mem = Group_member::staticGet('uri', $notice->uri); if (!empty($mem)) { $group = $mem->getGroup(); $activity->objects = array(ActivityObject::fromGroup($group)); } break; - case ActivityVerb::LEAVE: + case ActivityVerb::LEAVE: // FIXME: ???? - break; - case ActivityVerb::FOLLOW: + break; + case ActivityVerb::FOLLOW: $sub = Subscription::staticGet('uri', $notice->uri); if (!empty($sub)) { $profile = Profile::staticGet('id', $sub->subscribed); @@ -371,13 +407,13 @@ class ActivityPlugin extends Plugin $activity->objects = array(ActivityObject::fromProfile($profile)); } } - break; - case ActivityVerb::UNFOLLOW: + break; + case ActivityVerb::UNFOLLOW: // FIXME: ???? - break; - } + break; + } - return true; + return true; } function onPluginVersion(&$versions) @@ -387,6 +423,7 @@ class ActivityPlugin extends Plugin 'author' => 'Evan Prodromou', 'homepage' => 'http://status.net/wiki/Plugin:Activity', 'rawdescription' => + // TRANS: Plugin description. _m('Emits notices when social activities happen.')); return true; }