Notify file manager when file starts to download.
GitOrigin-RevId: ee21c170dcd7098b734d31fb170e99053f64a139
This commit is contained in:
parent
0f07341e91
commit
ed54c461ae
@ -177,6 +177,8 @@ Result<std::pair<NetQueryPtr, bool>> FileDownloader::start_part(Part part, int32
|
|||||||
auto size = get_part_size();
|
auto size = get_part_size();
|
||||||
CHECK(part.size <= size);
|
CHECK(part.size <= size);
|
||||||
|
|
||||||
|
callback_->on_start_download();
|
||||||
|
|
||||||
NetQueryPtr net_query;
|
NetQueryPtr net_query;
|
||||||
if (!use_cdn_) {
|
if (!use_cdn_) {
|
||||||
net_query = G()->net_query_creator().create(
|
net_query = G()->net_query_creator().create(
|
||||||
|
@ -28,6 +28,7 @@ class FileDownloader : public FileLoader {
|
|||||||
public:
|
public:
|
||||||
class Callback : public FileLoader::Callback {
|
class Callback : public FileLoader::Callback {
|
||||||
public:
|
public:
|
||||||
|
virtual void on_start_download() = 0;
|
||||||
virtual void on_partial_download(const PartialLocalFileLocation &partial_local, int64 ready_size) = 0;
|
virtual void on_partial_download(const PartialLocalFileLocation &partial_local, int64 ready_size) = 0;
|
||||||
virtual void on_ok(const FullLocalFileLocation &full_local, int64 size) = 0;
|
virtual void on_ok(const FullLocalFileLocation &full_local, int64 size) = 0;
|
||||||
virtual void on_error(Status status) = 0;
|
virtual void on_error(Status status) = 0;
|
||||||
|
@ -152,6 +152,17 @@ void FileLoadManager::close() {
|
|||||||
loop();
|
loop();
|
||||||
}
|
}
|
||||||
|
|
||||||
|
void FileLoadManager::on_start_download() {
|
||||||
|
auto node_id = get_link_token();
|
||||||
|
auto node = nodes_container_.get(node_id);
|
||||||
|
if (node == nullptr) {
|
||||||
|
return;
|
||||||
|
}
|
||||||
|
if (!stop_flag_) {
|
||||||
|
send_closure(callback_, &Callback::on_start_download, node->query_id_);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
void FileLoadManager::on_partial_download(const PartialLocalFileLocation &partial_local, int64 ready_size) {
|
void FileLoadManager::on_partial_download(const PartialLocalFileLocation &partial_local, int64 ready_size) {
|
||||||
auto node_id = get_link_token();
|
auto node_id = get_link_token();
|
||||||
auto node = nodes_container_.get(node_id);
|
auto node = nodes_container_.get(node_id);
|
||||||
@ -162,6 +173,7 @@ void FileLoadManager::on_partial_download(const PartialLocalFileLocation &partia
|
|||||||
send_closure(callback_, &Callback::on_partial_download, node->query_id_, partial_local, ready_size);
|
send_closure(callback_, &Callback::on_partial_download, node->query_id_, partial_local, ready_size);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
void FileLoadManager::on_partial_upload(const PartialRemoteFileLocation &partial_remote, int64 ready_size) {
|
void FileLoadManager::on_partial_upload(const PartialRemoteFileLocation &partial_remote, int64 ready_size) {
|
||||||
auto node_id = get_link_token();
|
auto node_id = get_link_token();
|
||||||
auto node = nodes_container_.get(node_id);
|
auto node = nodes_container_.get(node_id);
|
||||||
@ -172,6 +184,7 @@ void FileLoadManager::on_partial_upload(const PartialRemoteFileLocation &partial
|
|||||||
send_closure(callback_, &Callback::on_partial_upload, node->query_id_, partial_remote, ready_size);
|
send_closure(callback_, &Callback::on_partial_upload, node->query_id_, partial_remote, ready_size);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
void FileLoadManager::on_ok_download(const FullLocalFileLocation &local, int64 size) {
|
void FileLoadManager::on_ok_download(const FullLocalFileLocation &local, int64 size) {
|
||||||
auto node_id = get_link_token();
|
auto node_id = get_link_token();
|
||||||
auto node = nodes_container_.get(node_id);
|
auto node = nodes_container_.get(node_id);
|
||||||
@ -184,6 +197,7 @@ void FileLoadManager::on_ok_download(const FullLocalFileLocation &local, int64 s
|
|||||||
close_node(node_id);
|
close_node(node_id);
|
||||||
loop();
|
loop();
|
||||||
}
|
}
|
||||||
|
|
||||||
void FileLoadManager::on_ok_upload(FileType file_type, const PartialRemoteFileLocation &remote, int64 size) {
|
void FileLoadManager::on_ok_upload(FileType file_type, const PartialRemoteFileLocation &remote, int64 size) {
|
||||||
auto node_id = get_link_token();
|
auto node_id = get_link_token();
|
||||||
auto node = nodes_container_.get(node_id);
|
auto node = nodes_container_.get(node_id);
|
||||||
@ -196,6 +210,7 @@ void FileLoadManager::on_ok_upload(FileType file_type, const PartialRemoteFileLo
|
|||||||
close_node(node_id);
|
close_node(node_id);
|
||||||
loop();
|
loop();
|
||||||
}
|
}
|
||||||
|
|
||||||
void FileLoadManager::on_ok_upload_full(const FullRemoteFileLocation &remote) {
|
void FileLoadManager::on_ok_upload_full(const FullRemoteFileLocation &remote) {
|
||||||
auto node_id = get_link_token();
|
auto node_id = get_link_token();
|
||||||
auto node = nodes_container_.get(node_id);
|
auto node = nodes_container_.get(node_id);
|
||||||
@ -208,10 +223,12 @@ void FileLoadManager::on_ok_upload_full(const FullRemoteFileLocation &remote) {
|
|||||||
close_node(node_id);
|
close_node(node_id);
|
||||||
loop();
|
loop();
|
||||||
}
|
}
|
||||||
|
|
||||||
void FileLoadManager::on_error(Status status) {
|
void FileLoadManager::on_error(Status status) {
|
||||||
auto node_id = get_link_token();
|
auto node_id = get_link_token();
|
||||||
on_error_impl(node_id, std::move(status));
|
on_error_impl(node_id, std::move(status));
|
||||||
}
|
}
|
||||||
|
|
||||||
void FileLoadManager::on_error_impl(NodeId node_id, Status status) {
|
void FileLoadManager::on_error_impl(NodeId node_id, Status status) {
|
||||||
auto node = nodes_container_.get(node_id);
|
auto node = nodes_container_.get(node_id);
|
||||||
if (node == nullptr) {
|
if (node == nullptr) {
|
||||||
|
@ -33,6 +33,7 @@ class FileLoadManager final : public Actor {
|
|||||||
Callback(const Callback &) = delete;
|
Callback(const Callback &) = delete;
|
||||||
Callback &operator=(const Callback &) = delete;
|
Callback &operator=(const Callback &) = delete;
|
||||||
~Callback() override = default;
|
~Callback() override = default;
|
||||||
|
virtual void on_start_download(QueryId id) = 0;
|
||||||
virtual void on_partial_download(QueryId id, const PartialLocalFileLocation &partial_local, int64 ready_size) = 0;
|
virtual void on_partial_download(QueryId id, const PartialLocalFileLocation &partial_local, int64 ready_size) = 0;
|
||||||
virtual void on_partial_upload(QueryId id, const PartialRemoteFileLocation &partial_remote, int64 ready_size) = 0;
|
virtual void on_partial_upload(QueryId id, const PartialRemoteFileLocation &partial_remote, int64 ready_size) = 0;
|
||||||
virtual void on_upload_ok(QueryId id, FileType file_type, const PartialRemoteFileLocation &remtoe, int64 size) = 0;
|
virtual void on_upload_ok(QueryId id, FileType file_type, const PartialRemoteFileLocation &remtoe, int64 size) = 0;
|
||||||
@ -80,6 +81,7 @@ class FileLoadManager final : public Actor {
|
|||||||
|
|
||||||
void close_node(NodeId node_id);
|
void close_node(NodeId node_id);
|
||||||
|
|
||||||
|
void on_start_download();
|
||||||
void on_partial_download(const PartialLocalFileLocation &partial_local, int64 ready_size);
|
void on_partial_download(const PartialLocalFileLocation &partial_local, int64 ready_size);
|
||||||
void on_partial_upload(const PartialRemoteFileLocation &partial_remote, int64 ready_size);
|
void on_partial_upload(const PartialRemoteFileLocation &partial_remote, int64 ready_size);
|
||||||
void on_ok_download(const FullLocalFileLocation &local, int64 size);
|
void on_ok_download(const FullLocalFileLocation &local, int64 size);
|
||||||
@ -96,6 +98,9 @@ class FileLoadManager final : public Actor {
|
|||||||
private:
|
private:
|
||||||
ActorShared<FileLoadManager> actor_id_;
|
ActorShared<FileLoadManager> actor_id_;
|
||||||
|
|
||||||
|
void on_start_download() override {
|
||||||
|
send_closure(actor_id_, &FileLoadManager::on_start_download);
|
||||||
|
}
|
||||||
void on_partial_download(const PartialLocalFileLocation &partial_local, int64 ready_size) override {
|
void on_partial_download(const PartialLocalFileLocation &partial_local, int64 ready_size) override {
|
||||||
send_closure(actor_id_, &FileLoadManager::on_partial_download, partial_local, ready_size);
|
send_closure(actor_id_, &FileLoadManager::on_partial_download, partial_local, ready_size);
|
||||||
}
|
}
|
||||||
|
@ -802,6 +802,7 @@ void FileManager::cancel_download(FileNode *node) {
|
|||||||
}
|
}
|
||||||
send_closure(file_load_manager_, &FileLoadManager::cancel, node->download_id_);
|
send_closure(file_load_manager_, &FileLoadManager::cancel, node->download_id_);
|
||||||
node->download_id_ = 0;
|
node->download_id_ = 0;
|
||||||
|
node->is_download_started_ = false;
|
||||||
node->set_download_priority(0);
|
node->set_download_priority(0);
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -911,8 +912,10 @@ Result<FileId> FileManager::merge(FileId x_file_id, FileId y_file_id, bool no_sy
|
|||||||
cancel_download(node);
|
cancel_download(node);
|
||||||
node->set_local_location(other_node->local_, other_node->local_ready_size_);
|
node->set_local_location(other_node->local_, other_node->local_ready_size_);
|
||||||
node->download_id_ = other_node->download_id_;
|
node->download_id_ = other_node->download_id_;
|
||||||
|
node->is_download_started_ |= other_node->is_download_started_;
|
||||||
node->set_download_priority(other_node->download_priority_);
|
node->set_download_priority(other_node->download_priority_);
|
||||||
other_node->download_id_ = 0;
|
other_node->download_id_ = 0;
|
||||||
|
other_node->is_download_started_ = false;
|
||||||
other_node->download_priority_ = 0;
|
other_node->download_priority_ = 0;
|
||||||
|
|
||||||
//cancel_generate(node);
|
//cancel_generate(node);
|
||||||
@ -1245,6 +1248,7 @@ bool FileManager::set_content(FileId file_id, BufferSlice bytes) {
|
|||||||
|
|
||||||
QueryId id = queries_container_.create(Query{file_id, Query::SetContent});
|
QueryId id = queries_container_.create(Query{file_id, Query::SetContent});
|
||||||
node->download_id_ = id;
|
node->download_id_ = id;
|
||||||
|
node->is_download_started_ = true;
|
||||||
send_closure(file_load_manager_, &FileLoadManager::from_bytes, id, node->remote_.full().type_, std::move(bytes),
|
send_closure(file_load_manager_, &FileLoadManager::from_bytes, id, node->remote_.full().type_, std::move(bytes),
|
||||||
node->name_);
|
node->name_);
|
||||||
return true;
|
return true;
|
||||||
@ -1387,6 +1391,7 @@ void FileManager::run_download(FileNode *node) {
|
|||||||
auto file_id = node->file_ids_.back();
|
auto file_id = node->file_ids_.back();
|
||||||
QueryId id = queries_container_.create(Query{file_id, Query::Download});
|
QueryId id = queries_container_.create(Query{file_id, Query::Download});
|
||||||
node->download_id_ = id;
|
node->download_id_ = id;
|
||||||
|
node->is_download_started_ = false;
|
||||||
send_closure(file_load_manager_, &FileLoadManager::download, id, node->remote_.full(), node->local_, node->size_,
|
send_closure(file_load_manager_, &FileLoadManager::download, id, node->remote_.full(), node->local_, node->size_,
|
||||||
node->name_, node->encryption_key_, priority);
|
node->name_, node->encryption_key_, priority);
|
||||||
}
|
}
|
||||||
@ -1927,6 +1932,23 @@ FileManager::FileNodeId FileManager::next_file_node_id() {
|
|||||||
return res;
|
return res;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
void FileManager::on_start_download(QueryId query_id) {
|
||||||
|
auto query = queries_container_.get(query_id);
|
||||||
|
CHECK(query != nullptr);
|
||||||
|
|
||||||
|
auto file_id = query->file_id_;
|
||||||
|
auto *file_node = get_file_node(file_id);
|
||||||
|
if (file_node == nullptr) {
|
||||||
|
return;
|
||||||
|
}
|
||||||
|
if (file_node->download_id_ != query_id) {
|
||||||
|
return;
|
||||||
|
}
|
||||||
|
|
||||||
|
LOG(DEBUG) << "Start to download part of file " << file_id;
|
||||||
|
file_node->is_download_started_ = true;
|
||||||
|
}
|
||||||
|
|
||||||
void FileManager::on_partial_download(QueryId query_id, const PartialLocalFileLocation &partial_local,
|
void FileManager::on_partial_download(QueryId query_id, const PartialLocalFileLocation &partial_local,
|
||||||
int64 ready_size) {
|
int64 ready_size) {
|
||||||
auto query = queries_container_.get(query_id);
|
auto query = queries_container_.get(query_id);
|
||||||
@ -2203,6 +2225,7 @@ std::pair<FileManager::Query, bool> FileManager::finish_query(QueryId query_id)
|
|||||||
}
|
}
|
||||||
if (node->download_id_ == query_id) {
|
if (node->download_id_ == query_id) {
|
||||||
node->download_id_ = 0;
|
node->download_id_ = 0;
|
||||||
|
node->is_download_started_ = false;
|
||||||
node->set_download_priority(0);
|
node->set_download_priority(0);
|
||||||
was_active = true;
|
was_active = true;
|
||||||
}
|
}
|
||||||
|
@ -86,6 +86,7 @@ class FileNode {
|
|||||||
FileLoadManager::QueryId download_id_ = 0;
|
FileLoadManager::QueryId download_id_ = 0;
|
||||||
int32 download_priority_ = 0;
|
int32 download_priority_ = 0;
|
||||||
int64 remote_ready_size_ = 0;
|
int64 remote_ready_size_ = 0;
|
||||||
|
bool is_download_started_ = false;
|
||||||
|
|
||||||
GenerateFileLocation generate_;
|
GenerateFileLocation generate_;
|
||||||
FileLoadManager::QueryId generate_id_ = 0;
|
FileLoadManager::QueryId generate_id_ = 0;
|
||||||
@ -370,6 +371,7 @@ class FileManager : public FileLoadManager::Callback {
|
|||||||
void run_download(FileNode *node);
|
void run_download(FileNode *node);
|
||||||
void run_generate(FileNode *node);
|
void run_generate(FileNode *node);
|
||||||
|
|
||||||
|
void on_start_download(QueryId query_id) override;
|
||||||
void on_partial_download(QueryId query_id, const PartialLocalFileLocation &partial_local, int64 ready_size) override;
|
void on_partial_download(QueryId query_id, const PartialLocalFileLocation &partial_local, int64 ready_size) override;
|
||||||
void on_partial_upload(QueryId query_id, const PartialRemoteFileLocation &partial_remote, int64 ready_size) override;
|
void on_partial_upload(QueryId query_id, const PartialRemoteFileLocation &partial_remote, int64 ready_size) override;
|
||||||
void on_download_ok(QueryId query_id, const FullLocalFileLocation &local, int64 size) override;
|
void on_download_ok(QueryId query_id, const FullLocalFileLocation &local, int64 size) override;
|
||||||
|
Reference in New Issue
Block a user