概览

作为 Actions Center 的“预订”端到端集成的一部分,您可以让商家在用户进行预订、预约或预订时接收用户付款。Google 与付款处理方合作来设置令牌化。然后,付款处理方会使用唯一的令牌安全地向商家付款。

对于支持付款的预订,我们会在结账流程中提供付款信息模块。这样,用户就可以输入其信用卡信息。

我们提供对 3DS1 和 3DS2 的支持,请参阅本教程了解实现方式。

资格要求

为了让您的商家能够通过 Actions Center 接收付款,您必须满足以下要求:

  1. 使用受支持的付款处理方。您可以在 Google Pay 网站上找到受支持的处理方的最新列表。
  2. 根据您的处理方接受令牌化付款。
  3. 完成 此处所列的身份验证和商家验证流程。
  4. 无法为需要 异步确认 的预订启用结算功能。

对 Feed 和预订服务器进行更改以启用付款功能

通过在商家级别选择启用,您即可启用付款功能。您必须为需要针对其任何服务接收付款的商家启用付款功能。如需启用付款功能,必须对 Feed 和预订服务器进行更改。

Feed

  • 商家 Feed:通过 tokenization_config 字段中设置的 tokenization_parameter 指定付款信息。该集合取决于所选的付款处理方。此集合与要传递给 Google Pay 的 paymentMethodTokenizationParameters.parameters 集(如果要与其集成的话)相同。
  • 服务/可用性 Feed:根据相应的用例指定付款要求。如需了解详情,请参阅付款用例

预订服务器

付款用例

在决定是否针对每个用例进行付款时,请查看我们的付款政策,并确保您能够遵守所有相关政策。

以下是付款的用例:

如需详细了解如何实现每个用例,请参阅有关配置付款的教程。

全额预付费预订

图 1 显示了用户、您(时间安排合作伙伴)、Google 和付款处理方之间的活动流程。

图 1:预付费预订序列图
图 1:预付费预订序列图
  • 付款金额必须为服务费用的 100%。换句话说,预订时必须全额支付服务费用。
服务 Feed 变更

押金和违约金

押金和违约金的设置方式相同。图 2 显示了用户、您(时间安排合作伙伴)、Google 和付款处理方之间的这些活动流程。

图 2:押金或违约金预订序列图
图 2:收取押金或违约金的预订流程图

押金和违约金可用于确保用户准时赴约。

  • 系统可能会提前或稍后从用户的信用卡中收取押金。
  • 如果用户未出现在预订信息中,可向其收取违约金。
  • 如有必要,可在预订时同时收取押金和违约金。
  • 即使不需要预先付款,预订服务器也必须使用 PaymentInformation(包含 payment_transaction_id,该 ID 必须是唯一的)来响应 CreateBooking 请求。payment_transaction_id 无需由付款处理方提供,但可以由预订服务器生成。
服务或可用性 Feed 变更

押金和违约金可在商家的服务级别或可用性空档级别指定。如果在可用性空档级别指定它们,则会替换服务级别的定义。

  • 如需启用押金,请在服务级别或可用性空档级别设置 deposit 字段。
  • 如需启用违约金,请在服务或可用性空档级别设置 no_show_fee 字段。
  • 在服务级别或可用性空档级别将 require_credit_card 字段设置为 REQUIRE_CREDIT_CARD_CONDITIONAL
  • (可选)将 prepayment_type 设置为 REQUIREDOPTIONAL

需要提供信用卡

还有一些其他用例需要在预订时提供信用卡。

  • 在商家的服务级别或可用性空档级别将 require_credit_card 字段设置为 REQUIRE_CREDIT_CARD_ALWAYS

取消和退款

取消和退款可由合作伙伴(您)发起,也可以由用户通过 Actions Center 发起。在这两种情况下,您都必须遵守在服务级别设置并在预订结账时传达给用户的 CancellationPolicy

如果您未提供 CancellationPolicy,则在由 min_advance_online_canceling 定义(在服务级别中设置的)取消时间范围内的任何取消均可退款。 如果未定义 min_advance_online_canceling,则其值为 0(表示可以随时取消)。

如果您必须从 Actions Center 端停用取消功能,请与您的 Google 联系人讨论。

RTU 变更
  • 向用户提供退款后,您必须发送更新预订 RTU 以更改预订的付款状态。将 update_mask 设置为 status,payment_information.prepayment_status,并设置 payment_information.prepayment_status = PREPAYMENT_REFUNDEDstatus = CANCELED
    • 请使用新的 BookingStatus = CANCELEDPrepaymentStatus = PREPAYMENT_REFUNDED。Maps Booking API 和 gRPC 模板的枚举值 CANCELED_AUTOMATIC_REFUND 均已弃用。
更改预订服务器