nextcloud-news/lib/Service/FolderServiceV2.php

182 lines
4.7 KiB
PHP

<?php
/**
* Nextcloud - News
*
* This file is licensed under the Affero General Public License version 3 or
* later. See the COPYING file.
*
* @author Alessandro Cosentino <cosenal@gmail.com>
* @author Bernhard Posselt <dev@bernhard-posselt.com>
* @copyright 2012 Alessandro Cosentino
* @copyright 2012-2014 Bernhard Posselt
*/
namespace OCA\News\Service;
use OC\AppFramework\Utility\TimeFactory;
use OCA\News\Db\Folder;
use OCA\News\Db\FolderMapperV2;
use OCA\News\Service\Exceptions\ServiceConflictException;
use OCA\News\Service\Exceptions\ServiceNotFoundException;
use OCP\AppFramework\Db\DoesNotExistException;
use OCP\AppFramework\Db\Entity;
use OCP\AppFramework\Db\MultipleObjectsReturnedException;
use Psr\Log\LoggerInterface;
/**
* Class FolderService
*
* @package OCA\News\Service
*/
class FolderServiceV2 extends Service
{
/**
* @var FeedServiceV2
*/
private $feedService;
/**
* @var FeedServiceV2
*/
private $timeFactory;
public function __construct(
FolderMapperV2 $mapper,
FeedServiceV2 $feedService,
TimeFactory $timeFactory,
LoggerInterface $logger
) {
parent::__construct($mapper, $logger);
$this->feedService = $feedService;
$this->timeFactory = $timeFactory;
}
/**
* Finds all folders of a user
*
* @param string $userId The name/ID of the user
* @param array $params Filter parameters
*
* @return Folder[]
*/
public function findAllForUser(string $userId, array $params = []): array
{
return $this->mapper->findAllFromUser($userId, $params);
}
/**
* Find all folders and it's feeds.
*
* @param string $userId The name/ID of the owner
*
* @return Folder[]
*/
public function findAllForUserRecursive(string $userId): array
{
$folders = $this->findAllForUser($userId);
foreach ($folders as $folder) {
$feeds = $this->feedService->findAllFromFolder($folder->getId());
$folder->feeds = $feeds;
}
return $folders;
}
/**
* Find all folders.
*
* @return Folder[]
*/
public function findAll(): array
{
return $this->mapper->findAll();
}
/**
* Create a folder
*
* @param string $userId
* @param string $name
* @param int|null $parent
*
* @return Folder
*/
public function create(string $userId, string $name, ?int $parent = null): Entity
{
$folder = new Folder();
$folder->setUserId($userId)
->setName($name)
->setParentId($parent)
->setOpened(true);
return $this->mapper->insert($folder);
}
/**
* Purge all deleted folders.
*
* @param string|null $userID The user to purge
* @param int|null $minTimestamp The timestamp to purge from
*/
public function purgeDeleted(?string $userID, ?int $minTimestamp)
{
$this->mapper->purgeDeleted($userID, $minTimestamp);
}
/**
* Rename a folder
*
* @param string $userId Folder owner
* @param int $folderId Folder ID
* @param string $newName New name
*
* @return Folder
* @throws ServiceConflictException
* @throws ServiceNotFoundException
*/
public function rename(string $userId, int $folderId, string $newName): Entity
{
$folder = $this->find($userId, $folderId);
$folder->setName($newName);
return $this->mapper->update($folder);
}
/**
* Mark a folder as deleted
*
* @param string $userId Folder owner
* @param int $folderId Folder ID
* @param bool $mark If the mark should be added or removed
*
* @return Folder
* @throws ServiceConflictException
* @throws ServiceNotFoundException
*/
public function markDelete(string $userId, int $folderId, bool $mark): Entity
{
$folder = $this->find($userId, $folderId);
$time = $mark ? $this->timeFactory->getTime() : 0;
$folder->setDeletedAt($time);
return $this->mapper->update($folder);
}
/**
* Mark a folder as opened
*
* @param string $userId Folder owner
* @param int|null $folderId Folder ID
* @param bool $open If the mark should be added or removed
*
* @return Folder
* @throws ServiceConflictException
* @throws ServiceNotFoundException
*/
public function open(string $userId, ?int $folderId, bool $open): Entity
{
$folder = $this->find($userId, $folderId);
$folder->setOpened($open);
return $this->mapper->update($folder);
}
}