Skip to content

Commit

Permalink
Fix tracks identity cookie cache (#9249)
Browse files Browse the repository at this point in the history
  • Loading branch information
alefesouza authored and Jessy committed Aug 19, 2024
1 parent 0c72b41 commit 2ce5bc7
Show file tree
Hide file tree
Showing 6 changed files with 78 additions and 3 deletions.
4 changes: 4 additions & 0 deletions changelog/fix-wcpay-tracking-cookie-cache
Original file line number Diff line number Diff line change
@@ -0,0 +1,4 @@
Significance: patch
Type: fix

Fix caching with tracking cookie.
12 changes: 12 additions & 0 deletions client/frontend-tracks/index.js
Original file line number Diff line number Diff line change
@@ -0,0 +1,12 @@
/**
* Internal dependencies
*/
import { recordUserEvent } from 'tracks';

if ( window.wcPayFrontendTracks && window.wcPayFrontendTracks.length ) {
for ( const track of window.wcPayFrontendTracks ) {
recordUserEvent( track.event, track.properties );
}

window.wcPayFrontendTracks = [];
}
4 changes: 4 additions & 0 deletions client/payment-methods-map.tsx
Original file line number Diff line number Diff line change
Expand Up @@ -31,6 +31,10 @@ declare global {
country: string;
};
};
wcPayFrontendTracks: {
event: string;
properties: Record< string, unknown >;
};
}
}

Expand Down
1 change: 1 addition & 0 deletions client/tracks/index.ts
Original file line number Diff line number Diff line change
Expand Up @@ -125,6 +125,7 @@ export const getTracksIdentity = async (): Promise< string | undefined > => {

body.append( 'tracksNonce', nonce );
body.append( 'action', 'get_identity' );

try {
const response = await fetch( ajaxUrl, {
method: 'post',
Expand Down
59 changes: 56 additions & 3 deletions includes/class-woopay-tracker.php
Original file line number Diff line number Diff line change
Expand Up @@ -73,6 +73,7 @@ public function __construct( $http ) {
add_action( 'woocommerce_checkout_order_processed', [ $this, 'checkout_order_processed' ], 10, 2 );
add_action( 'woocommerce_store_api_checkout_order_processed', [ $this, 'checkout_order_processed' ], 10, 2 );
add_action( 'woocommerce_payments_save_user_in_woopay', [ $this, 'must_save_payment_method_to_platform' ] );
add_action( 'wp_footer', [ $this, 'add_frontend_tracks_scripts' ] );
add_action( 'before_woocommerce_pay_form', [ $this, 'pay_for_order_page_view' ] );
add_action( 'woocommerce_thankyou', [ $this, 'thank_you_page_view' ] );
}
Expand Down Expand Up @@ -144,8 +145,9 @@ public function maybe_record_event( $event, $data = [] ) {
*
* @param string $event name of the event.
* @param array $data array of event properties.
* @param bool $record_on_frontend whether to record the event on the frontend to prevent cache break.
*/
public function maybe_record_wcpay_shopper_event( $event, $data = [] ) {
public function maybe_record_wcpay_shopper_event( $event, $data = [], $record_on_frontend = true ) {
// Top level events should not be namespaced.
if ( '_aliasUser' !== $event ) {
$event = self::$user_prefix . '_' . $event;
Expand All @@ -154,7 +156,23 @@ public function maybe_record_wcpay_shopper_event( $event, $data = [] ) {
$is_admin_event = false;
$track_on_all_stores = true;

return $this->tracks_record_event( $event, $data, $is_admin_event, $track_on_all_stores );
if ( ! $record_on_frontend ) {
return $this->tracks_record_event( $event, $data, $is_admin_event, $track_on_all_stores );
}

$data['record_event_data'] = compact( 'is_admin_event', 'track_on_all_stores' );

add_filter(
'wcpay_frontend_tracks',
function ( $tracks ) use ( $event, $data ) {
$tracks[] = [
'event' => $event,
'properties' => $data,
];

return $tracks;
}
);
}

/**
Expand Down Expand Up @@ -275,6 +293,18 @@ public function tracks_record_event( $event_name, $properties = [], $is_admin_ev
return false;
}

if ( isset( $properties['record_event_data'] ) ) {
if ( isset( $properties['record_event_data']['is_admin_event'] ) ) {
$is_admin_event = $properties['record_event_data']['is_admin_event'];
}

if ( isset( $properties['record_event_data']['track_on_all_stores'] ) ) {
$track_on_all_stores = $properties['record_event_data']['track_on_all_stores'];
}

unset( $properties['record_event_data'] );
}

if ( ! $this->should_enable_tracking( $is_admin_event, $track_on_all_stores ) ) {
return false;
}
Expand Down Expand Up @@ -519,7 +549,7 @@ public function checkout_order_processed( $order_id ) {

// Don't track WooPay orders. They will be tracked on WooPay side with more details.
if ( ! $is_woopay_order ) {
$this->maybe_record_wcpay_shopper_event( 'checkout_order_placed', $properties );
$this->maybe_record_wcpay_shopper_event( 'checkout_order_placed', $properties, false );
}
// If the order was placed using a different payment gateway, just increment a counter.
} else {
Expand Down Expand Up @@ -576,4 +606,27 @@ public function woopay_locations_updated( $all_locations, $platform_checkout_ena

$this->maybe_record_admin_event( 'woopay_express_button_locations_updated', $props );
}

/**
* Add front-end tracks scripts to prevent cache break.
*
* @return void
*/
public function add_frontend_tracks_scripts() {
$frontent_tracks = apply_filters( 'wcpay_frontend_tracks', [] );

if ( count( $frontent_tracks ) === 0 ) {
return;
}

WC_Payments::register_script_with_dependencies( 'wcpay-frontend-tracks', 'dist/frontend-tracks' );

wp_enqueue_script( 'wcpay-frontend-tracks' );

wp_localize_script(
'wcpay-frontend-tracks',
'wcPayFrontendTracks',
$frontent_tracks
);
}
}
1 change: 1 addition & 0 deletions webpack/shared.js
Original file line number Diff line number Diff line change
Expand Up @@ -41,6 +41,7 @@ module.exports = {
'product-details': './client/product-details/index.js',
'cart-block': './client/cart/blocks/index.js',
'plugins-page': './client/plugins-page/index.js',
'frontend-tracks': './client/frontend-tracks/index.js',
},
// Override webpack public path dynamically on every entry.
// Required for chunks loading to work on sites with JS concatenation.
Expand Down

0 comments on commit 2ce5bc7

Please sign in to comment.