]> git.mxchange.org Git - friendica.git/blobdiff - src/Object/Thread.php
Use more Attach model
[friendica.git] / src / Object / Thread.php
index 2a72f0f659144f1621a3872ff61743eca1d44d76..0068fa2fb9d7ac81ddadd78f409a45207b07fb49 100644 (file)
@@ -5,10 +5,10 @@
 namespace Friendica\Object;
 
 use Friendica\BaseObject;
-use Friendica\Object\Item;
-
-require_once 'boot.php';
-require_once 'include/text.php';
+use Friendica\Core\Logger;
+use Friendica\Core\Protocol;
+use Friendica\Object\Post;
+use Friendica\Util\Security;
 
 /**
  * A list of threads
@@ -17,7 +17,7 @@ require_once 'include/text.php';
  */
 class Thread extends BaseObject
 {
-       private $parents = array();
+       private $parents = [];
        private $mode = null;
        private $writable = false;
        private $profile_owner = 0;
@@ -27,11 +27,12 @@ class Thread extends BaseObject
         * Constructor
         *
         * @param string  $mode    The mode
-        * @param boolean $preview boolean value
+        * @param boolean $preview Are we in the preview mode?
+        * @param boolean $writable Override the writable check
         */
-       public function __construct($mode, $preview)
+       public function __construct($mode, $preview, $writable = false)
        {
-               $this->setMode($mode);
+               $this->setMode($mode, $writable);
                $this->preview = $preview;
        }
 
@@ -39,10 +40,11 @@ class Thread extends BaseObject
         * Set the mode we'll be displayed on
         *
         * @param string $mode The mode to set
+        * @param boolean $writable Override the writable check
         *
         * @return void
         */
-       private function setMode($mode)
+       private function setMode($mode, $writable)
        {
                if ($this->getMode() == $mode) {
                        return;
@@ -58,14 +60,22 @@ class Thread extends BaseObject
                                break;
                        case 'profile':
                                $this->profile_owner = $a->profile['profile_uid'];
-                               $this->writable = can_write_wall($a, $this->profile_owner);
+                               $this->writable = Security::canWriteToUserWall($this->profile_owner);
                                break;
                        case 'display':
                                $this->profile_owner = $a->profile['uid'];
-                               $this->writable = can_write_wall($a, $this->profile_owner);
+                               $this->writable = Security::canWriteToUserWall($this->profile_owner) || $writable;
+                               break;
+                       case 'community':
+                               $this->profile_owner = 0;
+                               $this->writable = $writable;
+                               break;
+                       case 'contacts':
+                               $this->profile_owner = 0;
+                               $this->writable = $writable;
                                break;
                        default:
-                               logger('[ERROR] Conversation::setMode : Unhandled mode ('. $mode .').', LOGGER_DEBUG);
+                               Logger::log('[ERROR] Conversation::setMode : Unhandled mode ('. $mode .').', Logger::DEBUG);
                                return false;
                                break;
                }
@@ -120,30 +130,30 @@ class Thread extends BaseObject
         * @return mixed The inserted item on success
         *               false on failure
         */
-       public function addParent($item)
+       public function addParent(Post $item)
        {
                $item_id = $item->getId();
 
                if (!$item_id) {
-                       logger('[ERROR] Conversation::addThread : Item has no ID!!', LOGGER_DEBUG);
+                       Logger::log('[ERROR] Conversation::addThread : Item has no ID!!', Logger::DEBUG);
                        return false;
                }
 
                if ($this->getParent($item->getId())) {
-                       logger('[WARN] Conversation::addThread : Thread already exists ('. $item->getId() .').', LOGGER_DEBUG);
+                       Logger::log('[WARN] Conversation::addThread : Thread already exists ('. $item->getId() .').', Logger::DEBUG);
                        return false;
                }
 
                /*
                 * Only add will be displayed
                 */
-               if ($item->getDataValue('network') === NETWORK_MAIL && local_user() != $item->getDataValue('uid')) {
-                       logger('[WARN] Conversation::addThread : Thread is a mail ('. $item->getId() .').', LOGGER_DEBUG);
+               if ($item->getDataValue('network') === Protocol::MAIL && local_user() != $item->getDataValue('uid')) {
+                       Logger::log('[WARN] Conversation::addThread : Thread is a mail ('. $item->getId() .').', Logger::DEBUG);
                        return false;
                }
 
                if ($item->getDataValue('verb') === ACTIVITY_LIKE || $item->getDataValue('verb') === ACTIVITY_DISLIKE) {
-                       logger('[WARN] Conversation::addThread : Thread is a (dis)like ('. $item->getId() .').', LOGGER_DEBUG);
+                       Logger::log('[WARN] Conversation::addThread : Thread is a (dis)like ('. $item->getId() .').', Logger::DEBUG);
                        return false;
                }
 
@@ -166,18 +176,18 @@ class Thread extends BaseObject
        public function getTemplateData($conv_responses)
        {
                $a = self::getApp();
-               $result = array();
+               $result = [];
                $i = 0;
 
                foreach ($this->parents as $item) {
-                       if ($item->getDataValue('network') === NETWORK_MAIL && local_user() != $item->getDataValue('uid')) {
+                       if ($item->getDataValue('network') === Protocol::MAIL && local_user() != $item->getDataValue('uid')) {
                                continue;
                        }
 
                        $item_data = $item->getTemplateData($conv_responses);
 
                        if (!$item_data) {
-                               logger('[ERROR] Conversation::getTemplateData : Failed to get item template data ('. $item->getId() .').', LOGGER_DEBUG);
+                               Logger::log('[ERROR] Conversation::getTemplateData : Failed to get item template data ('. $item->getId() .').', Logger::DEBUG);
                                return false;
                        }
                        $result[] = $item_data;