Chromium Code Reviews
chromiumcodereview-hr@appspot.gserviceaccount.com (chromiumcodereview-hr) | Please choose your nickname with Settings | Help | Chromium Project | Gerrit Changes | Sign out
(1256)

Side by Side Diff: net/url_request/url_request_prepackaged_interceptor.h

Issue 508473002: Componentize component_updater: Move URLRequestPrepackagedInterceptor from content/ to net/ (Closed) Base URL: https://chromium.googlesource.com/chromium/src.git@master
Patch Set: self review Created 6 years, 3 months ago
Use n/p to move between diff chunks; N/P to move between comments. Draft comments are only viewable by you.
Jump to:
View unified diff | Download patch
OLDNEW
1 // Copyright (c) 2012 The Chromium Authors. All rights reserved. 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 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 CHROME_BROWSER_COMPONENT_UPDATER_COMPONENT_UPDATER_INTERCEPTOR_H_ 5 #ifndef NET_URL_REQUEST_URL_REQUEST_PREPACKAGED_INTERCEPTOR_H_
6 #define CHROME_BROWSER_COMPONENT_UPDATER_COMPONENT_UPDATER_INTERCEPTOR_H_ 6 #define NET_URL_REQUEST_URL_REQUEST_PREPACKAGED_INTERCEPTOR_H_
7 7
8 #include <string> 8 #include <string>
9 9
10 #include "base/basictypes.h" 10 #include "base/basictypes.h"
11 #include "base/memory/ref_counted.h"
11 12
12 class GURL; 13 class GURL;
13 14
14 namespace base { 15 namespace base {
15 class FilePath; 16 class FilePath;
17 class TaskRunner;
16 } 18 }
17 19
18 namespace content { 20 namespace net {
19 21
20 // Intercepts HTTP requests and gives pre-defined responses to specified URLs. 22 // Intercepts HTTP requests and gives pre-defined responses to specified URLs.
21 // The pre-defined responses are loaded from files on disk. The interception 23 // The pre-defined responses are loaded from files on disk. The interception
22 // occurs while the URLRequestPrepackagedInterceptor is alive. 24 // occurs while the URLRequestPrepackagedInterceptor is alive.
23 class URLRequestPrepackagedInterceptor { 25 class URLRequestPrepackagedInterceptor {
wtc 2014/08/26 18:15:59 I think chrome/browser/net is a better home for th
Ryan Sleevi 2014/08/26 18:21:09 Except that they wish to use it from iOS
tommycli 2014/08/26 18:21:34 I can't do that, as components/ cannot depend on c
24 public: 26 public:
25 // Registers an interceptor for urls using |scheme| and |hostname|. Urls 27 // Registers an interceptor for urls using |scheme| and |hostname|. Urls
26 // passed to "SetResponse" are required to use |scheme| and |hostname|. 28 // passed to "SetResponse" are required to use |scheme| and |hostname|.
27 URLRequestPrepackagedInterceptor(const std::string& scheme, 29 URLRequestPrepackagedInterceptor(
28 const std::string& hostname); 30 const std::string& scheme,
31 const std::string& hostname,
32 const scoped_refptr<base::TaskRunner>& io_task_runner,
Sorin Jianu 2014/08/26 20:32:52 Any reason we are passing ref counted pointers by
tommycli 2014/08/26 21:06:58 Quote from that page: The one exception is functi
Sorin Jianu 2014/08/26 23:31:50 ok, sg, using CS shows that passing scoped_refptr
33 const scoped_refptr<base::TaskRunner>& worker_task_runner);
29 virtual ~URLRequestPrepackagedInterceptor(); 34 virtual ~URLRequestPrepackagedInterceptor();
30 35
31 // When requests for |url| arrive, respond with the contents of |path|. The 36 // When requests for |url| arrive, respond with the contents of |path|. The
32 // hostname and scheme of |url| must match the corresponding parameters 37 // hostname and scheme of |url| must match the corresponding parameters
33 // passed as constructor arguments. 38 // passed as constructor arguments.
34 void SetResponse(const GURL& url, const base::FilePath& path); 39 void SetResponse(const GURL& url, const base::FilePath& path);
35 40
36 // Identical to SetResponse except that query parameters are ignored on 41 // Identical to SetResponse except that query parameters are ignored on
37 // incoming URLs when comparing against |url|. 42 // incoming URLs when comparing against |url|.
38 void SetResponseIgnoreQuery(const GURL& url, const base::FilePath& path); 43 void SetResponseIgnoreQuery(const GURL& url, const base::FilePath& path);
39 44
40 // Returns how many requests have been issued that have a stored reply. 45 // Returns how many requests have been issued that have a stored reply.
41 int GetHitCount(); 46 int GetHitCount();
42 47
43 private: 48 private:
44 class Delegate; 49 class Delegate;
45 50
46 const std::string scheme_; 51 const std::string scheme_;
47 const std::string hostname_; 52 const std::string hostname_;
48 53
49 // After creation, |delegate_| lives on the IO thread, and a task to delete 54 const scoped_refptr<base::TaskRunner> io_task_runner_;
Sorin Jianu 2014/08/26 20:32:52 I wonder what is the meaning of the "const" object
tommycli 2014/08/26 21:06:58 I thought: After we initialize its value, it canno
Sorin Jianu 2014/08/26 23:31:49 I think this is a strange idiom. It is hard to cou
tommycli 2014/08/26 23:45:22 Oh I see. You're saying it gives the false impress
50 // it is posted from ~URLRequestPrepackagedInterceptor(). 55
56 // After creation, |delegate_| lives on the thread of the |io_task_runner_|,
57 // and a task to delete it is posted from ~URLRequestPrepackagedInterceptor().
51 Delegate* delegate_; 58 Delegate* delegate_;
52 59
53 DISALLOW_COPY_AND_ASSIGN(URLRequestPrepackagedInterceptor); 60 DISALLOW_COPY_AND_ASSIGN(URLRequestPrepackagedInterceptor);
54 }; 61 };
55 62
56 // Specialization of URLRequestPrepackagedInterceptor where scheme is "http" and 63 // Specialization of URLRequestPrepackagedInterceptor where scheme is "http" and
57 // hostname is "localhost". 64 // hostname is "localhost".
58 class URLLocalHostRequestPrepackagedInterceptor 65 class URLLocalHostRequestPrepackagedInterceptor
59 : public URLRequestPrepackagedInterceptor { 66 : public URLRequestPrepackagedInterceptor {
60 public: 67 public:
61 URLLocalHostRequestPrepackagedInterceptor(); 68 URLLocalHostRequestPrepackagedInterceptor(
69 const scoped_refptr<base::TaskRunner>& io_task_runner,
70 const scoped_refptr<base::TaskRunner>& worker_task_runner);
62 71
63 private: 72 private:
64 DISALLOW_COPY_AND_ASSIGN(URLLocalHostRequestPrepackagedInterceptor); 73 DISALLOW_COPY_AND_ASSIGN(URLLocalHostRequestPrepackagedInterceptor);
65 }; 74 };
66 75
67 } // namespace content 76 } // namespace net
68 77
69 #endif // CHROME_BROWSER_COMPONENT_UPDATER_COMPONENT_UPDATER_INTERCEPTOR_H_ 78 #endif // NET_URL_REQUEST_URL_REQUEST_PREPACKAGED_INTERCEPTOR_H_
OLDNEW

Powered by Google App Engine
This is Rietveld 408576698