2020-05-05 17:58:22 -04:00
|
|
|
/*
|
|
|
|
* Copyright (c) 2020, Andreas Kling <kling@serenityos.org>
|
2022-02-10 14:28:48 -05:00
|
|
|
* Copyright (c) 2022, the SerenityOS developers.
|
2020-05-05 17:58:22 -04:00
|
|
|
*
|
2021-04-22 04:24:48 -04:00
|
|
|
* SPDX-License-Identifier: BSD-2-Clause
|
2020-05-05 17:58:22 -04:00
|
|
|
*/
|
|
|
|
|
|
|
|
#pragma once
|
|
|
|
|
|
|
|
#include <AK/URL.h>
|
|
|
|
#include <LibCore/ElapsedTimer.h>
|
2021-05-31 12:20:50 -04:00
|
|
|
#include <LibGUI/ImageWidget.h>
|
2021-04-13 10:18:20 -04:00
|
|
|
#include <LibGUI/Progressbar.h>
|
2020-05-05 17:58:22 -04:00
|
|
|
#include <LibGUI/Widget.h>
|
2022-04-30 06:06:30 -04:00
|
|
|
#include <LibWeb/Loader/ResourceLoader.h>
|
2020-05-05 17:58:22 -04:00
|
|
|
|
|
|
|
namespace Browser {
|
|
|
|
|
|
|
|
class DownloadWidget final : public GUI::Widget {
|
|
|
|
C_OBJECT(DownloadWidget);
|
|
|
|
|
|
|
|
public:
|
2022-02-10 14:28:48 -05:00
|
|
|
virtual ~DownloadWidget() override = default;
|
2020-05-05 17:58:22 -04:00
|
|
|
|
|
|
|
private:
|
|
|
|
explicit DownloadWidget(const URL&);
|
|
|
|
|
2023-06-10 19:56:35 -04:00
|
|
|
void did_progress(Optional<u64> total_size, u64 downloaded_size);
|
ProtocolServer: Stream the downloaded data if possible
This patchset makes ProtocolServer stream the downloads to its client
(LibProtocol), and as such changes the download API; a possible
download lifecycle could be as such:
notation = client->server:'>', server->client:'<', pipe activity:'*'
```
> StartDownload(GET, url, headers, {})
< Response(0, fd 8)
* {data, 1024b}
< HeadersBecameAvailable(0, response_headers, 200)
< DownloadProgress(0, 4K, 1024)
* {data, 1024b}
* {data, 1024b}
< DownloadProgress(0, 4K, 2048)
* {data, 1024b}
< DownloadProgress(0, 4K, 1024)
< DownloadFinished(0, true, 4K)
```
Since managing the received file descriptor is a pain, LibProtocol
implements `Download::stream_into(OutputStream)`, which can be used to
stream the download into any given output stream (be it a file, or
memory, or writing stuff with a delay, etc.).
Also, as some of the users of this API require all the downloaded data
upfront, LibProtocol also implements `set_should_buffer_all_input()`,
which causes the download instance to buffer all the data until the
download is complete, and to call the `on_buffered_download_finish`
hook.
2020-12-26 08:44:12 -05:00
|
|
|
void did_finish(bool success);
|
2020-05-05 17:58:22 -04:00
|
|
|
|
|
|
|
URL m_url;
|
2022-12-04 13:02:33 -05:00
|
|
|
DeprecatedString m_destination_path;
|
2022-04-30 06:06:30 -04:00
|
|
|
RefPtr<Web::ResourceLoaderConnectorRequest> m_download;
|
2021-04-13 10:18:20 -04:00
|
|
|
RefPtr<GUI::Progressbar> m_progressbar;
|
2020-05-05 17:58:22 -04:00
|
|
|
RefPtr<GUI::Label> m_progress_label;
|
|
|
|
RefPtr<GUI::Button> m_cancel_button;
|
|
|
|
RefPtr<GUI::Button> m_close_button;
|
2021-05-31 12:19:13 -04:00
|
|
|
RefPtr<GUI::CheckBox> m_close_on_finish_checkbox;
|
2021-05-31 12:20:50 -04:00
|
|
|
RefPtr<GUI::ImageWidget> m_browser_image;
|
2023-02-08 21:02:46 -05:00
|
|
|
OwnPtr<Core::File> m_output_file_stream;
|
2020-05-05 17:58:22 -04:00
|
|
|
Core::ElapsedTimer m_elapsed_timer;
|
|
|
|
};
|
|
|
|
|
|
|
|
}
|