Respond with QuotaExceededError when IndexedDB has no disk space on open.
[chromium-blink-merge.git] / content / browser / download / download_create_info.h
blob4326b2428b0eebd928d7d91481f4ff752d6e0f75
1 // Copyright (c) 2012 The Chromium Authors. All rights reserved.
2 // Use of this source code is governed by a BSD-style license that can be
3 // found in the LICENSE file.
5 #ifndef CONTENT_BROWSER_DOWNLOAD_DOWNLOAD_CREATE_INFO_H_
6 #define CONTENT_BROWSER_DOWNLOAD_DOWNLOAD_CREATE_INFO_H_
8 #include <string>
9 #include <vector>
11 #include "base/basictypes.h"
12 #include "base/files/file_path.h"
13 #include "base/time/time.h"
14 #include "content/browser/download/download_file.h"
15 #include "content/browser/download/download_request_handle.h"
16 #include "content/common/content_export.h"
17 #include "content/public/browser/download_save_info.h"
18 #include "content/public/common/page_transition_types.h"
19 #include "net/base/net_log.h"
20 #include "url/gurl.h"
22 namespace content {
24 // Used for informing the download manager of a new download, since we don't
25 // want to pass |DownloadItem|s between threads.
26 struct CONTENT_EXPORT DownloadCreateInfo {
27 DownloadCreateInfo(const base::Time& start_time,
28 int64 total_bytes,
29 const net::BoundNetLog& bound_net_log,
30 bool has_user_gesture,
31 PageTransition transition_type);
32 DownloadCreateInfo();
33 ~DownloadCreateInfo();
35 std::string DebugString() const;
37 // The URL from which we are downloading. This is the final URL after any
38 // redirection by the server for |url_chain|.
39 const GURL& url() const;
41 // The chain of redirects that leading up to and including the final URL.
42 std::vector<GURL> url_chain;
44 // The URL that referred us.
45 GURL referrer_url;
47 // The time when the download started.
48 base::Time start_time;
50 // The total download size.
51 int64 total_bytes;
53 // The ID of the download.
54 uint32 download_id;
56 // True if the download was initiated by user action.
57 bool has_user_gesture;
59 PageTransition transition_type;
61 // The content-disposition string from the response header.
62 std::string content_disposition;
64 // The mime type string from the response header (may be overridden).
65 std::string mime_type;
67 // The value of the content type header sent with the downloaded item. It
68 // may be different from |mime_type|, which may be set based on heuristics
69 // which may look at the file extension and first few bytes of the file.
70 std::string original_mime_type;
72 // For continuing a download, the modification time of the file.
73 // Storing as a string for exact match to server format on
74 // "If-Unmodified-Since" comparison.
75 std::string last_modified;
77 // For continuing a download, the ETAG of the file.
78 std::string etag;
80 // The download file save info.
81 scoped_ptr<DownloadSaveInfo> save_info;
83 // The remote IP address where the download was fetched from. Copied from
84 // UrlRequest::GetSocketAddress().
85 std::string remote_address;
87 // The handle to the URLRequest sourcing this download.
88 DownloadRequestHandle request_handle;
90 // The request's |BoundNetLog|, for "source_dependency" linking with the
91 // download item's.
92 const net::BoundNetLog request_bound_net_log;
94 private:
95 DISALLOW_COPY_AND_ASSIGN(DownloadCreateInfo);
98 } // namespace content
100 #endif // CONTENT_BROWSER_DOWNLOAD_DOWNLOAD_CREATE_INFO_H_