blob: dc51f3b5e4e5bbf8a7732131d75f001c440e76f1 [file] [log] [blame]
// Copyright 2019 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 "third_party/blink/public/mojom/payments/payment_request.mojom-blink.h"
#include "third_party/blink/renderer/modules/modules_export.h"
#include "third_party/blink/renderer/platform/heap/handle.h"
namespace blink {
class PaymentOptions;
class PaymentMethodData;
class MODULES_EXPORT SkipToGPayUtils final {
// Skip-to-Google-Pay is eligible if the request specifies basic-card and
//, with no other URL-based payment methods that is
// not
static bool IsEligible(
const HeapVector<Member<blink::PaymentMethodData>>& method_data);
// Given a |payment_method_data| that contains the merchant-specified
// GPay-specific data, patch it with the following additional parameters so
// shipping and contact information requested in |options| can be requested
// from GPay, if the experiment is enabled in the browser process:
// - |gpay_bridge_data.stringified_data|: encodes a JSON object that is an
// extension of the JSON object in |stringified_data| with parameters
// for shipping and contact information set.
// - |gpay_bridge_data.{phone, name, email, shipping}_requested|: each flag is
// set to true if the corresponding piece of information was not in the
// merchant-specified GPay data, but is now set in
// |gpay_bridge_data.stringified_data|.
// Returns true if |gpay_bridge_data| is generated successfully.
// |payment_method_data| is guaranteed to be unchanged if this function
// returns false.
static bool PatchPaymentMethodData(
const PaymentOptions& options,
::payments::mojom::blink::PaymentMethodDataPtr& payment_method_data);
} // namespace blink