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

Side by Side Diff: chrome/browser/ui/search/new_tab_page_interceptor_service.h

Issue 845973005: [New Tab Page] Change the mechanism to intercept online NTP errors (Closed) Base URL: https://chromium.googlesource.com/chromium/src.git@master
Patch Set: test comment fix Created 5 years, 11 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
(Empty)
1 // Copyright 2015 The Chromium Authors. All rights reserved.
2 // Use of this source code is governed by a BSD-style license that can be
3 // found in the LICENSE file.
4
5 #ifndef CHROME_BROWSER_UI_SEARCH_NEW_TAB_PAGE_INTERCEPTOR_SERVICE_H_
6 #define CHROME_BROWSER_UI_SEARCH_NEW_TAB_PAGE_INTERCEPTOR_SERVICE_H_
7
8 #include "base/macros.h"
9 #include "base/memory/scoped_ptr.h"
10 #include "base/memory/weak_ptr.h"
11 #include "components/keyed_service/core/keyed_service.h"
12 #include "components/search_engines/template_url_service_observer.h"
13 #include "net/url_request/url_request_interceptor.h"
14 #include "url/gurl.h"
15
16 class NewTabPageInterceptor;
17 class Profile;
18 class TemplateURLService;
19
20 namespace net {
21 class URLRequestInterceptor;
22 }
23
24 // Owns a NewTabPageInterceptor.
25 class NewTabPageInterceptorService : public KeyedService,
26 public TemplateURLServiceObserver {
27 public:
28 explicit NewTabPageInterceptorService(Profile* profile);
29 ~NewTabPageInterceptorService() override;
30
31 // TemplateURLServiceObserver override.
32 void OnTemplateURLServiceChanged() override;
33
34 scoped_ptr<net::URLRequestInterceptor> CreateInterceptor();
35
36 private:
37 // Implementation of the URLRequestInterceptor for the New Tab Page. Will look
38 // at incoming response from the server and possibly divert to the local NTP.
39 class NewTabPageInterceptor : public net::URLRequestInterceptor {
mmenke 2015/01/22 20:53:51 I'd suggest just forward declaring the class here,
Mathieu 2015/01/22 21:44:22 Done. Have a look!
40 public:
41 explicit NewTabPageInterceptor(const GURL& new_tab_url);
42
43 ~NewTabPageInterceptor() override;
44
45 base::WeakPtr<NewTabPageInterceptor> GetWeakPtr();
46
47 void SetNewTabPageURL(const GURL& new_tab_page_url);
48
49 private:
50 // Overrides from net::URLRequestInterceptor:
51 net::URLRequestJob* MaybeInterceptRequest(
52 net::URLRequest* request,
53 net::NetworkDelegate* network_delegate) const override;
54 net::URLRequestJob* MaybeInterceptResponse(
55 net::URLRequest* request,
56 net::NetworkDelegate* network_delegate) const override;
57
58 GURL new_tab_url_;
59 base::WeakPtrFactory<NewTabPageInterceptor> weak_factory_;
60
61 DISALLOW_COPY_AND_ASSIGN(NewTabPageInterceptor);
62 };
63
64 Profile* profile_;
65 base::WeakPtr<NewTabPageInterceptor> interceptor_;
66 // The TemplateURLService that we are observing. It will outlive this
67 // NewTabPageInterceptorService due to the dependency declared in
68 // NewTabPageInterceptorServiceFactory.
69 TemplateURLService* template_url_service_;
70
71 DISALLOW_COPY_AND_ASSIGN(NewTabPageInterceptorService);
72 };
73
74 #endif // CHROME_BROWSER_UI_SEARCH_NEW_TAB_PAGE_INTERCEPTOR_SERVICE_H_
OLDNEW

Powered by Google App Engine
This is Rietveld 408576698