2021-06-26 17:23:15 +02:00
|
|
|
<?php
|
|
|
|
|
2023-05-17 18:56:55 +02:00
|
|
|
namespace BookStack\Activity;
|
2017-01-13 17:15:48 +01:00
|
|
|
|
2023-05-17 18:56:55 +02:00
|
|
|
use BookStack\Activity\Models\Comment;
|
2020-11-22 01:17:45 +01:00
|
|
|
use BookStack\Entities\Models\Entity;
|
2020-11-08 00:15:13 +01:00
|
|
|
use BookStack\Facades\Activity as ActivityService;
|
2024-01-30 16:16:58 +01:00
|
|
|
use BookStack\Util\HtmlDescriptionFilter;
|
2017-01-13 17:15:48 +01:00
|
|
|
|
2018-01-28 17:58:52 +01:00
|
|
|
class CommentRepo
|
|
|
|
{
|
2017-09-03 17:37:51 +02:00
|
|
|
/**
|
|
|
|
* Get a comment by ID.
|
|
|
|
*/
|
2020-05-02 00:24:11 +02:00
|
|
|
public function getById(int $id): Comment
|
2017-09-03 17:37:51 +02:00
|
|
|
{
|
2023-06-07 14:24:49 +02:00
|
|
|
return Comment::query()->findOrFail($id);
|
2017-04-18 21:51:45 +02:00
|
|
|
}
|
|
|
|
|
2017-09-03 17:37:51 +02:00
|
|
|
/**
|
|
|
|
* Create a new comment on an entity.
|
|
|
|
*/
|
2024-01-30 16:16:58 +01:00
|
|
|
public function create(Entity $entity, string $html, ?int $parent_id): Comment
|
2017-09-03 17:37:51 +02:00
|
|
|
{
|
2017-04-18 21:51:45 +02:00
|
|
|
$userId = user()->id;
|
2023-06-07 14:24:49 +02:00
|
|
|
$comment = new Comment();
|
2020-05-02 00:24:11 +02:00
|
|
|
|
2024-01-30 16:16:58 +01:00
|
|
|
$comment->html = HtmlDescriptionFilter::filterFromString($html);
|
2017-09-03 17:37:51 +02:00
|
|
|
$comment->created_by = $userId;
|
2017-04-18 21:51:45 +02:00
|
|
|
$comment->updated_by = $userId;
|
2017-09-03 17:37:51 +02:00
|
|
|
$comment->local_id = $this->getNextLocalId($entity);
|
2020-05-02 00:24:11 +02:00
|
|
|
$comment->parent_id = $parent_id;
|
|
|
|
|
2017-09-03 17:37:51 +02:00
|
|
|
$entity->comments()->save($comment);
|
2023-07-18 16:07:31 +02:00
|
|
|
ActivityService::add(ActivityType::COMMENT_CREATE, $comment);
|
2021-12-11 18:29:33 +01:00
|
|
|
ActivityService::add(ActivityType::COMMENTED_ON, $entity);
|
2021-06-26 17:23:15 +02:00
|
|
|
|
2017-06-04 15:22:44 +02:00
|
|
|
return $comment;
|
|
|
|
}
|
|
|
|
|
2017-09-03 17:37:51 +02:00
|
|
|
/**
|
|
|
|
* Update an existing comment.
|
|
|
|
*/
|
2024-01-30 16:16:58 +01:00
|
|
|
public function update(Comment $comment, string $html): Comment
|
2017-09-03 17:37:51 +02:00
|
|
|
{
|
|
|
|
$comment->updated_by = user()->id;
|
2024-01-30 16:16:58 +01:00
|
|
|
$comment->html = HtmlDescriptionFilter::filterFromString($html);
|
2020-05-02 00:24:11 +02:00
|
|
|
$comment->save();
|
2021-06-26 17:23:15 +02:00
|
|
|
|
2023-07-18 16:07:31 +02:00
|
|
|
ActivityService::add(ActivityType::COMMENT_UPDATE, $comment);
|
|
|
|
|
2017-04-18 21:51:45 +02:00
|
|
|
return $comment;
|
|
|
|
}
|
2017-05-15 21:10:14 +02:00
|
|
|
|
2017-09-03 17:37:51 +02:00
|
|
|
/**
|
|
|
|
* Delete a comment from the system.
|
|
|
|
*/
|
2021-11-01 12:17:30 +01:00
|
|
|
public function delete(Comment $comment): void
|
2017-09-03 17:37:51 +02:00
|
|
|
{
|
2020-05-02 00:24:11 +02:00
|
|
|
$comment->delete();
|
2023-07-18 16:07:31 +02:00
|
|
|
|
|
|
|
ActivityService::add(ActivityType::COMMENT_DELETE, $comment);
|
2020-05-02 00:24:11 +02:00
|
|
|
}
|
|
|
|
|
2017-09-03 17:37:51 +02:00
|
|
|
/**
|
|
|
|
* Get the next local ID relative to the linked entity.
|
|
|
|
*/
|
2020-05-02 00:24:11 +02:00
|
|
|
protected function getNextLocalId(Entity $entity): int
|
2017-09-03 17:37:51 +02:00
|
|
|
{
|
2023-06-07 14:24:49 +02:00
|
|
|
$currentMaxId = $entity->comments()->max('local_id');
|
2021-06-26 17:23:15 +02:00
|
|
|
|
2023-06-07 14:24:49 +02:00
|
|
|
return $currentMaxId + 1;
|
2017-04-18 21:51:45 +02:00
|
|
|
}
|
2018-01-28 17:58:52 +01:00
|
|
|
}
|