// Copyright (c) 2011 The Chromium Authors. All rights reserved. // Use of this source code is governed by a BSD-style license that can be // found in the LICENSE file. #ifndef CHROME_BROWSER_WEB_RESOURCE_WEB_RESOURCE_SERVICE_H_ #define CHROME_BROWSER_WEB_RESOURCE_WEB_RESOURCE_SERVICE_H_ #pragma once #include #include "base/memory/ref_counted.h" #include "base/memory/scoped_ptr.h" #include "base/memory/weak_ptr.h" #include "content/public/common/url_fetcher_delegate.h" class PrefService; class ResourceDispatcherHost; namespace base { class DictionaryValue; } // A WebResourceService fetches JSON data from a web server and periodically // refreshes it. class WebResourceService : public base::RefCountedThreadSafe, public content::URLFetcherDelegate { public: WebResourceService(PrefService* prefs, const char* web_resource_server, bool apply_locale_to_url_, const char* last_update_time_pref_name, int start_fetch_delay_ms, int cache_update_delay_ms); // Sleep until cache needs to be updated, but always for at least // |start_fetch_delay_ms| so we don't interfere with startup. // Then begin updating resources. void StartAfterDelay(); protected: virtual ~WebResourceService(); virtual void Unpack(const base::DictionaryValue& parsed_json) = 0; PrefService* prefs_; private: class UnpackerClient; friend class base::RefCountedThreadSafe; // content::URLFetcherDelegate implementation: virtual void OnURLFetchComplete(const content::URLFetcher* source) OVERRIDE; // Schedules a fetch after |delay_ms| milliseconds. void ScheduleFetch(int64 delay_ms); // Starts fetching data from the server. void StartFetch(); // Set |in_fetch_| to false, clean up temp directories (in the future). void EndFetch(); // So that we can delay our start so as not to affect start-up time; also, // so that we can schedule future cache updates. base::WeakPtrFactory weak_ptr_factory_; // The tool that fetches the url data from the server. scoped_ptr url_fetcher_; // True if we are currently fetching or unpacking data. If we are asked to // start a fetch when we are still fetching resource data, schedule another // one in |cache_update_delay_ms_| time, and silently exit. bool in_fetch_; // URL that hosts the web resource. const char* web_resource_server_; // Indicates whether we should append locale to the web resource server URL. bool apply_locale_to_url_; // Pref name to store the last update's time. const char* last_update_time_pref_name_; // Delay on first fetch so we don't interfere with startup. int start_fetch_delay_ms_; // Delay between calls to update the web resource cache. This delay may be // different for different builds of Chrome. int cache_update_delay_ms_; DISALLOW_COPY_AND_ASSIGN(WebResourceService); }; #endif // CHROME_BROWSER_WEB_RESOURCE_WEB_RESOURCE_SERVICE_H_