From 2269a79ecc288478e41959810ce974388b7aa49f Mon Sep 17 00:00:00 2001 From: Fatai Salami Date: Thu, 5 Dec 2024 19:18:47 +0000 Subject: [PATCH 1/2] Add support for MOTO in credit card payments extension schema --- .../credit_card_payments_app_extension_schema.test.ts | 2 ++ .../credit_card_payments_app_extension_schema.ts | 4 ++++ 2 files changed, 6 insertions(+) diff --git a/packages/app/src/cli/models/extensions/specifications/payments_app_extension_schemas/credit_card_payments_app_extension_schema.test.ts b/packages/app/src/cli/models/extensions/specifications/payments_app_extension_schemas/credit_card_payments_app_extension_schema.test.ts index b5f5e5867b3..6ca0bf4061f 100644 --- a/packages/app/src/cli/models/extensions/specifications/payments_app_extension_schemas/credit_card_payments_app_extension_schema.test.ts +++ b/packages/app/src/cli/models/extensions/specifications/payments_app_extension_schemas/credit_card_payments_app_extension_schema.test.ts @@ -21,6 +21,7 @@ const config: CreditCardPaymentsAppExtensionConfigType = { supported_countries: ['CA'], supported_payment_methods: ['PAYMENT_METHOD'], supported_buyer_contexts: [{currency: 'USD'}, {currency: 'CAD'}], + supports_moto: true, supports_3ds: false, test_mode_available: true, supports_deferred_payments: false, @@ -194,6 +195,7 @@ describe('creditCardPaymentsAppExtensionDeployConfig', () => { supported_payment_methods: config.supported_payment_methods, supported_buyer_contexts: config.supported_buyer_contexts, test_mode_available: config.test_mode_available, + supports_moto: config.supports_moto, supports_3ds: config.supports_3ds, supports_deferred_payments: config.supports_deferred_payments, supports_installments: config.supports_installments, diff --git a/packages/app/src/cli/models/extensions/specifications/payments_app_extension_schemas/credit_card_payments_app_extension_schema.ts b/packages/app/src/cli/models/extensions/specifications/payments_app_extension_schemas/credit_card_payments_app_extension_schema.ts index e4f65957dc0..22d004d586b 100644 --- a/packages/app/src/cli/models/extensions/specifications/payments_app_extension_schemas/credit_card_payments_app_extension_schema.ts +++ b/packages/app/src/cli/models/extensions/specifications/payments_app_extension_schemas/credit_card_payments_app_extension_schema.ts @@ -29,6 +29,7 @@ export const CreditCardPaymentsAppExtensionSchema = BasePaymentsAppExtensionSche targeting: zod.array(zod.object({target: zod.literal(CREDIT_CARD_TARGET)})).length(1), verification_session_url: zod.string().url().optional(), ui_extension_handle: zod.string().optional(), + supports_moto: zod.boolean(), encryption_certificate_fingerprint: zod .string() .min(1, {message: "Encryption certificate fingerprint can't be blank"}), @@ -72,6 +73,7 @@ export interface CreditCardPaymentsAppExtensionDeployConfigType extends BasePaym supports_3ds: boolean // CreditCard-specific fields + supports_moto: boolean start_verification_session_url?: string ui_extension_registration_uuid?: string ui_extension_handle?: string @@ -106,6 +108,7 @@ export function creditCardDeployConfigToCLIConfig( supported_buyer_contexts: config.supported_buyer_contexts, test_mode_available: config.test_mode_available, supports_3ds: config.supports_3ds, + supports_moto: config.supports_moto, supports_deferred_payments: config.supports_deferred_payments, supports_installments: config.supports_installments, verification_session_url: config.start_verification_session_url, @@ -132,6 +135,7 @@ export async function creditCardPaymentsAppExtensionDeployConfig( supported_buyer_contexts: config.supported_buyer_contexts, test_mode_available: config.test_mode_available, supports_3ds: config.supports_3ds, + supports_moto: config.supports_moto, supports_deferred_payments: config.supports_deferred_payments, encryption_certificate_fingerprint: config.encryption_certificate_fingerprint, supports_installments: config.supports_installments, From cf2bc94b0fc73abe04512019eff8bc1234088e1c Mon Sep 17 00:00:00 2001 From: Paul Buzuloiu Date: Thu, 9 Jan 2025 21:21:52 +0000 Subject: [PATCH 2/2] fixup! Add support for MOTO in credit card payments extension schema --- ...card_payments_app_extension_schema.test.ts | 40 +++++++++++++++++++ ...edit_card_payments_app_extension_schema.ts | 5 ++- 2 files changed, 44 insertions(+), 1 deletion(-) diff --git a/packages/app/src/cli/models/extensions/specifications/payments_app_extension_schemas/credit_card_payments_app_extension_schema.test.ts b/packages/app/src/cli/models/extensions/specifications/payments_app_extension_schemas/credit_card_payments_app_extension_schema.test.ts index 6ca0bf4061f..c8d4fd47f9b 100644 --- a/packages/app/src/cli/models/extensions/specifications/payments_app_extension_schemas/credit_card_payments_app_extension_schema.test.ts +++ b/packages/app/src/cli/models/extensions/specifications/payments_app_extension_schemas/credit_card_payments_app_extension_schema.test.ts @@ -173,6 +173,46 @@ describe('CreditCardPaymentsAppExtensionSchema', () => { ]), ) }) + + test('returns an error if supports_moto is not a boolean', async () => { + // When/Then + expect(() => + CreditCardPaymentsAppExtensionSchema.parse({ + ...config, + supports_moto: 'true', + }), + ).toThrowError( + new zod.ZodError([ + { + code: 'invalid_type', + expected: 'boolean', + received: 'string', + path: ['supports_moto'], + message: 'Value must be Boolean', + }, + ]), + ) + }) + + test('returns an error if supports_moto is not present', async () => { + // When/Then + expect(() => + CreditCardPaymentsAppExtensionSchema.parse({ + ...config, + supports_moto: undefined, + }), + ).toThrowError( + new zod.ZodError([ + { + code: 'invalid_type', + expected: 'boolean', + received: 'undefined', + path: ['supports_moto'], + message: 'supports_moto is required', + }, + ]), + ) + }) }) describe('creditCardPaymentsAppExtensionDeployConfig', () => { diff --git a/packages/app/src/cli/models/extensions/specifications/payments_app_extension_schemas/credit_card_payments_app_extension_schema.ts b/packages/app/src/cli/models/extensions/specifications/payments_app_extension_schemas/credit_card_payments_app_extension_schema.ts index 22d004d586b..b6515040426 100644 --- a/packages/app/src/cli/models/extensions/specifications/payments_app_extension_schemas/credit_card_payments_app_extension_schema.ts +++ b/packages/app/src/cli/models/extensions/specifications/payments_app_extension_schemas/credit_card_payments_app_extension_schema.ts @@ -29,7 +29,10 @@ export const CreditCardPaymentsAppExtensionSchema = BasePaymentsAppExtensionSche targeting: zod.array(zod.object({target: zod.literal(CREDIT_CARD_TARGET)})).length(1), verification_session_url: zod.string().url().optional(), ui_extension_handle: zod.string().optional(), - supports_moto: zod.boolean(), + supports_moto: zod.boolean({ + required_error: 'supports_moto is required', + invalid_type_error: 'Value must be Boolean', + }), encryption_certificate_fingerprint: zod .string() .min(1, {message: "Encryption certificate fingerprint can't be blank"}),