123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132 |
- <?php
- namespace OCA\Comments\Search;
- use OCP\Comments\IComment;
- use OCP\Files\NotFoundException;
- use OCP\Search\Result as BaseResult;
- class Result extends BaseResult {
-
- public $type = 'comment';
-
- public $comment;
-
- public $authorId;
-
- public $authorName;
-
- public $path;
-
- public $fileName;
-
- public function __construct(string $search,
- IComment $comment,
- string $authorName,
- string $path) {
- parent::__construct(
- (int) $comment->getId(),
- $comment->getMessage()
-
- );
- $this->comment = $this->getRelevantMessagePart($comment->getMessage(), $search);
- $this->authorId = $comment->getActorId();
- $this->authorName = $authorName;
- $this->fileName = basename($path);
- $this->path = $this->getVisiblePath($path);
- }
-
- protected function getVisiblePath(string $path): string {
- $segments = explode('/', trim($path, '/'), 3);
- if (!isset($segments[2])) {
- throw new NotFoundException('Path not inside visible section');
- }
- return $segments[2];
- }
-
- protected function getRelevantMessagePart(string $message, string $search): string {
- $start = mb_stripos($message, $search);
- if ($start === false) {
- throw new NotFoundException('Comment section not found');
- }
- $end = $start + mb_strlen($search);
- if ($start <= 25) {
- $start = 0;
- $prefix = '';
- } else {
- $start -= 25;
- $prefix = '…';
- }
- if ((mb_strlen($message) - $end) <= 25) {
- $end = mb_strlen($message);
- $suffix = '';
- } else {
- $end += 25;
- $suffix = '…';
- }
- return $prefix . mb_substr($message, $start, $end - $start) . $suffix;
- }
- }
|