owncloud/core

View on GitHub
apps/comments/lib/Dav/EntityCollection.php

Summary

Maintainability
A
50 mins
Test Coverage
<?php
/**
 * @author Arthur Schiwon <blizzz@arthur-schiwon.de>
 * @author Joas Schilling <coding@schilljs.com>
 * @author Vincent Petry <pvince81@owncloud.com>
 *
 * @copyright Copyright (c) 2018, ownCloud GmbH
 * @license AGPL-3.0
 *
 * This code is free software: you can redistribute it and/or modify
 * it under the terms of the GNU Affero General Public License, version 3,
 * as published by the Free Software Foundation.
 *
 * 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, version 3,
 * along with this program.  If not, see <http://www.gnu.org/licenses/>
 *
 */

namespace OCA\Comments\Dav;

use OCP\Comments\ICommentsManager;
use OCP\Comments\NotFoundException;
use OCP\ILogger;
use OCP\IUserManager;
use OCP\IUserSession;
use Sabre\DAV\Exception\NotFound;
use Sabre\DAV\IProperties;
use Sabre\DAV\PropPatch;
use Symfony\Component\EventDispatcher\EventDispatcherInterface;

/**
 * Class EntityCollection
 *
 * this represents a specific holder of comments, identified by an entity type
 * (class member $name) and an entity id (class member $id).
 *
 * @package OCA\Comments\Dav
 */
class EntityCollection extends RootCollection implements IProperties {
    public const PROPERTY_NAME_READ_MARKER  = '{http://owncloud.org/ns}readMarker';

    /** @var  string */
    protected $id;

    /**
     * @param string $id
     * @param string $name
     * @param ICommentsManager $commentsManager
     * @param IUserManager $userManager
     * @param IUserSession $userSession
     * @param EventDispatcherInterface $dispatcher
     * @param ILogger $logger
     */
    public function __construct(
        $id,
        $name,
        ICommentsManager $commentsManager,
        IUserManager $userManager,
        IUserSession $userSession,
        EventDispatcherInterface $dispatcher,
        ILogger $logger
    ) {
        parent::__construct($commentsManager, $userManager, $userSession, $dispatcher, $logger);
        foreach (['id', 'name'] as $property) {
            $$property = \trim($$property);
            if (empty($$property) || !\is_string($$property)) {
                throw new \InvalidArgumentException('"' . $property . '" parameter must be non-empty string');
            }
        }
        $this->id = $id;
        $this->name = $name;
    }

    /**
     * returns the ID of this entity
     *
     * @return string
     */
    public function getId() {
        return $this->id;
    }

    /**
     * Returns a specific child node, referenced by its name
     *
     * This method must throw Sabre\DAV\Exception\NotFound if the node does not
     * exist.
     *
     * @param string $name
     * @return \Sabre\DAV\INode
     * @throws NotFound
     */
    public function getChild($name) {
        try {
            $comment = $this->commentsManager->get($name);
            return new CommentNode(
                $this->commentsManager,
                $comment,
                $this->userManager,
                $this->userSession,
                $this->logger
            );
        } catch (NotFoundException $e) {
            throw new NotFound();
        }
    }

    /**
     * Returns an array with all the child nodes
     *
     * @return \Sabre\DAV\INode[]
     */
    public function getChildren() {
        return $this->findChildren();
    }

    /**
     * Returns an array of comment nodes. Result can be influenced by offset,
     * limit and date time parameters.
     *
     * @param int $limit
     * @param int $offset
     * @param \DateTime|null $datetime
     * @return CommentNode[]
     */
    public function findChildren($limit = 0, $offset = 0, \DateTime $datetime = null) {
        $comments = $this->commentsManager->getForObject($this->name, $this->id, $limit, $offset, $datetime);
        $result = [];
        foreach ($comments as $comment) {
            $result[] = new CommentNode(
                $this->commentsManager,
                $comment,
                $this->userManager,
                $this->userSession,
                $this->logger
            );
        }
        return $result;
    }

    /**
     * Checks if a child-node with the specified name exists
     *
     * @param string $name
     * @return bool
     */
    public function childExists($name) {
        try {
            $this->commentsManager->get($name);
            return true;
        } catch (NotFoundException $e) {
            return false;
        }
    }

    /**
     * Sets the read marker to the specified date for the logged in user
     *
     * @param \DateTime $value
     * @return bool
     */
    public function setReadMarker($value) {
        $dateTime = new \DateTime($value);
        $user = $this->userSession->getUser();
        $this->commentsManager->setReadMark($this->name, $this->id, $dateTime, $user);
        return true;
    }

    /**
     * @inheritdoc
     */
    public function propPatch(PropPatch $propPatch) {
        $propPatch->handle(self::PROPERTY_NAME_READ_MARKER, [$this, 'setReadMarker']);
    }

    /**
     * @inheritdoc
     */
    public function getProperties($properties) {
        $marker = null;
        $user = $this->userSession->getUser();
        if ($user !== null) {
            $marker = $this->commentsManager->getReadMark($this->name, $this->id, $user);
        }
        return [self::PROPERTY_NAME_READ_MARKER => $marker];
    }
}