summaryrefslogtreecommitdiffstats
path: root/chrome/browser/template_url.h
diff options
context:
space:
mode:
Diffstat (limited to 'chrome/browser/template_url.h')
-rw-r--r--chrome/browser/template_url.h448
1 files changed, 448 insertions, 0 deletions
diff --git a/chrome/browser/template_url.h b/chrome/browser/template_url.h
new file mode 100644
index 0000000..274c835
--- /dev/null
+++ b/chrome/browser/template_url.h
@@ -0,0 +1,448 @@
+// Copyright 2008, Google Inc.
+// All rights reserved.
+//
+// Redistribution and use in source and binary forms, with or without
+// modification, are permitted provided that the following conditions are
+// met:
+//
+// * Redistributions of source code must retain the above copyright
+// notice, this list of conditions and the following disclaimer.
+// * Redistributions in binary form must reproduce the above
+// copyright notice, this list of conditions and the following disclaimer
+// in the documentation and/or other materials provided with the
+// distribution.
+// * Neither the name of Google Inc. nor the names of its
+// contributors may be used to endorse or promote products derived from
+// this software without specific prior written permission.
+//
+// THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS
+// "AS IS" AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT
+// LIMITED TO, THE IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR
+// A PARTICULAR PURPOSE ARE DISCLAIMED. IN NO EVENT SHALL THE COPYRIGHT
+// OWNER OR CONTRIBUTORS BE LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL,
+// SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT
+// LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS OF USE,
+// DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON ANY
+// THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT
+// (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE
+// OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE.
+
+#ifndef CHROME_BROWSER_TEMPLATE_URL_H__
+#define CHROME_BROWSER_TEMPLATE_URL_H__
+
+#include <vector>
+
+#include "base/basictypes.h"
+#include "base/time.h"
+#include "chrome/common/l10n_util.h"
+#include "googleurl/src/gurl.h"
+
+class TemplateURL;
+
+// TemplateURL represents the relevant portions of the Open Search Description
+// Document (http://www.opensearch.org/Specifications/OpenSearch).
+// The main use case for TemplateURL is to use the TemplateURLRef returned by
+// suggestions_url or url for keyword/suggestion expansion:
+// . suggestions_url describes a URL that is ideal for as you type suggestions.
+// The returned results are in the mime type application/x-suggestions+json.
+// . url describes a URL that may be used as a shortcut. Returned results are
+// are text/html.
+// Before using either one, make sure it's non-NULL, and if you intend to use
+// it to replace search terms, make sure SupportsReplacement returns true.
+// To use either URL invoke the ReplaceSearchTerms method on the corresponding
+// TemplateURLRef.
+//
+// For files parsed from the Web, be sure and invoke IsValid. IsValid returns
+// true if the URL could be parsed.
+//
+// Both TemplateURL and TemplateURLRef have value semantics. This allows the
+// UI to create a copy while the user modifies the values.
+class TemplateURLRef {
+ public:
+ // Magic numbers to pass to ReplaceSearchTerms() for the |accepted_suggestion|
+ // parameter. Most callers aren't using Suggest capabilities and should just
+ // pass NO_SUGGESTIONS_AVAILABLE.
+ // NOTE: Because positive values are meaningful, make sure these are negative!
+ enum AcceptedSuggestion {
+ NO_SUGGESTION_CHOSEN = -1,
+ NO_SUGGESTIONS_AVAILABLE = -2,
+ };
+
+ TemplateURLRef();
+
+ TemplateURLRef(const std::wstring& url, int index_offset, int page_offset)
+ : url_(url),
+ index_offset_(index_offset),
+ page_offset_(page_offset),
+ parsed_(false),
+ valid_(false),
+ supports_replacements_(false) {
+ }
+
+ // Returns true if this URL supports replacement.
+ bool SupportsReplacement() const;
+
+ // Returns a string that is the result of replacing the search terms in
+ // the url with the specified value.
+ //
+ // If this TemplateURLRef does not support replacement (SupportsReplacement
+ // returns false), an empty string is returned.
+ //
+ // The TemplateURL is used to determine the input encoding for the term.
+ std::wstring ReplaceSearchTerms(
+ const TemplateURL& host,
+ const std::wstring& terms,
+ int accepted_suggestion,
+ const std::wstring& original_query_for_suggestion) const;
+
+ // Returns the raw URL. None of the parameters will have been replaced.
+ const std::wstring& url() const { return url_; }
+
+ // Returns the index number of the first search result.
+ int index_offset() const { return index_offset_; }
+
+ // Returns the page number of the first search results.
+ int page_offset() const { return page_offset_; }
+
+ // Returns true if the TemplateURLRef is valid. An invalid TemplateURLRef is
+ // one that contains unknown terms, or invalid characters.
+ bool IsValid() const;
+
+ // Returns a string representation of this TemplateURLRef suitable for
+ // display. The display format is the same as the format used by Firefox.
+ std::wstring DisplayURL() const;
+
+ // Converts a string as returned by DisplayURL back into a string as
+ // understood by TemplateURLRef.
+ static std::wstring DisplayURLToURLRef(const std::wstring& display_url);
+
+ // If this TemplateURLRef is valid and contains one search term, this returns
+ // the host/path of the URL, otherwise this returns an empty string.
+ const std::string& GetHost() const;
+ const std::string& GetPath() const;
+
+ // If this TemplateURLRef is valid and contains one search term, this returns
+ // the key of the search term, otherwise this returns an empty string.
+ const std::string& GetSearchTermKey() const;
+
+ // Converts the specified term in the encoding of the host TemplateURL to a
+ // wide string.
+ std::wstring SearchTermToWide(const TemplateURL& host,
+ const std::string& term) const;
+
+ // Returns true if this TemplateURLRef has a replacement term of
+ // {google:baseURL} or {google:baseSuggestURL}.
+ bool HasGoogleBaseURLs() const;
+
+ // TemplateURLRef internally caches values to make replacement quick. This
+ // method invalidates any cached values. You shouldn't have a need to invoke
+ // this, it's invoked by TemplateURLModel when the google base url changes.
+ void InvalidateCachedValues() const;
+
+ private:
+ friend class TemplateURL;
+ friend class TemplateURLModelTest;
+ friend class TemplateURLTest;
+
+ // Enumeration of the known types.
+ enum ReplacementType {
+ ENCODING,
+ GOOGLE_ACCEPTED_SUGGESTION,
+ GOOGLE_BASE_URL,
+ GOOGLE_BASE_SUGGEST_URL,
+ GOOGLE_ORIGINAL_QUERY_FOR_SUGGESTION,
+ GOOGLE_RLZ,
+ GOOGLE_UNESCAPED_SEARCH_TERMS,
+ LANGUAGE,
+ SEARCH_TERMS,
+ };
+
+ // Used to identify an element of the raw url that can be replaced.
+ struct Replacement {
+ Replacement(ReplacementType type, int index) : type(type), index(index) {}
+ ReplacementType type;
+ int index;
+ };
+
+ // The list of elements to replace.
+ typedef std::vector<struct Replacement> Replacements;
+
+ // Resets the url.
+ void Set(const std::wstring& url, int index_offset, int page_offset);
+
+ // Parses the parameter in url at the specified offset. start/end specify the
+ // range of the parameter in the url, including the braces. If the parameter
+ // is valid, url is updated to reflect the appropriate parameter. If
+ // the parameter is one of the known parameters an element is added to
+ // replacements indicating the type and range of the element.
+ //
+ // If the parameter is not a known parameter, false is returned.
+ bool ParseParameter(size_t start,
+ size_t end,
+ std::wstring* url,
+ Replacements* replacements) const;
+
+ // Parses the specified url, replacing parameters as necessary. If
+ // successful, valid is set to true, and the parsed url is returned. For all
+ // known parameters that are encountered an entry is added to replacements.
+ // If there is an error parsing (unknown parameter, or bogus url), valid is
+ // set to false, and an empty string is returned.
+ std::wstring ParseURL(const std::wstring& url,
+ Replacements* replacements,
+ bool* valid) const;
+
+ // If the url has not yet been parsed, ParseURL is invoked.
+ // NOTE: While this is const, it modifies parsed_, valid_, parsed_url_ and
+ // search_offset_.
+ void ParseIfNecessary() const;
+
+ // Extracts the query key and host from the url.
+ void ParseHostAndSearchTermKey() const;
+
+ // Returns the value for the GOOGLE_BASE_URL term.
+ static std::wstring GoogleBaseURLValue();
+
+ // Returns the value for the GOOGLE_BASE_SUGGEST_URL term.
+ static std::wstring GoogleBaseSuggestURLValue();
+
+ // The raw URL. Where as this contains all the terms (such as {searchTerms}),
+ // parsed_url_ has them all stripped out.
+ std::wstring url_;
+
+ // indexOffset defined for the Url element.
+ int index_offset_;
+
+ // searchOffset defined for the Url element.
+ int page_offset_;
+
+ // Whether the URL has been parsed.
+ mutable bool parsed_;
+
+ // Whether the url was successfully parsed.
+ mutable bool valid_;
+
+ // The parsed URL. All terms have been stripped out of this with
+ // replacements_ giving the index of the terms to replace.
+ mutable std::wstring parsed_url_;
+
+ // Do we support replacement?
+ mutable bool supports_replacements_;
+
+ // The replaceable parts of url (parsed_url_). These are ordered by index
+ // into the string, and may be empty.
+ mutable Replacements replacements_;
+
+ // Host, path and key of the search term. These are only set if the url
+ // contains one search term.
+ mutable std::string host_;
+ mutable std::string path_;
+ mutable std::string search_term_key_;
+
+ // For testing. If non-null this is the replacement value for GOOGLE_BASE_URL
+ // terms.
+ static std::wstring* google_base_url_;
+};
+
+// Describes the relevant portions of a single OSD document.
+class TemplateURL {
+ public:
+ typedef int64 IDType;
+
+ // Describes a single image reference. Each TemplateURL may have
+ // any number (including 0) of ImageRefs.
+ //
+ // If a TemplateURL has no images, the favicon for the generated URL
+ // should be used.
+ struct ImageRef {
+ ImageRef(const std::wstring& type, int width, int height)
+ : type(type), width(width), height(height) {
+ }
+
+ ImageRef(const std::wstring& type, int width, int height, const GURL& url)
+ : type(type), width(width), height(height), url(url) {
+ }
+
+ // Mime type for the image.
+ // ICO image will have the format: image/x-icon or image/vnd.microsoft.icon
+ std::wstring type;
+
+ // Size of the image
+ int width;
+ int height;
+
+ // URL of the image.
+ GURL url;
+ };
+
+ // Generates a favicon URL from the specified url.
+ static GURL GenerateFaviconURL(const GURL& url);
+
+ TemplateURL()
+ : show_in_default_list_(false),
+ safe_for_autoreplace_(false),
+ id_(0),
+ date_created_(Time::Now()),
+ usage_count_(0),
+ prepopulate_id_(0) {}
+ ~TemplateURL() {}
+
+ // A short description of the template. This is the name we show to the user
+ // in various places that use keywords. For example, the location bar shows
+ // this when the user selects the keyword.
+ void set_short_name(const std::wstring& short_name) {
+ short_name_ = short_name;
+ }
+ const std::wstring& short_name() const { return short_name_; }
+
+ // A description of the template; this may be empty.
+ void set_description(const std::wstring& description) {
+ description_ = description;
+ }
+ const std::wstring& description() const { return description_; }
+
+ // URL providing JSON results. This is typically used to provide suggestions
+ // as your type. If NULL, this url does not support suggestions.
+ // Be sure and check the resulting TemplateURLRef for SupportsReplacement
+ // before using.
+ void SetSuggestionsURL(const std::wstring& suggestions_url,
+ int index_offset,
+ int page_offset);
+ const TemplateURLRef* suggestions_url() const {
+ if (suggestions_url_.url().empty())
+ return NULL;
+ return &suggestions_url_;
+ }
+
+ // Parameterized URL for providing the results. This may be NULL.
+ // Be sure and check the resulting TemplateURLRef for SupportsReplacement
+ // before using.
+ void SetURL(const std::wstring& url, int index_offset, int page_offset);
+ // Returns the TemplateURLRef that may be used for search results. This
+ // returns NULL if a url element was not specified.
+ const TemplateURLRef* url() const {
+ if (url_.url().empty())
+ return NULL;
+ return &url_;
+ }
+
+ // URL to the OSD file this came from. May be empty.
+ void set_originating_url(const GURL& url) {
+ originating_url_ = url;
+ }
+ const GURL& originating_url() const { return originating_url_; }
+
+ // The shortcut for this template url. May be empty.
+ void set_keyword(const std::wstring& keyword) {
+ // Case sensitive keyword matching is confusing. As such, we force all
+ // keywords to be lower case.
+ keyword_ = l10n_util::ToLower(keyword);
+ }
+ const std::wstring& keyword() const { return keyword_; }
+
+ // Whether this keyword is shown in the default list of search providers. This
+ // is just a property and does not indicate whether this TemplateURL has
+ // a TemplateURLRef that supports replacement. Use ShowInDefaultList to
+ // test both.
+ // The default value is false.
+ void set_show_in_default_list(bool show_in_default_list) {
+ show_in_default_list_ = show_in_default_list;
+ }
+ bool show_in_default_list() const { return show_in_default_list_; }
+
+ // Returns true if show_in_default_list() is true and this TemplateURL has a
+ // TemplateURLRef that supports replacement.
+ bool ShowInDefaultList() const;
+
+ // Whether it's safe for auto-modification code (the autogenerator and the
+ // code that imports data from other browsers) to replace the TemplateURL.
+ // This should be set to false for any keyword the user edits, or any keyword
+ // that the user clearly manually edited in the past, like a bookmark keyword
+ // from another browser.
+ void set_safe_for_autoreplace(bool safe_for_autoreplace) {
+ safe_for_autoreplace_ = safe_for_autoreplace;
+ }
+ bool safe_for_autoreplace() const { return safe_for_autoreplace_; }
+
+ // Images for this URL. May be empty.
+ void add_image_ref(const ImageRef& ref) { image_refs_.push_back(ref); }
+ const std::vector<ImageRef>& image_refs() const { return image_refs_; }
+
+ // Convenience methods for getting/setting an ImageRef that points to a
+ // favicon. A TemplateURL need not have an ImageRef for a favicon. In such
+ // a situation GetFavIconURL returns an invalid url.
+ //
+ // If url is empty and there is an image ref for a favicon, it is removed.
+ void SetFavIconURL(const GURL& url);
+ GURL GetFavIconURL() const;
+
+ // Set of languages supported. This may be empty.
+ void add_language(const std::wstring& language) {
+ languages_.push_back(language);
+ }
+ const std::vector<std::wstring>& languages() const { return languages_; }
+
+ // Date this keyword was created.
+ //
+ // NOTE: this may be 0, which indicates the keyword was created before we
+ // started tracking creation time.
+ void set_date_created(Time time) { date_created_ = time; }
+ Time date_created() const { return date_created_; }
+
+ // Number of times this keyword has been explicitly used to load a URL. We
+ // don't increment this for uses as the "default search engine" since that's
+ // not really "explicit" usage and incrementing would result in pinning the
+ // user's default search engine(s) to the top of the list of searches on the
+ // New Tab page, de-emphasizing the omnibox as "where you go to search".
+ void set_usage_count(int count) { usage_count_ = count; }
+ int usage_count() const { return usage_count_; }
+
+ // The list of supported encodings for the search terms. This may be empty,
+ // which indicates the terms should be encoded with UTF-8.
+ void set_input_encodings(const std::vector<std::string>& encodings) {
+ input_encodings_ = encodings;
+ }
+ void add_input_encoding(const std::string& encoding) {
+ input_encodings_.push_back(encoding);
+ }
+ const std::vector<std::string>& input_encodings() const {
+ return input_encodings_;
+ }
+
+ // Returns the unique identifier of this TemplateURL. The unique ID is set
+ // by the TemplateURLModel when the TemplateURL is added to it.
+ IDType id() const { return id_; }
+
+ // If this TemplateURL comes from prepopulated data the prepopulate_id is > 0.
+ void set_prepopulate_id(int id) { prepopulate_id_ = id; }
+ int prepopulate_id() const { return prepopulate_id_; }
+
+ private:
+ // For access to set id.
+ friend class WebDatabaseTest;
+ friend class WebDatabase;
+ friend class TemplateURLModel;
+
+ // Unique identifier, used when archived to the database.
+ void set_id(IDType id) { id_ = id;}
+
+ std::wstring short_name_;
+ std::wstring description_;
+ TemplateURLRef suggestions_url_;
+ TemplateURLRef url_;
+ GURL originating_url_;
+ std::wstring keyword_;
+ bool show_in_default_list_;
+ bool safe_for_autoreplace_;
+ std::vector<ImageRef> image_refs_;
+ std::vector<std::wstring> languages_;
+ // List of supported input encodings.
+ std::vector<std::string> input_encodings_;
+ IDType id_;
+ Time date_created_;
+ int usage_count_;
+ int prepopulate_id_;
+
+ // TODO(sky): Add date last parsed OSD file.
+};
+
+#endif // CHROME_BROWSER_TEMPLATE_URL_PARSER_H__