2 * Copyright (C) 2012 Intel Corporation. All rights reserved.
4 * Redistribution and use in source and binary forms, with or without
5 * modification, are permitted provided that the following conditions
7 * 1. Redistributions of source code must retain the above copyright
8 * notice, this list of conditions and the following disclaimer.
9 * 2. Redistributions in binary form must reproduce the above copyright
10 * notice, this list of conditions and the following disclaimer in the
11 * documentation and/or other materials provided with the distribution.
13 * THIS SOFTWARE IS PROVIDED BY APPLE INC. AND ITS CONTRIBUTORS ``AS IS''
14 * AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO,
15 * THE IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR
16 * PURPOSE ARE DISCLAIMED. IN NO EVENT SHALL APPLE INC. OR ITS CONTRIBUTORS
17 * BE LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR
18 * CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF
19 * SUBSTITUTE GOODS OR SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS
20 * INTERRUPTION) HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN
21 * CONTRACT, STRICT LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE)
22 * ARISING IN ANY WAY OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF
23 * THE POSSIBILITY OF SUCH DAMAGE.
27 #include "ewk_download_job.h"
29 #include "DownloadProxy.h"
30 #include "WKAPICast.h"
31 #include "WKRetainPtr.h"
32 #include "WebURLRequest.h"
33 #include "ewk_download_job_private.h"
34 #include "ewk_url_response_private.h"
37 using namespace WebKit;
39 Ewk_Download_Job::Ewk_Download_Job(WebKit::DownloadProxy* download, EwkViewImpl* viewImpl)
40 : m_downloadProxy(download)
41 , m_viewImpl(viewImpl)
42 , m_state(EWK_DOWNLOAD_JOB_STATE_NOT_STARTED)
48 Ewk_Download_Job* ewk_download_job_ref(Ewk_Download_Job* download)
50 EINA_SAFETY_ON_NULL_RETURN_VAL(download, 0);
57 void ewk_download_job_unref(Ewk_Download_Job* download)
59 EINA_SAFETY_ON_NULL_RETURN(download);
66 * Queries the identifier for this download
68 uint64_t Ewk_Download_Job::id() const
70 return m_downloadProxy->downloadID();
75 * Returns the view this download is attached to.
76 * The view is needed to send notification signals.
78 EwkViewImpl* Ewk_Download_Job::viewImpl() const
83 Ewk_Download_Job_State ewk_download_job_state_get(const Ewk_Download_Job* download)
85 EINA_SAFETY_ON_NULL_RETURN_VAL(download, EWK_DOWNLOAD_JOB_STATE_UNKNOWN);
87 return download->state();
90 Ewk_Download_Job_State Ewk_Download_Job::state() const
95 Ewk_Url_Request* ewk_download_job_request_get(const Ewk_Download_Job* download)
97 EINA_SAFETY_ON_NULL_RETURN_VAL(download, 0);
99 return download->request();
102 Ewk_Url_Request* Ewk_Download_Job::request() const
105 WKRetainPtr<WKURLRequestRef> wkURLRequest(AdoptWK, toAPI(WebURLRequest::create(m_downloadProxy->request()).leakRef()));
106 m_request = Ewk_Url_Request::create(wkURLRequest.get());
109 return m_request.get();
112 Ewk_Url_Response* ewk_download_job_response_get(const Ewk_Download_Job* download)
114 EINA_SAFETY_ON_NULL_RETURN_VAL(download, 0);
116 return download->response();
119 Ewk_Url_Response* Ewk_Download_Job::response() const
121 return m_response.get();
124 const char* ewk_download_job_destination_get(const Ewk_Download_Job* download)
126 EINA_SAFETY_ON_NULL_RETURN_VAL(download, 0);
128 return download->destination();
131 const char* Ewk_Download_Job::destination() const
133 return m_destination;
136 Eina_Bool ewk_download_job_destination_set(Ewk_Download_Job* download, const char* destination)
138 EINA_SAFETY_ON_NULL_RETURN_VAL(download, false);
139 EINA_SAFETY_ON_NULL_RETURN_VAL(destination, false);
141 download->setDestination(destination);
146 void Ewk_Download_Job::setDestination(const char* destination)
148 m_destination = destination;
151 const char* ewk_download_job_suggested_filename_get(const Ewk_Download_Job* download)
153 EINA_SAFETY_ON_NULL_RETURN_VAL(download, 0);
155 return download->suggestedFileName();
158 const char* Ewk_Download_Job::suggestedFileName() const
160 return m_suggestedFilename;
163 Eina_Bool ewk_download_job_cancel(Ewk_Download_Job* download)
165 EINA_SAFETY_ON_NULL_RETURN_VAL(download, false);
167 return download->cancel();
170 bool Ewk_Download_Job::cancel()
172 if (m_state != EWK_DOWNLOAD_JOB_STATE_DOWNLOADING)
175 m_state = EWK_DOWNLOAD_JOB_STATE_CANCELLING;
176 m_downloadProxy->cancel();
180 double ewk_download_job_estimated_progress_get(const Ewk_Download_Job* download)
182 EINA_SAFETY_ON_NULL_RETURN_VAL(download, 0);
184 return download->estimatedProgress();
187 double Ewk_Download_Job::estimatedProgress() const
192 const unsigned long contentLength = m_response->contentLength();
196 return static_cast<double>(m_downloaded) / contentLength;
199 double ewk_download_job_elapsed_time_get(const Ewk_Download_Job* download)
201 EINA_SAFETY_ON_NULL_RETURN_VAL(download, 0);
203 return download->elapsedTime();
206 double Ewk_Download_Job::elapsedTime() const
208 // Download has not started yet.
212 // Download had ended, return the time elapsed between the
213 // download start and the end event.
215 return m_endTime - m_startTime;
217 // Download is still going.
218 return ecore_time_get() - m_startTime;
223 * Sets the URL @a response for this @a download.
225 void Ewk_Download_Job::setResponse(PassRefPtr<Ewk_Url_Response> response)
229 m_response = response;
234 * Sets the suggested file name for this @a download.
236 void Ewk_Download_Job::setSuggestedFileName(const char* suggestedFilename)
238 m_suggestedFilename = suggestedFilename;
243 * Report a given amount of data was received.
245 void Ewk_Download_Job::incrementReceivedData(uint64_t length)
247 m_downloaded += length;
252 * Sets the state of the download.
254 void Ewk_Download_Job::setState(Ewk_Download_Job_State state)
259 case EWK_DOWNLOAD_JOB_STATE_DOWNLOADING:
260 m_startTime = ecore_time_get();
262 case EWK_DOWNLOAD_JOB_STATE_FAILED:
263 case EWK_DOWNLOAD_JOB_STATE_CANCELLED:
264 case EWK_DOWNLOAD_JOB_STATE_FINISHED:
265 m_endTime = ecore_time_get();