blob: 32ba7a227fff635c47c0d0a152c339c73fd4eba6 [file] [log] [blame]
<?php
/**
* Plugin Name: WooCommerce Stripe Gateway
* Plugin URI: https://wordpress.org/plugins/woocommerce-gateway-stripe/
* Description: Take credit card payments on your store using Stripe.
* Author: WooCommerce
* Author URI: https://woocommerce.com/
* Version: 7.0.1
* Requires at least: 5.8
* Tested up to: 6.0
* WC requires at least: 6.8
* WC tested up to: 7.0
* Text Domain: woocommerce-gateway-stripe
* Domain Path: /languages
*/
if ( ! defined( 'ABSPATH' ) ) {
exit;
}
/**
* Required minimums and constants
*/
define( 'WC_STRIPE_VERSION', '7.0.1' ); // WRCS: DEFINED_VERSION.
define( 'WC_STRIPE_MIN_PHP_VER', '7.3.0' );
define( 'WC_STRIPE_MIN_WC_VER', '6.8' );
define( 'WC_STRIPE_FUTURE_MIN_WC_VER', '6.9' );
define( 'WC_STRIPE_MAIN_FILE', __FILE__ );
define( 'WC_STRIPE_ABSPATH', __DIR__ . '/' );
define( 'WC_STRIPE_PLUGIN_URL', untrailingslashit( plugins_url( basename( plugin_dir_path( __FILE__ ) ), basename( __FILE__ ) ) ) );
define( 'WC_STRIPE_PLUGIN_PATH', untrailingslashit( plugin_dir_path( __FILE__ ) ) );
// phpcs:disable WordPress.Files.FileName
/**
* WooCommerce fallback notice.
*
* @since 4.1.2
*/
function woocommerce_stripe_missing_wc_notice() {
/* translators: 1. URL link. */
echo '<div class="error"><p><strong>' . sprintf( esc_html__( 'Stripe requires WooCommerce to be installed and active. You can download %s here.', 'woocommerce-gateway-stripe' ), '<a href="https://woocommerce.com/" target="_blank">WooCommerce</a>' ) . '</strong></p></div>';
}
/**
* WooCommerce not supported fallback notice.
*
* @since 4.4.0
*/
function woocommerce_stripe_wc_not_supported() {
/* translators: $1. Minimum WooCommerce version. $2. Current WooCommerce version. */
echo '<div class="error"><p><strong>' . sprintf( esc_html__( 'Stripe requires WooCommerce %1$s or greater to be installed and active. WooCommerce %2$s is no longer supported.', 'woocommerce-gateway-stripe' ), WC_STRIPE_MIN_WC_VER, WC_VERSION ) . '</strong></p></div>';
}
function woocommerce_gateway_stripe() {
static $plugin;
if ( ! isset( $plugin ) ) {
class WC_Stripe {
/**
* The *Singleton* instance of this class
*
* @var WC_Stripe
*/
private static $instance;
/**
* Returns the *Singleton* instance of this class.
*
* @return WC_Stripe The *Singleton* instance.
*/
public static function get_instance() {
if ( null === self::$instance ) {
self::$instance = new self();
}
return self::$instance;
}
/**
* Stripe Connect API
*
* @var WC_Stripe_Connect_API
*/
private $api;
/**
* Stripe Connect
*
* @var WC_Stripe_Connect
*/
public $connect;
/**
* Stripe Payment Request configurations.
*
* @var WC_Stripe_Payment_Request
*/
public $payment_request_configuration;
/**
* Stripe Account.
*
* @var WC_Stripe_Account
*/
public $account;
/**
* The main Stripe gateway instance. Use get_main_stripe_gateway() to access it.
*
* @var null|WC_Stripe_Payment_Gateway
*/
protected $stripe_gateway = null;
/**
* Private clone method to prevent cloning of the instance of the
* *Singleton* instance.
*
* @return void
*/
public function __clone() {}
/**
* Private unserialize method to prevent unserializing of the *Singleton*
* instance.
*
* @return void
*/
public function __wakeup() {}
/**
* Protected constructor to prevent creating a new instance of the
* *Singleton* via the `new` operator from outside of this class.
*/
public function __construct() {
add_action( 'admin_init', [ $this, 'install' ] );
$this->init();
add_action( 'rest_api_init', [ $this, 'register_routes' ] );
}
/**
* Init the plugin after plugins_loaded so environment variables are set.
*
* @since 1.0.0
* @version 5.0.0
*/
public function init() {
if ( is_admin() ) {
require_once dirname( __FILE__ ) . '/includes/admin/class-wc-stripe-privacy.php';
}
require_once dirname( __FILE__ ) . '/includes/class-wc-stripe-feature-flags.php';
require_once dirname( __FILE__ ) . '/includes/class-wc-stripe-upe-compatibility.php';
require_once dirname( __FILE__ ) . '/includes/class-wc-stripe-exception.php';
require_once dirname( __FILE__ ) . '/includes/class-wc-stripe-logger.php';
require_once dirname( __FILE__ ) . '/includes/class-wc-stripe-helper.php';
include_once dirname( __FILE__ ) . '/includes/class-wc-stripe-api.php';
require_once dirname( __FILE__ ) . '/includes/compat/trait-wc-stripe-subscriptions-utilities.php';
require_once dirname( __FILE__ ) . '/includes/compat/trait-wc-stripe-subscriptions.php';
require_once dirname( __FILE__ ) . '/includes/compat/trait-wc-stripe-pre-orders.php';
require_once dirname( __FILE__ ) . '/includes/abstracts/abstract-wc-stripe-payment-gateway.php';
require_once dirname( __FILE__ ) . '/includes/abstracts/abstract-wc-stripe-payment-gateway-voucher.php';
require_once dirname( __FILE__ ) . '/includes/class-wc-stripe-webhook-state.php';
require_once dirname( __FILE__ ) . '/includes/class-wc-stripe-webhook-handler.php';
require_once dirname( __FILE__ ) . '/includes/class-wc-stripe-sepa-payment-token.php';
require_once dirname( __FILE__ ) . '/includes/class-wc-stripe-link-payment-token.php';
require_once dirname( __FILE__ ) . '/includes/class-wc-stripe-apple-pay-registration.php';
require_once dirname( __FILE__ ) . '/includes/class-wc-gateway-stripe.php';
require_once dirname( __FILE__ ) . '/includes/payment-methods/class-wc-stripe-upe-payment-gateway.php';
require_once dirname( __FILE__ ) . '/includes/payment-methods/class-wc-stripe-upe-payment-method.php';
require_once dirname( __FILE__ ) . '/includes/payment-methods/class-wc-stripe-upe-payment-method-cc.php';
require_once dirname( __FILE__ ) . '/includes/payment-methods/class-wc-stripe-upe-payment-method-giropay.php';
require_once dirname( __FILE__ ) . '/includes/payment-methods/class-wc-stripe-upe-payment-method-ideal.php';
require_once dirname( __FILE__ ) . '/includes/payment-methods/class-wc-stripe-upe-payment-method-bancontact.php';
require_once dirname( __FILE__ ) . '/includes/payment-methods/class-wc-stripe-upe-payment-method-boleto.php';
require_once dirname( __FILE__ ) . '/includes/payment-methods/class-wc-stripe-upe-payment-method-oxxo.php';
require_once dirname( __FILE__ ) . '/includes/payment-methods/class-wc-stripe-upe-payment-method-eps.php';
require_once dirname( __FILE__ ) . '/includes/payment-methods/class-wc-stripe-upe-payment-method-sepa.php';
require_once dirname( __FILE__ ) . '/includes/payment-methods/class-wc-stripe-upe-payment-method-p24.php';
require_once dirname( __FILE__ ) . '/includes/payment-methods/class-wc-stripe-upe-payment-method-sofort.php';
require_once dirname( __FILE__ ) . '/includes/payment-methods/class-wc-stripe-upe-payment-method-link.php';
require_once dirname( __FILE__ ) . '/includes/payment-methods/class-wc-gateway-stripe-bancontact.php';
require_once dirname( __FILE__ ) . '/includes/payment-methods/class-wc-gateway-stripe-sofort.php';
require_once dirname( __FILE__ ) . '/includes/payment-methods/class-wc-gateway-stripe-giropay.php';
require_once dirname( __FILE__ ) . '/includes/payment-methods/class-wc-gateway-stripe-eps.php';
require_once dirname( __FILE__ ) . '/includes/payment-methods/class-wc-gateway-stripe-ideal.php';
require_once dirname( __FILE__ ) . '/includes/payment-methods/class-wc-gateway-stripe-p24.php';
require_once dirname( __FILE__ ) . '/includes/payment-methods/class-wc-gateway-stripe-alipay.php';
require_once dirname( __FILE__ ) . '/includes/payment-methods/class-wc-gateway-stripe-sepa.php';
require_once dirname( __FILE__ ) . '/includes/payment-methods/class-wc-gateway-stripe-multibanco.php';
require_once dirname( __FILE__ ) . '/includes/payment-methods/class-wc-gateway-stripe-boleto.php';
require_once dirname( __FILE__ ) . '/includes/payment-methods/class-wc-gateway-stripe-oxxo.php';
require_once dirname( __FILE__ ) . '/includes/payment-methods/class-wc-stripe-payment-request.php';
require_once dirname( __FILE__ ) . '/includes/compat/class-wc-stripe-woo-compat-utils.php';
require_once dirname( __FILE__ ) . '/includes/connect/class-wc-stripe-connect.php';
require_once dirname( __FILE__ ) . '/includes/connect/class-wc-stripe-connect-api.php';
require_once dirname( __FILE__ ) . '/includes/class-wc-stripe-order-handler.php';
require_once dirname( __FILE__ ) . '/includes/class-wc-stripe-payment-tokens.php';
require_once dirname( __FILE__ ) . '/includes/class-wc-stripe-customer.php';
require_once dirname( __FILE__ ) . '/includes/class-wc-stripe-intent-controller.php';
require_once dirname( __FILE__ ) . '/includes/admin/class-wc-stripe-inbox-notes.php';
require_once dirname( __FILE__ ) . '/includes/admin/class-wc-stripe-upe-compatibility-controller.php';
require_once dirname( __FILE__ ) . '/includes/migrations/class-allowed-payment-request-button-types-update.php';
require_once dirname( __FILE__ ) . '/includes/class-wc-stripe-account.php';
new Allowed_Payment_Request_Button_Types_Update();
$this->api = new WC_Stripe_Connect_API();
$this->connect = new WC_Stripe_Connect( $this->api );
$this->payment_request_configuration = new WC_Stripe_Payment_Request();
$this->account = new WC_Stripe_Account( $this->connect, 'WC_Stripe_API' );
if ( is_admin() ) {
require_once dirname( __FILE__ ) . '/includes/admin/class-wc-stripe-admin-notices.php';
require_once dirname( __FILE__ ) . '/includes/admin/class-wc-stripe-settings-controller.php';
if ( WC_Stripe_Feature_Flags::is_upe_preview_enabled() ) {
require_once dirname( __FILE__ ) . '/includes/admin/class-wc-stripe-old-settings-upe-toggle-controller.php';
new WC_Stripe_Old_Settings_UPE_Toggle_Controller();
}
if ( isset( $_GET['area'] ) && 'payment_requests' === $_GET['area'] ) {
require_once dirname( __FILE__ ) . '/includes/admin/class-wc-stripe-payment-requests-controller.php';
new WC_Stripe_Payment_Requests_Controller();
} else {
new WC_Stripe_Settings_Controller( $this->account );
}
if ( WC_Stripe_Feature_Flags::is_upe_checkout_enabled() ) {
require_once dirname( __FILE__ ) . '/includes/admin/class-wc-stripe-payment-gateways-controller.php';
new WC_Stripe_Payment_Gateways_Controller();
}
}
// REMOVE IN THE FUTURE.
require_once dirname( __FILE__ ) . '/includes/deprecated/class-wc-stripe-apple-pay.php';
add_filter( 'woocommerce_payment_gateways', [ $this, 'add_gateways' ] );
add_filter( 'pre_update_option_woocommerce_stripe_settings', [ $this, 'gateway_settings_update' ], 10, 2 );
add_filter( 'plugin_action_links_' . plugin_basename( __FILE__ ), [ $this, 'plugin_action_links' ] );
add_filter( 'plugin_row_meta', [ $this, 'plugin_row_meta' ], 10, 2 );
// Update the email field position.
if ( ! is_admin() ) {
add_filter( 'woocommerce_billing_fields', [ $this, 'checkout_update_email_field_priority' ], 50 );
}
// Modify emails emails.
add_filter( 'woocommerce_email_classes', [ $this, 'add_emails' ], 20 );
if ( version_compare( WC_VERSION, '3.4', '<' ) ) {
add_filter( 'woocommerce_get_sections_checkout', [ $this, 'filter_gateway_order_admin' ] );
}
new WC_Stripe_UPE_Compatibility_Controller();
}
/**
* Updates the plugin version in db
*
* @since 3.1.0
* @version 4.0.0
*/
public function update_plugin_version() {
delete_option( 'wc_stripe_version' );
update_option( 'wc_stripe_version', WC_STRIPE_VERSION );
}
/**
* Handles upgrade routines.
*
* @since 3.1.0
* @version 3.1.0
*/
public function install() {
if ( ! is_plugin_active( plugin_basename( __FILE__ ) ) ) {
return;
}
if ( ! defined( 'IFRAME_REQUEST' ) && ( WC_STRIPE_VERSION !== get_option( 'wc_stripe_version' ) ) ) {
do_action( 'woocommerce_stripe_updated' );
if ( ! defined( 'WC_STRIPE_INSTALLING' ) ) {
define( 'WC_STRIPE_INSTALLING', true );
}
add_woocommerce_inbox_variant();
$this->update_plugin_version();
// TODO: Remove this when we're reasonably sure most merchants have had their
// settings updated like this. ~80% of merchants is a good threshold.
// - @reykjalin
$this->update_prb_location_settings();
}
}
/**
* Updates the PRB location settings based on deprecated filters.
*
* The filters were removed in favor of plugin settings. This function can, and should,
* be removed when we're reasonably sure most merchants have had their settings updated
* through this function. Maybe ~80% of merchants is a good threshold?
*
* @since 5.5.0
* @version 5.5.0
*/
public function update_prb_location_settings() {
$stripe_settings = get_option( 'woocommerce_stripe_settings', [] );
$prb_locations = isset( $stripe_settings['payment_request_button_locations'] )
? $stripe_settings['payment_request_button_locations']
: [];
if ( ! empty( $stripe_settings ) && empty( $prb_locations ) ) {
global $post;
$should_show_on_product_page = ! apply_filters( 'wc_stripe_hide_payment_request_on_product_page', false, $post );
$should_show_on_cart_page = apply_filters( 'wc_stripe_show_payment_request_on_cart', true );
$should_show_on_checkout_page = apply_filters( 'wc_stripe_show_payment_request_on_checkout', false, $post );
$new_prb_locations = [];
if ( $should_show_on_product_page ) {
$new_prb_locations[] = 'product';
}
if ( $should_show_on_cart_page ) {
$new_prb_locations[] = 'cart';
}
if ( $should_show_on_checkout_page ) {
$new_prb_locations[] = 'checkout';
}
$stripe_settings['payment_request_button_locations'] = $new_prb_locations;
update_option( 'woocommerce_stripe_settings', $stripe_settings );
}
}
/**
* Add plugin action links.
*
* @since 1.0.0
* @version 4.0.0
*/
public function plugin_action_links( $links ) {
$plugin_links = [
'<a href="admin.php?page=wc-settings&tab=checkout&section=stripe">' . esc_html__( 'Settings', 'woocommerce-gateway-stripe' ) . '</a>',
];
return array_merge( $plugin_links, $links );
}
/**
* Add plugin action links.
*
* @since 4.3.4
* @param array $links Original list of plugin links.
* @param string $file Name of current file.
* @return array $links Update list of plugin links.
*/
public function plugin_row_meta( $links, $file ) {
if ( plugin_basename( __FILE__ ) === $file ) {
$row_meta = [
'docs' => '<a href="' . esc_url( apply_filters( 'woocommerce_gateway_stripe_docs_url', 'https://woocommerce.com/document/stripe/' ) ) . '" title="' . esc_attr( __( 'View Documentation', 'woocommerce-gateway-stripe' ) ) . '">' . __( 'Docs', 'woocommerce-gateway-stripe' ) . '</a>',
'support' => '<a href="' . esc_url( apply_filters( 'woocommerce_gateway_stripe_support_url', 'https://woocommerce.com/my-account/create-a-ticket?select=18627' ) ) . '" title="' . esc_attr( __( 'Open a support request at WooCommerce.com', 'woocommerce-gateway-stripe' ) ) . '">' . __( 'Support', 'woocommerce-gateway-stripe' ) . '</a>',
];
return array_merge( $links, $row_meta );
}
return (array) $links;
}
/**
* Add the gateways to WooCommerce.
*
* @since 1.0.0
* @version 5.6.0
*/
public function add_gateways( $methods ) {
$methods[] = $this->get_main_stripe_gateway();
if ( ! WC_Stripe_Feature_Flags::is_upe_preview_enabled() || ! WC_Stripe_Feature_Flags::is_upe_checkout_enabled() ) {
// These payment gateways will be hidden when UPE is enabled:
$methods[] = WC_Gateway_Stripe_Sepa::class;
$methods[] = WC_Gateway_Stripe_Giropay::class;
$methods[] = WC_Gateway_Stripe_Ideal::class;
$methods[] = WC_Gateway_Stripe_Bancontact::class;
$methods[] = WC_Gateway_Stripe_Eps::class;
$methods[] = WC_Gateway_Stripe_Sofort::class;
$methods[] = WC_Gateway_Stripe_P24::class;
$methods[] = WC_Gateway_Stripe_Boleto::class;
$methods[] = WC_Gateway_Stripe_Oxxo::class;
}
// These payment gateways will always be visible, regardless if UPE is enabled or disabled:
$methods[] = WC_Gateway_Stripe_Alipay::class;
$methods[] = WC_Gateway_Stripe_Multibanco::class;
return $methods;
}
/**
* Modifies the order of the gateways displayed in admin.
*
* @since 4.0.0
* @version 4.0.0
*/
public function filter_gateway_order_admin( $sections ) {
unset( $sections['stripe'] );
if ( WC_Stripe_Feature_Flags::is_upe_preview_enabled() ) {
unset( $sections['stripe_upe'] );
}
unset( $sections['stripe_bancontact'] );
unset( $sections['stripe_sofort'] );
unset( $sections['stripe_giropay'] );
unset( $sections['stripe_eps'] );
unset( $sections['stripe_ideal'] );
unset( $sections['stripe_p24'] );
unset( $sections['stripe_alipay'] );
unset( $sections['stripe_sepa'] );
unset( $sections['stripe_multibanco'] );
$sections['stripe'] = 'Stripe';
if ( WC_Stripe_Feature_Flags::is_upe_preview_enabled() ) {
$sections['stripe_upe'] = 'Stripe checkout experience';
}
$sections['stripe_bancontact'] = __( 'Stripe Bancontact', 'woocommerce-gateway-stripe' );
$sections['stripe_sofort'] = __( 'Stripe Sofort', 'woocommerce-gateway-stripe' );
$sections['stripe_giropay'] = __( 'Stripe giropay', 'woocommerce-gateway-stripe' );
$sections['stripe_eps'] = __( 'Stripe EPS', 'woocommerce-gateway-stripe' );
$sections['stripe_ideal'] = __( 'Stripe iDEAL', 'woocommerce-gateway-stripe' );
$sections['stripe_p24'] = __( 'Stripe P24', 'woocommerce-gateway-stripe' );
$sections['stripe_alipay'] = __( 'Stripe Alipay', 'woocommerce-gateway-stripe' );
$sections['stripe_sepa'] = __( 'Stripe SEPA Direct Debit', 'woocommerce-gateway-stripe' );
$sections['stripe_multibanco'] = __( 'Stripe Multibanco', 'woocommerce-gateway-stripe' );
return $sections;
}
/**
* Provide default values for missing settings on initial gateway settings save.
*
* @since 4.5.4
* @version 4.5.4
*
* @param array $settings New settings to save.
* @param array|bool $old_settings Existing settings, if any.
* @return array New value but with defaults initially filled in for missing settings.
*/
public function gateway_settings_update( $settings, $old_settings ) {
if ( false === $old_settings ) {
$gateway = new WC_Gateway_Stripe();
$fields = $gateway->get_form_fields();
$old_settings = array_merge( array_fill_keys( array_keys( $fields ), '' ), wp_list_pluck( $fields, 'default' ) );
$settings = array_merge( $old_settings, $settings );
}
if ( ! WC_Stripe_Feature_Flags::is_upe_preview_enabled() ) {
return $settings;
}
return $this->toggle_upe( $settings, $old_settings );
}
/**
* Enable or disable UPE.
*
* When enabling UPE: For each currently enabled Stripe LPM, the corresponding UPE method is enabled.
*
* When disabling UPE: For each currently enabled UPE method, the corresponding LPM is enabled.
*
* @param array $settings New settings to save.
* @param array|bool $old_settings Existing settings, if any.
* @return array New value but with defaults initially filled in for missing settings.
*/
protected function toggle_upe( $settings, $old_settings ) {
if ( false === $old_settings || ! isset( $old_settings[ WC_Stripe_Feature_Flags::UPE_CHECKOUT_FEATURE_ATTRIBUTE_NAME ] ) ) {
$old_settings = [ WC_Stripe_Feature_Flags::UPE_CHECKOUT_FEATURE_ATTRIBUTE_NAME => 'no' ];
}
if ( ! isset( $settings[ WC_Stripe_Feature_Flags::UPE_CHECKOUT_FEATURE_ATTRIBUTE_NAME ] ) || $settings[ WC_Stripe_Feature_Flags::UPE_CHECKOUT_FEATURE_ATTRIBUTE_NAME ] === $old_settings[ WC_Stripe_Feature_Flags::UPE_CHECKOUT_FEATURE_ATTRIBUTE_NAME ] ) {
return $settings;
}
if ( 'yes' === $settings[ WC_Stripe_Feature_Flags::UPE_CHECKOUT_FEATURE_ATTRIBUTE_NAME ] ) {
return $this->enable_upe( $settings );
}
return $this->disable_upe( $settings );
}
protected function enable_upe( $settings ) {
$settings['upe_checkout_experience_accepted_payments'] = [];
$payment_gateways = WC()->payment_gateways->payment_gateways();
foreach ( WC_Stripe_UPE_Payment_Gateway::UPE_AVAILABLE_METHODS as $method_class ) {
if ( ! defined( "$method_class::LPM_GATEWAY_CLASS" ) ) {
continue;
}
$lpm_gateway_id = constant( $method_class::LPM_GATEWAY_CLASS . '::ID' );
if ( isset( $payment_gateways[ $lpm_gateway_id ] ) && 'yes' === $payment_gateways[ $lpm_gateway_id ]->enabled ) {
// DISABLE LPM
if ( 'stripe' !== $lpm_gateway_id ) {
/**
* TODO: This can be replaced with:
*
* $payment_gateways[ $lpm_gateway_id ]->update_option( 'enabled', 'no' );
* $payment_gateways[ $lpm_gateway_id ]->enabled = 'no';
*
* ...once the minimum WC version is 3.4.0.
*/
$payment_gateways[ $lpm_gateway_id ]->settings['enabled'] = 'no';
update_option(
$payment_gateways[ $lpm_gateway_id ]->get_option_key(),
apply_filters( 'woocommerce_settings_api_sanitized_fields_' . $payment_gateways[ $lpm_gateway_id ]::ID, $payment_gateways[ $lpm_gateway_id ]->settings ),
'yes'
);
}
// ENABLE UPE METHOD
$settings['upe_checkout_experience_accepted_payments'][] = $method_class::STRIPE_ID;
}
}
if ( empty( $settings['upe_checkout_experience_accepted_payments'] ) ) {
$settings['upe_checkout_experience_accepted_payments'] = [ 'card' ];
} else {
// The 'stripe' gateway must be enabled for UPE if any LPMs were enabled.
$settings['enabled'] = 'yes';
}
return $settings;
}
protected function disable_upe( $settings ) {
$upe_gateway = new WC_Stripe_UPE_Payment_Gateway();
$upe_enabled_method_ids = $upe_gateway->get_upe_enabled_payment_method_ids();
foreach ( WC_Stripe_UPE_Payment_Gateway::UPE_AVAILABLE_METHODS as $method_class ) {
if ( ! defined( "$method_class::LPM_GATEWAY_CLASS" ) || ! in_array( $method_class::STRIPE_ID, $upe_enabled_method_ids, true ) ) {
continue;
}
// ENABLE LPM
$gateway_class = $method_class::LPM_GATEWAY_CLASS;
$gateway = new $gateway_class();
/**
* TODO: This can be replaced with:
*
* $gateway->update_option( 'enabled', 'yes' );
*
* ...once the minimum WC version is 3.4.0.
*/
$gateway->settings['enabled'] = 'yes';
update_option( $gateway->get_option_key(), apply_filters( 'woocommerce_settings_api_sanitized_fields_' . $gateway::ID, $gateway->settings ), 'yes' );
}
// Disable main Stripe/card LPM if 'card' UPE method wasn't enabled.
if ( ! in_array( 'card', $upe_enabled_method_ids, true ) ) {
$settings['enabled'] = 'no';
}
// DISABLE ALL UPE METHODS
if ( ! isset( $settings['upe_checkout_experience_accepted_payments'] ) ) {
$settings['upe_checkout_experience_accepted_payments'] = [];
}
return $settings;
}
/**
* Adds the failed SCA auth email to WooCommerce.
*
* @param WC_Email[] $email_classes All existing emails.
* @return WC_Email[]
*/
public function add_emails( $email_classes ) {
require_once WC_STRIPE_PLUGIN_PATH . '/includes/compat/class-wc-stripe-email-failed-authentication.php';
require_once WC_STRIPE_PLUGIN_PATH . '/includes/compat/class-wc-stripe-email-failed-renewal-authentication.php';
require_once WC_STRIPE_PLUGIN_PATH . '/includes/compat/class-wc-stripe-email-failed-preorder-authentication.php';
require_once WC_STRIPE_PLUGIN_PATH . '/includes/compat/class-wc-stripe-email-failed-authentication-retry.php';
// Add all emails, generated by the gateway.
$email_classes['WC_Stripe_Email_Failed_Renewal_Authentication'] = new WC_Stripe_Email_Failed_Renewal_Authentication( $email_classes );
$email_classes['WC_Stripe_Email_Failed_Preorder_Authentication'] = new WC_Stripe_Email_Failed_Preorder_Authentication( $email_classes );
$email_classes['WC_Stripe_Email_Failed_Authentication_Retry'] = new WC_Stripe_Email_Failed_Authentication_Retry( $email_classes );
return $email_classes;
}
/**
* Register REST API routes.
*
* New endpoints/controllers can be added here.
*/
public function register_routes() {
/** API includes */
require_once WC_STRIPE_PLUGIN_PATH . '/includes/admin/class-wc-stripe-rest-base-controller.php';
require_once WC_STRIPE_PLUGIN_PATH . '/includes/abstracts/abstract-wc-stripe-connect-rest-controller.php';
require_once WC_STRIPE_PLUGIN_PATH . '/includes/admin/class-wc-rest-stripe-account-controller.php';
require_once WC_STRIPE_PLUGIN_PATH . '/includes/admin/class-wc-rest-stripe-connection-tokens-controller.php';
require_once WC_STRIPE_PLUGIN_PATH . '/includes/admin/class-wc-rest-stripe-locations-controller.php';
require_once WC_STRIPE_PLUGIN_PATH . '/includes/admin/class-wc-rest-stripe-orders-controller.php';
require_once WC_STRIPE_PLUGIN_PATH . '/includes/admin/class-wc-rest-stripe-tokens-controller.php';
require_once WC_STRIPE_PLUGIN_PATH . '/includes/connect/class-wc-stripe-connect-rest-oauth-init-controller.php';
require_once WC_STRIPE_PLUGIN_PATH . '/includes/connect/class-wc-stripe-connect-rest-oauth-connect-controller.php';
$connection_tokens_controller = new WC_REST_Stripe_Connection_Tokens_Controller( $this->get_main_stripe_gateway() );
$locations_controller = new WC_REST_Stripe_Locations_Controller();
$orders_controller = new WC_REST_Stripe_Orders_Controller( $this->get_main_stripe_gateway() );
$stripe_tokens_controller = new WC_REST_Stripe_Tokens_Controller();
$oauth_init = new WC_Stripe_Connect_REST_Oauth_Init_Controller( $this->connect, $this->api );
$oauth_connect = new WC_Stripe_Connect_REST_Oauth_Connect_Controller( $this->connect, $this->api );
$stripe_account_controller = new WC_REST_Stripe_Account_Controller( $this->get_main_stripe_gateway(), $this->account );
$connection_tokens_controller->register_routes();
$locations_controller->register_routes();
$orders_controller->register_routes();
$stripe_tokens_controller->register_routes();
$oauth_init->register_routes();
$oauth_connect->register_routes();
$stripe_account_controller->register_routes();
if ( WC_Stripe_Feature_Flags::is_upe_preview_enabled() ) {
require_once WC_STRIPE_PLUGIN_PATH . '/includes/admin/class-wc-rest-stripe-settings-controller.php';
require_once WC_STRIPE_PLUGIN_PATH . '/includes/admin/class-wc-stripe-rest-upe-flag-toggle-controller.php';
require_once WC_STRIPE_PLUGIN_PATH . '/includes/admin/class-wc-rest-stripe-account-keys-controller.php';
require_once WC_STRIPE_PLUGIN_PATH . '/includes/admin/class-wc-rest-stripe-payment-gateway-controller.php';
$upe_flag_toggle_controller = new WC_Stripe_REST_UPE_Flag_Toggle_Controller();
$upe_flag_toggle_controller->register_routes();
$settings_controller = new WC_REST_Stripe_Settings_Controller( $this->get_main_stripe_gateway() );
$settings_controller->register_routes();
$stripe_account_keys_controller = new WC_REST_Stripe_Account_Keys_Controller( $this->account );
$stripe_account_keys_controller->register_routes();
$settings_controller = new WC_REST_Stripe_Payment_Gateway_Controller();
$settings_controller->register_routes();
}
}
/**
* Returns the main Stripe payment gateway class instance.
*
* @return WC_Stripe_Payment_Gateway
*/
public function get_main_stripe_gateway() {
if ( ! is_null( $this->stripe_gateway ) ) {
return $this->stripe_gateway;
}
if ( WC_Stripe_Feature_Flags::is_upe_preview_enabled() && WC_Stripe_Feature_Flags::is_upe_checkout_enabled() ) {
$this->stripe_gateway = new WC_Stripe_UPE_Payment_Gateway();
return $this->stripe_gateway;
}
$this->stripe_gateway = new WC_Gateway_Stripe();
return $this->stripe_gateway;
}
/**
* Move the email field to the top of the Checkout page.
*
* @param array $fields WooCommerce checkout fields.
*
* @return array WooCommerce checkout fields.
*/
public function checkout_update_email_field_priority( $fields ) {
if ( isset( $fields['billing_email'] ) && WC_Stripe_UPE_Payment_Method_Link::is_link_enabled() ) {
// Update the field priority.
$fields['billing_email']['priority'] = 1;
// Add extra `wcpay-checkout-email-field` class.
$fields['billing_email']['class'][] = 'stripe-gateway-checkout-email-field';
// Append StripeLink modal trigger button for logged in users.
$fields['billing_email']['label'] = $fields['billing_email']['label']
. ' <button class="stripe-gateway-stripelink-modal-trigger"></button>';
}
return $fields;
}
}
$plugin = WC_Stripe::get_instance();
}
return $plugin;
}
add_action( 'plugins_loaded', 'woocommerce_gateway_stripe_init' );
function woocommerce_gateway_stripe_init() {
load_plugin_textdomain( 'woocommerce-gateway-stripe', false, plugin_basename( dirname( __FILE__ ) ) . '/languages' );
if ( ! class_exists( 'WooCommerce' ) ) {
add_action( 'admin_notices', 'woocommerce_stripe_missing_wc_notice' );
return;
}
if ( version_compare( WC_VERSION, WC_STRIPE_MIN_WC_VER, '<' ) ) {
add_action( 'admin_notices', 'woocommerce_stripe_wc_not_supported' );
return;
}
woocommerce_gateway_stripe();
}
/**
* Add woocommerce_inbox_variant for the Remote Inbox Notification.
*
* P2 post can be found at https://wp.me/paJDYF-1uJ.
*/
if ( ! function_exists( 'add_woocommerce_inbox_variant' ) ) {
function add_woocommerce_inbox_variant() {
$config_name = 'woocommerce_inbox_variant_assignment';
if ( false === get_option( $config_name, false ) ) {
update_option( $config_name, wp_rand( 1, 12 ) );
}
}
}
register_activation_hook( __FILE__, 'add_woocommerce_inbox_variant' );
function wcstripe_deactivated() {
// admin notes are not supported on older versions of WooCommerce.
require_once WC_STRIPE_PLUGIN_PATH . '/includes/class-wc-stripe-upe-compatibility.php';
if ( WC_Stripe_Inbox_Notes::are_inbox_notes_supported() ) {
// requirements for the note
require_once WC_STRIPE_PLUGIN_PATH . '/includes/class-wc-stripe-feature-flags.php';
require_once WC_STRIPE_PLUGIN_PATH . '/includes/notes/class-wc-stripe-upe-availability-note.php';
WC_Stripe_UPE_Availability_Note::possibly_delete_note();
require_once WC_STRIPE_PLUGIN_PATH . '/includes/notes/class-wc-stripe-upe-stripelink-note.php';
WC_Stripe_UPE_StripeLink_Note::possibly_delete_note();
}
}
register_deactivation_hook( __FILE__, 'wcstripe_deactivated' );
// Hook in Blocks integration. This action is called in a callback on plugins loaded, so current Stripe plugin class
// implementation is too late.
add_action( 'woocommerce_blocks_loaded', 'woocommerce_gateway_stripe_woocommerce_block_support' );
function woocommerce_gateway_stripe_woocommerce_block_support() {
if ( class_exists( 'Automattic\WooCommerce\Blocks\Payments\Integrations\AbstractPaymentMethodType' ) ) {
require_once dirname( __FILE__ ) . '/includes/class-wc-stripe-blocks-support.php';
// priority is important here because this ensures this integration is
// registered before the WooCommerce Blocks built-in Stripe registration.
// Blocks code has a check in place to only register if 'stripe' is not
// already registered.
add_action(
'woocommerce_blocks_payment_method_type_registration',
function( Automattic\WooCommerce\Blocks\Payments\PaymentMethodRegistry $payment_method_registry ) {
// I noticed some incompatibility with WP 5.x and WC 5.3 when `_wcstripe_feature_upe_settings` is enabled.
if ( ! class_exists( 'WC_Stripe_Payment_Request' ) ) {
return;
}
$container = Automattic\WooCommerce\Blocks\Package::container();
// registers as shared instance.
$container->register(
WC_Stripe_Blocks_Support::class,
function() {
if ( class_exists( 'WC_Stripe' ) ) {
return new WC_Stripe_Blocks_Support( WC_Stripe::get_instance()->payment_request_configuration );
} else {
return new WC_Stripe_Blocks_Support();
}
}
);
$payment_method_registry->register(
$container->get( WC_Stripe_Blocks_Support::class )
);
},
5
);
}
}
add_action(
'before_woocommerce_init',
function() {
if ( class_exists( '\Automattic\WooCommerce\Utilities\FeaturesUtil' ) ) {
\Automattic\WooCommerce\Utilities\FeaturesUtil::declare_compatibility( 'custom_order_tables', __FILE__, false );
}
}
);