]> git.mxchange.org Git - friendica.git/blobdiff - mod/item.php
autocomplete contacts nickname while writting in a comment box.
[friendica.git] / mod / item.php
index 6ecca8f4a1d7df82c35a832dc481b0537b964a60..0e855d54d91d3315cbf950a39d6971065ca152ca 100644 (file)
@@ -38,6 +38,7 @@ function item_post(&$a) {
        call_hooks('post_local_start', $_POST);
 
        $api_source = ((x($_POST,'api_source') && $_POST['api_source']) ? true : false);
+       $return_path = ((x($_POST,'return')) ? $_POST['return'] : '');
 
        /**
         * Is this a reply to something?
@@ -82,7 +83,7 @@ function item_post(&$a) {
                if(($r === false) || (! count($r))) {
                        notice( t('Unable to locate original post.') . EOL);
                        if(x($_POST,'return')) 
-                               goaway($a->get_baseurl() . "/" . $_POST['return'] );
+                               goaway($a->get_baseurl() . "/" . $return_path );
                        killme();
                }
                $parent_item = $r[0];
@@ -111,7 +112,7 @@ function item_post(&$a) {
        if(! can_write_wall($a,$profile_uid)) {
                notice( t('Permission denied.') . EOL) ;
                if(x($_POST,'return')) 
-                       goaway($a->get_baseurl() . "/" . $_POST['return'] );
+                       goaway($a->get_baseurl() . "/" . $return_path );
                killme();
        }
 
@@ -197,7 +198,7 @@ function item_post(&$a) {
                if(! strlen($body)) {
                        info( t('Empty post discarded.') . EOL );
                        if(x($_POST,'return')) 
-                               goaway($a->get_baseurl() . "/" . $_POST['return'] );
+                               goaway($a->get_baseurl() . "/" . $return_path );
                        killme();
                }
        }
@@ -332,11 +333,21 @@ function item_post(&$a) {
                }
        }
 
+       // embedded bookmark in post? convert to regular url and set bookmark flag
+
+       $bookmark = 0;
+       if(preg_match_all("/\[bookmark\=([^\]]*)\](.*?)\[\/bookmark\]/ism",$body,$match)) {
+               $bookmark = 1;
+       }
+
+
+       $body = bb_translate_video($body);
+
        /**
         * Fold multi-line [code] sequences
         */
 
-       $body = preg_replace('/\[\/code\]\s*\[code\]/m',"\n",$body); 
+       $body = preg_replace('/\[\/code\]\s*\[code\]/ism',"\n",$body); 
 
        /**
         * Look for any tags and linkify them
@@ -472,7 +483,12 @@ function item_post(&$a) {
                $verb = ACTIVITY_POST ;
 
        $gravity = (($parent) ? 6 : 0 );
+
+       // even if the post arrived via API we are considering that it 
+       // originated on this site by default for determining relayability.
+
+       $origin = ((x($_REQUEST,'origin')) ? intval($_REQUEST['origin']) : 1);
+       
        $notify_type = (($parent) ? 'comment-new' : 'wall-new' );
 
        $uri = item_new_uri($a->get_hostname(),$profile_uid);
@@ -491,6 +507,7 @@ function item_post(&$a) {
        $datarray['author-avatar'] = $author['thumb'];
        $datarray['created']       = datetime_convert();
        $datarray['edited']        = datetime_convert();
+       $datarray['commented']     = datetime_convert();
        $datarray['received']      = datetime_convert();
        $datarray['changed']       = datetime_convert();
        $datarray['uri']           = $uri;
@@ -509,7 +526,10 @@ function item_post(&$a) {
        $datarray['private']       = $private;
        $datarray['pubmail']       = $pubmail_enable;
        $datarray['attach']        = $attachments;
+       $datarray['bookmark']      = intval($bookmark);
        $datarray['thr-parent']    = $thr_parent;
+       $datarray['postopts']      = '';
+       $datarray['origin']        = $origin;
 
        /**
         * These fields are for the convenience of plugins...
@@ -519,7 +539,7 @@ function item_post(&$a) {
 
        $datarray['parent']        = $parent;
        $datarray['self']          = $self;
-       $datarray['prvnets']       = $user['prvnets'];
+//     $datarray['prvnets']       = $user['prvnets'];
 
        if($orig_post)
                $datarray['edit']      = true;
@@ -539,9 +559,9 @@ function item_post(&$a) {
                );
 
                proc_run('php', "include/notifier.php", 'edit_post', "$post_id");
-               if((x($_POST,'return')) && strlen($_POST['return'])) {
-                       logger('return: ' . $_POST['return']);
-                       goaway($a->get_baseurl() . "/" . $_POST['return'] );
+               if((x($_POST,'return')) && strlen($return_path)) {
+                       logger('return: ' . $return_path);
+                       goaway($a->get_baseurl() . "/" . $return_path );
                }
                killme();
        }
@@ -550,9 +570,9 @@ function item_post(&$a) {
 
 
        $r = q("INSERT INTO `item` (`guid`, `uid`,`type`,`wall`,`gravity`,`contact-id`,`owner-name`,`owner-link`,`owner-avatar`, 
-               `author-name`, `author-link`, `author-avatar`, `created`, `edited`, `received`, `changed`, `uri`, `thr-parent`, `title`, `body`, `app`, `location`, `coord`, 
-               `tag`, `inform`, `verb`, `allow_cid`, `allow_gid`, `deny_cid`, `deny_gid`, `private`, `pubmail`, `attach` )
-               VALUES( '%s', %d, '%s', %d, %d, %d, '%s', '%s', '%s', '%s', '%s', '%s', '%s', '%s', '%s', '%s', '%s', '%s', '%s', '%s', '%s', '%s', '%s', '%s', '%s', '%s', '%s', '%s', '%s', '%s', %d, %d, '%s' )",
+               `author-name`, `author-link`, `author-avatar`, `created`, `edited`, `commented`, `received`, `changed`, `uri`, `thr-parent`, `title`, `body`, `app`, `location`, `coord`, 
+               `tag`, `inform`, `verb`, `postopts`, `allow_cid`, `allow_gid`, `deny_cid`, `deny_gid`, `private`, `pubmail`, `attach`, `bookmark`,`origin` )
+               VALUES( '%s', %d, '%s', %d, %d, %d, '%s', '%s', '%s', '%s', '%s', '%s', '%s', '%s', '%s', '%s', '%s', '%s', '%s', '%s', '%s', '%s', '%s', '%s', '%s', '%s', '%s', '%s', '%s', '%s', '%s', '%s', %d, %d, '%s', %d, %d )",
                dbesc($datarray['guid']),
                intval($datarray['uid']),
                dbesc($datarray['type']),
@@ -567,6 +587,7 @@ function item_post(&$a) {
                dbesc($datarray['author-avatar']),
                dbesc($datarray['created']),
                dbesc($datarray['edited']),
+               dbesc($datarray['commented']),
                dbesc($datarray['received']),
                dbesc($datarray['changed']),
                dbesc($datarray['uri']),
@@ -579,13 +600,16 @@ function item_post(&$a) {
                dbesc($datarray['tag']),
                dbesc($datarray['inform']),
                dbesc($datarray['verb']),
+               dbesc($datarray['postopts']),
                dbesc($datarray['allow_cid']),
                dbesc($datarray['allow_gid']),
                dbesc($datarray['deny_cid']),
                dbesc($datarray['deny_gid']),
                intval($datarray['private']),
                intval($datarray['pubmail']),
-               dbesc($datarray['attach'])
+               dbesc($datarray['attach']),
+               intval($datarray['bookmark']),
+               intval($datarray['origin'])
        );
 
        $r = q("SELECT `id` FROM `item` WHERE `uri` = '%s' LIMIT 1",
@@ -689,7 +713,7 @@ function item_post(&$a) {
                                else
                                $signed_text = $datarray['guid'] . ';' . $parent_item['guid'] . ';' . $signed_body . ';' . $myaddr;
 
-                               $authorsig = base64_encode(rsa_sign($signed_text,$a->user['prvkey'],'sha'));
+                               $authorsig = base64_encode(rsa_sign($signed_text,$a->user['prvkey'],'sha256'));
 
                                q("insert into sign (`iid`,`signed_text`,`signature`,`signer`) values (%d,'%s','%s','%s') ",
                                        intval($post_id),
@@ -765,6 +789,11 @@ function item_post(&$a) {
                        }
                }
 
+               // fallback so that parent always gets set to non-zero.
+
+               if(! $parent)
+                       $parent = $post_id;
+
                $r = q("UPDATE `item` SET `parent` = %d, `parent-uri` = '%s', `plink` = '%s', `changed` = '%s', `last-child` = 1, `visible` = 1
                        WHERE `id` = %d LIMIT 1",
                        intval($parent),
@@ -787,11 +816,17 @@ function item_post(&$a) {
        else {
                logger('mod_item: unable to retrieve post that was just stored.');
                notify( t('System error. Post not saved.'));
-               goaway($a->get_baseurl() . "/" . $_POST['return'] );
+               goaway($a->get_baseurl() . "/" . $return_path );
                // NOTREACHED
        }
 
-       proc_run('php', "include/notifier.php", $notify_type, "$post_id");
+       // update the commented timestamp on the parent
+
+       q("UPDATE `item` set `commented` = '%s', `changed` = '%s' WHERE `id` = %d LIMIT 1",
+               dbesc(datetime_convert()),
+               dbesc(datetime_convert()),
+               intval($parent)
+       );
 
        $datarray['id']    = $post_id;
        $datarray['plink'] = $a->get_baseurl() . '/display/' . $user['nickname'] . '/' . $post_id;
@@ -823,11 +858,16 @@ function item_post(&$a) {
                }
        }
 
+       // This is a real juggling act on shared hosting services which kill your processes
+       // e.g. dreamhost. We used to start delivery to our native delivery agents in the background
+       // and then run our plugin delivery from the foreground. We're now doing plugin delivery first,
+       // because as soon as you start loading up a bunch of remote delivey processes, *this* page is
+       // likely to get killed off. If you end up looking at an /item URL and a blank page,
+       // it's very likely the delivery got killed before all your friends could be notified.
+       // Currently the only realistic fixes are to use a reliable server - which precludes shared hosting,
+       // or cut back on plugins which do remote deliveries.  
 
-
-
-
-
+       proc_run('php', "include/notifier.php", $notify_type, "$post_id");
 
        logger('post_complete');
 
@@ -836,10 +876,10 @@ function item_post(&$a) {
        if($api_source)
                return;
 
-       if((x($_POST,'return')) && strlen($_POST['return'])) {
-               logger('return: ' . $_POST['return']);
-               goaway($a->get_baseurl() . "/" . $_POST['return'] );
+       if($return_path) {
+               goaway($a->get_baseurl() . "/" . $return_path);
        }
+
        $json = array('success' => 1);
        if(x($_POST,'jsreload') && strlen($_POST['jsreload']))
                $json['reload'] = $a->get_baseurl() . '/' . $_POST['jsreload'];