%PDF- %PDF-
| Direktori : /www/varak.net/nextcloud.varak.net/nextcloud/apps/activity/lib/ |
| Current File : //www/varak.net/nextcloud.varak.net/nextcloud/apps/activity/lib/GroupHelper.php |
<?php
/**
* SPDX-FileCopyrightText: 2016-2024 Nextcloud GmbH and Nextcloud contributors
* SPDX-FileCopyrightText: 2016 ownCloud, Inc.
* SPDX-License-Identifier: AGPL-3.0-only
*/
namespace OCA\Activity;
use OCP\Activity\Exceptions\UnknownActivityException;
use OCP\Activity\IEvent;
use OCP\Activity\IManager;
use OCP\IL10N;
use OCP\RichObjectStrings\InvalidObjectExeption;
use OCP\RichObjectStrings\IValidator;
use Psr\Log\LoggerInterface;
class GroupHelper {
/** @var IEvent[] */
protected array $event = [];
protected int $lastEvent = 0;
protected bool $allowGrouping = true;
public function __construct(
protected IL10N $l,
protected IManager $activityManager,
protected IValidator $richObjectValidator,
protected LoggerInterface $logger
) {
}
public function resetEvents(): void {
$this->event = [];
$this->lastEvent = 0;
}
public function setL10n(IL10N $l): void {
$this->l = $l;
}
/**
* Add an activity to the internal array
*/
public function addActivity(array $activity): void {
$id = (int) $activity['activity_id'];
$event = $this->arrayToEvent($activity);
$this->addEvent($id, $event);
}
/**
* Add an event to the internal array
*/
public function addEvent(int $id, IEvent $event): void {
$language = $this->l->getLanguageCode();
foreach ($this->activityManager->getProviders() as $provider) {
try {
$this->activityManager->setFormattingObject($event->getObjectType(), $event->getObjectId());
if ($this->allowGrouping && $this->lastEvent !== 0 && isset($this->event[$this->lastEvent])) {
$event = $provider->parse($language, $event, $this->event[$this->lastEvent]);
} else {
$event = $provider->parse($language, $event);
}
} catch (UnknownActivityException) {
} catch (\InvalidArgumentException) {
// todo 33.0.0 Log as warning
// todo 39.0.0 Log as error
$this->logger->debug(get_class($provider) . '::parse() threw \InvalidArgumentException which is deprecated. Throw \OCP\Activity\Exceptions\UnknownActivityException when the event is not known to your provider and otherwise handle all \InvalidArgumentException yourself.');
} catch (\Throwable $e) {
$this->logger->error('Error while parsing activity event', ['exception' => $e]);
}
}
try {
$this->richObjectValidator->validate($event->getRichSubject(), $event->getRichSubjectParameters());
} catch (InvalidObjectExeption $e) {
$this->logger->error(
$e->getMessage(),
[
'app' => 'activity',
'exception' => $e
],
);
$event->setRichSubject('Rich subject or a parameter for "' . $event->getRichSubject() . '" is malformed', []);
$event->setParsedSubject('Rich subject or a parameter for "' . $event->getRichSubject() . '" is malformed');
}
if ($event->getRichMessage()) {
try {
$this->richObjectValidator->validate($event->getRichMessage(), $event->getRichMessageParameters());
} catch (InvalidObjectExeption $e) {
$this->logger->error(
$e->getMessage(),
[
'app' => 'activity',
'exception' => $e
],
);
$event->setRichMessage('Rich message or a parameter is malformed', []);
$event->setParsedMessage('Rich message or a parameter is malformed');
}
}
$this->activityManager->setFormattingObject('', 0);
$child = $event->getChildEvent();
if ($child instanceof IEvent) {
unset($this->event[$this->lastEvent]);
}
if (!$event->getParsedSubject()) {
$this->logger->debug('Activity "' . $event->getRichSubject() . '" was not parsed by any provider');
return;
}
$this->event[$id] = $event;
$this->lastEvent = $id;
}
/**
* Get the prepared activities
*
* @return array translated activities ready for use
*/
public function getActivities(): array {
$return = [];
foreach ($this->event as $id => $event) {
$return[] = $this->eventToArray($event, $id);
}
$this->event = [];
return $return;
}
/**
* @return IEvent[]
*/
public function getEvents(): array {
$return = $this->event;
$this->event = [];
return $return;
}
protected function arrayToEvent(array $row): IEvent {
$event = $this->activityManager->generateEvent();
$event->setApp((string) $row['app'])
->setType((string) $row['type'])
->setAffectedUser((string) $row['affecteduser'])
->setAuthor((string) $row['user'])
->setTimestamp((int) $row['timestamp'])
->setSubject((string) $row['subject'], (array) json_decode($row['subjectparams'], true))
->setMessage((string) $row['message'], (array) json_decode($row['messageparams'], true))
->setObject((string) $row['object_type'], (int) $row['object_id'], (string) $row['file'])
->setLink((string) $row['link']);
return $event;
}
/**
* @param (int|string) $id
* @psalm-param array-key $id
*/
protected function eventToArray(IEvent $event, $id): array {
return [
'activity_id' => $id,
'app' => $event->getApp(),
'type' => $event->getType(),
'affecteduser' => $event->getAffectedUser(),
'user' => $event->getAuthor(),
'timestamp' => $event->getTimestamp(),
'subject' => $event->getParsedSubject(),
'subject_rich' => [
$event->getRichSubject(),
$event->getRichSubjectParameters(),
],
'message' => $event->getParsedMessage(),
'message_rich' => [
$event->getRichMessage(),
$event->getRichMessageParameters(),
],
'object_type' => $event->getObjectType(),
'object_id' => $event->getObjectId(),
'object_name' => $event->getObjectName(),
'objects' => $this->getObjectsFromChildren($event),
'link' => $event->getLink(),
'icon' => $event->getIcon(),
];
}
protected function getObjectsFromChildren(IEvent $event): array {
$child = $event->getChildEvent();
$objects = [];
if ($child instanceof IEvent) {
$objects = $this->getObjectsFromChildren($child);
}
if ($event->getObjectId() !== 0 || $event->getObjectName() !== '') {
$objects[$event->getObjectId()] = $event->getObjectName();
}
return $objects;
}
}