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 50 51 52 53 54 55 56 57 58 59 60 61 62 63 64 65 66 67 68 69 70 71 72 73 74 75 76 77 78 79 80 81 82 83 84 85 86 87 88 89
|
// Copyright 2016 The Chromium Authors
// Use of this source code is governed by a BSD-style license that can be
// found in the LICENSE file.
#ifndef COMPONENTS_AUTOFILL_CORE_BROWSER_PAYMENTS_LEGAL_MESSAGE_LINE_H_
#define COMPONENTS_AUTOFILL_CORE_BROWSER_PAYMENTS_LEGAL_MESSAGE_LINE_H_
#include <string>
#include <vector>
#include "base/gtest_prod_util.h"
#include "base/values.h"
#include "ui/gfx/range/range.h"
#include "url/gurl.h"
namespace autofill {
class LegalMessageLine;
using LegalMessageLines = std::vector<LegalMessageLine>;
class LegalMessageLine {
public:
struct Link {
Link(size_t start, size_t end, const std::string& url_spec);
~Link();
bool operator==(const Link& other) const;
gfx::Range range;
GURL url;
};
using Links = std::vector<Link>;
LegalMessageLine();
LegalMessageLine(const LegalMessageLine& other);
virtual ~LegalMessageLine(); // Overridden in TestLegalMessageLine.
bool operator==(const LegalMessageLine& other) const;
// Parses |legal_message|. Returns false on failure.
//
// Example of valid |legal_message| data:
// {
// "line" : [ {
// "template" : "The legal documents are: {0} and {1}",
// "template_parameter" : [ {
// "display_text" : "Terms of Service",
// "url": "http://www.example.com/tos"
// }, {
// "display_text" : "Privacy Policy",
// "url": "http://www.example.com/pp"
// } ],
// }, {
// "template" : "This is the second line and it has no parameters"
// } ]
// }
//
// Caveats:
// 1. '{' and '}' may be displayed by escaping them with an apostrophe in the
// template string, e.g. template "Here is a literal '{'".
// 2. Two or more consecutive dollar signs in the template string will not
// expand correctly.
// 3. "${" anywhere in the template string is invalid.
// 4. "\n" embedded anywhere in the template string, or an empty template
// string, can be used to separate paragraphs.
// 5. Because a single apostrophe before a curly brace starts quoted literal
// text in MessageFormat, "'{0}" gets treated as a literal. To avoid
// situations like these, setting |escape_apostrophes| to true will escape
// all ASCII apostrophes by doubling them up.
static bool Parse(const base::Value::Dict& legal_message,
LegalMessageLines* out,
bool escape_apostrophes = false);
const std::u16string& text() const { return text_; }
const Links& links() const { return links_; }
private:
friend class TestLegalMessageLine;
bool ParseLine(const base::Value::Dict& line, bool escape_apostrophes);
std::u16string text_;
Links links_;
};
} // namespace autofill
#endif // COMPONENTS_AUTOFILL_CORE_BROWSER_PAYMENTS_LEGAL_MESSAGE_LINE_H_
|