X-Git-Url: https://git.mxchange.org/?a=blobdiff_plain;f=plugins%2FActivity%2FActivityPlugin.php;h=aa718d079e6d044ae4907f7cea942f29c803d1ec;hb=b4da5f3785de138b9b7c3672d331676ea7929c16;hp=2785931d0ef9e85058ba4181d9a33312a59f09fd;hpb=1bfbf92868a6402788703443e8d017a3d6155df6;p=quix0rs-gnu-social.git diff --git a/plugins/Activity/ActivityPlugin.php b/plugins/Activity/ActivityPlugin.php index 2785931d0e..aa718d079e 100644 --- a/plugins/Activity/ActivityPlugin.php +++ b/plugins/Activity/ActivityPlugin.php @@ -44,18 +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 = '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) { @@ -63,6 +63,13 @@ class ActivityPlugin extends Plugin switch ($cls) { + case 'JoinListItem': + case 'LeaveListItem': + case 'FollowListItem': + case 'UnfollowListItem': + case 'SystemListItem': + include_once $dir . '/'.strtolower($cls).'.php'; + return false; default: return true; } @@ -74,26 +81,34 @@ 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, - 'activity', + ActivityPlugin::SOURCE, array('rendered' => $rendered, - 'verb' => ActivityVerb::FOLLOW, - 'object_type' => ActivityObject::PERSON, - 'uri' => $sub->uri)); + 'urls' => array(), + 'replies' => array($other->getUri()), + 'verb' => ActivityVerb::FOLLOW, + 'object_type' => ActivityObject::PERSON, + 'uri' => $sub->uri)); } return true; } @@ -104,29 +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, - 'activity', + ActivityPlugin::SOURCE, array('rendered' => $rendered, - 'uri' => $uri, - 'verb' => ActivityVerb::UNFOLLOW, - 'object_type' => ActivityObject::PERSON)); + 'urls' => array(), + 'replies' => array($other->getUri()), + 'uri' => $uri, + 'verb' => ActivityVerb::UNFOLLOW, + 'object_type' => ActivityObject::PERSON)); } return true; } @@ -135,34 +158,42 @@ 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, - 'activity', + ActivityPlugin::SOURCE, array('rendered' => $rendered, - 'uri' => $fave->getURI(), - 'verb' => ActivityVerb::FAVORITE, - 'object_type' => (($notice->verb == ActivityVerb::POST) ? - $notice->object_type : ActivityObject::ACTIVITY))); + 'urls' => array(), + 'replies' => array($author->getUri()), + 'uri' => $fave->getURI(), + 'verb' => ActivityVerb::FAVORITE, + 'object_type' => (($notice->verb == ActivityVerb::POST) ? + $notice->object_type : ActivityObject::ACTIVITY))); } return true; } @@ -175,30 +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, - 'activity', + ActivityPlugin::SOURCE, array('rendered' => $rendered, - 'uri' => $uri, - 'verb' => ActivityVerb::UNFAVORITE, - 'object_type' => (($notice->verb == ActivityVerb::POST) ? - $notice->object_type : ActivityObject::ACTIVITY))); + 'urls' => array(), + 'replies' => array($author->getUri()), + 'uri' => $uri, + 'verb' => ActivityVerb::UNFAVORITE, + 'object_type' => (($notice->verb == ActivityVerb::POST) ? + $notice->object_type : ActivityObject::ACTIVITY))); } return true; } @@ -207,34 +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, - 'activity', + ActivityPlugin::SOURCE, array('rendered' => $rendered, - 'uri' => $mem->getURI(), - 'verb' => ActivityVerb::JOIN, - 'object_type' => ActivityObject::GROUP)); + 'urls' => array(), + 'groups' => array($group->id), + 'uri' => $mem->getURI(), + 'verb' => ActivityVerb::JOIN, + 'object_type' => ActivityObject::GROUP)); return true; } @@ -242,44 +289,132 @@ 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())); $notice = Notice::saveNew($user->id, $content, - 'activity', + ActivityPlugin::SOURCE, array('rendered' => $rendered, - 'uri' => $uri, - 'verb' => ActivityVerb::LEAVE, - 'object_type' => ActivityObject::GROUP)); + 'urls' => array(), + 'groups' => array($group->id), + 'uri' => $uri, + 'verb' => ActivityVerb::LEAVE, + 'object_type' => ActivityObject::GROUP)); return true; } - function onEndNoticeAsActivity($notice, &$activity) + function onStartShowNoticeItem($nli) { - return true; + $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; + } + + if (!empty($adapter)) { + $adapter->showNotice(); + $adapter->showNoticeAttachments(); + $adapter->showNoticeInfo(); + $adapter->showNoticeOptions(); + return false; + } + + return true; } + function onEndNoticeAsActivity($notice, &$activity) + { + 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)) { + $cur = common_current_user(); + $target = $notice->asActivity($cur); + 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; + case ActivityVerb::UNFAVORITE: + // FIXME: do something here + 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: + // 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::UNFOLLOW: + // FIXME: ???? + break; + } + + return true; + } function onPluginVersion(&$versions) { @@ -288,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; }