*/
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\DI;
+use Friendica\Protocol\Activity;
+use Friendica\Util\Security;
/**
* A list of threads
*
* We should think about making this a SPL Iterator
*/
-class Thread extends BaseObject
+class Thread
{
- private $parents = array();
+ private $parents = [];
private $mode = null;
private $writable = false;
private $profile_owner = 0;
/**
* Constructor
*
- * @param string $mode The mode
- * @param boolean $preview boolean value
+ * @param string $mode The mode
+ * @param boolean $preview Are we in the preview mode?
+ * @param boolean $writable Override the writable check
+ * @throws \Exception
*/
- public function __construct($mode, $preview)
+ public function __construct($mode, $preview, $writable = false)
{
- $this->setMode($mode);
+ $this->setMode($mode, $writable);
$this->preview = $preview;
}
/**
* Set the mode we'll be displayed on
*
- * @param string $mode The mode to set
+ * @param string $mode The mode to set
+ * @param boolean $writable Override the writable check
*
* @return void
+ * @throws \Exception
*/
- private function setMode($mode)
+ private function setMode($mode, $writable)
{
if ($this->getMode() == $mode) {
return;
}
- $a = self::getApp();
+ $a = DI::app();
switch ($mode) {
case 'network':
$this->writable = true;
break;
case 'profile':
- $this->profile_owner = $a->profile['profile_uid'];
- $this->writable = can_write_wall($a, $this->profile_owner);
+ $this->profile_owner = $a->profile['uid'];
+ $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;
}
/**
* Add a thread to the conversation
*
- * @param object $item The item to insert
+ * @param Post $item The item to insert
*
* @return mixed The inserted item on success
* false on failure
+ * @throws \Exception
*/
- 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);
+ if ($item->getDataValue('verb') === Activity::LIKE || $item->getDataValue('verb') === Activity::DISLIKE) {
+ Logger::log('[WARN] Conversation::addThread : Thread is a (dis)like ('. $item->getId() .').', Logger::DEBUG);
return false;
}
*
* We should find a way to avoid using those arguments (at least most of them)
*
- * @param object $conv_responses data
+ * @param array $conv_responses data
*
* @return mixed The data requested on success
* false on failure
+ * @throws \Exception
*/
public function getTemplateData($conv_responses)
{
- $a = self::getApp();
- $result = array();
- $i = 0;
+ $result = [];
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;