diff options
| author | 2010-07-15 12:31:29 -0700 | |
|---|---|---|
| committer | 2010-07-15 12:31:29 -0700 | |
| commit | 9db328463a61357a3928ef2012c209bd5e7b09e1 (patch) | |
| tree | 811f504c07a20cc110781680feb49ed72ed7259d | |
| parent | 3864d243a91474c6c410969944d99e379a1da121 (diff) | |
| parent | 203ec9fa6eab21621969f36053d4cd59c23977a9 (diff) | |
am 203ec9fa: am d6343c26: Merge "Interface support for custom HTTP headers in DL manager" into gingerbread
Merge commit '203ec9fa6eab21621969f36053d4cd59c23977a9'
* commit '203ec9fa6eab21621969f36053d4cd59c23977a9':
Interface support for custom HTTP headers in DL manager
| -rw-r--r-- | core/java/android/net/DownloadManager.java | 12 | ||||
| -rw-r--r-- | core/java/android/provider/Downloads.java | 21 |
2 files changed, 31 insertions, 2 deletions
diff --git a/core/java/android/net/DownloadManager.java b/core/java/android/net/DownloadManager.java index 02b6210da88d..00b6864c0393 100644 --- a/core/java/android/net/DownloadManager.java +++ b/core/java/android/net/DownloadManager.java @@ -350,8 +350,7 @@ public class DownloadManager { } if (!mRequestHeaders.isEmpty()) { - // TODO request headers support - throw new UnsupportedOperationException(); + encodeHttpHeaders(values); } putIfNonNull(values, Downloads.COLUMN_TITLE, mTitle); @@ -367,6 +366,15 @@ public class DownloadManager { return values; } + private void encodeHttpHeaders(ContentValues values) { + int index = 0; + for (Map.Entry<String, String> entry : mRequestHeaders.entrySet()) { + String headerString = entry.getKey() + ": " + entry.getValue(); + values.put(Downloads.Impl.RequestHeaders.INSERT_KEY_PREFIX + index, headerString); + index++; + } + } + private void putIfNonNull(ContentValues contentValues, String key, String value) { if (value != null) { contentValues.put(key, value); diff --git a/core/java/android/provider/Downloads.java b/core/java/android/provider/Downloads.java index 1a4f8c0f8a95..2a612fe5e301 100644 --- a/core/java/android/provider/Downloads.java +++ b/core/java/android/provider/Downloads.java @@ -1115,5 +1115,26 @@ public final class Downloads { * This download doesn't show in the UI or in the notifications. */ public static final int VISIBILITY_HIDDEN = 2; + + /** + * Constants related to HTTP request headers associated with each download. + */ + public static class RequestHeaders { + public static final String HEADERS_DB_TABLE = "request_headers"; + public static final String COLUMN_DOWNLOAD_ID = "download_id"; + public static final String COLUMN_HEADER = "header"; + public static final String COLUMN_VALUE = "value"; + + /** + * Path segment to add to a download URI to retrieve request headers + */ + public static final String URI_SEGMENT = "headers"; + + /** + * Prefix for ContentValues keys that contain HTTP header lines, to be passed to + * DownloadProvider.insert(). + */ + public static final String INSERT_KEY_PREFIX = "http_header_"; + } } } |