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

content / browser / payments / payment_app_provider_util.cc [blame]

// Copyright 2020 The Chromium Authors
// Use of this source code is governed by a BSD-style license that can be
// found in the LICENSE file.

#include "content/public/browser/payment_app_provider_util.h"

#include "content/browser/service_worker/service_worker_loader_helpers.h"
#include "content/browser/service_worker/service_worker_security_utils.h"
#include "content/public/browser/browser_thread.h"

namespace content {

// static
ukm::SourceId PaymentAppProviderUtil::GetSourceIdForPaymentAppFromScope(
    const GURL& sw_scope) {
  return ukm::UkmRecorder::GetSourceIdForPaymentAppFromScope(
      base::PassKey<PaymentAppProviderUtil>(),
      sw_scope.DeprecatedGetOriginAsURL());
}

// static
bool PaymentAppProviderUtil::IsValidInstallablePaymentApp(
    const GURL& manifest_url,
    const GURL& sw_js_url,
    const GURL& sw_scope,
    std::string* error_message) {
  DCHECK(manifest_url.is_valid() && sw_js_url.is_valid() &&
         sw_scope.is_valid());

  // Scope will be checked against service worker js url when registering, but
  // we check it here earlier to avoid presenting unusable payment handlers.
  if (!service_worker_loader_helpers::IsPathRestrictionSatisfiedWithoutHeader(
          sw_scope, sw_js_url, error_message)) {
    return false;
  }

  std::vector<GURL> urls = {manifest_url, sw_js_url, sw_scope};
  if (!service_worker_security_utils::AllOriginsMatchAndCanAccessServiceWorkers(
          urls)) {
    *error_message =
        "Origins are not matching, or some origins cannot access service "
        "worker (manifest:" +
        manifest_url.spec() + " scope:" + sw_scope.spec() +
        " sw:" + sw_js_url.spec() + ")";
    return false;
  }

  return true;
}

// static
payments::mojom::CanMakePaymentResponsePtr
PaymentAppProviderUtil::CreateBlankCanMakePaymentResponse(
    payments::mojom::CanMakePaymentEventResponseType response_type) {
  return payments::mojom::CanMakePaymentResponse::New(
      response_type, /*can_make_payment=*/false);
}

// static
payments::mojom::PaymentHandlerResponsePtr
PaymentAppProviderUtil::CreateBlankPaymentHandlerResponse(
    payments::mojom::PaymentEventResponseType response_type) {
  return payments::mojom::PaymentHandlerResponse::New(
      /*method_name=*/"", /*stringified_details=*/"", response_type,
      /*payer_name=*/std::nullopt, /*payer_email=*/std::nullopt,
      /*payer_phone=*/std::nullopt, /*shipping_address=*/nullptr,
      /*shipping_option=*/std::nullopt);
}

}  // namespace content