2019-02-06 01:06:29 +01:00
|
|
|
//
|
2022-01-01 01:35:39 +01:00
|
|
|
// Copyright Aliaksei Levin (levlam@telegram.org), Arseny Smirnov (arseny30@gmail.com) 2014-2022
|
2019-02-06 01:06:29 +01: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
|
|
|
|
|
|
|
|
#include "td/telegram/files/FileData.h"
|
|
|
|
|
|
|
|
#include "td/telegram/FileReferenceManager.h"
|
|
|
|
#include "td/telegram/FileReferenceManager.hpp"
|
|
|
|
#include "td/telegram/files/FileEncryptionKey.h"
|
|
|
|
#include "td/telegram/files/FileLocation.h"
|
2019-02-07 22:00:26 +01:00
|
|
|
#include "td/telegram/files/FileLocation.hpp"
|
2019-02-06 01:06:29 +01:00
|
|
|
#include "td/telegram/Global.h"
|
|
|
|
#include "td/telegram/Td.h"
|
2019-06-12 15:05:22 +02:00
|
|
|
#include "td/telegram/Version.h"
|
2019-02-06 01:06:29 +01:00
|
|
|
|
|
|
|
#include "td/utils/common.h"
|
|
|
|
#include "td/utils/misc.h"
|
|
|
|
#include "td/utils/tl_helpers.h"
|
|
|
|
|
|
|
|
namespace td {
|
|
|
|
|
|
|
|
template <class StorerT>
|
|
|
|
void FileData::store(StorerT &storer) const {
|
|
|
|
using ::td::store;
|
|
|
|
bool has_owner_dialog_id = owner_dialog_id_.is_valid();
|
|
|
|
bool has_expected_size = size_ == 0 && expected_size_ != 0;
|
|
|
|
bool encryption_key_is_secure = encryption_key_.is_secure();
|
|
|
|
bool has_sources = !file_source_ids_.empty();
|
2019-06-11 12:10:14 +02:00
|
|
|
bool has_version = true;
|
2019-02-06 01:06:29 +01:00
|
|
|
BEGIN_STORE_FLAGS();
|
|
|
|
STORE_FLAG(has_owner_dialog_id);
|
|
|
|
STORE_FLAG(has_expected_size);
|
|
|
|
STORE_FLAG(encryption_key_is_secure);
|
|
|
|
STORE_FLAG(has_sources);
|
2019-06-11 12:10:14 +02:00
|
|
|
STORE_FLAG(has_version);
|
2019-02-06 01:06:29 +01:00
|
|
|
END_STORE_FLAGS();
|
|
|
|
|
2019-06-11 12:10:14 +02:00
|
|
|
if (has_version) {
|
|
|
|
store(static_cast<int32>(Version::Next) - 1, storer);
|
|
|
|
}
|
2019-02-06 01:06:29 +01:00
|
|
|
if (has_owner_dialog_id) {
|
|
|
|
store(owner_dialog_id_, storer);
|
|
|
|
}
|
|
|
|
store(pmc_id_, storer);
|
|
|
|
store(remote_, storer);
|
|
|
|
store(local_, storer);
|
|
|
|
auto generate = generate_ == nullptr ? GenerateFileLocation() : GenerateFileLocation(*generate_);
|
|
|
|
store(generate, storer);
|
|
|
|
if (has_expected_size) {
|
|
|
|
store(expected_size_, storer);
|
|
|
|
} else {
|
|
|
|
store(size_, storer);
|
|
|
|
}
|
|
|
|
store(remote_name_, storer);
|
|
|
|
store(url_, storer);
|
|
|
|
store(encryption_key_, storer);
|
|
|
|
if (has_sources) {
|
|
|
|
auto td = G()->td().get_actor_unsafe();
|
|
|
|
store(narrow_cast<int32>(file_source_ids_.size()), storer);
|
|
|
|
for (auto file_source_id : file_source_ids_) {
|
|
|
|
td->file_reference_manager_->store_file_source(file_source_id, storer);
|
|
|
|
}
|
|
|
|
}
|
|
|
|
}
|
2019-08-01 02:40:28 +02:00
|
|
|
|
2019-02-06 01:06:29 +01:00
|
|
|
template <class ParserT>
|
2019-03-17 22:40:10 +01:00
|
|
|
void FileData::parse(ParserT &parser, bool register_file_sources) {
|
2019-02-06 01:06:29 +01:00
|
|
|
using ::td::parse;
|
|
|
|
bool has_owner_dialog_id;
|
|
|
|
bool has_expected_size;
|
|
|
|
bool encryption_key_is_secure;
|
|
|
|
bool has_sources;
|
2019-06-11 12:10:14 +02:00
|
|
|
bool has_version;
|
2019-02-06 01:06:29 +01:00
|
|
|
BEGIN_PARSE_FLAGS();
|
|
|
|
PARSE_FLAG(has_owner_dialog_id);
|
|
|
|
PARSE_FLAG(has_expected_size);
|
|
|
|
PARSE_FLAG(encryption_key_is_secure);
|
|
|
|
PARSE_FLAG(has_sources);
|
2019-06-11 12:10:14 +02:00
|
|
|
PARSE_FLAG(has_version);
|
2019-08-01 02:40:28 +02:00
|
|
|
END_PARSE_FLAGS();
|
|
|
|
if (parser.get_error()) {
|
|
|
|
return;
|
|
|
|
}
|
2019-02-06 01:06:29 +01:00
|
|
|
|
2019-06-11 12:10:14 +02:00
|
|
|
int32 version = 0;
|
|
|
|
if (has_version) {
|
|
|
|
parse(version, parser);
|
|
|
|
}
|
|
|
|
parser.set_version(version);
|
2019-02-06 01:06:29 +01:00
|
|
|
if (has_owner_dialog_id) {
|
|
|
|
parse(owner_dialog_id_, parser);
|
|
|
|
}
|
|
|
|
parse(pmc_id_, parser);
|
|
|
|
parse(remote_, parser);
|
|
|
|
parse(local_, parser);
|
|
|
|
GenerateFileLocation generate;
|
|
|
|
parse(generate, parser);
|
|
|
|
if (generate.type() == GenerateFileLocation::Type::Full) {
|
|
|
|
generate_ = make_unique<FullGenerateFileLocation>(generate.full());
|
|
|
|
} else {
|
|
|
|
generate_ = nullptr;
|
|
|
|
}
|
|
|
|
if (has_expected_size) {
|
|
|
|
parse(expected_size_, parser);
|
|
|
|
} else {
|
|
|
|
parse(size_, parser);
|
|
|
|
}
|
|
|
|
parse(remote_name_, parser);
|
|
|
|
parse(url_, parser);
|
|
|
|
encryption_key_.parse(encryption_key_is_secure ? FileEncryptionKey::Type::Secure : FileEncryptionKey::Type::Secret,
|
|
|
|
parser);
|
2019-03-17 22:40:10 +01:00
|
|
|
if (has_sources && register_file_sources) {
|
|
|
|
Td *td = G()->td().get_actor_unsafe();
|
2022-05-11 16:17:20 +02:00
|
|
|
int32 file_source_count;
|
|
|
|
parse(file_source_count, parser);
|
|
|
|
if (0 < file_source_count && file_source_count < 5) {
|
|
|
|
for (int i = 0; i < file_source_count; i++) {
|
2019-08-01 02:40:28 +02:00
|
|
|
if (parser.get_error()) {
|
|
|
|
return;
|
|
|
|
}
|
2022-10-06 14:15:45 +02:00
|
|
|
auto file_source_id = td->file_reference_manager_->parse_file_source(td, parser);
|
|
|
|
if (file_source_id.is_valid() && !td::contains(file_source_ids_, file_source_id)) {
|
|
|
|
file_source_ids_.push_back(file_source_id);
|
|
|
|
}
|
2019-02-06 01:06:29 +01:00
|
|
|
}
|
|
|
|
} else {
|
|
|
|
parser.set_error("Wrong number of file source ids");
|
|
|
|
}
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
} // namespace td
|