Integrating WP Full Pay with other systems

WP Full Pay fires WordPress actions and WordPress filters when certain events occur.

You can integrate WP Full Pay with other system by hooking into these actions and filters, and running your own code.

Possible integrations include, but not limited to:

  • Inserting a row into the database with some customer data after payment
  • Adding the customer’s email address to an email list in Mailchimp
  • Sending an SMS notification when a new subscription is made

For v7+ the objects returned from the \StripeWPFS\StripeClient are stdClass or arrays and not native Stripe objects. Review your customization code prior to upgrading


Table of contents:

Plugin action catalog

You can find all supported actions in the tables below. Click on an action to jump into the detailed description and usage example.

Action Description
fullstripe_before_payment_charge Triggered before a one-time payment (inline form)
fullstripe_after_payment_charge Triggered after a one-time payment (inline form)
fullstripe_before_checkout_payment_charge Triggered before a one-time payment (checkout form)
fullstripe_after_checkout_payment_charge Triggered after a one-time payment (checkout form)
fullstripe_before_subscription_charge Triggered before a subscription payment (inline form)
fullstripe_after_subscription_charge Triggered after a subscription payment (inline form)
fullstripe_before_checkout_subscription_charge Triggered before a subscription payment (checkout form)
fullstripe_after_checkout_subscription_charge Triggered after a subscription payment (checkout form)
fullstripe_before_donation_charge Triggered before a donation payment (inline form)
fullstripe_after_donation_charge Triggered after a donation payment (inline form)
fullstripe_before_checkout_donation_charge Triggered before a donation payment (checkout form)
fullstripe_after_checkout_donation_charge Triggered after a donation payment (checkout form)
fullstripe_before_card_capture Triggered before saving a card (inline form)
fullstripe_after_card_capture Triggered after saving a card (inline form)
fullstripe_before_checkout_card_capture Triggered before saving a card (checkout form)
fullstripe_after_checkout_card_capture Triggered after saving a card (checkout form)

Action Description
fullstripe_before_subscription_cancellation Triggered before a subscription is canceled
fullstripe_after_subscription_cancellation Triggered after a subscription is canceled
fullstripe_before_subscription_update Triggered before a subscription is updated
fullstripe_after_subscription_update Triggered after a subscription is updated
fullstripe_before_subscription_activation Triggered before a subscription is activated
fullstripe_after_subscription_activation Triggered after a subscription is activated

Plugin filter catalog

You can find all supported filters in the table below. Click on a filter to jump into the detailed description and usage example.

Filter Description
fullstripe_select_subscription_plan

Set the subscription plan selected by default via URL parameter.


Triggered when a plan selector parameter is found in the page URL.

fullstripe_set_custom_amount

Set the custom payment amount entered by default via URL parameter.


Triggered when a custom amount parameter is found in the page URL.

fullstripe_add_transaction_metadata

Add metadata to transactions.


Triggered before the page is loaded so that metadata can be added to the transaction from URL parameters.

fullstripe_get_upgrade_downgrade_plans

Tell the customer portal which subscription plans should be offered for upgrading/downgrading the current plan.


Triggered before the list of subscription plans is displayed to the customer on the “Customer portal” page.

fullstripe_customer_portal_header

Display extra content at the top of the customer portal pane.


Triggered before the “Customer portal” page is displayed.

fullstripe_customer_portal_footer

Display extra content at the bottom of the customer portal pane.


Triggered before the “Customer portal” page is displayed.

fullstripe_modify_email_subject

Modify the subject of plugin email notications.


Triggered before sending a plugin email notification.

fullstripe_modify_email_message

Modify the body of plugin email notications.


Triggered before sending a plugin email notification.

fullstripe_thank_you_output

Modify the thank you page.


Triggered before displaying a thank you page.

fullstripe_thank_you_url_parameters

Modify the URL parameters added to the thank you page URL.


Triggered before opening the thank you page.

fullstripe_thank_you_post_types

Modify the post types whose pages are offered as thank ypu pages in WP admin.


Triggered before displaying the thank you page selector in WP admin.

fullstripe_billing_countries

Filter the billing countries.


Triggered before displaying a form where the billing country is collected.

fullstripe_shipping_countries

Filter the shipping countries.


Triggered before displaying a form where the shipping country is collected.

fullstripe_payment_intent_parameters

Modify the PaymentIntent parameters.


Triggered before creating a PaymentIntent via the Stripe API.

fullstripe_checkout_session_parameters

Modify the CheckoutSession parameters.


Triggered before creating a CheckoutSession via the Stripe API.

fullstripe_determine_tax_rates

Filter the tax rates.


Triggered before payment is made to determine the Stripe tax rates used for the payment.

fullstripe_determine_tax_label

Filter the tax label.


Triggered before an inline payment or subscription form using Stripe Tax is (re)rendered.

fullstripe_members_supported_post_types

Filter the custom post types used for protected content.


Triggered before the Wordpress page editor is displayed to the user.

fullstripe_form_field_configuration Set which form fields can be pre-filled via URL parameters, and which form fields should be read-only once they are set.

Plugin actions

fullstripe_before_payment_charge

The fullstripe_before_payment_charge action is fired before a one-time payment transaction is about to be started on an inline form.

You can block the transaction by throwing an exception.

Action parameters:


Name Description
$params

An array containing data about the customer and the transaction.

See the example below for details.

An example implementation with the documentation of the ‘params’ parameter:


<?php
/**
 * A &#39;fullstripe_before_payment_charge&#39; action hook example for WP Full Stripe.
 * It blocks the payment if the payment amount is less than $20.
 *
 * @param array $params with the following keys:
 *   email            => Email address of the customer
 *   urlParameters    => Array of URL parameters
 *   formName         => Name of the form the payment is being made on
 *   priceId          => Id of Stripe price being purchased. Null for custom amounts.
 *   productName      => Name of the Stripe product being purchased.
 *   currency         => ISO code of the payment currency (eg. USD)
 *   amount           => Payment amount (it&#39;s in cents for non-zerodecimal currencies like the USD, EUR)
 *   stripeClient     => Instance of the \StripeWPFS\StripeClient object, initialized in the same API mode as the current transaction  
 */

function beforeInlinePaymentCharge( $params ) {
	$amount = $params[&#39;amount&#39;];

	if ( $amount < 2000 ) {
		$ex = new WPFS_UserFriendlyException( "Price must be $20 or more" );
		$ex->setTitle( &#39;Not allowed&#39; );		
		throw $ex;
	}
}

add_action(&#39;fullstripe_before_payment_charge&#39;, &#39;beforeInlinePaymentCharge&#39;, 10, 1 );

fullstripe_after_payment_charge

The fullstripe_after_payment_charge action is fired after a successful one-time payment on an inline form.

Action parameters:

Name Description
$params

An array containing data about the customer and the transaction.

See the example below for details.

The example implementation with the documentation of the ‘params’ parameter:


<?php
/**
 * A &#39;fullstripe_after_payment_charge&#39; action hook example for WP Full Stripe.
 * It logs the payment amount, form name, and customer email address 
 * to the webserver error log.
 *
 * @param array $params with the following keys:
 *   email                  => Email address of the customer
 *   urlParameters          => Array of URL parameters
 *   formName               => Name of the form the payment is being made on
 *   priceId                => Id of Stripe price being purchased. Null for custom amounts.
 *   productName            => Name of the Stripe product being purchased.
 *   currency               => ISO code of the payment currency (eg. USD)
 *   amount                 => Payment amount (it&#39;s in cents for non-zerodecimal currencies like the USD, EUR)
 *   stripeClient           => Instance of the \StripeWPFS\StripeClient object, intialized in the same API mode as the current transaction
 *   stripePaymentIntent    => Instance of the \StripeWPFS\PaymentIntent object created in the transaction
 *   rawPlaceholders        => All placeholder tokens, no decoration
 *   decoratedPlaceholders  => All placeholder tokens with decoration
 */

function afterInlinePaymentCharge( $params ) {
    $paymentIntent = $params[ &#39;stripePaymentIntent&#39; ];
    $stripeCustomer = MM_WPFS_API_v1::getStripeCustomer( $paymentIntent->customer );
  
    $customerEmail   = $stripeCustomer->email;
    $paymentCurrency = $paymentIntent->currency;
    $paymentAmount   = $paymentIntent->amount_received;
    $paymentMetadata = $paymentIntent->metadata;
    $paymentFormName = $params[&#39;formName&#39;];

    error_log(__FUNCTION__ . "(): Successful payment of " .
            $paymentAmount  . " " . $paymentCurrency .
                " on form &#39;" . $paymentFormName .
                "&#39; from " . $customerEmail . " ." );
}

add_action(&#39;fullstripe_after_payment_charge&#39;, &#39;afterInlinePaymentCharge&#39;, 10, 1);

fullstripe_before_checkout_payment_charge

The fullstripe_before_checkout_payment_charge action is fired before a one-time payment transaction is about to be started on a checkout form.

You can block the transaction by throwing an exception.

Action parameters:

Name Description
$params

An array containing data about the customer and the transaction.

See the example below for details.

An example implementation with the documentation of the ‘params’ parameter:

<?php
/**
 * A &#39;fullstripe_before_checkout_payment_charge&#39; action hook example for WP Full Stripe.
 * It blocks the payment if the payment amount is less than $20.
 *
 * @param array $params with the following keys:
 *   email            => Email address of the customer
 *   urlParameters    => Array of URL parameters
 *   formName         => Name of the form the payment is being made on
 *   priceId          => Id of Stripe price being purchased. Null for custom amounts.
 *   productName      => Name of the Stripe product being purchased.
 *   currency         => ISO code of the payment currency (eg. USD)
 *   amount           => Payment amount (it&#39;s in cents for non-zerodecimal currencies like the USD, EUR)
 *   stripeClient     => Instance of the \StripeWPFS\StripeClient object, intialized in the same API mode as the current transaction  
 */

function beforeCheckoutPaymentCharge( $params ) {
    $amount = $params[&#39;amount&#39;];

    if ( $amount < 2000 ) {
        $ex = new WPFS_UserFriendlyException( "Price must be $20 or more" );
        $ex->setTitle( &#39;Not allowed&#39; );     
        throw $ex;
    }
}

add_action(&#39;fullstripe_before_checkout_payment_charge&#39;, &#39;beforeCheckoutPaymentCharge&#39;, 10, 1 );

fullstripe_after_checkout_payment_charge

The fullstripe_after_checkout_payment_charge action is fired after a successful one-time payment on a checkout form.

Action parameters:

Name Description
$params

An array containing data about the customer and the transaction.

See the example below for details.

An example implementation with the documentation of the ‘params’ parameter:

<?php
/**
 * A &#39;fullstripe_after_checkout_payment_charge&#39; action hook example for WP Full Stripe.
 * It sends email notification about the successful payment to a preset email address. 
 *
 * @param array $params with the following keys:
 *   email                  => Email address of the customer
 *   urlParameters          => Array of URL parameters
 *   formName               => Name of the form the payment is being made on
 *   priceId                => Id of Stripe price being purchased. Null for custom amounts.
 *   productName            => Name of the Stripe product being purchased.
 *   currency               => ISO code of the payment currency (eg. USD)
 *   amount                 => Payment amount (it&#39;s in cents for non-zerodecimal currencies like the USD, EUR)
 *   stripeClient           => Instance of the \StripeWPFS\StripeClient object, intialized in the same API mode as the current transaction
 *   stripePaymentIntent    => Instance of the \StripeWPFS\PaymentIntent object created in the transaction
 *   rawPlaceholders        => All placeholder tokens, no decoration
 *   decoratedPlaceholders  => All placeholder tokens with decoration
 */

function afterCheckoutPaymentCharge( $params ) {
    $paymentIntent = $params[ &#39;stripePaymentIntent&#39; ];
    $stripeCustomer = MM_WPFS_API_v1::getStripeCustomer( $paymentIntent->customer );

    $customerEmail   = $stripeCustomer->email;
    $paymentCurrency = $paymentIntent->currency;
    $paymentAmount	 = $paymentIntent->amount_received;

    $sender_name	 = html_entity_decode( get_bloginfo( &#39;name&#39; ) );
    $sender_email	 = &#39;noreply@example.com&#39;;
    $recipient_email = &#39;john.doe@example.com&#39;;
    $subject	 = &#39;New sale!&#39;;
    $headers[]	 = "From: $sender_name <$sender_email>";
    $headers[]	 = "Content-type: text/html";
    $message 	 = "Successful payment of " .
		$paymentAmount  . " " . $paymentCurrency .
		" from " . $customerEmail . " .";

    $send_result = wp_mail( $recipient_email, $subject, $message, $headers );
}

add_action(&#39;fullstripe_after_checkout_payment_charge&#39;, &#39;afterCheckoutPaymentCharge&#39;, 10, 1);

fullstripe_before_subscription_charge

The fullstripe_before_subscription_charge action is fired before a subscription is about to be started on an inline form.

You can block the transaction by throwing an exception.

Action parameters:

Name Description
$params

An array containing data about the customer and the transaction.

See the example below for details.

An example implementation with the documentation of the ‘params’ parameter:


<?php
/**
 * A &#39;fullstripe_before_subscription_charge&#39; action hook example for WP Full Stripe.
 * It blocks the subscripton if the quantity is less than 3.
 *
 * @param array $params with the following keys:
 *   email            => Email address of the customer
 *   urlParameters    => Array of URL parameters
 *   formName         => Name of the form the payment is being made on
 *   productName      => Name of the Stripe product being purchased
 *   planId           => Id of Stripe recurring price being purchased
 *   currency         => ISO code of the payment currency (eg. USD)
 *   amount           => Plan amount (it&#39;s in cents for non-zerodecimal currencies like the USD, EUR)
 *   setupFee         => Setup fee amount (it&#39;s in cents for non-zerodecimal currencies like the USD, EUR). Zero if there is no setup fee.
 *   quantity         => Number of plans purchased
 *   stripeClient     => Instance of the \StripeWPFS\StripeClient object, intialized in the same API mode as the current transaction  
 */

function beforeInlineSubscriptionCharge( $params ) {
    $amount = $params[&#39;quantity&#39;];

    if ( $quantity < 3 ) {
        $ex = new WPFS_UserFriendlyException( "Please purchase at least 3 subscriptions" );
        $ex->setTitle( &#39;Not allowed&#39; );     
        throw $ex;
    }
}

add_action(&#39;fullstripe_before_subscription_charge&#39;, &#39;beforeInlineSubscriptionCharge&#39;, 10    , 1 );

fullstripe_after_subscription_charge

The fullstripe_after_subscription_charge action is fired after the customer successfully subscribed on an inline form.

Action parameters:

Name Description
$params

An array containing data about the customer and the transaction.

See the example below for details.

An example implementation with the documentation of the ‘params’ parameter:


<?php
/**
 * A &#39;fullstripe_after_subscription_charge&#39; action hook example for WP Full Stripe.
 * It registers a Wordpress user, and sends the user registration email to the customer. 
 *
 * @param array $params with the following keys:
 *   email                  => Email address of the customer
 *   urlParameters          => Array of URL parameters
 *   formName               => Name of the form the payment is being made on
 *   productName            => Name of the Stripe product being purchased
 *   planId                 => Id of Stripe recurring price being purchased
 *   currency               => ISO code of the payment currency (eg. USD)
 *   amount                 => Plan amount (it&#39;s in cents for non-zerodecimal currencies like the USD, EUR)
 *   setupFee               => Setup fee amount (it&#39;s in cents for non-zerodecimal currencies like the USD, EUR). Zero if there is no setup fee.
 *   quantity               => Number of plans purchased
 *   stripeClient           => Instance of the \StripeWPFS\StripeClient object, intialized in the same API mode as the current transaction
 *   stripeSubscription     => Instance of the \StripeWPFS\Subscription object
 *   rawPlaceholders        => All placeholder tokens, no decoration
 *   decoratedPlaceholders  => All placeholder tokens with decoration
 */

function afterInlineSubscriptionCharge( $params ) {
    $stripeSubscription     = $params[&#39;stripeSubscription&#39;];
    $stripeCustomer         = MM_WPFS_API_v1::getStripeCustomer( $stripeSubscription->customer );
    
    $userData = array();
    $sanitizedName = trim($stripeCustomer->name);
    $userData[&#39;display_name&#39;] = $sanitizedName;

    // Extract first name and last name from customer&#39;s name
    $lastPos = strrpos($sanitizedName, " ");
    if ($lastPos === false) {
        $userData[&#39;first_name&#39;] = $sanitizedName;
        $userData[&#39;last_name&#39;]  = "";
    } else {
        $userData[&#39;first_name&#39;] = trim(substr($sanitizedName, 0, $lastPos));
        $userData[&#39;last_name&#39;]  = trim(substr($sanitizedName, $lastPos));
    }
    $userData[&#39;nickname&#39;]   = $userData[&#39;first_name&#39;];
    $userData[&#39;user_login&#39;] = $stripeCustomer->email;
    $userData[&#39;user_pass&#39;]  = wp_generate_password( $length = 20, $include_standard_special_chars = false );;
    $userData[&#39;user_email&#39;] = $stripeCustomer->email;

    $user_id = wp_insert_user( $userData );

    // You can also add a role to the WP user, but you need the id of the role
    $user = get_user_by( &#39;id&#39;, $user_id );
    //$user->add_role( $planRole );

    // Send email with credentials to customer
    wp_new_user_notification($user_id,null,&#39;user&#39;);
}

add_action(&#39;fullstripe_after_subscription_charge&#39;, &#39;afterInlineSubscriptionCharge&#39;, 10, 1);

fullstripe_before_checkout_subscription_charge

The fullstripe_before_subscription_charge action is fired before a subscription is about to be started on a checkout form.

You can block the transaction by throwing an exception.

Action parameters:

Name Description
$params

An array containing data about the customer and the transaction.

See the example below for details.

An example implementation with the documentation of the ‘params’ parameter:

<?php
/**
 * A &#39;fullstripe_before_checkout_subscription_charge&#39; action hook example for WP Full Stripe.
 * It blocks the subscripton if the quantity is less than 3.
 *
 * @param array $params with the following keys:
 *   email            => Email address of the customer
 *   urlParameters    => Array of URL parameters
 *   formName         => Name of the form the payment is being made on
 *   productName      => Name of the Stripe product being purchased
 *   planId           => Id of Stripe recurring price being purchased
 *   currency         => ISO code of the payment currency (eg. USD)
 *   amount           => Plan amount (it&#39;s in cents for non-zerodecimal currencies like the USD, EUR)
 *   setupFee         => Setup fee amount (it&#39;s in cents for non-zerodecimal currencies like the USD, EUR). Zero if there is no setup fee.
 *   quantity         => Number of plans purchased
 *   stripeClient     => Instance of the \StripeWPFS\StripeClient object, intialized in the same API mode as the current transaction  
 */

function beforeCheckoutSubscriptionCharge( $params ) {
    $amount = $params[&#39;quantity&#39;];

    if ( $quantity < 3 ) {
        $ex = new WPFS_UserFriendlyException( "Please purchase at least 3 subscriptions" );
        $ex->setTitle( &#39;Not allowed&#39; );     
        throw $ex;
    }
}

add_action(&#39;fullstripe_before_checkout_subscription_charge&#39;, &#39;beforeCheckoutSubscriptionCharge&#39;, 10, 1 );

fullstripe_after_checkout_subscription_charge

The fullstripe_after_checkout_subscription_charge action is fired after the customer successfully subscribed on a checkout form.

Action parameters:

Name Description
$params

An array containing data about the customer and the transaction.

See the example below for details.

An example implementation with the documentation of the ‘params’ parameter:

<?php
/**
 * A &#39;fullstripe_after_checkout_subscription_charge&#39; action hook example for WP Full Stripe.
 * It adds the subscriber&#39;s email address to a Mailchimp list.
 *
 * @param array $params with the following keys:
 *   email                  => Email address of the customer
 *   urlParameters          => Array of URL parameters
 *   formName               => Name of the form the payment is being made on
 *   productName            => Name of the Stripe product being purchased
 *   planId                 => Id of Stripe recurring price being purchased
 *   currency               => ISO code of the payment currency (eg. USD)
 *   amount                 => Plan amount (it&#39;s in cents for non-zerodecimal currencies like the USD, EUR)
 *   setupFee               => Setup fee amount (it&#39;s in cents for non-zerodecimal currencies like the USD, EUR). Zero if there is no setup fee.
 *   quantity               => Number of plans purchased
 *   stripeClient           => Instance of the \StripeWPFS\StripeClient object, intialized in the same API mode as the current transaction
 *   stripeSubscription     => Instance of the \StripeWPFS\Subscription object
 *   rawPlaceholders        => All placeholder tokens, no decoration
 *   decoratedPlaceholders  => All placeholder tokens with decoration
 */

function checkoutAfterSubscription( $params ) {
    $stripeSubscription = $params[&#39;stripeSubscription&#39;];
    $stripeCustomer = MM_WPFS_API_v1::getStripeCustomer( $stripeSubscription->customer );
  
    // SET THESE CONSTANTS
    $MAILCHIMP_AUDIENCE_ID = &#39;YOUR-AUDIENCE-ID&#39;;
    $MAILCHIMP_API_KEY = &#39;YOUR-API-KEY&#39;;
    $MAILCHIMP_SERVER = &#39;YOUR_SERVER_ID&#39;;
    // SET THESE CONSTANTS
      
    $APP_AGENT = &#39;Your website agent&#39;;
    $MAILCHIMP_API_ENDPOINT = &#39;https://&#39; . $MAILCHIMP_SERVER . &#39;.api.mailchimp.com/3.0/lists/&#39; . $MAILCHIMP_AUDIENCE_ID . &#39;/members/&#39;;
 
    $response = wp_remote_post( $MAILCHIMP_API_ENDPOINT, array(
        &#39;method&#39;      => &#39;POST&#39;,
        &#39;timeout&#39;     => 45,
        &#39;redirection&#39; => 5,
        &#39;httpversion&#39; => &#39;1.1&#39;,
        &#39;blocking&#39;    => true,
        &#39;headers&#39;     => array(
            &#39;Content-Type&#39;  => &#39;application/json&#39;,
            &#39;Authorization&#39; => &#39;apikey &#39;. $MAILCHIMP_API_KEY,
        ),
        &#39;body&#39;        => wp_json_encode( array(
            "email_address" => $stripeCustomer->email,
            "status"        => "subscribed"
        )),
        &#39;cookies&#39;     => array()
    ));

    if ( is_wp_error( $response ) ) {
        error_log( "Something went wrong: " . $response->get_error_message() );
    }
}

add_action(&#39;fullstripe_after_checkout_subscription_charge&#39;, &#39;checkoutAfterSubscription&#39;, 10, 1 );

fullstripe_before_donation_charge

The fullstripe_before_donation_charge action is fired before a donation transaction is about to be started on an inline form.

You can block the transaction by throwing an exception.

Action parameters:

Name Description
$params

An array containing data about the customer and the transaction.

See the example below for details.

An example implementation with the documentation of the ‘params’ parameter:


<?php
/**
 * A &#39;fullstripe_before_donation_charge&#39; action hook example for WP Full Stripe.
 * It blocks the donation if the donation amount is less than $5.
 *
 * @param array $params with the following keys:
 *   email            => Email address of the customer
 *   urlParameters    => Array of URL parameters
 *   formName         => Name of the form the payment is being made on
 *   currency         => ISO code of the payment currency (eg. USD)
 *   frequency        => The donation frequency, possible values:
 *                           one-time
 *                           daily
 *                           weekly
 *                           monhtly
 *                           annual
 *   amount           => Donation amount (it&#39;s in cents for non-zerodecimal currencies like the USD, EUR)
 *   stripeClient     => Instance of the \StripeWPFS\StripeClient object, intialized in the same API mode as the current transaction  
 */

function beforeInlineDonationCharge( $params ) {
    $amount = $params[&#39;amount&#39;];

    if ( $amount < 500 ) {
        $ex = new WPFS_UserFriendlyException( "Please donate $5 or more" );
        $ex->setTitle( &#39;Not allowed&#39; );     
        throw $ex;
    }
}

add_action(&#39;fullstripe_before_donation_charge&#39;, &#39;beforeInlineDonationCharge&#39;, 10, 1 );

fullstripe_after_donation_charge

The fullstripe_after_donation_charge action is fired after a successful donation on an inline form.

Action parameters:

Name Description
$params

An array containing data about the customer and the transaction.

See the example below for details.

An example implementation with the documentation of the ‘params’ parameter:


<?php
/**
 * A &#39;fullstripe_after_donation_charge&#39; action hook example for WP Full Stripe.
 *
 * @param array $params with the following keys:
 *   email                  => Email address of the customer
 *   urlParameters          => Array of URL parameters
 *   formName               => Name of the form the payment is being made on
 *   currency               => ISO code of the payment currency (eg. USD)
 *   frequency              => The donation frequency, possible values:
 *                                 one-time
 *                                 daily
 *                                 weekly
 *                                 monhtly
 *                                 annual
 *   amount                 => Payment amount (it&#39;s in cents for non-zerodecimal currencies like the USD, EUR)
 *   stripeClient           => Instance of the \StripeWPFS\StripeClient object, intialized in the same API mode as the current transaction
 *   stripePaymentIntent    => Instance of the \StripeWPFS\PaymentIntent object created in the transaction
 *   stripeSubscription     => Instance of the \StripeWPFS\Subscription object created in the transaction for recurring donations 
 *   rawPlaceholders        => All placeholder tokens, no decoration
 *   decoratedPlaceholders  => All placeholder tokens with decoration
 */

function afterInlineDonationCharge( $params ) {
    $stripePaymentIntent    = $params[&#39;stripePaymentIntent&#39;];
    $stripeSubscription     = $params[&#39;stripeSubscription&#39;];

    // Do your thing here
}

add_action(&#39;fullstripe_after_donation_charge&#39;, &#39;afterInlineDonationCharge&#39;, 10, 1);

fullstripe_before_checkout_donation_charge

The fullstripe_before_checkout_donation_charge action is fired before a donation transaction is about to be started on a checkout form.

You can block the transaction by throwing an exception.

Action parameters:

Name Description
$params

An array containing data about the customer and the transaction.

See the example below for details.

An example implementation with the documentation of the ‘params’ parameter:


<?php
/**
 * A &#39;fullstripe_before_checkout_donation_charge&#39; action hook example for WP Full Stripe.
 * It blocks the donation if the donation amount is less than $5.
 *
 * @param array $params with the following keys:
 *   email            => Email address of the customer
 *   urlParameters    => Array of URL parameters
 *   formName         => Name of the form the payment is being made on
 *   currency         => ISO code of the payment currency (eg. USD)
 *   frequency        => The donation frequency, possible values:
 *                           one-time
 *                           daily
 *                           weekly
 *                           monhtly
 *                           annual
 *   amount           => Donation amount (it&#39;s in cents for non-zerodecimal currencies like the USD, EUR)
 *   stripeClient     => Instance of the \StripeWPFS\StripeClient object, intialized in the same API mode as the current transaction  
 */

function beforeCheckoutDonationCharge( $params ) {
    $amount = $params[&#39;amount&#39;];

    if ( $amount < 500 ) {
        $ex = new WPFS_UserFriendlyException( "Please donate $5 or more" );
        $ex->setTitle( &#39;Not allowed&#39; );     
        throw $ex;
    }
}

add_action(&#39;fullstripe_before_checkout_donation_charge&#39;, &#39;beforeCheckoutDonationCharge&#39;, 10, 1 );

fullstripe_after_checkout_donation_charge

The fullstripe_after_checkout_donation_charge action is fired after a successful donation on a checkout form.

Action parameters:

Name Description
$params

An array containing data about the customer and the transaction.

See the example below for details.

An example implementation with the documentation of the ‘params’ parameter:


<?php
/**
 * A &#39;fullstripe_after_checkout_donation_charge&#39; action hook example for WP Full Stripe.
 *
 * @param array $params with the following keys:
 *   email                  => Email address of the customer
 *   urlParameters          => Array of URL parameters
 *   formName               => Name of the form the payment is being made on
 *   currency               => ISO code of the payment currency (eg. USD)
 *   frequency              => The donation frequency, possible values:
 *                                 one-time
 *                                 daily
 *                                 weekly
 *                                 monhtly
 *                                 annual
 *   amount                 => Payment amount (it&#39;s in cents for non-zerodecimal currencies like the USD, EUR)
 *   stripeClient           => Instance of the \StripeWPFS\StripeClient object, intialized in the same API mode as the current transaction
 *   stripePaymentIntent    => Instance of the \StripeWPFS\PaymentIntent object created in the transaction
 *   stripeSubscription     => Instance of the \StripeWPFS\Subscription object created in the transaction for recurring donations 
 *   rawPlaceholders        => All placeholder tokens, no decoration
 *   decoratedPlaceholders  => All placeholder tokens with decoration
 */

function afterCheckoutDonationCharge( $params ) {
    $stripePaymentIntent    = $params[&#39;stripePaymentIntent&#39;];
    $stripeSubscription     = $params[&#39;stripeSubscription&#39;];

    // Do your thing here
}

add_action(&#39;fullstripe_after_checkout_donation_charge&#39;, &#39;afterCheckoutDonationCharge&#39;, 10, 1);

fullstripe_before_card_capture

The fullstripe_before_card_capture action is fired before a Stripe customer is about to be saved on a inline form.

You can block the transaction by throwing an exception.

Action parameters:

Name Description
$params

An array containing data about the customer and the transaction.

See the example below for details.

An example implementation with the documentation of the ‘params’ parameter:


<?php
/**
 * A &#39;fullstripe_before_card_capture&#39; action hook example for WP Full Stripe.
 *
 * @param array $params with the following keys:
 *   email            => Email address of the customer
 *   urlParameters    => Array of URL parameters
 *   formName         => Name of the form the payment is being made on
 *   stripeClient     => Instance of the \StripeWPFS\StripeClient object, intialized in the same API mode as the current transaction  
 */

function beforeInlineSaveCard( $params ) {
    $stripeClient = $params[&#39;stripeClient&#39;];

    // Do your thing here
}

add_action(&#39;fullstripe_before_card_capture&#39;, &#39;beforeInlineSaveCard&#39;, 10, 1 );

fullstripe_after_card_capture

The fullstripe_after_card_capture action is fired after the Stripe customer has been successfully created on a save card inline form.

Action parameters:

Name Description
$params

An array containing data about the customer and the transaction.

See the example below for details.

An example implementation with the documentation of the ‘params’ parameter:


<?php
/**
 * A &#39;fullstripe_after_card_capture&#39; action hook example for WP Full Stripe.
 * It posts an API request with the email address as a parameter in the content body.
 *
 * @param array $params with the following keys:
 *   email                  => Email address of the customer
 *   urlParameters          => Array of URL parameters
 *   formName               => Name of the form the payment is being made on
 *   stripeClient           => Instance of the \StripeWPFS\StripeClient object, intialized in the same API mode as the current transaction
 *   stripeCustomer         => Instance of the \StripeWPFS\Customer object created in the transaction 
 *   rawPlaceholders        => All placeholder tokens, no decoration
 *   decoratedPlaceholders  => All placeholder tokens with decoration
 */

function afterInlineSaveCard( $params ) {
    $stripeCustomer = $params[&#39;stripeCustomer&#39;];

    $url  = &#39;http://myapi.com&#39;;
    $data = array (
        &#39;email&#39; =>  $stripeCustomer->email
    );

    $response = wp_remote_post( $url, array(
        &#39;body&#39;    => $data,
    ));
    if ( !is_wp_error ($response) ) {
        // The call was successful
    } else {
        // The call was NOT successful, handle error
    }
}

add_action(&#39;fullstripe_after_card_capture&#39;, &#39;afterInlineSaveCard&#39;, 10, 1);

fullstripe_before_checkout_card_capture

The fullstripe_before_checkout_card_capture action is fired before a Stripe customer is about to be saved on a checkout form.

You can block the transaction by throwing an exception.

Action parameters:

Name Description
$params

An array containing data about the customer and the transaction.

See the example below for details.

An example implementation with the documentation of the ‘params’ parameter:


<?php
/**
 * A &#39;fullstripe_before_checkout_card_capture&#39; action hook example for WP Full Stripe.
 *
 * @param array $params with the following keys:
 *   email            => Email address of the customer
 *   urlParameters    => Array of URL parameters
 *   formName         => Name of the form the payment is being made on
 *   stripeClient     => Instance of the \StripeWPFS\StripeClient object, intialized in the same API mode as the current transaction  
 */

function beforeCheckoutSaveCard( $params ) {
    $stripeClient = $params[&#39;stripeClient&#39;];

    // Do your thing here
}

add_action(&#39;fullstripe_before_checkout_card_capture&#39;, &#39;beforeCheckoutSaveCard&#39;, 10, 1 );

fullstripe_after_checkout_card_capture

The fullstripe_after_checkout_card_capture action is fired after the Stripe customer has been successfully created on a save card checkout form.

Action parameters:

Name Description
$params

An array containing data about the customer and the transaction.

See the example below for details.

An example implementation with the documentation of the ‘params’ parameter:


<?php
/**
 * A &#39;fullstripe_after_checkout_card_capture&#39; action hook example for WP Full Stripe.
 * It posts an API request with the email address as a parameter in the content body.
 *
 * @param array $params with the following keys:
 *   email                  => Email address of the customer
 *   urlParameters          => Array of URL parameters
 *   formName               => Name of the form the payment is being made on
 *   stripeClient           => Instance of the \StripeWPFS\StripeClient object, intialized in the same API mode as the current transaction
 *   stripeCustomer         => Instance of the \StripeWPFS\Customer object created in the transaction 
 *   rawPlaceholders        => All placeholder tokens, no decoration
 *   decoratedPlaceholders  => All placeholder tokens with decoration
 */

function afterCheckoutSaveCard( $params ) {
    $stripeCustomer = $params[&#39;stripeCustomer&#39;];

    $url  = &#39;http://myapi.com&#39;;
    $data = array (
        &#39;email&#39; =>  $stripeCustomer->email
    );

    $response = wp_remote_post( $url, array(
        &#39;body&#39;    => $data,
    ));
    if ( !is_wp_error ($response) ) {
        // The call was successful
    } else {
        // The call was NOT successful, handle error
    }
}

add_action(&#39;fullstripe_after_checkout_card_capture&#39;, &#39;afterCheckoutSaveCard&#39;, 10, 1);

fullstripe_before_subscription_cancellation

The fullstripe_before_subscription_cancellation action is fired before a subscription is canceled in Stripe.

Action parameters:

Name Description
$subscriptionId The identifier of the Stripe subscription.

An example implementation with the documentation of the ‘subscriptionId’ parameter:


<?php
/**
 * A &#39;fullstripe_before_subscription_cancellation&#39; action hook example for WP Full Stripe.
 *
 * @param string $subscriptionId  => Identifier of the Stripe subscription which is about to be cancelled
 */

function beforeSubscriptionCancellation( $subscriptionId ) {
    $stripeSubscription = MM_WPFS_API_v1::getStripeSubscription( $subscriptionId );
    $stripeCustomer = MM_WPFS_API_v1::getStripeCustomer( $stripeSubscription->customer );
    
    // Do your thing here
}

add_action(&#39;fullstripe_before_subscription_cancellation&#39;, &#39;beforeSubscriptionCancellation&#39;, 10, 1);

fullstripe_after_subscription_cancellation

The fullstripe_after_subscription_cancellation action is fired after a subscription has been canceled in Stripe.

Action parameters:

Name Description
$subscriptionId The identifier of the Stripe subscription.

An example implementation with the documentation of the ‘subscriptionId’ parameter:


<?php
/**
 * A &#39;fullstripe_after_subscription_cancellation&#39; action hook example for WP Full Stripe.
 *
 * @param string subscriptionId  => Identifier of the Stripe subscription which was cancelled
 */

function afterSubscriptionCancellation( $subscriptionId ) {
    $stripeClient = MM_WPFS_API_v1::getStripeClient();
    
    $filter = array(
        &#39;expand&#39;   => array(
            &#39;customer&#39;, 
            &#39;plan.product&#39;
        )
    );
    $subscription = $stripeClient->subscriptions->retrieve( $subscriptionId, $filter );
        
    $stripeCustomer = $subscription->customer;
    $customerName   = $stripeCustomer->name;
    $customerEmail  = $stripeCustomer->email;
    $subscriptionId = $subscription->id;
    $planName       = $subscription->plan->product->name;

    $sender_name     = html_entity_decode( get_bloginfo( &#39;name&#39; ) );
    $sender_email    = &#39;subscriptions@example.com&#39;;
    $recipient_email = "${customerEmail}";
    $subject   = &#39;Your subscription has been canceled&#39;;
    $headers[] = "From: $sender_name <$sender_email>";
    $headers[] = "Bcc: ${sender_email}";
    $headers[] = "Content-type: text/html";
    $message   =
        "<html><body>
        
        <p>Dear ${customerName},</p>
        <p>Your ${planName} has been canceled. We are sorry to see you go.</p>
        <p>If you have any questions, contact us by replying to this email or by writing us at info@example.com.</p>
        <br/>
        
        </body></html>";

    $send_result = wp_mail( $recipient_email, $subject, $message, $headers );
}

add_filter( &#39;fullstripe_after_subscription_cancellation&#39;, &#39;afterSubscriptionCancellation&#39;, 10, 1);

fullstripe_before_subscription_update

The fullstripe_before_subscription_update action is fired before a subscription is updated on the “Customer Portal” page or via the plugin’s API.

Action parameters:

Name Description
$params An array containing data about the changes made to the subscription.

An example implementation with the documentation of the ‘params’ parameter:


<?php
/**
 * A &#39;fullstripe_before_subscription_update&#39; action hook example for WP Full Stripe.
 *
 * @param array $params with the following keys:
 *   stripeSubscriptionId   => Identifier of the Stripe subscription
 *   planId                 => Identifier of the new Stripe recurring price
 *   quantity               => The new subscription quantity
 */

function beforeSubscriptionUpdate( $params ) {
    $subscriptionId = $params[&#39;stripeSubscriptionId&#39;];
        
    $stripeSubscription = MM_WPFS_API_v1::getStripeSubscription( $subscriptionId );
    $stripeCustomer = MM_WPFS_API_v1::getStripeCustomer( $stripeSubscription->customer );
    
    // Do your thing here
}

add_action(&#39;fullstripe_before_subscription_update&#39;, &#39;beforeSubscriptionUpdate&#39;, 10, 1);

fullstripe_after_subscription_update

The fullstripe_after_subscription_update action is fired after a subscription has been updated updated on the “Customer Portal” page or via the plugin’s API.

Action parameters:

Name Description
$params An array containing data about the changes made to the subscription.

An example implementation with the documentation of the ‘params’ parameter:

<?php
/**
 * A &#39;fullstripe_after_subscription_update&#39; action hook example for WP Full Stripe.
 *
 * @param array $params with the following keys:
 *   stripeSubscriptionId   => Identifier of the Stripe subscription
 *   planId                 => Identifier of the new Stripe recurring price
 *   quantity               => The new subscription quantity
 */

function afterSubscriptionUpdate( $params ) {
    $subscriptionId = $params[&#39;stripeSubscriptionId&#39;];
    
    $stripeSubscription = MM_WPFS_API_v1::getStripeSubscription( $subscriptionId );
    $stripeCustomer = MM_WPFS_API_v1::getStripeCustomer( $stripeSubscription->customer );
    
    // Do your thing here
}

add_action(&#39;fullstripe_after_subscription_update&#39;, &#39;afterSubscriptionUpdate&#39;, 10, 1);

fullstripe_before_subscription_activation

The fullstripe_before_subscription_activation action is fired before a canceled subscription is reactivated by the customer on the “Customer portal” page.

Action parameters:

Name Description
$subscriptionId The identifier of the Stripe subscription.

An example implementation with the documentation of the ‘subscriptionId’ parameter:


<?php
/**
 * A &#39;fullstripe_before_subscription_activation&#39; action hook example for WP Full Stripe.
 *
 * @param string subscriptionId  => Identifier of the Stripe subscription which is about to be reactivated
 */

function beforeSubscriptionActivation( subscriptionId ) {
    $stripeSubscription = MM_WPFS_API_v1::getStripeSubscription( subscriptionId );
    $stripeCustomer = MM_WPFS_API_v1::getStripeCustomer( $stripeSubscription->customer );
    
    // Do your thing here
}

add_action(&#39;fullstripe_before_subscription_activation&#39;, &#39;beforeSubscriptionActivation&#39;, 10, 1);

fullstripe_after_subscription_activation

The fullstripe_after_subscription_activation action is fired after a canceled subscription has been reactivated by the customer on the “Customer portal” page.

Action parameters:

Name Description
$subscriptionId The identifier of the Stripe subscription.

An example implementation with the documentation of the ‘subscriptionId’ parameter:


<?php
/**
 * A &#39;fullstripe_after_subscription_activation&#39; action hook example for WP Full Stripe.
 *
 * @param string subscriptionId  => Identifier of the Stripe subscription which is about to be reactivated
 */

function afterSubscriptionActivation( subscriptionId ) {
    $stripeSubscription = MM_WPFS_API_v1::getStripeSubscription( subscriptionId );
    $stripeCustomer = MM_WPFS_API_v1::getStripeCustomer( $stripeSubscription->customer );
    
    // Do your thing here
}

add_action(&#39;fullstripe_after_subscription_activation&#39;, &#39;afterSubscriptionActivation&#39;, 10, 1);

Plugin filters

fullstripe_select_subscription_plan

The fullstripe_select_subscription_plan filter is used to control which subscription plan is selected by default when the page is loaded.

The filter is called when the URL parameter dedicated to selecting the default subscription plan is found in the page URL when loading a form.

Filter parameters and return value:

Name Description
$selectedPlanId The identifier of the subscription plan set by a previous filter of this filter chain.
$formName Name of the form that triggered the filter.
$formPlanIds An associative array of plan ids assigned to the current form.
$planIdParamValue Value of the ‘wpfsPlan’ URL parameter
   
Return value Identifier of the subscription plan that will be selected by default

An example implementation of the filter:


<?php
/**
 * Default implementation of the &#39;fullstripe_select_subscription_plan&#39; Wordpress filter 
 * for WP Full Stripe.
 *
 * @param $selectedPlanId Plan id set by a previous filter instance
 * @param $formName Name of the form that triggered the filter
 * @param $formPlanIds An associative array of plan ids assigned to the current form
 * @param $planIdParamValue Value of the wpfsPlan URL parameter
 *
 * @return integer The id of the plan to be selected on form $formName
 */

function selectSubscriptionPlan($selectedPlanId, $formName, $formPlanIds, $planIdParamValue) {
    $resultPlanId = $selectedPlanId;

    if (in_array($planIdParamValue, $formPlanIds)) {
        $resultPlanId = $planIdParamValue;
    }

    return $resultPlanId;
}

add_filter(&#39;fullstripe_select_subscription_plan&#39;, &#39;selectSubscriptionPlan&#39;, 10, 4);

fullstripe_set_custom_amount

The fullstripe_set_custom_amount filter is used to set the custom payment amount of a one-time payment form via an URL parameter.

The filter is called when the URL parameter dedicated to setting the custom payment amount is found in the page URL when loading a form.

Filter parameters and return value:

Name Description
$customAmount Custom payment amount set by a previous filter of this filter chain.
$formName Name of the form that triggered the filter.
$customAmountParamValue The value of the ‘wpfsAmount’ URL parameter
   
Return value Custom payment amount that will be entered by default

An example implementation of the filter:


<?php 
/**
 * Default implementation of the &#39;fullstripe_set_custom_amount&#39; Wordpress filter 
 * for WP Full Stripe.
 *
 * @param $customAmount Payment amount set by a previous filter instance
 * @param $formName Name of the form that triggered the filter
 * @param $customAmountParamValue The value of the wpfsAmount 
 *
 * @return integer The initial payment amount to be set on form $formName
 */

function set_custom_amount($customAmount, $formName, $customAmountParamValue) {
 	return $customAmountParamValue;
}

add_action(&#39;fullstripe_set_custom_amount&#39;, &#39;set_custom_amount&#39;, 10, 3);

fullstripe_add_transaction_metadata

The fullstripe_add_transaction_metadata filter is used to set transaction metadata via URL parameters.

The filter is called when the page containing the form is loaded.

Filter parameters and return value:

Name Description
$metadata Associative array of metadata set by a previous filter instance.
$formName Name of the form that triggered the filter.
$pageParams Associative array of page URL parameters.
   
Return value Associative array of metadata to be added to the transaction

An example implementation of the filter:


/**
 * Example implementation of the &#39;fullstripe_add_transaction_metadata&#39; Wordpress filter 
 * for WP Full Stripe.
 *
 * @param $metadata    Associative array of metadata set by a previous filter instance
 * @param $formName    Name of the form that triggered the filter
 * @param $pageParams  Associative array of page URL parameters
 *
 * @return Associative array of metadata to be added to the transaction
 */

function set_affiliate_metadata($metadata, $formName, $pageParams) {
	$result_meta = is_null($metadata) ? array() : $metadata;

	if (array_key_exists(&#39;affid&#39;, $pageParams)) {
		$result_meta[&#39;affid&#39;] = $pageParams[&#39;affid&#39;];
 	}

 	return $result_meta;
}

add_action(&#39;fullstripe_add_transaction_metadata&#39;, &#39;set_affiliate_metadata&#39;, 10, 3);

Where can you find metadata on the Stripe dashboard?

Go to the Where are custom fields on the Stripe dashboard? knowledge base article for instructions.

fullstripe_get_upgrade_downgrade_plans

The fullstripe_get_upgrade_downgrade_plans filter is used to set the list of subscription plans the customer is offered on the “Customer portal” page when upgrading/downgrading a subscription.

The filter is called before the “Customer portal” page is loaded.

The filter is useful when the Customer portal must offer more plans for upgrade/downgrade than the plans originally offered by the subscription form. This can happen when subscription forms with a single plan are integrated into pricing tables.

Filter parameters and return value:

Name Description
$formPlanIds Array of recurring price ids set by a previous filter instance.
$formName Name of the form using which the current subscription was purchased.
   
Return value Array of recurring price ids that is offered to the customer for upgrading/downgrading.

An example implementation of the filter:

<?php
/**
 * A &#39;fullstripe_get_upgrade_downgrade_plans&#39; filter hook example for WP Full Stripe.
 *
 * @param array $formPlanIds    => Array of recurring price ids set by a previous filter instance
 * @param string $formName      => Name of the form using which the current subscription was purchased
 *
 * @return array $formPlanIds   Array of recurring price ids that is offered to the customer for upgrading/downgrading
 */

function getUpgradeDowngradePlans( $formPlanIds, $formName ) {
    return [&#39;price_4fgv4t5fdgfdgdfg&#39;, &#39;price_5tGxv45tGFsv3&#39;, &#39;price_bFG6hgFSnb34fC&#39;];
}

add_action(&#39;fullstripe_get_upgrade_downgrade_plans&#39;, &#39;getUpgradeDowngradePlans&#39;, 10, 2);

fullstripe_customer_portal_header

The fullstripe_customer_portal_header filter is used to display extra content at the top of the “Customer portal” page.

The filter is called before the “Customer portal” page is loaded.

Filter parameters and return value:

Name Description
$content Header content set by a previous filter instance.
$params

An array containing data about the customer and the Stripe client.

See the example below for details.

   
Return value Header content modified by the filter

An example implementation of the filter:

<?php
/**
 * A &#39;fullstripe_customer_portal_header&#39; filter hook example for WP Full Stripe.
 *
 * @param string $content Header content set by a previous filter instance.
 * @param array $params with the following keys:
 *   email               => Email address of the logged-in customer 
 *   stripeCustomerId    => Stripe customer id of the logged-in customer
 *   stripeClient        => Instance of the \StripeWPFS\StripeClient object, intialized in the API mode selected in the plugin&#39;s settings 
 *
 * @return string Filtered content
 */
 
function customerPortalHeader( $headerContent, $params ) {
    $email            = $params[&#39;email&#39;];
    $stripeCustomerId = $params[&#39;stripeCustomerId&#39;];
    $stripeClient     = $params[&#39;stripeClient&#39;];
    $headerContent .= &#39;<h3>Header</h3>&#39;;
    $headerContent .= &#39;<p>Email: &#39; . $email . &#39;</p>&#39;;
    $headerContent .= &#39;<p>stripeCustomerId: &#39; . $stripeCustomerId . &#39;</p>&#39;;

    return $headerContent;
}

add_filter( &#39;fullstripe_customer_portal_header&#39;, &#39;customerPortalHeader&#39;, 10, 2 );

The fullstripe_customer_portal_footer filter is used to display extra content at the bottom of the “Customer portal” page.

The filter is called before the “Customer portal” page is loaded.

Filter parameters and return value:

Name Description
$content Header content set by a previous filter instance.
$params

An array containing data about the customer and the Stripe client.

See the example below for details.

   
Return value Header content modified by the filter

An example implementation of the filter:


<?php
/**
 * A &#39;fullstripe_customer_portal_footer&#39; filter hook example for WP Full Stripe.
 *
 * @param string $content Footer content set by a previous filter instance.
 * @param array $params with the following keys:
 *   email               => Email address of the logged-in customer 
 *   stripeCustomerId    => Stripe customer id of the logged-in customer
 *   stripeClient        => Instance of the \StripeWPFS\StripeClient object, intialized in the API mode selected in the plugin&#39;s settings 
 *
 * @return string Filtered content
 */
function customerPortalFooter( $headerContent, $params ) {
    $email            = $params[&#39;email&#39;];
    $stripeCustomerId = $params[&#39;stripeCustomerId&#39;];
    $stripeClient     = $params[&#39;stripeClient&#39;];
    $headerContent .= &#39;<h3>Footer</h3>&#39;;
    $headerContent .= &#39;<p>Email: &#39; . $email . &#39;</p>&#39;;
    $headerContent .= &#39;<p>stripeCustomerId: &#39; . $stripeCustomerId . &#39;</p>&#39;;

    return $headerContent;
}

add_filter( &#39;fullstripe_customer_portal_footer&#39;, &#39;customerPortalFooter&#39;, 10, 2 );

fullstripe_modify_email_subject

The fullstripe_modify_email_subject filter is used to change the subject of an email notification which is to be sent by the plugin.

The filter is called before placeholder tokens are resolved in the email subject and before the email is sent out.

Filter parameters and return value:

Name Description
$subject Email subject set by a previous filter instance.
$params

An array containing data about email to be sent.

See the example below for details.

   
Return value Filtered email subject

An example implementation of the filter:


<?php
/**
 * A &#39;fullstripe_modify_email_subject&#39; filter hook example for WP Full Stripe.
 *
 * @param string $subject Email subject set by a previous filter instance
 * @param array $params with the following keys:
 *   template               => Identifier of the mail template to be sent. Possible values:
 *                             PaymentReceipt                  - One-time payment receipt
 *                             SubscriptionReceipt             - Subscription receipt
 *                             SubscriptionEnded               - Payment-in-istallments subscription terminated by plugin
 *                             DonationReceipt                 - Donation receipt
 *                             CardSaved                       - Saved card notification
 *                             ManageSubscriptionsSecurityCode - One-time login code for Customer portal
 *                             registrationSuccessful          - Registration email sent by WP Full Stripe Members
 *   formName               => Name of the form the payment was submitted on.
 *                             Null if email is not payment related.
 *   rawPlaceholders        => All placeholder tokens, no decoration
 *   decoratedPlaceholders  => All placeholder tokens with decoration
 *
 * @return string Filtered email subject
 */

function modifyEmailSubject( $subject, $params ) {
    $result = $subject;
    $prefix = &#39;[Full Stripe] &#39;;

    if ( strpos( $result, $prefix ) === false ) {
        $subject = $prefix . $result;
    }

    return $result;
}
add_action(&#39;fullstripe_modify_email_subject&#39;, &#39;modifyEmailSubject&#39;, 10, 2);

fullstripe_modify_email_message

The fullstripe_modify_email_message filter is used to change the body of an email notification which is to be sent by the plugin.

The filter is called before placeholder tokens are resolved in the email body and before the email is sent out.

Filter parameters and return value:

Name Description
$body Email body set by a previous filter instance.
$params

An array containing data about email to be sent.

See the example below for details.

   
Return value Filtered email body

An example implementation of the filter:


<?php
/**
 * A &#39;fullstripe_modify_email_message&#39; filter hook example for WP Full Stripe.
 *
 * @param string $body Email body set by a previous filter instance
 * @param array $params with the following keys:
 *   template               => Identifier of the mail template to be sent. Possible values:
 *                             PaymentReceipt                  - One-time payment receipt
 *                             SubscriptionReceipt             - Subscription receipt
 *                             SubscriptionEnded               - Payment-in-istallments subscription terminated by plugin
 *                             DonationReceipt                 - Donation receipt
 *                             CardSaved                       - Saved card notification
 *                             ManageSubscriptionsSecurityCode - One-time login code for Customer portal
 *                             registrationSuccessful          - Registration email sent by WP Full Stripe Members
 *   formName               => Name of the form the payment was submitted on.
 *                             Null if email is not payment related.
 *   rawPlaceholders        => All placeholder tokens, no decoration
 *   decoratedPlaceholders  => All placeholder tokens with decoration
 *
 * @return string Filtered email body
 */

function modifyEmailMessage( $body, $params ) {
    $result = $body;
    $template = $params[&#39;template&#39;];
    
    if ( $template === &#39;registrationSuccessful&#39; ) {
        // Do something with the email body here        
    }
    
    return $result;
}
add_action(&#39;fullstripe_modify_email_message&#39;, &#39;modifyEmailMessage&#39;, 10, 2);

fullstripe_thank_you_output

The fullstripe_thank_you_output filter is used to change the contents of content area marked by the thank you shortcode before it’s displayed.

The filter is called before placeholder tokens are resolved.

Filter parameters and return value:

Name Description
$params

An array containing data about the thank you page.

See the example below for details.

   
Return value Filtered contents marked by the thank you shortcode

An example implementation of the filter:


<?php
/**
 * A &#39;fullstripe_thank_you_output&#39; filter hook example for WP Full Stripe.
 * It sends a conversion to the affiliate system called Tapfiliate.
 *
 * @param string output Contents of the thank you shortcode
 * @param array $params with the following keys:
 *   formType               => Type of the form that opened the thank you page. Possible values:
 *                             payment (one-time)
 *                             subscription
 *                             donation
 *                             save_card
 *   rawPlaceholders        => All placeholder tokens, no decoration
 *   decoratedPlaceholders  => All placeholder tokens with decoration
 *
 * @return string Filtered contents of the thank you shortcode
 */

function thankYouOutput($output, $params) {
    if ($params[&#39;formType&#39;] === &#39;subscription&#39;) {
        $rawPlaceholders = $params[&#39;rawPlaceholders&#39;];
        $rawAmount = $rawPlaceholders[&#39;%AMOUNT%&#39;];
        $amount = round($rawAmount / 100, 2);

        $tapBlock = <<<EOT
<script src="https://script.tapfiliate.com/tapfiliate.js" type="text/javascript" async></script>
<script type="text/javascript">
    (function(t,a,p){t.TapfiliateObject=a;t[a]=t[a]||function(){
        (t[a].q=t[a].q||[]).push(arguments)}})(window,&#39;tap&#39;);

    tap(&#39;create&#39;, &#39;YOUR ACCOUNT ID&#39;, { integration: "stripe" });
    tap(&#39;conversion&#39;, &#39;%TRANSACTION_ID%&#39;, ${amount}, {customer_id: &#39;%STRIPE_CUSTOMER_ID%&#39;});
</script>
EOT;
        $output = $output . $tapBlock;
    }

    return $output;
}

add_filter(&#39;fullstripe_thank_you_output&#39;, &#39;thankYouOutput&#39;, 10, 2);

fullstripe_thank_you_url_parameters

The fullstripe_thank_you_url_parameters filter is used to add URL parameters to the thank you page URL.

The filter is called before the thank you page URL is opened.

Filter parameters and return value:

Name Description
$urlParams An associative array of URL parameters returned by previous filters of the chain.
$filterParams

An array containing data about form opening the thank you page.

See the example below for details.

   
Return value Filtered associative array of URL parameters to be added to the thank you page URL.

An example implementation of the filter:


<?php
/**
 * A &#39;fullstripe_thank_you_url_parameters&#39; filter hook example for WP Full Stripe.
 * It adds the transaction id and the customer&#39;s email address as URL parameters to the thank you page URL.
 *
 * @param string $urlParams Associative array of URL parameters returned by previous filters of the chain.
 * @param array $filterParams with the following keys:
 *   formName               => Name of the form that opened the thank you page.
 *   formType               => Type of the form that opened the thank you page. Possible values:
 *                             inline_payment
 *                             checkout_payment
 *                             inline_subscription
 *                             checkout_subscription
 *                             inline_donation
 *                             checkout_donation
 *                             inline_save_card
 *                             checkout_save_card
 *   rawPlaceholders        => All placeholder tokens, no decoration
 *   decoratedPlaceholders  => All placeholder tokens with decoration
 *
 * @return string Filtered array of URL parameters
 */

function thankYouUrlParameters( $urlParams, $filterParams ) {
    $result = $urlParams;
    $rawPlaceholders = $filterParams[&#39;rawPlaceholders&#39;];

    $result[&#39;id&#39;] = $rawPlaceholders[&#39;%TRANSACTION_ID%&#39;];
    $result[&#39;email&#39;] = $rawPlaceholders[&#39;%CUSTOMER_EMAIL%&#39;];
		
    return $result;
}

add_filter(&#39;fullstripe_thank_you_url_parameters&#39;, &#39;thankYouUrlParameters&#39;, 10, 2);

fullstripe_thank_you_post_types

The fullstripe_thank_you_post_types filter is used to extend the list of pages/posts offered by forms as thank you page candidates in WP admin.

The filter is called before a form is opened for editing in WP admin.

Filter parameters and return value:

Name Description
$postTypes An array of post types returned by previous filters of the chain.
$filterParams

An array containing data about the form to be opened for editing.

See the example below for details.

   
Return value Filtered array of post types.

An example implementation of the filter:


<?php
/**
 * A &#39;fullstripe_thank_you_url_parameters&#39; filter hook example for WP Full Stripe.
 * It adds the transaction id and the customer&#39;s email address as URL parameters to the thank you page URL.
 *
 * @param string $postTypes Array of post types returned by previous filters of the chain.
 * @param array $params with the following keys:
 *   formName               => Name of the form to be opened for editing 
 *   formType               => Type of the form to be opened for editing. Possible values:
 *                             inline_payment
 *                             checkout_payment
 *                             inline_subscription
 *                             checkout_subscription
 *                             inline_donation
 *                             checkout_donation
 *                             inline_save_card
 *                             checkout_save_card
 *
 * @return string Filtered array of post types
 */
function thankYouPostTypes( $postTypes, $params ) {
    $result = $postTypes;
    
    if ( false === array_search( &#39;post&#39;, $postTypes ) ) {
        array_push( $result, &#39;post&#39; );
    }
    
    return $result;
}

add_filter(&#39;fullstripe_thank_you_post_types&#39;, &#39;thankYouPostTypes&#39;, 10, 2);

fullstripe_billing_countries

The fullstripe_billing_countries filter is used to collect the list of countries that should be offered as billing countries on forms.

The filter is called before a form is displayed.

Filter parameters and return value:

Name Description
$countryCodes An array of 2-letter ISO country codes returned by previous filters of the chain.
$filterParams

An array containing data about the form that will display the billing country options.

See the example below for details.

   
Return value Filtered array of 2-letter ISO country codes.

An example implementation of the filter:


<?php
/**
 * A &#39;fullstripe_billing_countries&#39; filter hook example for WP Full Stripe.
 * It sets Spain as the only country offered in billing country dropdown on all forms.
 *
 * @param string $countryCodes Array of 2-letter ISO country codes returned by previous filters of the chain.
 * @param array $params with the following keys:
 *   formName               => Name of the form that requires the list of billing countries. 
 *   formType               => Type of the form that requires the list of billing countries. Possible values:
 *                             inline_payment
 *                             checkout_payment
 *                             inline_subscription
 *                             checkout_subscription
 *                             inline_donation
 *                             checkout_donation
 *                             inline_save_card
 *                             checkout_save_card
 *
 * @return string Filtered array of 2-letter ISO country codes
 */
function getBillingCountries( $countryCodes, $params) {
    $result = $countryCodes;
    
    // Set Spain as the only billing country for every form
    $result = [ &#39;ES&#39; ]; 

    return $result;
}

add_filter(&#39;fullstripe_billing_countries&#39;, &#39;getBillingCountries&#39;, 10, 2 );

fullstripe_shipping_countries

The fullstripe_shipping_countries filter is used to collect the list of countries that should be offered as shipping countries on forms.

The filter is called before a form is displayed.

Filter parameters and return value:

Name Description
$countryCodes An array of 2-letter ISO country codes returned by previous filters of the chain.
$filterParams

An array containing data about the form that will display the shipping country options.

See the example below for details.

   
Return value Filtered array of 2-letter ISO country codes.

An example implementation of the filter:


<?php
/**
 * A &#39;fullstripe_shipping_countries&#39; filter hook example for WP Full Stripe.
 *
 * @param string $countryCodes Array of 2-letter ISO country codes returned by previous filters of the chain.
 * @param array $params with the following keys:
 *   formName               => Name of the form that requires the list of shipping countries. 
 *   formType               => Type of the form that requires the list of shipping countries. Possible values:
 *                             inline_payment
 *                             checkout_payment
 *                             inline_subscription
 *                             checkout_subscription
 *                             inline_donation
 *                             checkout_donation
 *                             inline_save_card
 *                             checkout_save_card
 *
 * @return string Filtered array of 2-letter ISO country codes
 */
function getShippingCountries( $countryCodes, $params) {
    $result = $countryCodes;
    
    // Set Italy, United States, and Hungary as the shipping countries if the name of the form is &#39;paymentInlineDefault&#39;
    // For every other form, display all countries
    if ( $params[&#39;formName&#39;] === &#39;paymentInlineDefault&#39; ) {
        $result = [ &#39;IT&#39;, &#39;US&#39;, &#39;HU&#39; ]; 
    }

    return $result;
}

add_filter(&#39;fullstripe_shipping_countries&#39;, &#39;getShippingCountries&#39;, 10, 2 );

fullstripe_payment_intent_parameters

The fullstripe_payment_intent_parameters filter is used to change the Stripe PaymentIntent parameters.

The filter is called before the plugin creates the PaymentIntent.

Name Description
$params An array containing the PaymentIntent parameters
   
Return value Filtered PaymentIntent parameters

An example implementation of the filter:


<?php
/**
 * A &#39;fullstripe_payment_intent_parameters&#39; filter hook example for WP Full Stripe.
 *
 * @param array params PaymentIntent parameters
 * 
 * @return array Filtered PaymentIntent parameters
 */

function paymentIntentParameters( $params ) {
    $result = $params;

    // Modify the parameters
    
    return $result;
}
add_filter(&#39;fullstripe_payment_intent_parameters&#39;, &#39;paymentIntentParameters&#39;, 10, 1 );

fullstripe_checkout_session_parameters

The fullstripe_checkout_session_parameters filter is used to change the Stripe CheckoutSession parameters.

The filter is called before the plugin creates the CheckoutSession.

Name Description
$params An array containing the CheckoutSession parameters
   
Return value Filtered CheckoutSession parameters

An example implementation of the filter:


<?php
/**
 * A &#39;fullstripe_checkout_session_parameters&#39; filter hook example for WP Full Stripe.
 * This examples enables Stripe Tax for all checkout sessions.
 *
 * @param array params CheckoutSession parameters
 * 
 * @return array Filtered CheckoutSession parameters
 */

function checkoutSessionParameters( $params ) {
    $result = $params;

    if ( false === array_key_exists( &#39;automatic_tax&#39;, $result ) ) {
        $result[&#39;automatic_tax&#39;] = [
    	    &#39;enabled&#39; => true,
        ];
    }
	
    return $result;
}
add_filter(&#39;fullstripe_checkout_session_parameters&#39;, &#39;checkoutSessionParameters&#39;, 10, 1 );

fullstripe_determine_tax_rates

The fullstripe_determine_tax_rates filter is used to select the Stripe tax rates based on tax id, tax country, and tax state of the customer.

The filter is called when a vat id is entered or modified, or a new tax country or tax state is selected on a form.

Name Description
$taxRates The Stripe tax rates selected by the plugin or a previous filter of the filter chain.
$params

An array containing tax-related data about the customer.

See the example below for details.

   
Return value Filtered Stripe tax rates

An example implementation of the filter:


<?php
/**
 * A &#39;fullstripe_determine_tax_rates&#39; filter hook example for WP Full Stripe.
 * It implements an EU tax rate filter for business buyers in the EU. The EU tax ID is not validated.
 *
 * @param array taxRates The Stripe tax rates selected by the plugin or a previous filter of the filter chain.
 * @param array params array $params with the following keys:
 *                           country     => Tax country selected by the customer
 *                           state       => Tax state/region selected by the customer
 *                           taxId       => Tax id entered by the customer
 * 
 * @return array Filtered tax rates
 */

function determineTaxRates( $taxRates, $params ) {
    $result = $taxRates;

    $euCountries = array(&#39;LU&#39;, &#39;MT&#39;, &#39;CY&#39;, &#39;DE&#39;, &#39;RO&#39;, &#39;AT&#39;, &#39;EE&#39;, &#39;FR&#39;, &#39;SK&#39;, &#39;SE&#39;, &#39;BE&#39;, &#39;BG&#39;, &#39;CZ&#39;, &#39;ES&#39;, &#39;NL&#39;,
        &#39;LT&#39;, &#39;LV&#39;, &#39;IT&#39;, &#39;PT&#39;, &#39;SI&#39;, &#39;IE&#39;, &#39;PL&#39;, &#39;FI&#39;, &#39;GR&#39;, &#39;HR&#39;, &#39;DK&#39;, &#39;HU&#39;);
    $country = $params[&#39;country&#39;];
    $taxId = $params[&#39;taxId&#39;];

    if ( array_search( $country, $euCountries) && ! empty( $taxId )) {
        $result = [];
    }

    return $result;
}

add_filter(&#39;fullstripe_determine_tax_rates&#39;, &#39;determineTaxRates&#39;, 10, 2 );

fullstripe_determine_tax_label

The fullstripe_determine_tax_label filter is used to set the tax label when Stripe Tax is used to calculate tax.

The filter is called by inline payment and subscription forms when the form is either opened or updated due to an applied coupon, a set tax id, or a changed address.

Name Description
$label The tax label set by the plugin or a previous filter of the filter chain.
$params

An array containing data about the tax calculation.

See the example below for details.

   
Return value Filtered tax label

An example implementation of the filter:


<?php
/**
 * A &#39;fullstripe_determine_tax_label&#39; filter hook example for WP Full Pay.
 *
 * @param string $label The tax label returned by the previous filter instance.
 * @param array $params with the following keys:
 *   taxableAmount      => The net payment amount, in cents. 
 *   amount    		=> The tax amount, in cents.
 *   inclusive          => Boolean value indicating whether the tax amount is included in the product price. 
 *   taxabilityReason   => Taxability reason, see https://stripe.com/docs/api/invoices/line_item#invoice_line_item_object-tax_amounts-taxability_reason for more information,
 *   country    	=> The buyer&#39;s uppercase ISO country code. 
 *   state    		=> The buyer&#39;s state or region. Applicable only in case of US and Canada.
 *   postalCode    	=> The buyer&#39;s state or region. Applicable only in case of US and Canada.
 *   taxIdType    	=> The buyer&#39;s tax id type. It&#39;s set only when the buyer&#39;s tax information is collected, otherwise null.
 *   taxId     		=> The buyer&#39;s tax id. It&#39;s set only when the buyer&#39;s tax information is collected, otherwise null.
 *
 * @return string Tax label
 */
function determineTaxLabel( $label, $params ) {
    $result = $label;
		
    $euCountries = array(&#39;LU&#39;, &#39;MT&#39;, &#39;CY&#39;, &#39;DE&#39;, &#39;RO&#39;, &#39;AT&#39;, &#39;EE&#39;, &#39;FR&#39;, &#39;SK&#39;, &#39;SE&#39;, &#39;BE&#39;, &#39;BG&#39;, &#39;CZ&#39;, &#39;ES&#39;, &#39;NL&#39;,
        &#39;LT&#39;, &#39;LV&#39;, &#39;IT&#39;, &#39;PT&#39;, &#39;SI&#39;, &#39;IE&#39;, &#39;PL&#39;, &#39;FI&#39;, &#39;GR&#39;, &#39;HR&#39;, &#39;DK&#39;, &#39;HU&#39;);
    $country = $params[&#39;country&#39;];

    if ( array_search( $country, $euCountries)) {
		$result = &#39;VAT&#39;;
    }

    return $result;
}
add_filter(&#39;fullstripe_determine_tax_label&#39;, &#39;determineTaxLabel&#39;, 10, 3 );

fullstripe_members_supported_post_types

The fullstripe_members_supported_post_types filter is used to return the custom post types that can be protected by the plugin.

The filter is called when the Wordpress page editor is about to open a content for editing.

Name Description
$postTypes The post types array provided by the plugin or a previous filter of the filter chain.
$params An array containing additional parameters. Not used currently.
   
Return value Filtered custom post types array

An example implementation of the filter:


<?php
/**
 * A &#39;fullstripe_members_supported_post_types&#39; filter hook example for WP Full Stripe Members.
 * It implements a filter hook that adds the &#39;post&#39; post type to the supported custom post types.  
 *
 * @param array postTypes The custom post types provided by the plugin or a previous filter of the filter chain.
 * @param array params array $params An array containing additional parameters. Not used currently.
 * 
 * @return array Filtered custom post types array
 */

function addCustomPostTypes( $postTypes, $params ) {
    $result = $postTypes;

    if ( false === array_search(&#39;post&#39;, $postTypes) ) {
        array_push( $result, &#39;post&#39; );
    }

    return $result;
}

add_filter(&#39;fullstripe_members_supported_post_types&#39;, &#39;addCustomPostTypes&#39;, 10, 2 );

fullstripe_form_field_configuration

The fullstripe_form_field_configuration filter is used to configure which form fields can be pre-filled via URL parameters, and which form fields should be read-only once they are set.

The filter is called before the plugin renders the form.

Name Description
$config A field configuration array of the form that is about to be rendered.
$params

An array containing data about the form.

See the example below for details.

   
Return value Filtered form field configuration array

An example implementation of the filter:


<?php
/**
 * A &#39;fullstripe_form_field_configuration&#39; filter hook example for WP Full Pay.
 *
 * @param array $config The field configuration returned by the previous filter instance.
 * @param array $params with the following keys:
 *   formName               => Name of the form.
 *   formType               => Type of the form. Possible values:
 *                             	inline_payment
 * 				checkout_payment
 * 				inline_subscription
 * 				checkout_subscription
 * 				inline_donation
 *				checkout_donation
 *				inline_save_card
 * 				checkout_save_card
 *
 * @return array Field configuration
 */
function formFieldConfiguration( $config, $params ) {
	$result = $config;
	$formName = $params[&#39;formName&#39;];
	
	if ( $formName === &#39;payment&#39; ) {
		WPFS_API_v2::setIsFormFieldConfigurable( $result, &#39;cardholdersName&#39;, true );

		WPFS_API_v2::setIsFormFieldConfigurable( $result, &#39;email&#39;, true );
		WPFS_API_v2::setIsFormFieldReadonly( $result, &#39;email&#39;, true );		
	}
	
	return $result;
}

add_filter(&#39;fullstripe_form_field_configuration&#39;, &#39;formFieldConfiguration&#39;, 10, 2 );

Use this filter in conjunction with the following API functions:

Did this answer your question? Thanks for the feedback There was a problem submitting your feedback. Please try again later.

Still need help? Contact Us Contact Us