// 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_CHROMEOS_CUSTOMIZATION_DOCUMENT_H_ #define CHROME_BROWSER_CHROMEOS_CUSTOMIZATION_DOCUMENT_H_ #pragma once #include <map> #include <string> #include "base/gtest_prod_util.h" #include "base/memory/scoped_ptr.h" #include "base/memory/singleton.h" #include "base/timer.h" #include "base/values.h" #include "chrome/common/net/url_fetcher.h" #include "googleurl/src/gurl.h" class DictionaryValue; class FilePath; class ListValue; class PrefService; namespace base { class Time; } namespace chromeos { class SystemAccess; // Base class for OEM customization document classes. class CustomizationDocument { public: virtual ~CustomizationDocument() {} // Return true if the document was successfully fetched and parsed. bool IsReady() const { return root_.get(); } protected: CustomizationDocument() {} virtual bool LoadManifestFromFile(const FilePath& manifest_path); virtual bool LoadManifestFromString(const std::string& manifest); std::string GetLocaleSpecificString(const std::string& locale, const std::string& dictionary_name, const std::string& entry_name) const; scoped_ptr<DictionaryValue> root_; private: DISALLOW_COPY_AND_ASSIGN(CustomizationDocument); }; // OEM startup customization document class. // Now StartupCustomizationDocument is loaded in c-tor so just after create it // may be ready or not (if manifest is missing or corrupted) and this state // won't be changed later (i.e. IsReady() always return the same value). class StartupCustomizationDocument : public CustomizationDocument { public: static StartupCustomizationDocument* GetInstance(); const std::string& initial_locale() const { return initial_locale_; } const std::string& initial_timezone() const { return initial_timezone_; } const std::string& keyboard_layout() const { return keyboard_layout_; } const std::string& registration_url() const { return registration_url_; } std::string GetHelpPage(const std::string& locale) const; std::string GetEULAPage(const std::string& locale) const; private: FRIEND_TEST(StartupCustomizationDocumentTest, Basic); FRIEND_TEST(StartupCustomizationDocumentTest, VPD); FRIEND_TEST(StartupCustomizationDocumentTest, BadManifest); friend struct DefaultSingletonTraits<StartupCustomizationDocument>; // C-tor for singleton construction. StartupCustomizationDocument(); // C-tor for test construction. StartupCustomizationDocument(SystemAccess* system_access, const std::string& manifest); void Init(SystemAccess* system_access); // If |attr| exists in machine stat, assign it to |value|. void InitFromMachineStatistic(const char* attr, std::string* value); std::string initial_locale_; std::string initial_timezone_; std::string keyboard_layout_; std::string registration_url_; DISALLOW_COPY_AND_ASSIGN(StartupCustomizationDocument); }; // OEM services customization document class. // ServicesCustomizationDocument is fetched from network or local file but on // FILE thread therefore it may not be ready just after creation. Fetching of // the manifest should be initiated outside this class by calling // StartFetching() method. User of the file should check IsReady before use it. class ServicesCustomizationDocument : public CustomizationDocument, private URLFetcher::Delegate { public: // OEM specific carrier deal. struct CarrierDeal { explicit CarrierDeal(DictionaryValue* deal_dict); // Returns string with the specified |locale| and |id|. // If there's no version for |locale|, default one is returned. // If there's no string with specified |id|, empty string is returned. std::string GetLocalizedString(const std::string& locale, const std::string& id) const; std::string deal_locale; std::string top_up_url; int notification_count; base::Time expire_date; DictionaryValue* localized_strings; }; // Carrier ID (ex. "Verizon (us)") mapping to carrier deals. typedef std::map<std::string, CarrierDeal*> CarrierDeals; static ServicesCustomizationDocument* GetInstance(); // Registers preferences. static void RegisterPrefs(PrefService* local_state); // Return true if the customization was applied. Customization is applied only // once per machine. static bool WasApplied(); // Start fetching customization document. void StartFetching(); // Apply customization and save in machine options that customization was // applied successfully. Return true if customization was applied. bool ApplyCustomization(); std::string GetInitialStartPage(const std::string& locale) const; std::string GetSupportPage(const std::string& locale) const; // Returns carrier deal by specified |carrier_id|. // Also checks deal restrictions, such as deal locale (launch locale) and // deal expiration date if |check_restrictions| is true. const ServicesCustomizationDocument::CarrierDeal* GetCarrierDeal( const std::string& carrier_id, bool check_restrictions) const; protected: virtual bool LoadManifestFromString(const std::string& manifest) OVERRIDE; private: FRIEND_TEST(ServicesCustomizationDocumentTest, Basic); FRIEND_TEST(ServicesCustomizationDocumentTest, BadManifest); FRIEND_TEST(ServicesCustomizationDocumentTest, DealOtherLocale); FRIEND_TEST(ServicesCustomizationDocumentTest, NoDealRestrictions); FRIEND_TEST(ServicesCustomizationDocumentTest, OldDeal); friend struct DefaultSingletonTraits<ServicesCustomizationDocument>; // C-tor for singleton construction. ServicesCustomizationDocument(); // C-tor for test construction. ServicesCustomizationDocument(const std::string& manifest, const std::string& initial_locale); // Save applied state in machine settings. static void SetApplied(bool val); // Overriden from URLFetcher::Delegate: virtual void OnURLFetchComplete(const URLFetcher* source, const GURL& url, const net::URLRequestStatus& status, int response_code, const ResponseCookies& cookies, const std::string& data); // Initiate file fetching. void StartFileFetch(); // Executes on FILE thread and reads file to string. void ReadFileInBackground(const FilePath& file); // Services customization manifest URL. GURL url_; // URLFetcher instance. scoped_ptr<URLFetcher> url_fetcher_; // Timer to retry fetching file if network is not available. base::OneShotTimer<ServicesCustomizationDocument> retry_timer_; // How many times we already tried to fetch customization manifest file. int num_retries_; // Carrier-specific deals. CarrierDeals carrier_deals_; // Initial locale value. std::string initial_locale_; DISALLOW_COPY_AND_ASSIGN(ServicesCustomizationDocument); }; } // namespace chromeos #endif // CHROME_BROWSER_CHROMEOS_CUSTOMIZATION_DOCUMENT_H_