summary refs log tree commit diff
path: root/src/EventAccessors.cpp
diff options
context:
space:
mode:
authorDeepBlueV7.X <nicolas.werner@hotmail.de>2022-03-21 06:11:46 +0100
committerGitHub <noreply@github.com>2022-03-21 06:11:46 +0100
commit15ff5dace504be49663b22cf69b03b33a9aee536 (patch)
treec7986603eae03241ded022e04e646461c3b0c69e /src/EventAccessors.cpp
parentTranslated using Weblate (Indonesian) (diff)
parentFix thumbnails for encrypted files and factor upload box out (diff)
downloadnheko-15ff5dace504be49663b22cf69b03b33a9aee536.tar.xz
Merge pull request #1008 from Nheko-Reborn/new-upload
New upload flow
Diffstat (limited to 'src/EventAccessors.cpp')
-rw-r--r--src/EventAccessors.cpp40
1 files changed, 40 insertions, 0 deletions
diff --git a/src/EventAccessors.cpp b/src/EventAccessors.cpp

index 935ff73a..e4dfe92e 100644 --- a/src/EventAccessors.cpp +++ b/src/EventAccessors.cpp
@@ -139,6 +139,19 @@ struct EventFile } }; +struct EventThumbnailFile +{ + template<class Content> + using file_t = decltype(Content::info.thumbnail_file); + template<class T> + std::optional<mtx::crypto::EncryptedFile> operator()(const mtx::events::Event<T> &e) + { + if constexpr (is_detected<file_t, T>::value) + return e.content.info.thumbnail_file; + return std::nullopt; + } +}; + struct EventUrl { template<class Content> @@ -163,12 +176,28 @@ struct EventThumbnailUrl std::string operator()(const mtx::events::Event<T> &e) { if constexpr (is_detected<thumbnail_url_t, T>::value) { + if (auto file = EventThumbnailFile{}(e)) + return file->url; return e.content.info.thumbnail_url; } return ""; } }; +struct EventDuration +{ + template<class Content> + using thumbnail_url_t = decltype(Content::info.duration); + template<class T> + uint64_t operator()(const mtx::events::Event<T> &e) + { + if constexpr (is_detected<thumbnail_url_t, T>::value) { + return e.content.info.duration; + } + return 0; + } +}; + struct EventBlurhash { template<class Content> @@ -410,6 +439,12 @@ mtx::accessors::file(const mtx::events::collections::TimelineEvents &event) return std::visit(EventFile{}, event); } +std::optional<mtx::crypto::EncryptedFile> +mtx::accessors::thumbnail_file(const mtx::events::collections::TimelineEvents &event) +{ + return std::visit(EventThumbnailFile{}, event); +} + std::string mtx::accessors::url(const mtx::events::collections::TimelineEvents &event) { @@ -420,6 +455,11 @@ mtx::accessors::thumbnail_url(const mtx::events::collections::TimelineEvents &ev { return std::visit(EventThumbnailUrl{}, event); } +uint64_t +mtx::accessors::duration(const mtx::events::collections::TimelineEvents &event) +{ + return std::visit(EventDuration{}, event); +} std::string mtx::accessors::blurhash(const mtx::events::collections::TimelineEvents &event) {