]> git.mxchange.org Git - quix0rs-gnu-social.git/blobdiff - actions/twitapidirect_messages.php
Profile block base style
[quix0rs-gnu-social.git] / actions / twitapidirect_messages.php
index 466e74823868f8749a6eed2fa2aea12760995e92..535795ca4321d6351edca4dbe6d2d2e3ced8ef2b 100644 (file)
@@ -23,20 +23,6 @@ require_once(INSTALLDIR.'/lib/twitterapi.php');
 
 class Twitapidirect_messagesAction extends TwitterapiAction {
 
-       function is_readonly() {
-
-               static $write_methods = array(  'direct_messages',
-                                                                               'sent');
-
-               $cmdtext = explode('.', $this->arg('method'));
-
-               if (in_array($cmdtext[0], $write_methods)) {
-                       return false;
-               }
-
-               return true;
-       }
-
        function direct_messages($args, $apidata) {
                parent::handle($args);
                return $this->show_messages($args, $apidata, 'received');
@@ -54,6 +40,8 @@ class Twitapidirect_messagesAction extends TwitterapiAction {
                $count = $this->arg('count');
                $since = $this->arg('since');
                $since_id = $this->arg('since_id');
+               $before_id = $this->arg('before_id');
+
                $page = $this->arg('page');
 
                if (!$page) {
@@ -83,6 +71,21 @@ class Twitapidirect_messagesAction extends TwitterapiAction {
                        $link = $server . $user->nickname . '/outbox';
                }
 
+               if ($before_id) {
+                       $message->whereAdd("id < $before_id");
+               }
+
+               if ($since_id) {
+                       $message->whereAdd("id > $since_id");
+               }
+
+               $since = strtotime($this->arg('since'));
+
+               if ($since) {
+                       $d = date('Y-m-d H:i:s', $since);
+                       $message->whereAdd("created > '$d'");
+               }
+
                $message->orderBy('created DESC, id DESC');
                $message->limit((($page-1)*20), $count);
                $message->find();
@@ -116,9 +119,10 @@ class Twitapidirect_messagesAction extends TwitterapiAction {
                }
 
                $user = $apidata['user'];
-               $source = $this->trimmed('source');  // Not supported by Twitter.
+               $source = $this->trimmed('source');      // Not supported by Twitter.
 
-               if (!$source) {
+        $reserved_sources = array('web', 'omb', 'mail', 'xmpp', 'api');
+               if (!$source || in_array($source, $reserved_sources)) {
                        $source = 'api';
                }
 
@@ -126,10 +130,13 @@ class Twitapidirect_messagesAction extends TwitterapiAction {
 
                if (!$content) {
                        $this->client_error(_('No message text!'), $code = 406, $apidata['content-type']);
-               } else if (mb_strlen($status) > 140) {
-                       $this->client_error(_('That\'s too long. Max message size is 140 chars.'),
-                               $code = 406, $apidata['content-type']);
-                       return;
+               } else {
+                       $content_shortened = common_shorten_links($content);
+                       if (mb_strlen($content_shortened) > 140) {
+                               $this->client_error(_('That\'s too long. Max message size is 140 chars.'),
+                                       $code = 406, $apidata['content-type']);
+                               return;
+                       }
                }
 
                $other = $this->get_user($this->trimmed('user'));
@@ -148,7 +155,8 @@ class Twitapidirect_messagesAction extends TwitterapiAction {
                        return;
                }
 
-               $message = Message::saveNew($user->id, $other->id, $content, $source);
+               $message = Message::saveNew($user->id, $other->id,
+                       html_entity_decode($content, ENT_NOQUOTES, 'UTF-8'), $source);
 
                if (is_string($message)) {
                        $this->server_error($message);
@@ -276,4 +284,4 @@ class Twitapidirect_messagesAction extends TwitterapiAction {
                # XXX: Jabber, SMS notifications... probably queued
        }
 
-}
\ No newline at end of file
+}