Welcome to mirror list, hosted at ThFree Co, Russian Federation.

github.com/nextcloud/spreed.git - Unnamed repository; edit this file 'description' to name the repository.
summaryrefslogtreecommitdiff
diff options
context:
space:
mode:
authorJoas Schilling <coding@schilljs.com>2022-03-31 10:28:08 +0300
committerJoas Schilling <coding@schilljs.com>2022-03-31 16:05:34 +0300
commit5278e716c7e45c0751257cc0b14db1fbe344f40b (patch)
tree9f053333edd813f67d5aa7ce9b29abe44fd737b1 /lib/Service
parent1fa1bb56cd566719df1f35343f3877cdf3670bee (diff)
Add the entity and a service to handle attachments
Signed-off-by: Joas Schilling <coding@schilljs.com>
Diffstat (limited to 'lib/Service')
-rw-r--r--lib/Service/AttachmentService.php62
1 files changed, 62 insertions, 0 deletions
diff --git a/lib/Service/AttachmentService.php b/lib/Service/AttachmentService.php
new file mode 100644
index 000000000..f26a22967
--- /dev/null
+++ b/lib/Service/AttachmentService.php
@@ -0,0 +1,62 @@
+<?php
+
+namespace OCA\Talk\Service;
+
+use OCA\Talk\Model\Attachment;
+use OCA\Talk\Model\AttachmentMapper;
+use OCA\Talk\Room;
+use OCP\Comments\IComment;
+
+class AttachmentService {
+ public AttachmentMapper $attachmentMapper;
+
+ public function __construct(AttachmentMapper $attachmentMapper) {
+ $this->attachmentMapper = $attachmentMapper;
+ }
+
+ public function createAttachmentEntry(Room $room, IComment $comment, string $messageType, array $parameters): void {
+ $attachment = new Attachment();
+ $attachment->setRoomId($room->getId());
+ $attachment->setActorType($comment->getActorType());
+ $attachment->setActorId($comment->getActorId());
+ $attachment->setMessageId((int) $comment->getId());
+ $attachment->setMessageTime($comment->getCreationDateTime()->getTimestamp());
+
+ if ($messageType === 'object_shared') {
+ $objectType = $parameters['objectType'] ?? '';
+ if ($objectType === 'geo-location') {
+ $attachment->setObjectType(Attachment::TYPE_LOCATION);
+ } elseif ($objectType === 'deck-card') {
+ $attachment->setObjectType(Attachment::TYPE_DECK_CARD);
+ } else {
+ $attachment->setObjectType(Attachment::TYPE_OTHER);
+ }
+ } else {
+ $messageType = $parameters['metaData']['messageType'] ?? '';
+ $mimetype = $parameters['metaData']['mimeType'] ?? '';
+
+ if ($messageType === 'voice-message') {
+ $attachment->setObjectType(Attachment::TYPE_VOICE);
+ } elseif (str_starts_with($mimetype, 'audio/')) {
+ $attachment->setObjectType(Attachment::TYPE_AUDIO);
+ } elseif (str_starts_with($mimetype, 'image/') || str_starts_with($mimetype, 'video/')) {
+ $attachment->setObjectType(Attachment::TYPE_MEDIA);
+ } else {
+ $attachment->setObjectType(Attachment::TYPE_FILE);
+ }
+ }
+
+ $this->attachmentMapper->insert($attachment);
+ }
+
+ /**
+ * @param Room $room
+ * @param string $objectType
+ * @param int $offset
+ * @param int $limit
+ * @return Attachment[]
+ */
+ public function getAttachmentsByType(Room $room, string $objectType, int $offset, int $limit): array {
+ return $this->attachmentMapper->getAttachmentsByType($room->getId(), $objectType, $offset, $limit);
+ }
+}