]> git.mxchange.org Git - friendica.git/blobdiff - src/Model/FContact.php
Merge pull request #10283 from very-ape/fix-message-button
[friendica.git] / src / Model / FContact.php
index f61100093455f7243c153735a1aacfa9343880a8..cf75a03dbc1df976ecc84c505d7fde2325df95ad 100644 (file)
@@ -1,6 +1,6 @@
 <?php
 /**
- * @copyright Copyright (C) 2020, Friendica
+ * @copyright Copyright (C) 2010-2021, the Friendica project
  *
  * @license GNU AGPL version 3 or any later version
  *
@@ -25,7 +25,6 @@ use Friendica\Core\Logger;
 use Friendica\Core\Protocol;
 use Friendica\Database\DBA;
 use Friendica\DI;
-use Friendica\Model\Notify\Type;
 use Friendica\Network\Probe;
 use Friendica\Protocol\Activity;
 use Friendica\Util\DateTimeFormat;
@@ -43,12 +42,12 @@ class FContact
         * @throws \Friendica\Network\HTTPException\InternalServerErrorException
         * @throws \ImagickException
         */
-       public static function getByURL($handle, $update = null)
+       public static function getByURL($handle, $update = null, $network = Protocol::DIASPORA)
        {
-               $person = DBA::selectFirst('fcontact', [], ['network' => Protocol::DIASPORA, 'addr' => $handle]);
+               $person = DBA::selectFirst('fcontact', [], ['network' => $network, 'addr' => $handle]);
                if (!DBA::isResult($person)) {
                        $urls = [$handle, str_replace('http://', 'https://', $handle), Strings::normaliseLink($handle)];
-                       $person = DBA::selectFirst('fcontact', [], ['network' => Protocol::DIASPORA, 'url' => $urls]);
+                       $person = DBA::selectFirst('fcontact', [], ['network' => $network, 'url' => $urls]);
                }
 
                if (DBA::isResult($person)) {
@@ -73,14 +72,14 @@ class FContact
 
                if ($update) {
                        Logger::info('create or refresh', ['handle' => $handle]);
-                       $r = Probe::uri($handle, Protocol::DIASPORA);
+                       $r = Probe::uri($handle, $network);
 
                        // Note that Friendica contacts will return a "Diaspora person"
                        // if Diaspora connectivity is enabled on their server
-                       if ($r && ($r["network"] === Protocol::DIASPORA)) {
+                       if ($r && ($r["network"] === $network)) {
                                self::updateFContact($r);
 
-                               $person = self::getByURL($handle, false);
+                               $person = self::getByURL($handle, false, $network);
                        }
                }
 
@@ -135,56 +134,45 @@ class FContact
        }
 
        /**
-        * Add suggestions for a given contact
+        * Suggest a given contact to a given user from a given contact
         *
         * @param integer $uid
         * @param integer $cid
+        * @param integer $from_cid
         * @return bool   Was the adding successful?
         */
-       public static function addSuggestion(int $uid, int $cid)
+       public static function addSuggestion(int $uid, int $cid, int $from_cid, string $note = '')
        {
                $owner = User::getOwnerDataById($uid);
                $contact = Contact::getById($cid);
+               $from_contact = Contact::getById($from_cid);
 
                if (DBA::exists('contact', ['nurl' => Strings::normaliseLink($contact['url']), 'uid' => $uid])) {
                        return false;
                }
 
+               $fcontact = self::getByURL($contact['url'], null, $contact['network']);
+               if (empty($fcontact)) {
+                       Logger::warning('FContact had not been found', ['fcontact' => $contact['url']]);
+                       return false;
+               }
+
+               $fid = $fcontact['id'];
+
+               // Quit if we already have an introduction for this person
+               if (DBA::exists('intro', ['uid' => $uid, 'fid' => $fid])) {
+                       return false;
+               }
+
                $suggest = [];
                $suggest['uid'] = $uid;
-               $suggest['cid'] = $contact['id'];
+               $suggest['cid'] = $from_cid;
                $suggest['url'] = $contact['url'];
                $suggest['name'] = $contact['name'];
                $suggest['photo'] = $contact['photo'];
                $suggest['request'] = $contact['request'];
                $suggest['title'] = '';
-               $suggest['body'] = '';
-
-               // Do we already have an fcontact record for this person?
-               $fid = 0;
-               $fcontact = DBA::selectFirst('fcontact', ['id'], ['url' => $suggest['url']]);
-               if (DBA::isResult($fcontact)) {
-                       $fid = $fcontact['id'];
-
-                       $fields = ['name' => $suggest['name'], 'photo' => $suggest['photo'], 'request' => $suggest['request']];
-                       DBA::update('fcontact', $fields, ['id' => $fid]);
-
-                       // Quit if we already have an introduction for this person
-                       if (DBA::exists('intro', ['uid' => $suggest['uid'], 'fid' => $fid])) {
-                               return false;
-                       }
-               }
-
-               if (empty($fid)) {
-                       $fields = ['name' => $suggest['name'], 'url' => $suggest['url'],
-                               'photo' => $suggest['photo'], 'request' => $suggest['request']];
-                       DBA::insert('fcontact', $fields);
-                       $fid = DBA::lastInsertId();
-                       if (empty($fid)) {
-                               Logger::warning('FContact had not been created', ['fcontact' => $fields]);
-                               return false;
-                       }
-               }
+               $suggest['body'] = $note;
 
                $hash = Strings::getRandomHex();
                $fields = ['uid' => $suggest['uid'], 'fid' => $fid, 'contact-id' => $suggest['cid'], 
@@ -192,19 +180,13 @@ class FContact
                DBA::insert('intro', $fields);
 
                notification([
-                       'type'         => Type::SUGGEST,
-                       'notify_flags' => $owner['notify-flags'],
-                       'language'     => $owner['language'],
-                       'to_name'      => $owner['name'],
-                       'to_email'     => $owner['email'],
-                       'uid'          => $owner['uid'],
-                       'item'         => $suggest,
-                       'link'         => DI::baseUrl().'/notifications/intros',
-                       'source_name'  => $contact['name'],
-                       'source_link'  => $contact['url'],
-                       'source_photo' => $contact['photo'],
-                       'verb'         => Activity::REQ_FRIEND,
-                       'otype'        => 'intro'
+                       'type'  => Notification\Type::SUGGEST,
+                       'otype' => Notification\ObjectType::INTRO,
+                       'verb'  => Activity::REQ_FRIEND,
+                       'uid'   => $owner['uid'],
+                       'cid'   => $from_contact['uid'],
+                       'item'  => $suggest,
+                       'link'  => DI::baseUrl().'/notifications/intros',
                ]);
 
                return true;