Skip to content
New issue

Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.

By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.

Already on GitHub? Sign in to your account

Release branch for 6.5.0 #7228

Merged
merged 87 commits into from
Sep 21, 2023
Merged
Changes from 1 commit
Commits
Show all changes
87 commits
Select commit Hold shift + click to select a range
f6fad59
Disputes: Add dispute notice to transactions page (#6998)
brucealdridge Aug 28, 2023
98b6f79
Update multi currency documentation links (#7072)
eduardoumpierre Aug 28, 2023
e9baed0
Fix Currency Switcher Block flag rendering on Windows platform (#6832)
eduardoumpierre Aug 28, 2023
9d5e3e3
Update Base_Constant to return the singleton object for same static c…
htdat Aug 29, 2023
7b5c7f9
RPP - Payment request class for loading, sanitizing, and escaping dat…
htdat Aug 29, 2023
ba94ddd
Update inline notice component (#7078)
ismaeldcom Aug 29, 2023
900146c
Fix Multi-currency exchange rate date formatting when using custom da…
eduardoumpierre Aug 29, 2023
605e329
Migrate link-item and woopay-item to typescript (#7080)
naman03malhotra Aug 29, 2023
17c86d9
Fix the way request constants are traversed (#7095)
RadoslavGeorgiev Aug 30, 2023
71b9423
Modify title in task to continue with onboarding (#7101)
daquinons Aug 30, 2023
4e37352
Remove reference to the v1 experiment from the code. (#7096)
dmallory42 Aug 30, 2023
e6e7c3b
Fix AED and SAR currencies format (#7083)
allie500 Aug 30, 2023
1ba4330
Merge trunk v6.4.0 into develop
botwoo Aug 31, 2023
b5bfc76
Add support for kanji and kana statement descriptors (#7051)
dpaun1985 Aug 31, 2023
6b10aec
Fix deprecation warnings on blocks checkout (#7070)
alefesouza Aug 31, 2023
8ea5c5f
Add/5669 add further payment metadata (#7091)
zmaglica Aug 31, 2023
1a5af35
Fall back to site logo when no custom WooPay logo defined (#7103)
reykjalin Aug 31, 2023
d0db2a3
Schedule individual subscription migrations and add manual migration …
mattallan Aug 31, 2023
51879ea
Migrate DetailsLink component to TS to improve code quality (#7086)
Jinksi Aug 31, 2023
e00a4af
Use client-side routing for the transaction details `ch_` → `pi_` red…
Jinksi Aug 31, 2023
39a70c0
RPP - Load payment methods through the request class (#7100)
htdat Sep 1, 2023
ce50c7a
RPP: Factor flags (#7035)
RadoslavGeorgiev Sep 1, 2023
379bf0a
Temporarily disable saving SEPA (#7107)
gpressutto5 Sep 1, 2023
f9d55c6
Provide fallback for email payment method title (#7108)
mdmoore Sep 1, 2023
635e386
Allow requests to be extended by multiple classes in parallel (#7099)
RadoslavGeorgiev Sep 4, 2023
861de2a
Disable refund button when transaction disputed (#7043)
shendy-a8c Sep 5, 2023
fc451c5
Update Transaction Details → HorizontalList label styles to uppercase…
Jinksi Sep 6, 2023
7f796aa
Add onboarding task incentive badge (#7132)
ismaeldcom Sep 6, 2023
a2a6885
Refactor Woo Subscriptions compatibility to fix currency being able t…
jessepearson Sep 6, 2023
ec31559
Merge trunk v6.4.1 into develop
botwoo Sep 6, 2023
ef54b3b
Remove unused import `NoticeOutlineIcon` to fix JS linter warning (#7…
Jinksi Sep 7, 2023
12ac12d
Add Transaction Details notice when a dispute has staged evidence (#7…
Jinksi Sep 7, 2023
18192c3
Implement `BannerNotice` component (#7097)
ismaeldcom Sep 7, 2023
bfb391c
Add cli npm command (#7111)
vladolaru Sep 7, 2023
a4bc69a
Fix multicurrency widget error on post/page edit screen (#7141)
tpaksu Sep 7, 2023
9ea339b
Session compatible fix for WooPay multi-currency (#7055)
bborman22 Sep 8, 2023
69a25f7
Fix incorrect payment intent status check in cancel authorization API…
zmaglica Sep 8, 2023
122d739
Add Horizontal list of dispute details to the transaction page (#7077)
brucealdridge Sep 11, 2023
b2602b4
Avoid redirects on docs links (#7155)
aheckler Sep 11, 2023
78ed2d6
Update subscriptions-core to 6.2 (#6976)
james-allan Sep 11, 2023
9ccdab9
Add Woo Subscription Stripe Billing settings and migration status not…
james-allan Sep 11, 2023
7e61084
Updates to the Inbox Note logic. (#7136)
dmallory42 Sep 11, 2023
f86b08e
Add New Task to Enable Payment Methods (#7129)
dmallory42 Sep 11, 2023
83c0c4c
Implement a retry system to the WCPay Subscription migration process …
mattallan Sep 12, 2023
16d8da6
Update Subscriptions with WooPayments eligibility as we move to depre…
mattallan Sep 12, 2023
b0c0e79
Improve: has_multi_currency_orders query improvement and unit tests (…
ovidiul Sep 12, 2023
ed190bc
Improvement: Query optimisation for get_all_customer_currencies metho…
ovidiul Sep 12, 2023
8aa1e68
Avoid empty fields in new onboarding flow (#7180)
daquinons Sep 12, 2023
384ca6d
Extract minimum supported PHP version from plugin file for GH actions…
deepakpathania Sep 12, 2023
5f75b8f
Update new onboarding flow components to use admin color schema (#7177)
ismaeldcom Sep 12, 2023
ca7929f
Warn about dev mode enabled on new onboarding flow choice (#7082)
oaratovskyi Sep 12, 2023
b31489f
Add the WooPay Express button to the Pay for order page (#5903)
hsingyuc Sep 13, 2023
904a8da
Follow up of Warn about dev mode (#7188)
oaratovskyi Sep 13, 2023
31175a8
Update the links used in the migrate option and automatically notice …
james-allan Sep 13, 2023
7328668
Revert "Update Subscriptions with WooPayments eligibility as we move …
james-allan Sep 13, 2023
5e89beb
fix: remove max width on WooPay checkout appearance (#7184)
frosso Sep 13, 2023
152be9b
Change ConvertedAmount component to use an updated Tooltip (#7137)
eduardoumpierre Sep 13, 2023
a23c791
Bump WC and PHP versions (#7134)
ricardo Sep 13, 2023
88d45eb
Update occurence of all ubuntu versions to `ubuntu-latest` (#7209)
deepakpathania Sep 14, 2023
37bbac3
Increase admin enqueue scripts priority (#7197)
ismaeldcom Sep 14, 2023
4fa9b05
Notices for deferred UPE rollout (#7210)
timur27 Sep 14, 2023
68d8c64
Verify the migrated subscription has a valid WooPayments payment toke…
mattallan Sep 14, 2023
343cd67
Fix single currency settings saving manual rate (#7208)
tpaksu Sep 14, 2023
0c2de49
Disable tracking on Stripe disconnected accounts (#7160)
malithsen Sep 14, 2023
502d50c
fix: express checkouts links consistency (#7198)
frosso Sep 14, 2023
d5ec63c
Add Reference to V3 Experiment (#7168)
dmallory42 Sep 14, 2023
4986288
chore: add checkout appearance documentation link (#7185)
frosso Sep 14, 2023
c1a3d9d
Merge trunk v6.4.2 into develop
cesarcosta99 Sep 14, 2023
6b65491
Fix changing Stripe Billing payment method which wasn't cancelling at…
james-allan Sep 14, 2023
c05aaf3
Adds environment metadata to Stripe Billing subscription and invoice …
james-allan Sep 14, 2023
cda8ef4
Use fallback methods for updating the next payment date after migrati…
james-allan Sep 14, 2023
7ce30b4
Allow merchants to see dispute evidence (#7192)
brucealdridge Sep 15, 2023
f930e7f
Improve the logging in the Stripe Billing migration of token data (#…
james-allan Sep 15, 2023
e2df30f
Transaction Details → fix typo in staged dispute challenge notice (#7…
Jinksi Sep 15, 2023
c4a7445
Revert "Bump WC and PHP versions (#7134)" (#7213)
ricardo Sep 15, 2023
c8f19ec
Redirect back to the pay-for-order page when it's pay-for-order order…
hsingyuc Sep 15, 2023
6ba6fab
Fix deprecated string interpolation in Analytics.php (#7170)
ridonibishi Sep 16, 2023
3695514
Fix double indicators showing under Payments tab (#7201)
oaratovskyi Sep 16, 2023
2001034
Update version and add changelog entries for release 6.5.0
github-actions[bot] Sep 17, 2023
37d3017
Fix issues when the Stripe Billing `is_migrating()` function would re…
james-allan Sep 17, 2023
e4f764f
Remove changelog file
james-allan Sep 17, 2023
724b940
Amend changelog entries for release 6.5.0
botwoo Sep 18, 2023
7f31adc
Disable automatic currency switching and switcher widgets on pay_for_…
jessepearson Sep 18, 2023
2a5c644
Prevent WooPay from modifying non-WooPay Webhooks (#7235)
timur27 Sep 19, 2023
8c1e3ca
fix: save platform checkout info on blocks (#7204)
frosso Sep 20, 2023
954d10a
Squashed merge of improve block attribute escaping
rafaelzaleski Sep 19, 2023
654a7a9
Amend changelog entries for release 6.5.0
botwoo Sep 21, 2023
File filter

Filter by extension

Filter by extension

Conversations
Failed to load comments.
Loading
Jump to
Jump to file
Failed to load files.
Loading
Diff view
Diff view
Prev Previous commit
Next Next commit
Redirect back to the pay-for-order page when it's pay-for-order order (
  • Loading branch information
hsingyuc authored Sep 15, 2023
commit c8f19eca3515fd6fa591952f13bc7c95f5f8ac2f
4 changes: 4 additions & 0 deletions changelog/fix-2141
Original file line number Diff line number Diff line change
@@ -0,0 +1,4 @@
Significance: patch
Type: add

Redirect back to the pay-for-order page when it is pay-for-order order
4 changes: 4 additions & 0 deletions changelog/fix-init-woopay-error
Original file line number Diff line number Diff line change
@@ -0,0 +1,4 @@
Significance: patch
Type: fix

Fix init WooPay and empty cart error
4 changes: 4 additions & 0 deletions client/checkout/api/index.js
Original file line number Diff line number Diff line change
@@ -690,10 +690,14 @@ export default class WCPayAPI {
initWooPay( userEmail, woopayUserSession ) {
const wcAjaxUrl = getConfig( 'wcAjaxUrl' );
const nonce = getConfig( 'initWooPayNonce' );

return this.request( buildAjaxURL( wcAjaxUrl, 'init_woopay' ), {
_wpnonce: nonce,
email: userEmail,
user_session: woopayUserSession,
order_id: getConfig( 'order_id' ),
key: getConfig( 'key' ),
billing_email: getConfig( 'billing_email' ),
} );
}

13 changes: 12 additions & 1 deletion client/checkout/api/test/index.test.js
Original file line number Diff line number Diff line change
@@ -17,7 +17,15 @@ jest.mock( 'wcpay/utils/checkout', () => ( {
describe( 'WCPayAPI', () => {
test( 'initializes woopay using config params', () => {
buildAjaxURL.mockReturnValue( 'https://example.org/' );
getConfig.mockReturnValue( 'foo' );
getConfig.mockImplementation( ( key ) => {
const mockProperties = {
initWooPayNonce: 'foo',
order_id: 1,
key: 'testkey',
billing_email: '[email protected]',
};
return mockProperties[ key ];
} );

const api = new WCPayAPI( {}, request );
api.initWooPay( '[email protected]', 'qwerty123' );
@@ -26,6 +34,9 @@ describe( 'WCPayAPI', () => {
_wpnonce: 'foo',
email: '[email protected]',
user_session: 'qwerty123',
order_id: 1,
key: 'testkey',
billing_email: '[email protected]',
} );
} );
} );
3 changes: 3 additions & 0 deletions client/checkout/woopay/email-input-iframe.js
Original file line number Diff line number Diff line change
@@ -190,6 +190,9 @@ export const handleWooPayEmailInput = async (
buildAjaxURL( getConfig( 'wcAjaxUrl' ), 'get_woopay_session' ),
{
_ajax_nonce: getConfig( 'woopaySessionNonce' ),
order_id: getConfig( 'order_id' ),
key: getConfig( 'key' ),
billing_email: getConfig( 'billing_email' ),
}
).then( ( response ) => {
if ( response?.data?.session ) {
Original file line number Diff line number Diff line change
@@ -96,6 +96,9 @@ export const expressCheckoutIframe = async ( api, context, emailSelector ) => {
buildAjaxURL( getConfig( 'wcAjaxUrl' ), 'get_woopay_session' ),
{
_ajax_nonce: getConfig( 'woopaySessionNonce' ),
order_id: getConfig( 'order_id' ),
key: getConfig( 'key' ),
billing_email: getConfig( 'billing_email' ),
}
).then( ( response ) => {
if ( response?.data?.session ) {
56 changes: 36 additions & 20 deletions includes/woopay/class-woopay-session.php
Original file line number Diff line number Diff line change
@@ -44,7 +44,9 @@ class WooPay_Session {
'@^\/wc\/store(\/v[\d]+)?\/cart\/update-customer$@',
'@^\/wc\/store(\/v[\d]+)?\/cart\/update-item$@',
'@^\/wc\/store(\/v[\d]+)?\/cart\/extensions$@',
'@^\/wc\/store(\/v[\d]+)?\/checkout\/(?P<id>[\d]+)@',
'@^\/wc\/store(\/v[\d]+)?\/checkout$@',
'@^\/wc\/store(\/v[\d]+)?\/order\/(?P<id>[\d]+)@',
];

/**
@@ -289,7 +291,13 @@ public static function get_frontend_init_session_request() {
return [];
}

$session = self::get_init_session_request();
// phpcs:disable WordPress.Security.NonceVerification.Missing
$order_id = ! empty( $_POST['order_id'] ) ? absint( wp_unslash( $_POST['order_id'] ) ) : null;
$key = ! empty( $_POST['key'] ) ? sanitize_text_field( wp_unslash( $_POST['key'] ) ) : null;
$billing_email = ! empty( $_POST['billing_email'] ) ? sanitize_text_field( wp_unslash( $_POST['billing_email'] ) ) : null;
// phpcs:enable

$session = self::get_init_session_request( $order_id, $key, $billing_email );

$store_blog_token = ( WooPay_Utilities::get_woopay_url() === WooPay_Utilities::DEFAULT_WOOPAY_URL ) ? Jetpack_Options::get_option( 'blog_token' ) : 'dev_mode';

@@ -321,11 +329,16 @@ public static function get_frontend_init_session_request() {
/**
* Returns the initial session request data.
*
* @param int|null $order_id Pay-for-order order ID.
* @param string|null $key Pay-for-order key.
* @param string|null $billing_email Pay-for-order billing email.
* @return array The initial session request data without email and user_session.
*/
private static function get_init_session_request() {
$user = wp_get_current_user();
$customer_id = WC_Payments::get_customer_service()->get_customer_id_by_user_id( $user->ID );
private static function get_init_session_request( $order_id = null, $key = null, $billing_email = null ) {
$user = wp_get_current_user();
$is_pay_for_order = null !== $order_id;
$order = wc_get_order( $order_id );
$customer_id = WC_Payments::get_customer_service()->get_customer_id_by_user_id( $user->ID );
if ( null === $customer_id ) {
// create customer.
$customer_data = WC_Payments_Customer_Service::map_customer_data( null, new WC_Customer( $user->ID ) );
@@ -345,20 +358,15 @@ private static function get_init_session_request() {

$account_id = WC_Payments::get_account_service()->get_stripe_account_id();

$site_logo_id = get_theme_mod( 'custom_logo' );
$site_logo_url = $site_logo_id ? ( wp_get_attachment_image_src( $site_logo_id, 'full' )[0] ?? '' ) : '';
$woopay_store_logo = WC_Payments::get_gateway()->get_option( 'platform_checkout_store_logo' );

$store_logo = $site_logo_url;
if ( ! empty( $woopay_store_logo ) ) {
$store_logo = get_rest_url( null, 'wc/v3/payments/file/' . $woopay_store_logo );
}
$store_logo = WC_Payments::get_gateway()->get_option( 'platform_checkout_store_logo' );

include_once WCPAY_ABSPATH . 'includes/compat/blocks/class-blocks-data-extractor.php';
$blocks_data_extractor = new Blocks_Data_Extractor();

// This uses the same logic as the Checkout block in hydrate_from_api to get the cart and checkout data.
$cart_data = rest_preload_api_request( [], '/wc/store/v1/cart' )['/wc/store/v1/cart']['body'];
$cart_data = ! $is_pay_for_order
? rest_preload_api_request( [], '/wc/store/v1/cart' )['/wc/store/v1/cart']['body']
: rest_preload_api_request( [], "/wc/store/v1/order/{$order_id}?key={$key}&billing_email={$billing_email}" )[ "/wc/store/v1/order/{$order_id}?key={$key}&billing_email={$billing_email}" ]['body'];
add_filter( 'woocommerce_store_api_disable_nonce_check', '__return_true' );
$preloaded_checkout_data = rest_preload_api_request( [], '/wc/store/v1/checkout' );
remove_filter( 'woocommerce_store_api_disable_nonce_check', '__return_true' );
@@ -373,11 +381,11 @@ private static function get_init_session_request() {
'email' => '',
'store_data' => [
'store_name' => get_bloginfo( 'name' ),
'store_logo' => $store_logo,
'custom_message' => self::get_formatted_custom_message(),
'store_logo' => ! empty( $store_logo ) ? get_rest_url( null, 'wc/v3/payments/file/' . $store_logo ) : '',
'custom_message' => WC_Payments::get_gateway()->get_option( 'platform_checkout_custom_message' ),
'blog_id' => Jetpack_Options::get_option( 'id' ),
'blog_url' => get_site_url(),
'blog_checkout_url' => wc_get_checkout_url(),
'blog_checkout_url' => ! $is_pay_for_order ? wc_get_checkout_url() : $order->get_checkout_payment_url(),
'blog_shop_url' => get_permalink( wc_get_page_id( 'shop' ) ),
'store_api_url' => self::get_store_api_url(),
'account_id' => $account_id,
@@ -386,14 +394,19 @@ private static function get_init_session_request() {
'is_subscriptions_plugin_active' => WC_Payments::get_gateway()->is_subscriptions_plugin_active(),
'woocommerce_tax_display_cart' => get_option( 'woocommerce_tax_display_cart' ),
'ship_to_billing_address_only' => wc_ship_to_billing_address_only(),
'return_url' => wc_get_cart_url(),
'return_url' => ! $is_pay_for_order ? wc_get_cart_url() : $order->get_checkout_payment_url(),
'blocks_data' => $blocks_data_extractor->get_data(),
'checkout_schema_namespaces' => $blocks_data_extractor->get_checkout_schema_namespaces(),
],
'user_session' => null,
'preloaded_requests' => [
'preloaded_requests' => ! $is_pay_for_order ? [
'cart' => $cart_data,
'checkout' => $checkout_data,
] : [
'cart' => $cart_data,
'checkout' => [
'order_id' => $order_id, // This is a workaround for the checkout order error. https://github.com/woocommerce/woocommerce-blocks/blob/04f36065b34977f02079e6c2c8cb955200a783ff/assets/js/blocks/checkout/block.tsx#L81-L83.
],
],
'tracks_user_identity' => WC_Payments::woopay_tracker()->tracks_get_identity( $user->ID ),
];
@@ -416,9 +429,12 @@ public static function ajax_init_woopay() {
);
}

$email = ! empty( $_POST['email'] ) ? wc_clean( wp_unslash( $_POST['email'] ) ) : '';
$email = ! empty( $_POST['email'] ) ? wc_clean( wp_unslash( $_POST['email'] ) ) : '';
$order_id = ! empty( $_POST['order_id'] ) ? absint( wp_unslash( $_POST['order_id'] ) ) : null;
$key = ! empty( $_POST['key'] ) ? sanitize_text_field( wp_unslash( $_POST['key'] ) ) : null;
$billing_email = ! empty( $_POST['billing_email'] ) ? sanitize_text_field( wp_unslash( $_POST['billing_email'] ) ) : null;

$body = self::get_init_session_request();
$body = self::get_init_session_request( $order_id, $key, $billing_email );
$body['email'] = $email;
$body['user_session'] = isset( $_REQUEST['user_session'] ) ? sanitize_text_field( wp_unslash( $_REQUEST['user_session'] ) ) : null;