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
3 // found in the LICENSE file.
5 #ifndef CHROME_BROWSER_WEB_RESOURCE_WEB_RESOURCE_SERVICE_H_
6 #define CHROME_BROWSER_WEB_RESOURCE_WEB_RESOURCE_SERVICE_H_
10 #include "base/memory/ref_counted.h"
11 #include "base/memory/scoped_ptr.h"
12 #include "base/memory/weak_ptr.h"
13 #include "chrome/browser/web_resource/json_asynchronous_unpacker.h"
14 #include "chrome/browser/web_resource/resource_request_allowed_notifier.h"
15 #include "net/url_request/url_fetcher_delegate.h"
21 class DictionaryValue
;
28 // A WebResourceService fetches JSON data from a web server and periodically
30 class WebResourceService
31 : public net::URLFetcherDelegate
,
32 public JSONAsynchronousUnpackerDelegate
,
33 public base::RefCountedThreadSafe
<WebResourceService
>,
34 public ResourceRequestAllowedNotifier::Observer
{
36 WebResourceService(PrefService
* prefs
,
37 const GURL
& web_resource_server
,
38 bool apply_locale_to_url_
,
39 const char* last_update_time_pref_name
,
40 int start_fetch_delay_ms
,
41 int cache_update_delay_ms
);
43 // Sleep until cache needs to be updated, but always for at least
44 // |start_fetch_delay_ms| so we don't interfere with startup.
45 // Then begin updating resources.
46 void StartAfterDelay();
48 // JSONAsynchronousUnpackerDelegate methods.
49 virtual void OnUnpackFinished(
50 const base::DictionaryValue
& parsed_json
) OVERRIDE
;
51 virtual void OnUnpackError(const std::string
& error_message
) OVERRIDE
;
54 virtual ~WebResourceService();
56 // For the subclasses to process the result of a fetch.
57 virtual void Unpack(const base::DictionaryValue
& parsed_json
) = 0;
63 friend class base::RefCountedThreadSafe
<WebResourceService
>;
65 // net::URLFetcherDelegate implementation:
66 virtual void OnURLFetchComplete(const net::URLFetcher
* source
) OVERRIDE
;
68 // Schedules a fetch after |delay_ms| milliseconds.
69 void ScheduleFetch(int64 delay_ms
);
71 // Starts fetching data from the server.
74 // Set |in_fetch_| to false, clean up temp directories (in the future).
77 // Implements ResourceRequestAllowedNotifier::Observer.
78 virtual void OnResourceRequestsAllowed() OVERRIDE
;
80 // Helper class used to tell this service if it's allowed to make network
82 ResourceRequestAllowedNotifier resource_request_allowed_notifier_
;
84 // The tool that fetches the url data from the server.
85 scoped_ptr
<net::URLFetcher
> url_fetcher_
;
87 // The tool that parses and transforms the json data. Weak reference as it
88 // deletes itself once the unpack is done.
89 JSONAsynchronousUnpacker
* json_unpacker_
;
91 // True if we are currently fetching or unpacking data. If we are asked to
92 // start a fetch when we are still fetching resource data, schedule another
93 // one in |cache_update_delay_ms_| time, and silently exit.
96 // URL that hosts the web resource.
97 GURL web_resource_server_
;
99 // Indicates whether we should append locale to the web resource server URL.
100 bool apply_locale_to_url_
;
102 // Pref name to store the last update's time.
103 const char* last_update_time_pref_name_
;
105 // Delay on first fetch so we don't interfere with startup.
106 int start_fetch_delay_ms_
;
108 // Delay between calls to update the web resource cache. This delay may be
109 // different for different builds of Chrome.
110 int cache_update_delay_ms_
;
112 // So that we can delay our start so as not to affect start-up time; also,
113 // so that we can schedule future cache updates.
114 base::WeakPtrFactory
<WebResourceService
> weak_ptr_factory_
;
116 DISALLOW_COPY_AND_ASSIGN(WebResourceService
);
119 #endif // CHROME_BROWSER_WEB_RESOURCE_WEB_RESOURCE_SERVICE_H_