Automattic\WooCommerce\Internal\Admin\Settings\PaymentProviders

AmazonPay{}WC 1.0└─ PaymentGateway

AmazonPay payment gateway provider class.

This class handles all the custom logic for the AmazonPay payment gateway provider.

No Hooks.

Usage

$AmazonPay = new AmazonPay();
// use class methods

Methods

  1. public is_account_connected( WC_Payment_Gateway $payment_gateway )
  2. public is_in_dev_mode( WC_Payment_Gateway $payment_gateway )
  3. public is_in_test_mode( WC_Payment_Gateway $payment_gateway )
  4. public is_in_test_mode_onboarding( WC_Payment_Gateway $payment_gateway )
  5. public is_onboarding_completed( WC_Payment_Gateway $payment_gateway )
  6. private is_amazon_pay_in_sandbox_mode()
  7. private is_amazon_pay_onboarded()

AmazonPay{} code WC 9.9.4

class AmazonPay extends PaymentGateway {

	/**
	 * Try to determine if the payment gateway is in test mode.
	 *
	 * This is a best-effort attempt, as there is no standard way to determine this.
	 * Trust the true value, but don't consider a false value as definitive.
	 *
	 * @param WC_Payment_Gateway $payment_gateway The payment gateway object.
	 *
	 * @return bool True if the payment gateway is in test mode, false otherwise.
	 */
	public function is_in_test_mode( WC_Payment_Gateway $payment_gateway ): bool {
		$is_in_sandbox_mode = $this->is_amazon_pay_in_sandbox_mode();
		if ( ! is_null( $is_in_sandbox_mode ) ) {
			return $is_in_sandbox_mode;
		}

		return parent::is_in_test_mode( $payment_gateway );
	}

	/**
	 * Try to determine if the payment gateway is in dev mode.
	 *
	 * This is a best-effort attempt, as there is no standard way to determine this.
	 * Trust the true value, but don't consider a false value as definitive.
	 *
	 * @param WC_Payment_Gateway $payment_gateway The payment gateway object.
	 *
	 * @return bool True if the payment gateway is in dev mode, false otherwise.
	 */
	public function is_in_dev_mode( WC_Payment_Gateway $payment_gateway ): bool {
		$is_in_sandbox_mode = $this->is_amazon_pay_in_sandbox_mode();
		if ( ! is_null( $is_in_sandbox_mode ) ) {
			return $is_in_sandbox_mode;
		}

		return parent::is_in_dev_mode( $payment_gateway );
	}

	/**
	 * Check if the payment gateway has a payments processor account connected.
	 *
	 * @param WC_Payment_Gateway $payment_gateway The payment gateway object.
	 *
	 * @return bool True if the payment gateway account is connected, false otherwise.
	 *              If the payment gateway does not provide the information, it will return true.
	 */
	public function is_account_connected( WC_Payment_Gateway $payment_gateway ): bool {
		$is_onboarded = $this->is_amazon_pay_onboarded();
		if ( ! is_null( $is_onboarded ) ) {
			return $is_onboarded;
		}

		return parent::is_account_connected( $payment_gateway );
	}

	/**
	 * Check if the payment gateway has completed the onboarding process.
	 *
	 * @param WC_Payment_Gateway $payment_gateway The payment gateway object.
	 *
	 * @return bool True if the payment gateway has completed the onboarding process, false otherwise.
	 *              If the payment gateway does not provide the information,
	 *              it will infer it from having a connected account.
	 */
	public function is_onboarding_completed( WC_Payment_Gateway $payment_gateway ): bool {
		$is_onboarded = $this->is_amazon_pay_onboarded();
		if ( ! is_null( $is_onboarded ) ) {
			return $is_onboarded;
		}

		return parent::is_onboarding_completed( $payment_gateway );
	}

	/**
	 * Try to determine if the payment gateway is in test mode onboarding (aka sandbox or test-drive).
	 *
	 * This is a best-effort attempt, as there is no standard way to determine this.
	 * Trust the true value, but don't consider a false value as definitive.
	 *
	 * @param WC_Payment_Gateway $payment_gateway The payment gateway object.
	 *
	 * @return bool True if the payment gateway is in test mode onboarding, false otherwise.
	 */
	public function is_in_test_mode_onboarding( WC_Payment_Gateway $payment_gateway ): bool {
		$is_in_sandbox_mode = $this->is_amazon_pay_in_sandbox_mode();
		if ( ! is_null( $is_in_sandbox_mode ) ) {
			return $is_in_sandbox_mode;
		}

		return parent::is_in_test_mode( $payment_gateway );
	}

	/**
	 * Check if the AmazonPay payment gateway is in sandbox mode.
	 *
	 * For AmazonPay, there are two different environments: sandbox and production.
	 *
	 * @return ?bool True if the payment gateway is in sandbox mode, false otherwise.
	 *               Null if the environment could not be determined.
	 */
	private function is_amazon_pay_in_sandbox_mode(): ?bool {
		if ( class_exists( '\WC_Amazon_Payments_Advanced_API' ) &&
			is_callable( '\WC_Amazon_Payments_Advanced_API::get_settings' ) ) {

			$settings = \WC_Amazon_Payments_Advanced_API::get_settings();

			if ( isset( $settings['sandbox'] ) ) {
				return filter_var( $settings['sandbox'], FILTER_VALIDATE_BOOLEAN );
			}
		}

		// Let the caller know that we couldn't determine the environment.
		return null;
	}

	/**
	 * Check if the AmazonPay payment gateway is onboarded.
	 *
	 * For AmazonPay, there are two different environments: sandbox and production.
	 *
	 * @return ?bool True if the payment gateway is onboarded, false otherwise.
	 *               Null if we failed to determine the onboarding status.
	 */
	private function is_amazon_pay_onboarded(): ?bool {
		if ( class_exists( '\WC_Amazon_Payments_Advanced_API' ) &&
			is_callable( '\WC_Amazon_Payments_Advanced_API::validate_api_settings' ) ) {

			return true === \WC_Amazon_Payments_Advanced_API::validate_api_settings();
		}

		// Let the caller know that we couldn't determine the onboarding status.
		return null;
	}
}