blob: 863b99d54ecee13987b97528c8dcbdfe13409d1b [file] [log] [blame]
// Copyright 2016 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.
#include <string>
#include "base/strings/string16.h"
#include "base/strings/string_piece_forward.h"
namespace autofill {
class AutofillProfile;
namespace data_util {
struct NameParts {
base::string16 given;
base::string16 middle;
base::string16 family;
// Used to map Chrome card issuer networks to Payment Request API basic card
// payment spec issuer networks and icons.
struct PaymentRequestData {
const char* issuer_network;
const char* basic_card_issuer_network;
const int icon_resource_id;
const int a11y_label_resource_id;
// Returns true if |name| looks like a CJK name (or some kind of mish-mash of
// the three, at least).
bool IsCJKName(base::StringPiece16 name);
// TODO( Investigate the use of app_locale to do better name
// splitting.
// Returns the different name parts (given, middle and family names) of the full
// |name| passed as a parameter.
NameParts SplitName(base::StringPiece16 name);
// Concatenates the name parts together in the correct order (based on script),
// and returns the result.
base::string16 JoinNameParts(base::StringPiece16 given,
base::StringPiece16 middle,
base::StringPiece16 family);
// Returns true iff |full_name| is a concatenation of some combination of the
// first/middle/last (incl. middle initial) in |profile|.
bool ProfileMatchesFullName(base::StringPiece16 full_name,
const autofill::AutofillProfile& profile);
// Returns the Payment Request API basic card payment spec data for the provided
// autofill credit card |network|. Will set the network and the icon to
// "generic" for any unrecognized type.
const PaymentRequestData& GetPaymentRequestData(
const std::string& issuer_network);
// Returns the autofill credit card issuer network string for the provided
// Payment Request API basic card payment spec |basic_card_card_issuer_network|.
const char* GetIssuerNetworkForBasicCardIssuerNetwork(
const std::string& basic_card_issuer_network);
// Returns whether the specified |country_code| is a valid country code.
bool IsValidCountryCode(const std::string& country_code);
bool IsValidCountryCode(const base::string16& country_code);
// Returns a country code to be used when validating this profile. If the
// profile has a valid country code set, it is returned. If not, a country code
// associated with |app_locale| is used as a fallback.
std::string GetCountryCodeWithFallback(const autofill::AutofillProfile& profile,
const std::string& app_locale);
} // namespace data_util
} // namespace autofill