]> git.mxchange.org Git - quix0rs-gnu-social.git/blobdiff - actions/newnotice.php
add 'invite-only' mode for registration
[quix0rs-gnu-social.git] / actions / newnotice.php
index 607f4b087101c2a70506e8b69b8a3a24ee39fd7a..b5fc98c37c904d662200da2653931f5199be889e 100644 (file)
 if (!defined('LACONICA')) { exit(1); }
 
 class NewnoticeAction extends Action {
-
+       
        function handle($args) {
                parent::handle($args);
                # XXX: Ajax!
 
                if (!common_logged_in()) {
-                       common_user_error(_t('Not logged in.'));
+                       common_user_error(_('Not logged in.'));
                } else if ($_SERVER['REQUEST_METHOD'] == 'POST') {
                        $this->save_new_notice();
                } else {
@@ -36,54 +36,50 @@ class NewnoticeAction extends Action {
 
        function save_new_notice() {
 
-                #remember the current notice
-                $current_notice = DB_DataObject::factory('notice');
-                $current_notice->limit(1);
-                $current_notice->orderBy('created DESC');
-                $current_notice->find(1);
-
                $user = common_current_user();
                assert($user); # XXX: maybe an error instead...
-               $notice = DB_DataObject::factory('notice');
-               assert($notice);
-               $notice->profile_id = $user->id; # user id *is* profile id
-               $notice->created = DB_DataObject_Cast::dateTime();
-               # Default theme uses 'content' for something else
-               $notice->content = $this->trimmed('status_textarea');
-
-               if (!$notice->content) {
-                       $this->show_form(_t('No content!'));
+               $content = $this->trimmed('status_textarea');
+               
+               if (!$content) {
+                       $this->show_form(_('No content!'));
                        return;
-               } else if (strlen($notice->content) > 140) {
-                       $this->show_form(_t('That\'s too long. Max notice size is 140 chars.'));
+               } else if (mb_strlen($content) > 140) {
+                       common_debug("Content = '$content'", __FILE__);
+                       common_debug("mb_strlen(\$content) = " . mb_strlen($content), __FILE__);
+                       $this->show_form(_('That\'s too long. Max notice size is 140 chars.'));
                        return;
                }
 
-               $id = $notice->insert();
-
-               if (!$id) {
-                       common_server_error(_t('Problem saving notice.'));
+               $inter = new CommandInterpreter();
+               
+               $cmd = $inter->handle_command($user, $content);
+               
+               if ($cmd) {
+                       $cmd->execute(new WebChannel());
                        return;
                }
 
-               $orig = clone($notice);
-               $notice->uri = common_notice_uri($notice);
+               $replyto = $this->trimmed('inreplyto');
 
-               if (!$notice->update($orig)) {
-                       common_server_error(_t('Problem saving notice.'));
+               common_debug("Replyto = $replyto\n");
+               
+               $notice = Notice::saveNew($user->id, $content, 'web', 1, ($replyto == 'false') ? NULL : $replyto);
+               
+               if (is_string($notice)) {
+                       $this->show_form($notice);
                        return;
                }
-
-        common_save_replies($notice);  
-
+               
                common_broadcast_notice($notice);
+               
                $returnto = $this->trimmed('returnto');
+               
                if ($returnto) {
                        $url = common_local_url($returnto,
                                                                        array('nickname' => $user->nickname));
                } else {
                        $url = common_local_url('shownotice',
-                                                                       array('notice' => $id));
+                                                                       array('notice' => $notice->id));
                }
                common_redirect($url, 303);
        }
@@ -94,7 +90,14 @@ class NewnoticeAction extends Action {
 
        function show_form($msg=NULL) {
                $content = $this->trimmed('status_textarea');
-               common_show_header(_t('New notice'), NULL, $content,
+               if (!$content) {
+                       $replyto = $this->trimmed('replyto');
+                       $profile = Profile::staticGet('nickname', $replyto);
+                       if ($profile) {
+                               $content = '@' . $profile->nickname . ' ';
+                       }
+               }
+               common_show_header(_('New notice'), NULL, $content,
                                   array($this, 'show_top'));
                if ($msg) {
                        common_element('p', 'error', $msg);