2018-12-31 22:04:05 +03:00
|
|
|
//
|
2020-01-01 04:23:48 +03:00
|
|
|
// Copyright Aliaksei Levin (levlam@telegram.org), Arseny Smirnov (arseny30@gmail.com) 2014-2020
|
2018-12-31 22:04:05 +03:00
|
|
|
//
|
|
|
|
// Distributed under the Boost Software License, Version 1.0. (See accompanying
|
|
|
|
// file LICENSE_1_0.txt or copy at http://www.boost.org/LICENSE_1_0.txt)
|
|
|
|
//
|
|
|
|
#pragma once
|
2018-07-03 22:29:04 +03:00
|
|
|
|
2018-12-31 22:04:05 +03:00
|
|
|
#include "td/telegram/AudiosManager.h"
|
|
|
|
|
|
|
|
#include "td/telegram/files/FileId.hpp"
|
|
|
|
#include "td/telegram/Photo.hpp"
|
2019-05-14 17:26:13 +03:00
|
|
|
#include "td/telegram/Version.h"
|
2018-12-31 22:04:05 +03:00
|
|
|
|
2019-02-12 23:48:16 +03:00
|
|
|
#include "td/utils/common.h"
|
2018-12-31 22:04:05 +03:00
|
|
|
#include "td/utils/tl_helpers.h"
|
|
|
|
|
2020-08-05 11:23:52 +02:00
|
|
|
#include "td/telegram/ConfigShared.h"
|
|
|
|
|
2018-12-31 22:04:05 +03:00
|
|
|
namespace td {
|
|
|
|
|
2019-02-21 20:54:20 +03:00
|
|
|
template <class StorerT>
|
|
|
|
void AudiosManager::store_audio(FileId file_id, StorerT &storer) const {
|
2018-12-31 22:04:05 +03:00
|
|
|
auto it = audios_.find(file_id);
|
2020-05-23 21:27:24 +02:00
|
|
|
if (it == audios_.end() || it->second == nullptr) {
|
|
|
|
return;
|
|
|
|
}
|
2018-12-31 22:04:05 +03:00
|
|
|
const Audio *audio = it->second.get();
|
|
|
|
store(audio->file_name, storer);
|
|
|
|
store(audio->mime_type, storer);
|
|
|
|
store(audio->duration, storer);
|
|
|
|
store(audio->title, storer);
|
|
|
|
store(audio->performer, storer);
|
2019-03-01 22:51:33 +03:00
|
|
|
store(audio->minithumbnail, storer);
|
2018-12-31 22:04:05 +03:00
|
|
|
store(audio->thumbnail, storer);
|
2018-03-08 22:43:12 +03:00
|
|
|
store(file_id, storer);
|
2018-12-31 22:04:05 +03:00
|
|
|
}
|
|
|
|
|
2019-02-21 20:54:20 +03:00
|
|
|
template <class ParserT>
|
|
|
|
FileId AudiosManager::parse_audio(ParserT &parser) {
|
2018-12-31 22:04:05 +03:00
|
|
|
auto audio = make_unique<Audio>();
|
2020-08-05 11:23:52 +02:00
|
|
|
|
|
|
|
string tmp_filename;
|
|
|
|
parse(tmp_filename, parser);
|
|
|
|
|
2018-12-31 22:04:05 +03:00
|
|
|
parse(audio->mime_type, parser);
|
2020-08-05 11:23:52 +02:00
|
|
|
|
|
|
|
if ( G()->shared_config().get_option_boolean("disable_document_filenames") && (
|
|
|
|
audio->mime_type.rfind("image/") == 0 ||
|
|
|
|
audio->mime_type.rfind("video/") == 0 ||
|
|
|
|
audio->mime_type.rfind("audio/") == 0)) {
|
|
|
|
audio->file_name = "0";
|
|
|
|
} else {
|
|
|
|
audio->file_name = tmp_filename;
|
|
|
|
}
|
|
|
|
|
2018-12-31 22:04:05 +03:00
|
|
|
parse(audio->duration, parser);
|
|
|
|
parse(audio->title, parser);
|
|
|
|
parse(audio->performer, parser);
|
2019-03-01 22:51:33 +03:00
|
|
|
if (parser.version() >= static_cast<int32>(Version::SupportMinithumbnails)) {
|
2020-08-05 11:23:52 +02:00
|
|
|
string tmp_minithumbnail;
|
|
|
|
parse(tmp_minithumbnail, parser);
|
|
|
|
if (!G()->shared_config().get_option_boolean("disable_minithumbnails")) {
|
|
|
|
audio->minithumbnail = tmp_minithumbnail;
|
|
|
|
}
|
2019-03-01 22:51:33 +03:00
|
|
|
}
|
2018-12-31 22:04:05 +03:00
|
|
|
parse(audio->thumbnail, parser);
|
|
|
|
parse(audio->file_id, parser);
|
2019-08-01 03:58:49 +03:00
|
|
|
if (parser.get_error() != nullptr || !audio->file_id.is_valid()) {
|
|
|
|
return FileId();
|
|
|
|
}
|
2018-11-06 14:37:07 +03:00
|
|
|
return on_get_audio(std::move(audio), false);
|
2018-12-31 22:04:05 +03:00
|
|
|
}
|
|
|
|
|
|
|
|
} // namespace td
|