OLD | NEW |
1 // Copyright 2013 The Chromium Authors. All rights reserved. | 1 // Copyright 2013 The Chromium Authors. All rights reserved. |
2 // Use of this source code is governed by a BSD-style license that can be | 2 // Use of this source code is governed by a BSD-style license that can be |
3 // found in the LICENSE file. | 3 // found in the LICENSE file. |
4 | 4 |
5 #ifndef MEDIA_BLINK_CACHE_UTIL_H_ | 5 #ifndef MEDIA_BLINK_CACHE_UTIL_H_ |
6 #define MEDIA_BLINK_CACHE_UTIL_H_ | 6 #define MEDIA_BLINK_CACHE_UTIL_H_ |
7 | 7 |
8 #include <vector> | 8 #include <vector> |
9 | 9 |
10 #include "base/basictypes.h" | 10 #include "base/basictypes.h" |
| 11 #include "base/time/time.h" |
11 #include "media/blink/media_blink_export.h" | 12 #include "media/blink/media_blink_export.h" |
12 | 13 |
13 namespace blink { | 14 namespace blink { |
14 class WebURLResponse; | 15 class WebURLResponse; |
15 } | 16 } |
16 | 17 |
17 namespace media { | 18 namespace media { |
18 | 19 |
19 // Reasons that a cached WebURLResponse will *not* prevent a future request to | 20 // Reasons that a cached WebURLResponse will *not* prevent a future request to |
20 // the server. Reported via UMA, so don't change/reuse previously-existing | 21 // the server. Reported via UMA, so don't change/reuse previously-existing |
21 // values. | 22 // values. |
22 enum UncacheableReason { | 23 enum UncacheableReason { |
23 kNoData = 1 << 0, // Not 200 or 206. | 24 kNoData = 1 << 0, // Not 200 or 206. |
24 kPre11PartialResponse = 1 << 1, // 206 but HTTP version < 1.1. | 25 kPre11PartialResponse = 1 << 1, // 206 but HTTP version < 1.1. |
25 kNoStrongValidatorOnPartialResponse = 1 << 2, // 206, no strong validator. | 26 kNoStrongValidatorOnPartialResponse = 1 << 2, // 206, no strong validator. |
26 kShortMaxAge = 1 << 3, // Max age less than 1h (arbitrary value). | 27 kShortMaxAge = 1 << 3, // Max age less than 1h (arbitrary value). |
27 kExpiresTooSoon = 1 << 4, // Expires in less than 1h (arbitrary value). | 28 kExpiresTooSoon = 1 << 4, // Expires in less than 1h (arbitrary value). |
28 kHasMustRevalidate = 1 << 5, // Response asks for revalidation. | 29 kHasMustRevalidate = 1 << 5, // Response asks for revalidation. |
29 kNoCache = 1 << 6, // Response included a no-cache header. | 30 kNoCache = 1 << 6, // Response included a no-cache header. |
30 kNoStore = 1 << 7, // Response included a no-store header. | 31 kNoStore = 1 << 7, // Response included a no-store header. |
31 kMaxReason // Needs to be one more than max legitimate reason. | 32 kMaxReason // Needs to be one more than max legitimate reason. |
32 }; | 33 }; |
33 | 34 |
34 // Return the logical OR of the reasons "response" cannot be used for a future | 35 // Return the logical OR of the reasons "response" cannot be used for a future |
35 // request (using the disk cache), or 0 if it might be useful. | 36 // request (using the disk cache), or 0 if it might be useful. |
36 uint32 MEDIA_BLINK_EXPORT | 37 uint32 MEDIA_BLINK_EXPORT |
37 GetReasonsForUncacheability(const blink::WebURLResponse& response); | 38 GetReasonsForUncacheability(const blink::WebURLResponse& response); |
38 | 39 |
| 40 // Returns when we should evict data from this response from our |
| 41 // memory cache. Note that we may still cache data longer if |
| 42 // a audio/video tag is currently using it. |
| 43 base::TimeTicks MEDIA_BLINK_EXPORT |
| 44 GetMemoryCacheValidUntil(const blink::WebURLResponse& response); |
| 45 |
39 } // namespace media | 46 } // namespace media |
40 | 47 |
41 #endif // MEDIA_BLINK_CACHE_UTIL_H_ | 48 #endif // MEDIA_BLINK_CACHE_UTIL_H_ |
OLD | NEW |