/* This file is part of Telegram Desktop, the official desktop application for the Telegram messaging service. For license and copyright information please follow this link: https://github.com/telegramdesktop/tdesktop/blob/master/LEGAL */ #include "storage/storage_shared_media.h" #include namespace Storage { std::map::iterator SharedMedia::enforceLists(PeerId peer) { auto result = _lists.find(peer); if (result != _lists.end()) { return result; } result = _lists.emplace(peer, Lists {}).first; for (auto index = 0; index != kSharedMediaTypeCount; ++index) { auto &list = result->second[index]; auto type = static_cast(index); list.sliceUpdated( ) | rpl::map([=](const SparseIdsSliceUpdate &update) { return SharedMediaSliceUpdate( peer, type, update); }) | rpl::start_to_stream(_sliceUpdated, _lifetime); } return result; } void SharedMedia::add(SharedMediaAddNew &&query) { auto peer = query.peerId; auto peerIt = enforceLists(peer); for (auto index = 0; index != kSharedMediaTypeCount; ++index) { auto type = static_cast(index); if (query.types.test(type)) { peerIt->second[index].addNew(query.messageId); } } } void SharedMedia::add(SharedMediaAddExisting &&query) { auto peerIt = enforceLists(query.peerId); for (auto index = 0; index != kSharedMediaTypeCount; ++index) { auto type = static_cast(index); if (query.types.test(type)) { peerIt->second[index].addExisting(query.messageId, query.noSkipRange); } } } void SharedMedia::add(SharedMediaAddSlice &&query) { Expects(IsValidSharedMediaType(query.type)); auto peerIt = enforceLists(query.peerId); auto index = static_cast(query.type); peerIt->second[index].addSlice( std::move(query.messageIds), query.noSkipRange, query.count); } void SharedMedia::remove(SharedMediaRemoveOne &&query) { auto peerIt = _lists.find(query.peerId); if (peerIt != _lists.end()) { for (auto index = 0; index != kSharedMediaTypeCount; ++index) { auto type = static_cast(index); if (query.types.test(type)) { peerIt->second[index].removeOne(query.messageId); } } _oneRemoved.fire(std::move(query)); } } void SharedMedia::remove(SharedMediaRemoveAll &&query) { auto peerIt = _lists.find(query.peerId); if (peerIt != _lists.end()) { for (auto index = 0; index != kSharedMediaTypeCount; ++index) { peerIt->second[index].removeAll(); } _allRemoved.fire(std::move(query)); } } rpl::producer SharedMedia::query(SharedMediaQuery &&query) const { Expects(IsValidSharedMediaType(query.key.type)); auto peerIt = _lists.find(query.key.peerId); if (peerIt != _lists.end()) { auto index = static_cast(query.key.type); return peerIt->second[index].query(SparseIdsListQuery( query.key.messageId, query.limitBefore, query.limitAfter)); } return [](auto consumer) { consumer.put_done(); return rpl::lifetime(); }; } rpl::producer SharedMedia::sliceUpdated() const { return _sliceUpdated.events(); } rpl::producer SharedMedia::oneRemoved() const { return _oneRemoved.events(); } rpl::producer SharedMedia::allRemoved() const { return _allRemoved.events(); } } // namespace Storage