RichReminder.php 2.2 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475
  1. <?php
  2. declare(strict_types=1);
  3. /**
  4. * @copyright 2023 Christopher Ng <chrng8@gmail.com>
  5. *
  6. * @author Christopher Ng <chrng8@gmail.com>
  7. *
  8. * @license GNU AGPL version 3 or any later version
  9. *
  10. * This program is free software: you can redistribute it and/or modify
  11. * it under the terms of the GNU Affero General Public License as
  12. * published by the Free Software Foundation, either version 3 of the
  13. * License, or (at your option) any later version.
  14. *
  15. * This program is distributed in the hope that it will be useful,
  16. * but WITHOUT ANY WARRANTY; without even the implied warranty of
  17. * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
  18. * GNU Affero General Public License for more details.
  19. *
  20. * You should have received a copy of the GNU Affero General Public License
  21. * along with this program. If not, see <http://www.gnu.org/licenses/>.
  22. *
  23. */
  24. namespace OCA\FilesReminders\Model;
  25. use DateTimeInterface;
  26. use JsonSerializable;
  27. use OCA\FilesReminders\Db\Reminder;
  28. use OCA\FilesReminders\Exception\NodeNotFoundException;
  29. use OCP\Files\IRootFolder;
  30. use OCP\Files\Node;
  31. class RichReminder extends Reminder implements JsonSerializable {
  32. public function __construct(
  33. private Reminder $reminder,
  34. private IRootFolder $root,
  35. ) {
  36. parent::__construct();
  37. }
  38. /**
  39. * @throws NodeNotFoundException
  40. */
  41. public function getNode(): Node {
  42. $nodes = $this->root->getUserFolder($this->getUserId())->getById($this->getFileId());
  43. if (empty($nodes)) {
  44. throw new NodeNotFoundException();
  45. }
  46. $node = reset($nodes);
  47. return $node;
  48. }
  49. protected function getter(string $name): mixed {
  50. return $this->reminder->getter($name);
  51. }
  52. public function __call(string $methodName, array $args) {
  53. return $this->reminder->__call($methodName, $args);
  54. }
  55. public function jsonSerialize(): array {
  56. return [
  57. 'userId' => $this->getUserId(),
  58. 'fileId' => $this->getFileId(),
  59. 'path' => $this->getNode()->getPath(),
  60. 'dueDate' => $this->getDueDate()->format(DateTimeInterface::ATOM), // ISO 8601
  61. 'updatedAt' => $this->getUpdatedAt()->format(DateTimeInterface::ATOM), // ISO 8601
  62. 'createdAt' => $this->getCreatedAt()->format(DateTimeInterface::ATOM), // ISO 8601
  63. 'notified' => $this->getNotified(),
  64. ];
  65. }
  66. }