]> git.mxchange.org Git - quix0rs-gnu-social.git/blobdiff - scripts/backupuser.php
File_redirection->getFile could never get the file anyway if $redir->file_id was...
[quix0rs-gnu-social.git] / scripts / backupuser.php
index ef1008eb3b25c3f02172f75deb980d06de8a1b28..740ae25d446bbd0210f9af4aa6945b57a9d41fa1 100644 (file)
@@ -19,8 +19,8 @@
 
 define('INSTALLDIR', realpath(dirname(__FILE__) . '/..'));
 
-$shortoptions = 'i:n:f:';
-$longoptions = array('id=', 'nickname=', 'file=');
+$shortoptions = 'i:n:f:a:j';
+$longoptions = array('id=', 'nickname=', 'file=', 'after=', 'json');
 
 $helptext = <<<END_OF_EXPORTACTIVITYSTREAM_HELP
 exportactivitystream.php [options]
@@ -28,173 +28,27 @@ Export a StatusNet user history to a file
 
   -i --id       ID of user to export
   -n --nickname nickname of the user to export
-  -f --file     file to export to (default STDOUT)
+  -j --json     Output JSON (default Atom)
+  -a --after    Only activities after the given date
 
 END_OF_EXPORTACTIVITYSTREAM_HELP;
 
 require_once INSTALLDIR.'/scripts/commandline.inc';
 
-/**
- * Class for activity streams
- *
- * Includes faves, notices, and subscriptions.
- *
- * We extend atomusernoticefeed since it does some nice setup for us.
- *
- */
-
-class UserActivityStream extends AtomUserNoticeFeed
-{
-    function __construct($user, $indent = true)
-    {
-        parent::__construct($user, null, $indent);
-
-        $subscriptions = $this->getSubscriptions();
-        $subscribers   = $this->getSubscribers();
-        $groups        = $this->getGroups();
-        $faves         = $this->getFaves();
-        $notices       = $this->getNotices();
-
-        $objs = array_merge($subscriptions, $subscribers, $groups, $faves, $notices);
-
-        // Sort by create date
-
-        usort($objs, 'UserActivityStream::compareObject');
-
-        foreach ($objs as $obj) {
-            $act = $obj->asActivity();
-            // Only show the author sub-element if it's different from default user
-            $str = $act->asString(false, ($act->actor->id != $this->user->uri));
-            $this->addEntryRaw($str);
-        }
-    }
-
-    function compareObject($a, $b)
-    {
-        $ac = strtotime((empty($a->created)) ? $a->modified : $a->created);
-        $bc = strtotime((empty($b->created)) ? $b->modified : $b->created);
-
-        return (($ac == $bc) ? 0 : (($ac < $bc) ? 1 : -1));
-    }
-
-    function getSubscriptions()
-    {
-        $subs = array();
-
-        $sub = new Subscription();
-
-        $sub->subscriber = $this->user->id;
-
-        if ($sub->find()) {
-            while ($sub->fetch()) {
-                if ($sub->subscribed != $this->user->id) {
-                    $subs[] = clone($sub);
-                }
-            }
-        }
-
-        return $subs;
-    }
-
-    function getSubscribers()
-    {
-        $subs = array();
-
-        $sub = new Subscription();
-
-        $sub->subscribed = $this->user->id;
-
-        if ($sub->find()) {
-            while ($sub->fetch()) {
-                if ($sub->subscriber != $this->user->id) {
-                    $subs[] = clone($sub);
-                }
-            }
-        }
-
-        return $subs;
-    }
-
-    function getFaves()
-    {
-        $faves = array();
-
-        $fave = new Fave();
-
-        $fave->user_id = $this->user->id;
-
-        if ($fave->find()) {
-            while ($fave->fetch()) {
-                $faves[] = clone($fave);
-            }
-        }
-
-        return $faves;
-    }
-
-    function getNotices()
-    {
-        $notices = array();
-
-        $notice = new Notice();
-
-        $notice->profile_id = $this->user->id;
-
-        if ($notice->find()) {
-            while ($notice->fetch()) {
-                $notices[] = clone($notice);
-            }
-        }
-
-        return $notices;
-    }
-
-    function getGroups()
-    {
-        $groups = array();
-
-        $gm = new Group_member();
-
-        $gm->profile_id = $this->user->id;
-
-        if ($gm->find()) {
-            while ($gm->fetch()) {
-                $groups[] = clone($gm);
-            }
-        }
-
-        return $groups;
+try {
+    $user = getUser();
+    if (have_option('a', 'after')) {
+        $afterStr = get_option_value('a', 'after');
+        $after = strtotime($afterStr);
+        $actstr = new UserActivityStream($user, true, UserActivityStream::OUTPUT_RAW, $after);
+    } else {
+        $actstr = new UserActivityStream($user, true, UserActivityStream::OUTPUT_RAW);
     }
-}
-
-function getUser()
-{
-    $user = null;
-
-    if (have_option('i', 'id')) {
-        $id = get_option_value('i', 'id');
-        $user = User::staticGet('id', $id);
-        if (empty($user)) {
-            throw new Exception("Can't find user with id '$id'.");
-        }
-    } else if (have_option('n', 'nickname')) {
-        $nickname = get_option_value('n', 'nickname');
-        $user = User::staticGet('nickname', $nickname);
-        if (empty($user)) {
-            throw new Exception("Can't find user with nickname '$nickname'");
-        }
+    if (have_option('j', 'json')) {
+        $actstr->writeJSON(STDOUT);
     } else {
-        show_help();
-        exit(1);
+        print $actstr->getString();
     }
-
-    return $user;
-}
-
-try {
-    $user = getUser();
-    $actstr = new UserActivityStream($user);
-    print $actstr->getString();
 } catch (Exception $e) {
     print $e->getMessage()."\n";
     exit(1);