summaryrefslogtreecommitdiffstats
diff options
context:
space:
mode:
authormichaelbai@google.com <michaelbai@google.com@0039d316-1c4b-4281-b951-d872f2087c98>2011-07-11 22:47:57 +0000
committermichaelbai@google.com <michaelbai@google.com@0039d316-1c4b-4281-b951-d872f2087c98>2011-07-11 22:47:57 +0000
commitd2effadd83accd3df875694437ca766bb20cb6e1 (patch)
tree4ae89de7105c1850bdeac35d870fcc6e1d015e1b
parent734a36e98b8bb2dded95c0b7e4e35e82bb3f5507 (diff)
downloadchromium_src-d2effadd83accd3df875694437ca766bb20cb6e1.zip
chromium_src-d2effadd83accd3df875694437ca766bb20cb6e1.tar.gz
chromium_src-d2effadd83accd3df875694437ca766bb20cb6e1.tar.bz2
Upstream android net related code (part3)
Moved from http://codereview.chromium.org/7277057/ BUG= TEST= Review URL: http://codereview.chromium.org/7328025 git-svn-id: svn://svn.chromium.org/chrome/trunk/src@92069 0039d316-1c4b-4281-b951-d872f2087c98
-rw-r--r--net/base/cookie_monster.cc19
-rw-r--r--net/base/cookie_monster.h3
-rw-r--r--net/base/mime_util.cc6
-rw-r--r--net/net.gyp13
4 files changed, 41 insertions, 0 deletions
diff --git a/net/base/cookie_monster.cc b/net/base/cookie_monster.cc
index 13878a3..8e0b60b 100644
--- a/net/base/cookie_monster.cc
+++ b/net/base/cookie_monster.cc
@@ -99,6 +99,10 @@ const int kVlogGarbageCollection = 5;
const int kVlogSetCookies = 7;
const int kVlogGetCookies = 9;
+#if defined(ENABLE_PERSISTENT_SESSION_COOKIES)
+const int kPersistentSessionCookieExpiryInDays = 14;
+#endif
+
// Mozilla sorts on the path length (longest first), and then it
// sorts by creation time (oldest first).
// The RFC says the sort order for the domain attribute is undefined.
@@ -1956,6 +1960,7 @@ CookieMonster::CanonicalCookie::CanonicalCookie()
: secure_(false),
httponly_(false),
has_expires_(false) {
+ SetSessionCookieExpiryTime();
}
CookieMonster::CanonicalCookie::CanonicalCookie(
@@ -1977,6 +1982,8 @@ CookieMonster::CanonicalCookie::CanonicalCookie(
secure_(secure),
httponly_(httponly),
has_expires_(has_expires) {
+ if (!has_expires_)
+ SetSessionCookieExpiryTime();
}
CookieMonster::CanonicalCookie::CanonicalCookie(const GURL& url,
@@ -1994,6 +2001,8 @@ CookieMonster::CanonicalCookie::CanonicalCookie(const GURL& url,
has_expires_(pc.HasExpires()) {
if (has_expires_)
expiry_date_ = CanonExpiration(pc, creation_date_, CookieOptions());
+ else
+ SetSessionCookieExpiryTime();
// Do the best we can with the domain.
std::string cookie_domain;
@@ -2025,6 +2034,16 @@ std::string CookieMonster::CanonicalCookie::GetCookieSourceFromURL(
return url.GetOrigin().ReplaceComponents(replacements).spec();
}
+void CookieMonster::CanonicalCookie::SetSessionCookieExpiryTime() {
+#if defined(ENABLE_PERSISTENT_SESSION_COOKIES)
+ // Mobile apps can sometimes be shut down without any warning, so the session
+ // cookie has to be persistent and given a default expiration time.
+ expiry_date_ = base::Time::Now() +
+ base::TimeDelta::FromDays(kPersistentSessionCookieExpiryInDays);
+ has_expires_ = true;
+#endif
+}
+
CookieMonster::CanonicalCookie* CookieMonster::CanonicalCookie::Create(
const GURL& url,
const std::string& name,
diff --git a/net/base/cookie_monster.h b/net/base/cookie_monster.h
index c3943ac..edc40a9 100644
--- a/net/base/cookie_monster.h
+++ b/net/base/cookie_monster.h
@@ -629,6 +629,9 @@ class NET_API CookieMonster::CanonicalCookie {
static std::string GetCookieSourceFromURL(const GURL& url);
private:
+ // Gives the session cookie an expiration time if needed
+ void SetSessionCookieExpiryTime();
+
// The source member of a canonical cookie is the origin of the URL that tried
// to set this cookie, minus the port number if any. This field is not
// persistent though; its only used in the in-tab cookies dialog to show the
diff --git a/net/base/mime_util.cc b/net/base/mime_util.cc
index 75572a9..4dad7ad 100644
--- a/net/base/mime_util.cc
+++ b/net/base/mime_util.cc
@@ -227,10 +227,14 @@ static const char* const supported_image_types[] = {
// A list of media types: http://en.wikipedia.org/wiki/Internet_media_type
// A comprehensive mime type list: http://plugindoc.mozdev.org/winmime.php
static const char* const supported_media_types[] = {
+#if defined(ENABLE_MEDIA_TYPE_OGG)
// Ogg.
"video/ogg",
"audio/ogg",
"application/ogg",
+#endif
+
+ // WebM.
"video/webm",
"audio/webm",
"audio/wav",
@@ -259,7 +263,9 @@ static const char* const supported_media_codecs[] = {
"avc1",
"mp4a",
#endif
+#if defined(ENABLE_MEDIA_CODEC_THEORA)
"theora",
+#endif
"vorbis",
"vp8",
"1" // PCM for WAV.
diff --git a/net/net.gyp b/net/net.gyp
index 40de019..1186975d 100644
--- a/net/net.gyp
+++ b/net/net.gyp
@@ -854,6 +854,19 @@
},
},
],
+ [ 'OS == "android"', {
+ 'defines': [
+ # Android can shut down our app at any time, so we persist session cookies.
+ 'ENABLE_PERSISTENT_SESSION_COOKIES'
+ ],
+ }, { # else OS! = "android"
+ 'defines': [
+ # These are the features Android doesn't support.
+ 'ENABLE_MEDIA_CODEC_THEORA',
+ 'ENABLE_MEDIA_TYPE_OGG',
+ ],
+ },
+ ],
],
},
{