summaryrefslogtreecommitdiffstats
path: root/chrome/browser/search_engines/template_url_parser.h
blob: dfb139c8bba9d99f5b53c6f151418c70c024954f (plain)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
// Copyright (c) 2009 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_TEMPLATE_URL_PARSER_H_
#define CHROME_BROWSER_TEMPLATE_URL_PARSER_H_

#include <string>

#include "base/basictypes.h"

class TemplateURL;

// TemplateURLParser, as the name implies, handling reading of TemplateURLs
// from OpenSearch description documents.
class TemplateURLParser {
 public:
  class ParameterFilter {
   public:
    // Invoked for each parameter of the template URL while parsing.  If this
    // methods returns false, the parameter is not included.
    virtual bool KeepParameter(const std::string& key,
                               const std::string& value) = 0;
   protected:
    ~ParameterFilter() {}
  };
  // Decodes the chunk of data representing a TemplateURL. If data does
  // not describe a valid TemplateURL false is returned. Additionally, if the
  // URLs referenced do not point to valid http/https resources, false is
  // returned. |parameter_filter| can be used if you want to filter out some
  // parameters out of the URL. For example when importing from another browser
  // we remove any parameter identifying that browser.  If set to NULL, the URL
  // is not modified.
  //
  // NOTE: This does not clear all values of the supplied TemplateURL; it's
  // expected callers will supply a new TemplateURL to this method.
  static bool Parse(const unsigned char* data,
                    size_t length,
                    ParameterFilter* parameter_filter,
                    TemplateURL* url);

 private:
  // No one should create one of these.
  TemplateURLParser();

  DISALLOW_EVIL_CONSTRUCTORS(TemplateURLParser);
};

#endif // CHROME_BROWSER_TEMPLATE_URL_PARSER_H_