]> git.mxchange.org Git - friendica.git/blobdiff - include/like.php
It is now possible again to like yourself
[friendica.git] / include / like.php
index 6b8c138b952301d462626151de70bf89b642f918..1dbdcc936d727fc10fd05969674cfe8feeb06ed6 100644 (file)
@@ -1,6 +1,7 @@
 <?php
 
 use Friendica\App;
+use Friendica\Core\Addon;
 use Friendica\Core\System;
 use Friendica\Core\Worker;
 use Friendica\Database\DBM;
@@ -79,9 +80,14 @@ function do_like($item_id, $verb) {
        }
 
        $item = $items[0];
+       $uid = $item['uid'];
 
-       if (!can_write_wall($a, $item['uid'])) {
-               logger('like: unable to write on wall ' . $item['uid']);
+       if (($uid == 0) && local_user()) {
+               $uid = local_user();
+       }
+
+       if (!can_write_wall($uid)) {
+               logger('like: unable to write on wall ' . $uid);
                return false;
        }
 
@@ -89,12 +95,12 @@ function do_like($item_id, $verb) {
        $owners = q("SELECT `contact`.* FROM `contact`
                WHERE `contact`.`self`
                AND `contact`.`uid` = %d",
-               intval($item['uid'])
+               intval($uid)
        );
        if (DBM::is_result($owners)) {
                $owner_self_contact = $owners[0];
        } else {
-               logger('like: unknown owner ' . $item['uid']);
+               logger('like: unknown owner ' . $uid);
                return false;
        }
 
@@ -112,11 +118,11 @@ function do_like($item_id, $verb) {
        }
 
        // Contact-id is the uid-dependant author contact
-       if (local_user() == $item['uid']) {
+       if (local_user() == $uid) {
                $item_contact_id = $owner_self_contact['id'];
                $item_contact = $owner_self_contact;
        } else {
-               $item_contact_id = Contact::getIdForURL($author_contact['url'], $item['uid']);
+               $item_contact_id = Contact::getIdForURL($author_contact['url'], $uid);
 
                $contacts = q("SELECT * FROM `contact` WHERE `id` = %d",
                        intval($item_contact_id)
@@ -163,7 +169,7 @@ function do_like($item_id, $verb) {
                // Clean up the Diaspora signatures for this like
                // Go ahead and do it even if Diaspora support is disabled. We still want to clean up
                // if it had been enabled in the past
-               dba::delete('sign', array('iid' => $like_item['id']));
+               dba::delete('sign', ['iid' => $like_item['id']]);
 
                $like_item_id = $like_item['id'];
                Worker::add(PRIORITY_HIGH, "Notifier", "like", $like_item_id);
@@ -203,7 +209,7 @@ EOT;
        $alink = '[url=' . $item['author-link'] . ']' . $item['author-name'] . '[/url]';
        $plink = '[url=' . System::baseUrl() . '/display/' . $owner_self_contact['nick'] . '/' . $item['id'] . ']' . $post_type . '[/url]';
 
-       $new_item = array(
+       $new_item = [
                'guid'          => get_guid(32),
                'uri'           => item_new_uri($a->get_hostname(), $item['uid']),
                'uid'           => $item['uid'],
@@ -233,16 +239,14 @@ EOT;
                'deny_gid'      => $item['deny_gid'],
                'visible'       => 1,
                'unseen'        => 1,
-               'last-child'    => 0
-       );
+       ];
 
        $new_item_id = item_store($new_item);
 
        // @todo: Explain this block
        if (! $item['visible']) {
-               q("UPDATE `item` SET `visible` = 1 WHERE `id` = %d AND `uid` = %d",
-                       intval($item['id']),
-                       intval($item['uid'])
+               q("UPDATE `item` SET `visible` = 1 WHERE `id` = %d",
+                       intval($item['id'])
                );
        }
 
@@ -251,7 +255,7 @@ EOT;
 
        $new_item['id'] = $new_item_id;
 
-       call_hooks('post_local_end', $new_item);
+       Addon::callHooks('post_local_end', $new_item);
 
        Worker::add(PRIORITY_HIGH, "Notifier", "like", $new_item_id);