2012-08-10 15:46:39 +00:00
|
|
|
<?php
|
2017-11-16 18:05:41 +00:00
|
|
|
/**
|
2022-01-02 07:27:47 +00:00
|
|
|
* @copyright Copyright (C) 2010-2022, the Friendica project
|
2020-02-09 15:18:46 +00:00
|
|
|
*
|
|
|
|
* @license GNU AGPL version 3 or any later version
|
|
|
|
*
|
|
|
|
* This program is free software: you can redistribute it and/or modify
|
|
|
|
* it under the terms of the GNU Affero General Public License as
|
|
|
|
* published by the Free Software Foundation, either version 3 of the
|
|
|
|
* License, or (at your option) any later version.
|
|
|
|
*
|
|
|
|
* This program is distributed in the hope that it will be useful,
|
|
|
|
* but WITHOUT ANY WARRANTY; without even the implied warranty of
|
|
|
|
* MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
|
|
|
|
* GNU Affero General Public License for more details.
|
|
|
|
*
|
|
|
|
* You should have received a copy of the GNU Affero General Public License
|
|
|
|
* along with this program. If not, see <https://www.gnu.org/licenses/>.
|
|
|
|
*
|
2017-11-16 18:05:41 +00:00
|
|
|
*/
|
2020-02-09 15:18:46 +00:00
|
|
|
|
2017-11-19 21:50:49 +00:00
|
|
|
namespace Friendica\Object;
|
2017-11-16 18:24:59 +00:00
|
|
|
|
2018-10-29 21:20:46 +00:00
|
|
|
use Friendica\Core\Logger;
|
2018-08-11 20:40:44 +00:00
|
|
|
use Friendica\Core\Protocol;
|
2019-12-15 21:34:11 +00:00
|
|
|
use Friendica\DI;
|
2019-10-23 22:25:43 +00:00
|
|
|
use Friendica\Protocol\Activity;
|
2020-09-30 09:14:01 +00:00
|
|
|
use Friendica\Security\Security;
|
2012-08-10 15:46:39 +00:00
|
|
|
|
|
|
|
/**
|
|
|
|
* A list of threads
|
|
|
|
*
|
|
|
|
* We should think about making this a SPL Iterator
|
|
|
|
*/
|
2019-12-15 22:28:01 +00:00
|
|
|
class Thread
|
2017-11-16 18:24:59 +00:00
|
|
|
{
|
2020-02-23 01:41:12 +00:00
|
|
|
/** @var Post[] */
|
2018-01-15 13:05:12 +00:00
|
|
|
private $parents = [];
|
2012-08-10 17:57:39 +00:00
|
|
|
private $mode = null;
|
2012-08-17 14:40:41 +00:00
|
|
|
private $writable = false;
|
2012-08-11 16:12:35 +00:00
|
|
|
private $profile_owner = 0;
|
2012-09-10 07:50:30 +00:00
|
|
|
private $preview = false;
|
2012-08-10 17:57:39 +00:00
|
|
|
|
2017-11-19 19:15:25 +00:00
|
|
|
/**
|
|
|
|
* Constructor
|
|
|
|
*
|
2019-01-06 21:06:53 +00:00
|
|
|
* @param string $mode The mode
|
|
|
|
* @param boolean $preview Are we in the preview mode?
|
2017-12-20 10:34:42 +00:00
|
|
|
* @param boolean $writable Override the writable check
|
2019-01-06 21:06:53 +00:00
|
|
|
* @throws \Exception
|
2017-11-19 19:15:25 +00:00
|
|
|
*/
|
2017-12-19 17:15:56 +00:00
|
|
|
public function __construct($mode, $preview, $writable = false)
|
2017-11-16 18:24:59 +00:00
|
|
|
{
|
2017-12-19 17:15:56 +00:00
|
|
|
$this->setMode($mode, $writable);
|
2012-09-10 07:50:30 +00:00
|
|
|
$this->preview = $preview;
|
2012-08-11 16:12:35 +00:00
|
|
|
}
|
|
|
|
|
|
|
|
/**
|
|
|
|
* Set the mode we'll be displayed on
|
2017-11-19 19:15:25 +00:00
|
|
|
*
|
2019-01-06 21:06:53 +00:00
|
|
|
* @param string $mode The mode to set
|
2017-12-20 10:34:42 +00:00
|
|
|
* @param boolean $writable Override the writable check
|
2017-11-19 19:15:25 +00:00
|
|
|
*
|
|
|
|
* @return void
|
2019-01-06 21:06:53 +00:00
|
|
|
* @throws \Exception
|
2012-08-11 16:12:35 +00:00
|
|
|
*/
|
2017-12-19 17:15:56 +00:00
|
|
|
private function setMode($mode, $writable)
|
2017-11-16 18:24:59 +00:00
|
|
|
{
|
2017-11-19 19:15:25 +00:00
|
|
|
if ($this->getMode() == $mode) {
|
2012-08-11 16:12:35 +00:00
|
|
|
return;
|
2017-11-16 18:24:59 +00:00
|
|
|
}
|
2012-08-11 16:12:35 +00:00
|
|
|
|
2019-12-15 21:34:11 +00:00
|
|
|
$a = DI::app();
|
2012-08-11 16:12:35 +00:00
|
|
|
|
2017-11-16 18:24:59 +00:00
|
|
|
switch ($mode) {
|
2012-08-11 16:12:35 +00:00
|
|
|
case 'network':
|
|
|
|
case 'notes':
|
|
|
|
$this->profile_owner = local_user();
|
2012-08-17 14:40:41 +00:00
|
|
|
$this->writable = true;
|
2012-08-11 16:12:35 +00:00
|
|
|
break;
|
|
|
|
case 'profile':
|
2021-07-24 20:34:07 +00:00
|
|
|
$this->profile_owner = $a->getProfileOwner();
|
2021-09-19 10:53:19 +00:00
|
|
|
$this->writable = Security::canWriteToUserWall($this->profile_owner) || $writable;
|
2012-08-11 16:12:35 +00:00
|
|
|
break;
|
|
|
|
case 'display':
|
2021-07-24 20:34:07 +00:00
|
|
|
$this->profile_owner = $a->getProfileOwner();
|
2018-10-17 19:30:41 +00:00
|
|
|
$this->writable = Security::canWriteToUserWall($this->profile_owner) || $writable;
|
2012-08-11 16:12:35 +00:00
|
|
|
break;
|
2017-12-23 07:33:51 +00:00
|
|
|
case 'community':
|
2018-01-07 17:14:43 +00:00
|
|
|
$this->profile_owner = 0;
|
2017-12-23 07:33:51 +00:00
|
|
|
$this->writable = $writable;
|
|
|
|
break;
|
2018-08-25 13:48:00 +00:00
|
|
|
case 'contacts':
|
|
|
|
$this->profile_owner = 0;
|
|
|
|
$this->writable = $writable;
|
|
|
|
break;
|
2012-08-11 16:12:35 +00:00
|
|
|
default:
|
2021-11-03 23:19:24 +00:00
|
|
|
Logger::info('[ERROR] Conversation::setMode : Unhandled mode ('. $mode .').');
|
2012-08-11 16:12:35 +00:00
|
|
|
return false;
|
|
|
|
break;
|
|
|
|
}
|
2012-08-12 13:39:21 +00:00
|
|
|
$this->mode = $mode;
|
2012-08-11 16:12:35 +00:00
|
|
|
}
|
|
|
|
|
|
|
|
/**
|
|
|
|
* Get mode
|
2017-11-19 19:15:25 +00:00
|
|
|
*
|
|
|
|
* @return string
|
2012-08-11 16:12:35 +00:00
|
|
|
*/
|
2017-11-19 19:15:25 +00:00
|
|
|
public function getMode()
|
2017-11-16 18:24:59 +00:00
|
|
|
{
|
2012-08-11 16:12:35 +00:00
|
|
|
return $this->mode;
|
|
|
|
}
|
|
|
|
|
|
|
|
/**
|
2012-08-17 14:40:41 +00:00
|
|
|
* Check if page is writable
|
2017-11-19 19:15:25 +00:00
|
|
|
*
|
|
|
|
* @return boolean
|
2012-08-11 16:12:35 +00:00
|
|
|
*/
|
2017-11-19 19:15:25 +00:00
|
|
|
public function isWritable()
|
2017-11-16 18:24:59 +00:00
|
|
|
{
|
2012-08-17 14:40:41 +00:00
|
|
|
return $this->writable;
|
2012-08-11 16:12:35 +00:00
|
|
|
}
|
|
|
|
|
2012-09-10 07:50:30 +00:00
|
|
|
/**
|
|
|
|
* Check if page is a preview
|
2017-11-19 19:15:25 +00:00
|
|
|
*
|
|
|
|
* @return boolean
|
2012-09-10 07:50:30 +00:00
|
|
|
*/
|
2017-11-19 19:15:25 +00:00
|
|
|
public function isPreview()
|
2017-11-16 18:24:59 +00:00
|
|
|
{
|
2012-09-10 07:50:30 +00:00
|
|
|
return $this->preview;
|
|
|
|
}
|
|
|
|
|
2012-08-11 16:12:35 +00:00
|
|
|
/**
|
|
|
|
* Get profile owner
|
2017-11-19 19:15:25 +00:00
|
|
|
*
|
|
|
|
* @return integer
|
2012-08-11 16:12:35 +00:00
|
|
|
*/
|
2017-11-19 19:15:25 +00:00
|
|
|
public function getProfileOwner()
|
2017-11-16 18:24:59 +00:00
|
|
|
{
|
2012-08-11 16:12:35 +00:00
|
|
|
return $this->profile_owner;
|
2012-08-10 17:57:39 +00:00
|
|
|
}
|
2012-08-10 15:46:39 +00:00
|
|
|
|
|
|
|
/**
|
|
|
|
* Add a thread to the conversation
|
|
|
|
*
|
2019-01-06 21:06:53 +00:00
|
|
|
* @param Post $item The item to insert
|
2017-11-19 19:15:25 +00:00
|
|
|
*
|
|
|
|
* @return mixed The inserted item on success
|
|
|
|
* false on failure
|
2019-01-06 21:06:53 +00:00
|
|
|
* @throws \Exception
|
2012-08-10 15:46:39 +00:00
|
|
|
*/
|
2017-12-08 04:33:36 +00:00
|
|
|
public function addParent(Post $item)
|
2017-11-16 18:24:59 +00:00
|
|
|
{
|
2017-11-16 20:54:03 +00:00
|
|
|
$item_id = $item->getId();
|
2017-11-16 18:24:59 +00:00
|
|
|
|
|
|
|
if (!$item_id) {
|
2021-11-03 23:19:24 +00:00
|
|
|
Logger::info('[ERROR] Conversation::addThread : Item has no ID!!');
|
2012-08-10 15:46:39 +00:00
|
|
|
return false;
|
|
|
|
}
|
2017-11-16 18:24:59 +00:00
|
|
|
|
2017-12-07 14:05:23 +00:00
|
|
|
if ($this->getParent($item->getId())) {
|
2021-11-03 23:19:24 +00:00
|
|
|
Logger::info('[WARN] Conversation::addThread : Thread already exists ('. $item->getId() .').');
|
2012-08-10 15:46:39 +00:00
|
|
|
return false;
|
|
|
|
}
|
2012-08-12 15:46:02 +00:00
|
|
|
|
|
|
|
/*
|
|
|
|
* Only add will be displayed
|
|
|
|
*/
|
2018-08-11 20:40:44 +00:00
|
|
|
if ($item->getDataValue('network') === Protocol::MAIL && local_user() != $item->getDataValue('uid')) {
|
2021-11-03 23:19:24 +00:00
|
|
|
Logger::info('[WARN] Conversation::addThread : Thread is a mail ('. $item->getId() .').');
|
2012-08-12 15:46:02 +00:00
|
|
|
return false;
|
|
|
|
}
|
2017-11-16 18:24:59 +00:00
|
|
|
|
2019-10-23 22:25:43 +00:00
|
|
|
if ($item->getDataValue('verb') === Activity::LIKE || $item->getDataValue('verb') === Activity::DISLIKE) {
|
2021-11-03 23:19:24 +00:00
|
|
|
Logger::info('[WARN] Conversation::addThread : Thread is a (dis)like ('. $item->getId() .').');
|
2012-08-12 15:46:02 +00:00
|
|
|
return false;
|
|
|
|
}
|
2017-11-16 18:24:59 +00:00
|
|
|
|
2017-12-07 14:05:23 +00:00
|
|
|
$item->setThread($this);
|
|
|
|
$this->parents[] = $item;
|
2017-11-16 18:24:59 +00:00
|
|
|
|
2017-12-07 14:05:23 +00:00
|
|
|
return end($this->parents);
|
2012-08-10 15:46:39 +00:00
|
|
|
}
|
|
|
|
|
|
|
|
/**
|
|
|
|
* Get data in a form usable by a conversation template
|
|
|
|
*
|
|
|
|
* We should find a way to avoid using those arguments (at least most of them)
|
|
|
|
*
|
2019-01-21 16:36:01 +00:00
|
|
|
* @param array $conv_responses data
|
2021-09-12 19:20:12 +00:00
|
|
|
* @param string $formSecurityToken A security Token to avoid CSF attacks
|
2017-11-19 19:15:25 +00:00
|
|
|
*
|
|
|
|
* @return mixed The data requested on success
|
|
|
|
* false on failure
|
2019-01-06 21:06:53 +00:00
|
|
|
* @throws \Exception
|
2012-08-10 15:46:39 +00:00
|
|
|
*/
|
2021-09-12 19:20:12 +00:00
|
|
|
public function getTemplateData($conv_responses, string $formSecurityToken)
|
2017-11-16 18:24:59 +00:00
|
|
|
{
|
2018-01-15 13:05:12 +00:00
|
|
|
$result = [];
|
2013-09-15 08:40:58 +00:00
|
|
|
|
2017-12-07 14:05:23 +00:00
|
|
|
foreach ($this->parents as $item) {
|
2018-08-11 20:40:44 +00:00
|
|
|
if ($item->getDataValue('network') === Protocol::MAIL && local_user() != $item->getDataValue('uid')) {
|
2012-08-10 17:57:39 +00:00
|
|
|
continue;
|
2017-11-16 20:54:03 +00:00
|
|
|
}
|
2013-09-15 08:40:58 +00:00
|
|
|
|
2021-09-12 19:20:12 +00:00
|
|
|
$item_data = $item->getTemplateData($conv_responses, $formSecurityToken);
|
2013-09-15 08:40:58 +00:00
|
|
|
|
2017-11-16 18:24:59 +00:00
|
|
|
if (!$item_data) {
|
2021-11-03 23:19:24 +00:00
|
|
|
Logger::info('[ERROR] Conversation::getTemplateData : Failed to get item template data ('. $item->getId() .').');
|
2012-08-10 15:46:39 +00:00
|
|
|
return false;
|
|
|
|
}
|
|
|
|
$result[] = $item_data;
|
|
|
|
}
|
|
|
|
|
|
|
|
return $result;
|
|
|
|
}
|
|
|
|
|
|
|
|
/**
|
|
|
|
* Get a thread based on its item id
|
|
|
|
*
|
2017-11-19 19:15:25 +00:00
|
|
|
* @param integer $id Item id
|
|
|
|
*
|
|
|
|
* @return mixed The found item on success
|
|
|
|
* false on failure
|
2012-08-10 15:46:39 +00:00
|
|
|
*/
|
2017-12-07 14:05:23 +00:00
|
|
|
private function getParent($id)
|
2017-11-16 18:24:59 +00:00
|
|
|
{
|
2017-12-07 14:05:23 +00:00
|
|
|
foreach ($this->parents as $item) {
|
2017-11-16 20:54:03 +00:00
|
|
|
if ($item->getId() == $id) {
|
2012-08-10 17:57:39 +00:00
|
|
|
return $item;
|
2017-11-16 18:24:59 +00:00
|
|
|
}
|
2012-08-10 15:46:39 +00:00
|
|
|
}
|
|
|
|
|
2012-08-10 17:57:39 +00:00
|
|
|
return false;
|
2012-08-10 15:46:39 +00:00
|
|
|
}
|
|
|
|
}
|