]> git.mxchange.org Git - quix0rs-gnu-social.git/blobdiff - plugins/Activity/ActivityPlugin.php
Merge branch 'subscribers_as_addressees' into 'nightly'
[quix0rs-gnu-social.git] / plugins / Activity / ActivityPlugin.php
index 7ea705fbe22081c4d0def8ca02b0204978e73673..5144eb46662f3f86a4c1c25969b008aef3da4c99 100644 (file)
@@ -44,133 +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  = '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;
-
-    /**
-     * Database schema setup
-     *
-     * @see Schema
-     * @see ColumnDef
-     *
-     * @return boolean hook value; true means continue processing, false means stop.
-     */
-
-    function onCheckSchema()
-    {
-        $schema = Schema::get();
-
-        // For storing the activity part of a notice
-
-        $schema->ensureTable('notice_activity',
-                             array(new ColumnDef('notice_id', 'integer', null,
-                                                 false, 'PRI'),
-                                   new ColumnDef('verb', 'varchar', 255,
-                                                 false, 'MUL'),
-                                   new ColumnDef('object', 'varchar', 255,
-                                                 true, 'MUL')));
-
-        return true;
-    }
+    public $LeaveGroup = false;
+    public $StartLike = false;
+    public $StopLike = false;
 
-    function onAutoload($cls)
+    function onEndSubscribe(Profile $profile, Profile $other)
     {
-        $dir = dirname(__FILE__);
+        // Only do this if config is enabled
+        if(!$this->StartFollowUser) return true;
 
-        switch ($cls)
-        {
-        case 'Notice_activity':
-            include_once $dir . '/'.$cls.'.php';
-            return false;
-        default:
+        if (!$profile->isLocal()) {
+            // can't do anything with remote user anyway
             return true;
         }
-    }
 
-    function onEndSubscribe($subscriber, $other)
-    {
-        // Only do this if config is enabled
-        if(!$this->StartFollowUser) return true;
-        $user = User::staticGet('id', $subscriber->id);
-        if (!empty($user)) {
-            $rendered = sprintf(_m('<em>Started following <a href="%s">%s</a></em>.'),
-                                $other->profileurl,
-                                $other->getBestName());
-            $content  = sprintf(_m('Started following %s : %s'),
-                                $other->getBestName(),
-                               $other->profileurl);
-
-            $notice = Notice::saveNew($user->id,
-                                      $content,
-                                      'activity',
-                                      array('rendered' => $rendered));
-
-            Notice_activity::setActivity($notice->id,
-                                         ActivityVerb::FOLLOW,
-                                         $other->getUri());
-        }
+        $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('<a href="%1$s">%2$s</a> started following <a href="%3$s">%4$s</a>.'),
+                            $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 = User::staticGet('id', $subscriber->id);
-        if (!empty($user)) {
-            $rendered = sprintf(_m('<em>Stopped following <a href="%s">%s</a></em>.'),
-                                $other->profileurl,
-                                $other->getBestName());
-            $content  = sprintf(_m('Stopped following %s : %s'),
-                                $other->getBestName(),
-                               $other->profileurl);
-
-            $notice = Notice::saveNew($user->id,
-                                      $content,
-                                      'activity',
-                                      array('rendered' => $rendered));
-
-            Notice_activity::setActivity($notice->id,
-                                         ActivityVerb::UNFOLLOW,
-                                         $other->getUri());
-        }
-        return true;
-    }
 
-    function onEndFavorNotice($profile, $notice)
-    {
-        //  Only do this if config is enabled
-        if(!$this->StartLike) return true;
-        $user = User::staticGet('id', $profile->id);
-
-        if (!empty($user)) {
-            $author = Profile::staticGet('id', $notice->profile_id);
-            $rendered = sprintf(_m('<em>Liked <a href="%s">%s\'s status</a></em>.'),
-                                $notice->bestUrl(),
-                                $author->getBestName());
-            $content  = sprintf(_m('Liked %s\'s status: %s'),
-                                $author->getBestName(), 
-                               $notice->bestUrl());
-
-            $notice = Notice::saveNew($user->id,
-                                      $content,
-                                      'activity',
-                                      array('rendered' => $rendered));
-
-            Notice_activity::setActivity($notice->id,
-                                         ActivityVerb::FAVORITE,
-                                         $notice->uri);
+        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('<a href="%1$s">%2$s</a> stopped following <a href="%3$s">%4$s</a>.'),
+                            $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;
     }
 
@@ -178,124 +146,207 @@ 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('<em>Stopped liking <a href="%s">%s\'s status</a></em>.'),
-                                $notice->bestUrl(),
-                                $author->getBestName());
-            $content  = sprintf(_m('Stopped liking %s\'s status: %s'),
-                                $author->getBestName(),
-                               $notice->bestUrl());
-
-            $notice = Notice::saveNew($user->id,
-                                      $content,
-                                      'activity',
-                                      array('rendered' => $rendered));
-
-            Notice_activity::setActivity($notice->id,
-                                         ActivityVerb::UNFAVORITE,
-                                         $notice->uri);
+
+        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('<a href="%1$s">%2$s</a> stopped liking <a href="%3$s">%4$s\'s update</a>.'),
+                            $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;
     }
 
-    function onEndJoinGroup($group, $user)
+    function onEndJoinGroup($group, $profile)
     {
         // Only do this if config is enabled
         if(!$this->JoinGroup) return true;
-        $rendered = sprintf(_m('<em>Joined the group &quot;<a href="%s">%s</a>&quot;</em>.'),
+
+        if (!$profile->isLocal()) {
+            return true;
+        }
+
+        // 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('<a href="%1$s">%2$s</a> joined the group <a href="%3$s">%4$s</a>.'),
+                            $profile->getUrl(),
+                            $profile->getBestName(),
                             $group->homeUrl(),
                             $group->getBestName());
-        $content  = sprintf(_m('Joined the group %s : %s'),
+        // 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());
 
-        $notice = Notice::saveNew($user->id,
-                                  $content,
-                                  'activity',
-                                  array('rendered' => $rendered));
+        $mem = Group_member::pkeyGet(array('group_id' => $group->id,
+                                           'profile_id' => $profile->id));
 
-        Notice_activity::setActivity($notice->id,
-                                     ActivityVerb::JOIN,
-                                     $group->getUri());
+        $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));
         return true;
     }
 
-    function onEndLeaveGroup($group, $user)
+    function onEndLeaveGroup($group, $profile)
     {
         // Only do this if config is enabled
         if(!$this->LeaveGroup) return true;
-        $rendered = sprintf(_m('<em>Left the group &quot;<a href="%s">%s</a>&quot;</em>.'),
+
+        if (!$profile->isLocal()) {
+            return true;
+        }
+
+        // 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('<a href="%1$s">%2$s</a> left the group <a href="%3$s">%4$s</a>.'),
+                            $profile->getUrl(),
+                            $profile->getBestName(),
                             $group->homeUrl(),
                             $group->getBestName());
-        $content  = sprintf(_m('Left the group "%s" : %s'),
+        // 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());
+                            $group->homeUrl());
 
-        $notice = Notice::saveNew($user->id,
-                                  $content,
-                                  'activity',
-                                  array('rendered' => $rendered));
+        $uri = TagURI::mint('leave:%d:%d:%s',
+                            $profile->id,
+                            $group->id,
+                            common_date_iso8601(common_sql_now()));
 
-        Notice_activity::setActivity($notice->id,
-                                     ActivityVerb::LEAVE,
-                                     $group->getUri());
+        $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));
         return true;
     }
 
-    function onEndNoticeAsActivity($notice, &$activity)
+    function onStartShowNoticeItem($nli)
     {
-        $na = Notice_activity::staticGet('notice_id', $notice->id);
-
-        if (!empty($na)) {
-
-            $activity->verb = $na->verb;
+        $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;
+        }
 
-            // wipe the old object!
+        if (!empty($adapter)) {
+            $adapter->showNotice();
+            $adapter->showNoticeAttachments();
+            $adapter->showNoticeInfo();
+            $adapter->showNoticeOptions();
+            return false;
+        }
 
-            $activity->objects = array();
+        return true;
+    }
 
-            switch ($na->verb)
-            {
-            case ActivityVerb::FOLLOW:
-            case ActivityVerb::UNFOLLOW:
-                $profile = Profile::fromURI($na->object);
-                if (!empty($profile)) {
-                    $activity->objects[] = ActivityObject::fromProfile($profile);
-                }
-                break;
-            case ActivityVerb::FAVORITE:
-            case ActivityVerb::UNFAVORITE:
-                $target = Notice::staticGet('uri', $na->object);
-                if (!empty($target)) {
-                    $activity->objects[] = ActivityObject::fromNotice($target);
-                }
-                break;
-            case ActivityVerb::JOIN:
-            case ActivityVerb::LEAVE:
-                $group = User_group::staticGet('uri', $na->object);
-                if (!empty($notice)) {
-                    $activity->objects[] = ActivityObject::fromGroup($group);
+    public function onEndNoticeAsActivity(Notice $stored, Activity $act, Profile $scoped=null)
+    {
+        switch ($stored->verb) {
+        case ActivityVerb::UNFAVORITE:
+            // FIXME: do something here
+            break;
+        case ActivityVerb::JOIN:
+            $mem = Group_member::getKV('uri', $stored->getUri());
+            if ($mem instanceof Group_member) {
+                $group = $mem->getGroup();
+                $act->title = $stored->getTitle();
+                $act->objects = array(ActivityObject::fromGroup($group));
+            }
+            break;
+        case ActivityVerb::LEAVE:
+            // FIXME: ????
+            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;
-            default:
-                break;
             }
+            break;
+        case ActivityVerb::UNFOLLOW:
+            // FIXME: ????
+            break;
         }
 
         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;
     }