 Chromium Code Reviews
 Chromium Code Reviews Issue 6201005:
  Initial support for partitioning cookies for isolated apps.  (Closed) 
  Base URL: svn://svn.chromium.org/chrome/trunk/src
    
  
    Issue 6201005:
  Initial support for partitioning cookies for isolated apps.  (Closed) 
  Base URL: svn://svn.chromium.org/chrome/trunk/src| Index: chrome/browser/profiles/profile_impl_io_data.h | 
| diff --git a/chrome/browser/profiles/profile_impl_io_data.h b/chrome/browser/profiles/profile_impl_io_data.h | 
| index d4fcfc097efbb70d4bd7b78f9222d3b78369c3a5..0e2e7ecc8bff4e679cdc52e97d61bf81c52c9592 100644 | 
| --- a/chrome/browser/profiles/profile_impl_io_data.h | 
| +++ b/chrome/browser/profiles/profile_impl_io_data.h | 
| @@ -7,6 +7,7 @@ | 
| #pragma once | 
| #include "base/basictypes.h" | 
| +#include "base/hash_tables.h" | 
| #include "base/ref_counted.h" | 
| #include "chrome/browser/profiles/profile_io_data.h" | 
| @@ -37,14 +38,26 @@ class ProfileImplIOData : public ProfileIOData { | 
| int media_cache_max_size, | 
| const FilePath& extensions_cookie_path); | 
| + // Called on-demand for each isolated app. | 
| + void InitIsolatedApp(const Extension* app, | 
| + const FilePath& cookie_path, | 
| + const FilePath& cache_path, | 
| + int cache_max_size); | 
| + | 
| scoped_refptr<ChromeURLRequestContextGetter> | 
| GetMainRequestContextGetter() const; | 
| scoped_refptr<ChromeURLRequestContextGetter> | 
| GetMediaRequestContextGetter() const; | 
| scoped_refptr<ChromeURLRequestContextGetter> | 
| GetExtensionsRequestContextGetter() const; | 
| + scoped_refptr<ChromeURLRequestContextGetter> | 
| 
willchan no longer on Chromium
2011/03/02 19:52:17
I think the key will be for you to create a subcla
 
Charlie Reis
2011/03/03 01:08:05
Thanks for the pointer.  I think it's actually sim
 | 
| + GetIsolatedAppRequestContextGetter(const Extension* app) const; | 
| private: | 
| + typedef base::hash_map<std::string, | 
| + scoped_refptr<ChromeURLRequestContextGetter> > | 
| + ChromeURLRequestContextGetterMap; | 
| + | 
| // Lazily initialize ProfileParams. We do this on the calls to | 
| // Get*RequestContextGetter(), so we only initialize ProfileParams right | 
| // before posting a task to the IO thread to start using them. This prevents | 
| @@ -64,6 +77,7 @@ class ProfileImplIOData : public ProfileIOData { | 
| media_request_context_getter_; | 
| mutable scoped_refptr<ChromeURLRequestContextGetter> | 
| extensions_request_context_getter_; | 
| + mutable ChromeURLRequestContextGetterMap app_request_context_getter_map_; | 
| const scoped_refptr<ProfileImplIOData> io_data_; | 
| Profile* const profile_; | 
| @@ -92,21 +106,31 @@ class ProfileImplIOData : public ProfileIOData { | 
| ProfileParams profile_params; | 
| }; | 
| + typedef base::hash_map<std::string, LazyParams*> LazyParamsMap; | 
| + | 
| ProfileImplIOData(); | 
| virtual ~ProfileImplIOData(); | 
| // Lazily initializes ProfileImplIOData. | 
| virtual void LazyInitializeInternal() const; | 
| + virtual scoped_refptr<RequestContext> | 
| + InitializeAppRequestContext(const Extension *app) const; | 
| virtual scoped_refptr<ChromeURLRequestContext> | 
| AcquireMainRequestContext() const; | 
| virtual scoped_refptr<ChromeURLRequestContext> | 
| AcquireMediaRequestContext() const; | 
| virtual scoped_refptr<ChromeURLRequestContext> | 
| AcquireExtensionsRequestContext() const; | 
| + virtual scoped_refptr<ChromeURLRequestContext> | 
| + AcquireIsolatedAppRequestContext( | 
| + const Extension* installed_app) const; | 
| // Lazy initialization params. | 
| mutable scoped_ptr<LazyParams> lazy_params_; | 
| + // One LazyParams per isolated app. | 
| + mutable LazyParamsMap lazy_params_map_; | 
| + | 
| mutable scoped_refptr<RequestContext> main_request_context_; | 
| mutable scoped_refptr<RequestContext> media_request_context_; | 
| mutable scoped_refptr<RequestContext> extensions_request_context_; |