diff --git a/README.md b/README.md index 2b3f0c549..346f6c01e 100755 --- a/README.md +++ b/README.md @@ -29,7 +29,7 @@ override the new secure-http default setting)*. { "require": { "php": ">=8.0.0", - "cybersource/rest-client-php": "0.0.58" + "cybersource/rest-client-php": "0.0.59" } } ``` diff --git a/composer.json b/composer.json index 1ddb2574d..d1e6dbdc8 100644 --- a/composer.json +++ b/composer.json @@ -1,6 +1,6 @@ { "name": "cybersource/rest-client-php", - "version": "0.0.58", + "version": "0.0.59", "description": "Client SDK for CyberSource REST APIs", "keywords": [ "cybersource", "payments", "ecommerce", "merchant", "merchants", "authorize", "visa", "payment", "payment-gateway", "payment-integration", "payment-module", "payment-processing", "payment-service", "payment-methods" diff --git a/docs/Model/CommerceSolutionsProductsTokenManagementConfigurationInformationConfigurations.md b/docs/Model/CommerceSolutionsProductsTokenManagementConfigurationInformationConfigurations.md index 57ef330c8..b3ba1eeec 100644 --- a/docs/Model/CommerceSolutionsProductsTokenManagementConfigurationInformationConfigurations.md +++ b/docs/Model/CommerceSolutionsProductsTokenManagementConfigurationInformationConfigurations.md @@ -5,6 +5,7 @@ Name | Type | Description | Notes ------------ | ------------- | ------------- | ------------- **parentProfileId** | **string** | Specify the Vault ID to which transacting MID needs to be assigned.Provide Vault ID as seen on EBC Vault management page. If not provided , transacting MID will be assigned to the existing default Vault at merchant's level. If there are no Vaults at merchant level , a new Vault will be created and transacting MID will be assigned to it. | [optional] **vault** | [**\CyberSource\Model\CommerceSolutionsProductsTokenManagementConfigurationInformationConfigurationsVault**](CommerceSolutionsProductsTokenManagementConfigurationInformationConfigurationsVault.md) | | [optional] +**networkTokenEnrollment** | [**\CyberSource\Model\NetworkTokenEnrollment**](NetworkTokenEnrollment.md) | | [optional] [[Back to Model list]](../README.md#documentation-for-models) [[Back to API list]](../README.md#documentation-for-api-endpoints) [[Back to README]](../README.md) diff --git a/docs/Model/GenerateCaptureContextRequest.md b/docs/Model/GenerateCaptureContextRequest.md index 06685ceaf..7ecd23b9e 100644 --- a/docs/Model/GenerateCaptureContextRequest.md +++ b/docs/Model/GenerateCaptureContextRequest.md @@ -5,8 +5,9 @@ Name | Type | Description | Notes ------------ | ------------- | ------------- | ------------- **clientVersion** | **string** | Specify the version of Microform that you want to use. | [optional] **targetOrigins** | **string[]** | The [target origin](https://developer.mozilla.org/en-US/docs/Glossary/Origin) of the website on which you will be launching Microform is defined by the scheme (protocol), hostname (domain) and port number (if used). You must use https://hostname (unless you use http://localhost) Wildcards are NOT supported. Ensure that subdomains are included. Any valid top-level domain is supported (e.g. .com, .co.uk, .gov.br etc) Examples: - https://example.com - https://subdomain.example.com - https://example.com:8080<br><br> If you are embedding within multiple nested iframes you need to specify the origins of all the browser contexts used, for example: targetOrigins: [ \"https://example.com\", \"https://basket.example.com\", \"https://ecom.example.com\" ] | [optional] -**allowedCardNetworks** | **string[]** | The list of card networks you want to use for this Microform transaction. Microform currently supports the following card networks: - VISA - MASTERCARD - AMEX - CARNET - CARTESBANCAIRES - CUP - DINERSCLUB - DISCOVER - EFTPOS - ELO - JCB - JCREW - MADA - MAESTRO - MEEZA **Important:** - When integrating Microform (Accept Card) at least one card network should be specified in the allowedCardNetworks field in the capture context request. - When integrating Microform (Accept Check) the allowedCardNetworks field is not required in the capture context request. - When integrating both Microform (Accept Card) and Microform (Accept Check) at least one card network should be specified in the allowedCardNetworks field in the capture context request. | [optional] +**allowedCardNetworks** | **string[]** | The list of card networks you want to use for this Microform transaction. Microform currently supports the following card networks: - VISA - MASTERCARD - AMEX - CARNET - CARTESBANCAIRES - CUP - DINERSCLUB - DISCOVER - EFTPOS - ELO - JCB - JCREW - MADA - MAESTRO - MEEZA **Important:** - When integrating Microform (Card) at least one card network should be specified in the allowedCardNetworks field in the capture context request. - When integrating Microform (ACH/Echeck) the allowedCardNetworks field is not required in the capture context request. - When integrating both Microform (Card) and Microform (ACH/Echeck) at least one card network should be specified in the allowedCardNetworks field in the capture context request. | [optional] **allowedPaymentTypes** | **string[]** | The payment types that are allowed for the merchant. Possible values when launching Microform: - CARD - CHECK <br><br> | [optional] +**transientTokenResponseOptions** | [**\CyberSource\Model\Microformv2sessionsTransientTokenResponseOptions**](Microformv2sessionsTransientTokenResponseOptions.md) | | [optional] [[Back to Model list]](../README.md#documentation-for-models) [[Back to API list]](../README.md#documentation-for-api-endpoints) [[Back to README]](../README.md) diff --git a/docs/Model/GenerateUnifiedCheckoutCaptureContextRequest.md b/docs/Model/GenerateUnifiedCheckoutCaptureContextRequest.md index 27fd720ed..a56fea10c 100644 --- a/docs/Model/GenerateUnifiedCheckoutCaptureContextRequest.md +++ b/docs/Model/GenerateUnifiedCheckoutCaptureContextRequest.md @@ -11,6 +11,7 @@ Name | Type | Description | Notes **locale** | **string** | Localization of the User experience conforming to the ISO 639-1 language standards and two-character ISO Standard Country Code. Please refer to list of [supported locales through Unified Checkout](https://developer.cybersource.com/docs/cybs/en-us/unified-checkout/developer/all/rest/unified-checkout/uc-appendix-languages.html) | [optional] **captureMandate** | [**\CyberSource\Model\Upv1capturecontextsCaptureMandate**](Upv1capturecontextsCaptureMandate.md) | | [optional] **orderInformation** | [**\CyberSource\Model\Upv1capturecontextsOrderInformation**](Upv1capturecontextsOrderInformation.md) | | [optional] +**transientTokenResponseOptions** | [**\CyberSource\Model\Microformv2sessionsTransientTokenResponseOptions**](Microformv2sessionsTransientTokenResponseOptions.md) | | [optional] [[Back to Model list]](../README.md#documentation-for-models) [[Back to API list]](../README.md#documentation-for-api-endpoints) [[Back to README]](../README.md) diff --git a/docs/Model/Microformv2sessionsTransientTokenResponseOptions.md b/docs/Model/Microformv2sessionsTransientTokenResponseOptions.md new file mode 100644 index 000000000..b4265445d --- /dev/null +++ b/docs/Model/Microformv2sessionsTransientTokenResponseOptions.md @@ -0,0 +1,10 @@ +# Microformv2sessionsTransientTokenResponseOptions + +## Properties +Name | Type | Description | Notes +------------ | ------------- | ------------- | ------------- +**includeCardPrefix** | **bool** | Use the transientTokenResponseOptions.includeCardPrefix field to choose your preferred card number prefix length: 6-digit, 8-digit, or no card number prefix. Possible values: - True - False<br><br> To select the type of card number prefix: - No field included: A 6-digit prefix is returned (default) - True: An 8-digit prefix is returned - False: No prefix is returned<br><br> The following conditions apply: - 8-digit card number prefixes only apply to Discover, JCB, Mastercard, UnionPay, and Visa brands with 16-digit card numbers or more. - Any card with less than 16-digit numbers will return a 6-digit prefix even when the transientTokenResponseOptions.includeCardPrefix field is set to true. - Any card brand other than Discover, JCB, Mastercard, UnionPay, or Visa will return a 6-digit prefix even when the transientTokenResponseOptions.includeCardPrefix field is set to true. - If any card brand is co-branded with Discover, JCB, Mastercard, UnionPay, or Visa, an 8-digit prefix will be returned if the transientTokenResponseOptions.includeCardPrefix field is set to true.<br><br> **Important:** If your application does NOT require a card number prefix for routing or identification purposes, set the transientTokenResponseOptions.includeCardPrefix field to False. This will minimize your personal data exposure. | [optional] + +[[Back to Model list]](../README.md#documentation-for-models) [[Back to API list]](../README.md#documentation-for-api-endpoints) [[Back to README]](../README.md) + + diff --git a/docs/Model/NetworkTokenEnrollment.md b/docs/Model/NetworkTokenEnrollment.md new file mode 100644 index 000000000..525c4529d --- /dev/null +++ b/docs/Model/NetworkTokenEnrollment.md @@ -0,0 +1,11 @@ +# NetworkTokenEnrollment + +## Properties +Name | Type | Description | Notes +------------ | ------------- | ------------- | ------------- +**businessInformation** | [**\CyberSource\Model\TmsBusinessInformation**](TmsBusinessInformation.md) | | [optional] +**networkTokenServices** | [**\CyberSource\Model\NetworkTokenServicesEnablement**](NetworkTokenServicesEnablement.md) | | [optional] + +[[Back to Model list]](../README.md#documentation-for-models) [[Back to API list]](../README.md#documentation-for-api-endpoints) [[Back to README]](../README.md) + + diff --git a/docs/Model/NetworkTokenServicesEnablement.md b/docs/Model/NetworkTokenServicesEnablement.md new file mode 100644 index 000000000..af4ea79df --- /dev/null +++ b/docs/Model/NetworkTokenServicesEnablement.md @@ -0,0 +1,11 @@ +# NetworkTokenServicesEnablement + +## Properties +Name | Type | Description | Notes +------------ | ------------- | ------------- | ------------- +**visaTokenService** | [**\CyberSource\Model\NetworkTokenServicesEnablementVisaTokenService**](NetworkTokenServicesEnablementVisaTokenService.md) | | [optional] +**mastercardDigitalEnablementService** | [**\CyberSource\Model\NetworkTokenServicesEnablementMastercardDigitalEnablementService**](NetworkTokenServicesEnablementMastercardDigitalEnablementService.md) | | [optional] + +[[Back to Model list]](../README.md#documentation-for-models) [[Back to API list]](../README.md#documentation-for-api-endpoints) [[Back to README]](../README.md) + + diff --git a/docs/Model/NetworkTokenServicesEnablementMastercardDigitalEnablementService.md b/docs/Model/NetworkTokenServicesEnablementMastercardDigitalEnablementService.md new file mode 100644 index 000000000..aa3275dad --- /dev/null +++ b/docs/Model/NetworkTokenServicesEnablementMastercardDigitalEnablementService.md @@ -0,0 +1,10 @@ +# NetworkTokenServicesEnablementMastercardDigitalEnablementService + +## Properties +Name | Type | Description | Notes +------------ | ------------- | ------------- | ------------- +**enrollment** | **bool** | Indicates if an enrollment to create a TRID for the MasterCard card association should be attempted | [optional] + +[[Back to Model list]](../README.md#documentation-for-models) [[Back to API list]](../README.md#documentation-for-api-endpoints) [[Back to README]](../README.md) + + diff --git a/docs/Model/NetworkTokenServicesEnablementVisaTokenService.md b/docs/Model/NetworkTokenServicesEnablementVisaTokenService.md new file mode 100644 index 000000000..079c604ee --- /dev/null +++ b/docs/Model/NetworkTokenServicesEnablementVisaTokenService.md @@ -0,0 +1,10 @@ +# NetworkTokenServicesEnablementVisaTokenService + +## Properties +Name | Type | Description | Notes +------------ | ------------- | ------------- | ------------- +**enrollment** | **bool** | Indicates if an enrollment to create a TRID for the Visa card association should be attempted | [optional] + +[[Back to Model list]](../README.md#documentation-for-models) [[Back to API list]](../README.md#documentation-for-api-endpoints) [[Back to README]](../README.md) + + diff --git a/docs/Model/TmsBusinessInformation.md b/docs/Model/TmsBusinessInformation.md new file mode 100644 index 000000000..6dd84f715 --- /dev/null +++ b/docs/Model/TmsBusinessInformation.md @@ -0,0 +1,16 @@ +# TmsBusinessInformation + +## Properties +Name | Type | Description | Notes +------------ | ------------- | ------------- | ------------- +**name** | **string** | Name of the network token merchant. | [optional] +**doingBusinessAs** | **string** | Name the network token merchant does business as | [optional] +**address** | [**\CyberSource\Model\TmsBusinessInformationAddress**](TmsBusinessInformationAddress.md) | | [optional] +**websiteUrl** | **string** | Website of network token merchant. | [optional] +**businessIdentificationType** | **string** | The Identifier associated with the business type; required unless both acquirerId and acquirerMerchantId are provided. | [optional] +**businessIdentificationValue** | **string** | The value associated with the business identifier type; required unless both acquirerId and acquirerMerchantId are provided. | [optional] +**acquirer** | [**\CyberSource\Model\TmsBusinessInformationAcquirer**](TmsBusinessInformationAcquirer.md) | | [optional] + +[[Back to Model list]](../README.md#documentation-for-models) [[Back to API list]](../README.md#documentation-for-api-endpoints) [[Back to README]](../README.md) + + diff --git a/docs/Model/TmsBusinessInformationAcquirer.md b/docs/Model/TmsBusinessInformationAcquirer.md new file mode 100644 index 000000000..3aac9860d --- /dev/null +++ b/docs/Model/TmsBusinessInformationAcquirer.md @@ -0,0 +1,11 @@ +# TmsBusinessInformationAcquirer + +## Properties +Name | Type | Description | Notes +------------ | ------------- | ------------- | ------------- +**acquirerId** | **string** | Acquirer ID; required unless both businessIdentificationType and businessIdentificationValue are provided. | [optional] +**acquirerMerchantId** | **string** | Acquirer merchant ID; required unless both businessIdentificationType and businessIdentificationValue are provided. | [optional] + +[[Back to Model list]](../README.md#documentation-for-models) [[Back to API list]](../README.md#documentation-for-api-endpoints) [[Back to README]](../README.md) + + diff --git a/docs/Model/TmsBusinessInformationAddress.md b/docs/Model/TmsBusinessInformationAddress.md new file mode 100644 index 000000000..7a3f18f2f --- /dev/null +++ b/docs/Model/TmsBusinessInformationAddress.md @@ -0,0 +1,11 @@ +# TmsBusinessInformationAddress + +## Properties +Name | Type | Description | Notes +------------ | ------------- | ------------- | ------------- +**country** | **string** | Country of network token merchant. | [optional] +**locality** | **string** | City of network token merchant. | [optional] + +[[Back to Model list]](../README.md#documentation-for-models) [[Back to API list]](../README.md#documentation-for-api-endpoints) [[Back to README]](../README.md) + + diff --git a/docs/Model/Upv1capturecontextsCaptureMandate.md b/docs/Model/Upv1capturecontextsCaptureMandate.md index a8e58a2c6..32d021616 100644 --- a/docs/Model/Upv1capturecontextsCaptureMandate.md +++ b/docs/Model/Upv1capturecontextsCaptureMandate.md @@ -9,6 +9,8 @@ Name | Type | Description | Notes **requestShipping** | **bool** | Configure Unified Checkout to capture customer shipping details. Possible values: - True - False | [optional] **shipToCountries** | **string[]** | List of countries available to ship to. Use the two-character ISO Standard Country Codes. | [optional] **showAcceptedNetworkIcons** | **bool** | Configure Unified Checkout to display the list of accepted card networks beneath the payment button Possible values: - True - False | [optional] +**requestSaveCard** | **bool** | Configure Unified Checkout to display the \"Save card for future use\" checkbox.<br> Configurable check box that will show in a Manual card entry flow to allow a Cardholder to give consent to store their manually entered credential with the Merchant that they are paying.<br> Applicable when manually entering the details and not enrolling in Click to Pay. Possible values: - True - False<br><br> **Use Cases:** **Offer consumers option to save their card in Unified Checkout:** - Include the captureMandate.requestSaveCard field in the capture context request and set it to true. - When set to true, this will show a checkbox with the message 'Save card for future use' in Unified Checkout. - When selected this provides a response in both the Transient Token and Get Credentials API response.<br><br> **Do not offer consumers the option to save their card in Unified Checkout:** - Include the captureMandate.requestSaveCard field in the capture context request and set it to false OR omit the field from the capture context request. - When set to false, the save card option is not shown to consumers when manually entering card details. | [optional] +**comboCard** | **bool** | Configure Unified Checkout to display combo card at checkout.<br> A combo debit/credit card is a single card that functions both as a Debit/Credit card. Unified Checkout / Click to Pay Drop-in UI allows the Cardholder to choose whether they would like the transaction to be paid for using either debit or credit card. **Important:** This is applicable to Visa cards only. Possible values: - True - False<br><br> **Use Cases:** **Offer Combo Card at Checkout:** - Include the captureMandate.comboCard field in the capture context request and set it to true. - When set to true, Combo Card selection is shown at checkout <br><br> **Do not offer Combo Card at Checkout:** - Include the captureMandate.comboCard field in the capture context request and set it to false OR omit the field from the capture context request. - The Combo Card selection is not shown at checkout. | [optional] [[Back to Model list]](../README.md#documentation-for-models) [[Back to API list]](../README.md#documentation-for-api-endpoints) [[Back to README]](../README.md) diff --git a/generator/cybersource-rest-spec.json b/generator/cybersource-rest-spec.json index 8671afd97..e494a3c61 100644 --- a/generator/cybersource-rest-spec.json +++ b/generator/cybersource-rest-spec.json @@ -68404,7 +68404,7 @@ "items": { "type": "string" }, - "description": "The list of card networks you want to use for this Microform transaction.\n\nMicroform currently supports the following card networks:\n- VISA\n- MASTERCARD\n- AMEX\n- CARNET\n- CARTESBANCAIRES\n- CUP\n- DINERSCLUB\n- DISCOVER\n- EFTPOS\n- ELO\n- JCB\n- JCREW\n- MADA\n- MAESTRO\n- MEEZA\n\n**Important:** \n - When integrating Microform (Accept Card) at least one card network should be specified in the allowedCardNetworks field in the capture context request.\n - When integrating Microform (Accept Check) the allowedCardNetworks field is not required in the capture context request.\n - When integrating both Microform (Accept Card) and Microform (Accept Check) at least one card network should be specified in the allowedCardNetworks field in the capture context request.\n" + "description": "The list of card networks you want to use for this Microform transaction.\n\nMicroform currently supports the following card networks:\n- VISA\n- MASTERCARD\n- AMEX\n- CARNET\n- CARTESBANCAIRES\n- CUP\n- DINERSCLUB\n- DISCOVER\n- EFTPOS\n- ELO\n- JCB\n- JCREW\n- MADA\n- MAESTRO\n- MEEZA\n\n**Important:** \n - When integrating Microform (Card) at least one card network should be specified in the allowedCardNetworks field in the capture context request.\n - When integrating Microform (ACH/Echeck) the allowedCardNetworks field is not required in the capture context request.\n - When integrating both Microform (Card) and Microform (ACH/Echeck) at least one card network should be specified in the allowedCardNetworks field in the capture context request.\n" }, "allowedPaymentTypes": { "type": "array", @@ -68412,6 +68412,15 @@ "type": "string" }, "description": "The payment types that are allowed for the merchant. \n\nPossible values when launching Microform:\n- CARD\n- CHECK

\n" + }, + "transientTokenResponseOptions": { + "type": "object", + "properties": { + "includeCardPrefix": { + "type": "boolean", + "description": "Use the transientTokenResponseOptions.includeCardPrefix field to choose your preferred card number prefix length: 6-digit, 8-digit, or no card number prefix.\n\nPossible values:\n- True\n- False

\n\nTo select the type of card number prefix:\n- No field included: A 6-digit prefix is returned (default)\n- True: An 8-digit prefix is returned\n- False: No prefix is returned

\n\nThe following conditions apply:\n- 8-digit card number prefixes only apply to Discover, JCB, Mastercard, UnionPay, and Visa brands with 16-digit card numbers or more.\n- Any card with less than 16-digit numbers will return a 6-digit prefix even when the transientTokenResponseOptions.includeCardPrefix field is set to true.\n- Any card brand other than Discover, JCB, Mastercard, UnionPay, or Visa will return a 6-digit prefix even when the transientTokenResponseOptions.includeCardPrefix field is set to true.\n- If any card brand is co-branded with Discover, JCB, Mastercard, UnionPay, or Visa, an 8-digit prefix will be returned if the transientTokenResponseOptions.includeCardPrefix field is set to true.

\n\n**Important:** \nIf your application does NOT require a card number prefix for routing or identification purposes, set the transientTokenResponseOptions.includeCardPrefix field to False. This will minimize your personal data exposure.\n" + } + } } } } @@ -68419,7 +68428,7 @@ ], "x-example": { "example0": { - "summary": "Generate Capture Context (Accept Card)", + "summary": "Generate Capture Context (Card)", "value": { "clientVersion": "v2", "targetOrigins": [ @@ -68448,7 +68457,7 @@ } }, "example1": { - "summary": "Generate Capture Context (Accept Check)", + "summary": "Generate Capture Context (ACH/Echeck)", "value": { "clientVersion": "v2", "targetOrigins": [ @@ -68458,6 +68467,38 @@ "CHECK" ] } + }, + "example2": { + "summary": "Generate Capture Context (Card - Opt-out of receiving card number prefix)", + "value": { + "clientVersion": "v2", + "targetOrigins": [ + "https://www.test.com" + ], + "allowedCardNetworks": [ + "VISA", + "MASTERCARD", + "AMEX", + "CARNET", + "CARTESBANCAIRES", + "CUP", + "DINERSCLUB", + "DISCOVER", + "EFTPOS", + "ELO", + "JCB", + "JCREW", + "MADA", + "MAESTRO", + "MEEZA" + ], + "allowedPaymentTypes": [ + "CARD" + ], + "transientTokenResponseOptions": { + "includeCardPrefix": false + } + } } }, "responses": { @@ -107428,6 +107469,110 @@ } } } + }, + "networkTokenEnrollment": { + "title": "networkTokenEnrollment", + "type": "object", + "properties": { + "businessInformation": { + "title": "tmsBusinessInformation", + "type": "object", + "properties": { + "name": { + "type": "string", + "maxLength": 60, + "minLength": 1, + "pattern": "^[0-9a-zA-Z _\\-\\+\\.\\*\\\"/'&\\,\\(\\)!$;:?@\\#\u00a1-\uffff]+$", + "description": "Name of the network token merchant.", + "example": "NetworkTokenMerchant" + }, + "doingBusinessAs": { + "type": "string", + "maxLength": 60, + "pattern": "^[0-9a-zA-Z _\\-\\+\\.\\*\\\"/'&\\,\\(\\)!$;:?@\\#\u00a1-\uffff]+$", + "description": "Name the network token merchant does business as", + "example": "NetworkTokenCo1" + }, + "address": { + "type": "object", + "properties": { + "country": { + "type": "string", + "maxLength": 2, + "minLength": 2, + "pattern": "^[\u00c0-\u00d6\u00d8-\u00f6\u00f8-\u01ffa-zA-Z0-9().\\-_#,;/@$:!% ]{1,}$", + "description": "Country of network token merchant.", + "example": "US" + }, + "locality": { + "type": "string", + "maxLength": 50, + "minLength": 1, + "pattern": "^[0-9a-zA-Z _\\-\u00a1-\uffff]+$", + "description": "City of network token merchant.", + "example": "ORMOND BEACH" + } + } + }, + "websiteUrl": { + "type": "string", + "maxLength": 100, + "pattern": "\\b((?:https?://|www\\d{0,3}[.]|[a-z0-9.\\-]+[.][a-z]{2,4}/)(?:[^\\s()<>]+|\\(([^\\s()<>]+|(\\([^\\s()<>]+\\)))*\\))+(?:\\(([^\\s()<>]+|(\\([^\\s()<>]+\\)))*\\)|[^\\s`!()\\[\\]{};:'\".,<>?\u00c2\u00ab\u00c2\u00bb\u00e2\u20ac\u0153\u00e2\u20ac.\u00e2\u20ac\u02dc\u00e2\u20ac\u2122]))", + "description": "Website of network token merchant.", + "example": "https://www.NetworkTokenMerchant.com" + }, + "businessIdentificationType": { + "type": "string", + "description": "The Identifier associated with the business type; required unless both acquirerId and acquirerMerchantId are provided.\n", + "maxLength": 15 + }, + "businessIdentificationValue": { + "type": "string", + "description": "The value associated with the business identifier type; required unless both acquirerId and acquirerMerchantId are provided.\n", + "maxLength": 25 + }, + "acquirer": { + "type": "object", + "properties": { + "acquirerId": { + "type": "string", + "description": "Acquirer ID; required unless both businessIdentificationType and businessIdentificationValue are provided.\n", + "maxLength": 15 + }, + "acquirerMerchantId": { + "type": "string", + "description": "Acquirer merchant ID; required unless both businessIdentificationType and businessIdentificationValue are provided.\n", + "maxLength": 25 + } + } + } + } + }, + "networkTokenServices": { + "title": "NetworkTokenServicesEnablement", + "type": "object", + "properties": { + "visaTokenService": { + "type": "object", + "properties": { + "enrollment": { + "type": "boolean", + "description": "Indicates if an enrollment to create a TRID for the Visa card association should be attempted" + } + } + }, + "mastercardDigitalEnablementService": { + "type": "object", + "properties": { + "enrollment": { + "type": "boolean", + "description": "Indicates if an enrollment to create a TRID for the MasterCard card association should be attempted" + } + } + } + } + } + } } } } @@ -111323,6 +111468,109 @@ } } } + }, + "example12": { + "summary": "Merchant Boarding with TMS and Network Token TRID Enrollment (Production Only)", + "value": { + "organizationInformation": { + "parentOrganizationId": "apitester00", + "type": "MERCHANT", + "configurable": "true", + "businessInformation": { + "name": "StuartWickedFastEatz", + "address": { + "country": "US", + "address1": "123456 SandMarket", + "locality": "ORMOND BEACH", + "administrativeArea": "FL", + "postalCode": "32176" + }, + "websiteUrl": "https://www.NetworkTokenMerchant.com", + "businessContact": { + "firstName": "Token", + "lastName": "Man", + "phoneNumber": "6574567813", + "email": "networktokenman@visa.com" + } + } + }, + "productInformation": { + "selectedProducts": { + "commerceSolutions": { + "tokenManagement": { + "subscriptionInformation": { + "enabled": true + }, + "configurationInformation": { + "configurations": { + "vault": { + "defaultTokenType": "CUSTOMER", + "location": "GDC", + "tokenFormats": { + "customer": "32_HEX", + "paymentInstrument": "32_HEX", + "instrumentIdentifierCard": "19_DIGIT_LAST_4", + "instrumentIdentifierBankAccount": "32_HEX" + }, + "sensitivePrivileges": { + "cardNumberMaskingFormat": "FIRST_6_LAST_4" + }, + "networkTokenServices": { + "visaTokenService": { + "enableService": true, + "enableTransactionalTokens": true + }, + "mastercardDigitalEnablementService": { + "enableService": true, + "enableTransactionalTokens": true + }, + "americanExpressTokenService": { + "enableService": true, + "enableTransactionalTokens": true, + "tokenRequestorId": "12345678912", + "seNumber": "9876543212" + }, + "notifications": { + "enabled": true + }, + "paymentCredentials": { + "enabled": true + }, + "synchronousProvisioning": { + "enabled": false + } + } + }, + "networkTokenEnrollment": { + "businessInformation": { + "name": "NetworkTokenMerchant", + "doingBusinessAs": "NetworkTokenCo1", + "address": { + "country": "US", + "locality": "ORMOND BEACH" + }, + "websiteUrl": "https://www.NetworkTokenMerchant.com", + "acquirer": { + "acquirerId": "40010052242", + "acquirerMerchantId": "MerchantOrgID" + } + }, + "networkTokenServices": { + "visaTokenService": { + "enrollment": true + }, + "mastercardDigitalEnablementService": { + "enrollment": true + } + } + } + } + } + } + } + } + } + } } } } @@ -115856,6 +116104,110 @@ } } } + }, + "networkTokenEnrollment": { + "title": "networkTokenEnrollment", + "type": "object", + "properties": { + "businessInformation": { + "title": "tmsBusinessInformation", + "type": "object", + "properties": { + "name": { + "type": "string", + "maxLength": 60, + "minLength": 1, + "pattern": "^[0-9a-zA-Z _\\-\\+\\.\\*\\\"/'&\\,\\(\\)!$;:?@\\#\u00a1-\uffff]+$", + "description": "Name of the network token merchant.", + "example": "NetworkTokenMerchant" + }, + "doingBusinessAs": { + "type": "string", + "maxLength": 60, + "pattern": "^[0-9a-zA-Z _\\-\\+\\.\\*\\\"/'&\\,\\(\\)!$;:?@\\#\u00a1-\uffff]+$", + "description": "Name the network token merchant does business as", + "example": "NetworkTokenCo1" + }, + "address": { + "type": "object", + "properties": { + "country": { + "type": "string", + "maxLength": 2, + "minLength": 2, + "pattern": "^[\u00c0-\u00d6\u00d8-\u00f6\u00f8-\u01ffa-zA-Z0-9().\\-_#,;/@$:!% ]{1,}$", + "description": "Country of network token merchant.", + "example": "US" + }, + "locality": { + "type": "string", + "maxLength": 50, + "minLength": 1, + "pattern": "^[0-9a-zA-Z _\\-\u00a1-\uffff]+$", + "description": "City of network token merchant.", + "example": "ORMOND BEACH" + } + } + }, + "websiteUrl": { + "type": "string", + "maxLength": 100, + "pattern": "\\b((?:https?://|www\\d{0,3}[.]|[a-z0-9.\\-]+[.][a-z]{2,4}/)(?:[^\\s()<>]+|\\(([^\\s()<>]+|(\\([^\\s()<>]+\\)))*\\))+(?:\\(([^\\s()<>]+|(\\([^\\s()<>]+\\)))*\\)|[^\\s`!()\\[\\]{};:'\".,<>?\u00c2\u00ab\u00c2\u00bb\u00e2\u20ac\u0153\u00e2\u20ac.\u00e2\u20ac\u02dc\u00e2\u20ac\u2122]))", + "description": "Website of network token merchant.", + "example": "https://www.NetworkTokenMerchant.com" + }, + "businessIdentificationType": { + "type": "string", + "description": "The Identifier associated with the business type; required unless both acquirerId and acquirerMerchantId are provided.\n", + "maxLength": 15 + }, + "businessIdentificationValue": { + "type": "string", + "description": "The value associated with the business identifier type; required unless both acquirerId and acquirerMerchantId are provided.\n", + "maxLength": 25 + }, + "acquirer": { + "type": "object", + "properties": { + "acquirerId": { + "type": "string", + "description": "Acquirer ID; required unless both businessIdentificationType and businessIdentificationValue are provided.\n", + "maxLength": 15 + }, + "acquirerMerchantId": { + "type": "string", + "description": "Acquirer merchant ID; required unless both businessIdentificationType and businessIdentificationValue are provided.\n", + "maxLength": 25 + } + } + } + } + }, + "networkTokenServices": { + "title": "NetworkTokenServicesEnablement", + "type": "object", + "properties": { + "visaTokenService": { + "type": "object", + "properties": { + "enrollment": { + "type": "boolean", + "description": "Indicates if an enrollment to create a TRID for the Visa card association should be attempted" + } + } + }, + "mastercardDigitalEnablementService": { + "type": "object", + "properties": { + "enrollment": { + "type": "boolean", + "description": "Indicates if an enrollment to create a TRID for the MasterCard card association should be attempted" + } + } + } + } + } + } } } } @@ -120330,7 +120682,7 @@ "properties": { "clientVersion": { "type": "string", - "example": 0.22, + "example": "0.24", "maxLength": 60, "description": "Specify the version of Unified Checkout that you want to use." }, @@ -120405,6 +120757,14 @@ "showAcceptedNetworkIcons": { "type": "boolean", "description": "Configure Unified Checkout to display the list of accepted card networks beneath the payment button\n\nPossible values:\n- True\n- False\n" + }, + "requestSaveCard": { + "type": "boolean", + "description": "Configure Unified Checkout to display the \"Save card for future use\" checkbox.
\n\nConfigurable check box that will show in a Manual card entry flow to allow a Cardholder to give consent to store their manually entered credential with the Merchant that they are paying.
\nApplicable when manually entering the details and not enrolling in Click to Pay.\n\nPossible values:\n - True \n - False

\n\n**Use Cases:**\n\n**Offer consumers option to save their card in Unified Checkout:** \n- Include the captureMandate.requestSaveCard field in the capture context request and set it to true.\n- When set to true, this will show a checkbox with the message 'Save card for future use' in Unified Checkout.\n- When selected this provides a response in both the Transient Token and Get Credentials API response.

\n\n**Do not offer consumers the option to save their card in Unified Checkout:** \n- Include the captureMandate.requestSaveCard field in the capture context request and set it to false OR omit the field from the capture context request.\n- When set to false, the save card option is not shown to consumers when manually entering card details.\n" + }, + "comboCard": { + "type": "boolean", + "description": "Configure Unified Checkout to display combo card at checkout.
\n\nA combo debit/credit card is a single card that functions both as a Debit/Credit card. \nUnified Checkout / Click to Pay Drop-in UI allows the Cardholder to choose whether they would like the transaction to be paid for using either debit or credit card.\n**Important:** This is applicable to Visa cards only.\n\nPossible values:\n- True \n- False

\n\n**Use Cases:**\n\n**Offer Combo Card at Checkout:** \n- Include the captureMandate.comboCard field in the capture context request and set it to true.\n- When set to true, Combo Card selection is shown at checkout

\n\n**Do not offer Combo Card at Checkout:** \n- Include the captureMandate.comboCard field in the capture context request and set it to false OR omit the field from the capture context request.\n- The Combo Card selection is not shown at checkout.\n" } } }, @@ -120684,6 +121044,15 @@ } } } + }, + "transientTokenResponseOptions": { + "type": "object", + "properties": { + "includeCardPrefix": { + "type": "boolean", + "description": "Use the transientTokenResponseOptions.includeCardPrefix field to choose your preferred card number prefix length: 6-digit, 8-digit, or no card number prefix.\n\nPossible values:\n- True\n- False

\n\nTo select the type of card number prefix:\n- No field included: A 6-digit prefix is returned (default)\n- True: An 8-digit prefix is returned\n- False: No prefix is returned

\n\nThe following conditions apply:\n- 8-digit card number prefixes only apply to Discover, JCB, Mastercard, UnionPay, and Visa brands with 16-digit card numbers or more.\n- Any card with less than 16-digit numbers will return a 6-digit prefix even when the transientTokenResponseOptions.includeCardPrefix field is set to true.\n- Any card brand other than Discover, JCB, Mastercard, UnionPay, or Visa will return a 6-digit prefix even when the transientTokenResponseOptions.includeCardPrefix field is set to true.\n- If any card brand is co-branded with Discover, JCB, Mastercard, UnionPay, or Visa, an 8-digit prefix will be returned if the transientTokenResponseOptions.includeCardPrefix field is set to true.

\n\n**Important:** \nIf your application does NOT require a card number prefix for routing or identification purposes, set the transientTokenResponseOptions.includeCardPrefix field to False. This will minimize your personal data exposure.\n" + } + } } } } @@ -120693,7 +121062,7 @@ "example0": { "summary": "Generate Unified Checkout Capture Context", "value": { - "clientVersion": "0.23", + "clientVersion": "0.24", "targetOrigins": [ "https://yourCheckoutPage.com" ], @@ -120743,10 +121112,66 @@ } } }, - "example3": { + "example1": { + "summary": "Generate Unified Checkout Capture Context (Opt-out of receiving card number prefix)", + "value": { + "clientVersion": "0.24", + "targetOrigins": [ + "https://yourCheckoutPage.com" + ], + "allowedCardNetworks": [ + "VISA", + "MASTERCARD", + "AMEX", + "CARNET", + "CARTESBANCAIRES", + "CUP", + "DINERSCLUB", + "DISCOVER", + "EFTPOS", + "ELO", + "JCB", + "JCREW", + "MADA", + "MAESTRO", + "MEEZA" + ], + "allowedPaymentTypes": [ + "APPLEPAY", + "CHECK", + "CLICKTOPAY", + "GOOGLEPAY", + "PANENTRY", + "PAZE" + ], + "country": "US", + "locale": "en_US", + "captureMandate": { + "billingType": "FULL", + "requestEmail": true, + "requestPhone": true, + "requestShipping": true, + "shipToCountries": [ + "US", + "GB" + ], + "showAcceptedNetworkIcons": true + }, + "orderInformation": { + "amountDetails": { + "totalAmount": "21.00", + "currency": "USD" + } + }, + "transientTokenResponseOptions": { + "includeCardPrefix": false + } + } + }, + "example2": { "summary": "Generate Unified Checkout Capture Context passing Billing & Shipping", "value": { - "clientVersion": "0.23", + "clientVersion": "0.24", "targetOrigins": [ "https://yourCheckoutPage.com" ], @@ -120843,10 +121268,10 @@ } } }, - "example4": { + "example3": { "summary": "Generate Capture Context For Click To Pay Drop-In UI", "value": { - "clientVersion": "0.23", + "clientVersion": "0.24", "targetOrigins": [ "https://yourCheckoutPage.com" ], diff --git a/lib/Authentication/Jwt/JsonWebTokenGenerator.php b/lib/Authentication/Jwt/JsonWebTokenGenerator.php index 13c8e6536..022e9dee3 100644 --- a/lib/Authentication/Jwt/JsonWebTokenGenerator.php +++ b/lib/Authentication/Jwt/JsonWebTokenGenerator.php @@ -28,7 +28,7 @@ public function __construct(\CyberSource\Logging\LogConfiguration $logConfig) //calling Signature public function generateToken($resourcePath, $payloadData, $method, $merchantConfig) { - $date = date("D, d M Y G:i:s ").GlobalParameter::GMT; + $date = gmdate("D, d M Y G:i:s ").GlobalParameter::GMT; if($method==GlobalParameter::GET || $method==GlobalParameter::DELETE) { $jwtBody = array("iat"=>$date); diff --git a/lib/Authentication/Util/JWE/JWEUtility.php b/lib/Authentication/Util/JWE/JWEUtility.php index 24010b777..2fca423e3 100644 --- a/lib/Authentication/Util/JWE/JWEUtility.php +++ b/lib/Authentication/Util/JWE/JWEUtility.php @@ -20,7 +20,11 @@ class JWEUtility { private static $cache = null; + /** + * @deprecated This method has been marked as Deprecated and will be removed in coming releases. + */ private static function loadKeyFromPEMFile($path) { + trigger_error("This method has been marked as Deprecated and will be removed in coming releases.", E_USER_DEPRECATED); return JWKFactory::createFromKeyFile( $path, '', // Secret if the key is encrypted @@ -30,7 +34,11 @@ private static function loadKeyFromPEMFile($path) { ); } + /** + * @deprecated This method has been marked as Deprecated and will be removed in coming releases. Use decryptJWEUsingPrivateKey(\$privateKey, \$encodedResponse) instead. + */ public static function decryptJWEUsingPEM(MerchantConfiguration $merchantConfig, string $jweBase64Data) { + trigger_error("This method has been marked as Deprecated and will be removed in coming releases. Use decryptJWEUsingPrivateKey(\$privateKey, \$encodedResponse) instead.", E_USER_DEPRECATED); if (!isset(self::$cache)) { self::$cache = new Cache(); } @@ -77,6 +85,37 @@ public static function decryptJWEUsingPEM(MerchantConfiguration $merchantConfig, return null; } } + + public static function decryptJWEUsingPrivateKey(string $privateKey, string $encodedResponse) { + $jwk = JWKFactory::createFromKey($privateKey); + // The key encryption algorithm manager with the A256KW algorithm. + $keyEncryptionAlgorithmManager = new AlgorithmManager([ + new RSAOAEP256() + ]); + + // The content encryption algorithm manager with the A256CBC-HS256 algorithm. + $contentEncryptionAlgorithmManager = new AlgorithmManager([ + new A256GCM(), + ]); + + // The serializer manager. We only use the JWE Compact Serialization Mode. + $serializerManager = new JWESerializerManager([ + new CompactSerializer(), + ]); + + $jweDecrypter = new JWEDecrypter( + $keyEncryptionAlgorithmManager, + $contentEncryptionAlgorithmManager, + new CompressionMethodManager([new Deflate()]) + ); + + $jwe = $serializerManager->unserialize($encodedResponse); + if($jweDecrypter -> decryptUsingKey($jwe, $jwk, 0)) { + return $jwe ->getPayload(); + } else { + return null; + } + } } ?> diff --git a/lib/Model/CommerceSolutionsProductsTokenManagementConfigurationInformationConfigurations.php b/lib/Model/CommerceSolutionsProductsTokenManagementConfigurationInformationConfigurations.php index aca7625ce..066249754 100644 --- a/lib/Model/CommerceSolutionsProductsTokenManagementConfigurationInformationConfigurations.php +++ b/lib/Model/CommerceSolutionsProductsTokenManagementConfigurationInformationConfigurations.php @@ -54,7 +54,8 @@ class CommerceSolutionsProductsTokenManagementConfigurationInformationConfigurat */ protected static $swaggerTypes = [ 'parentProfileId' => 'string', - 'vault' => '\CyberSource\Model\CommerceSolutionsProductsTokenManagementConfigurationInformationConfigurationsVault' + 'vault' => '\CyberSource\Model\CommerceSolutionsProductsTokenManagementConfigurationInformationConfigurationsVault', + 'networkTokenEnrollment' => '\CyberSource\Model\NetworkTokenEnrollment' ]; /** @@ -63,7 +64,8 @@ class CommerceSolutionsProductsTokenManagementConfigurationInformationConfigurat */ protected static $swaggerFormats = [ 'parentProfileId' => null, - 'vault' => null + 'vault' => null, + 'networkTokenEnrollment' => null ]; public static function swaggerTypes() @@ -82,7 +84,8 @@ public static function swaggerFormats() */ protected static $attributeMap = [ 'parentProfileId' => 'parentProfileId', - 'vault' => 'vault' + 'vault' => 'vault', + 'networkTokenEnrollment' => 'networkTokenEnrollment' ]; @@ -92,7 +95,8 @@ public static function swaggerFormats() */ protected static $setters = [ 'parentProfileId' => 'setParentProfileId', - 'vault' => 'setVault' + 'vault' => 'setVault', + 'networkTokenEnrollment' => 'setNetworkTokenEnrollment' ]; @@ -102,7 +106,8 @@ public static function swaggerFormats() */ protected static $getters = [ 'parentProfileId' => 'getParentProfileId', - 'vault' => 'getVault' + 'vault' => 'getVault', + 'networkTokenEnrollment' => 'getNetworkTokenEnrollment' ]; public static function attributeMap() @@ -138,6 +143,7 @@ public function __construct(array $data = null) { $this->container['parentProfileId'] = isset($data['parentProfileId']) ? $data['parentProfileId'] : null; $this->container['vault'] = isset($data['vault']) ? $data['vault'] : null; + $this->container['networkTokenEnrollment'] = isset($data['networkTokenEnrollment']) ? $data['networkTokenEnrollment'] : null; } /** @@ -206,6 +212,27 @@ public function setVault($vault) return $this; } + + /** + * Gets networkTokenEnrollment + * @return \CyberSource\Model\NetworkTokenEnrollment + */ + public function getNetworkTokenEnrollment() + { + return $this->container['networkTokenEnrollment']; + } + + /** + * Sets networkTokenEnrollment + * @param \CyberSource\Model\NetworkTokenEnrollment $networkTokenEnrollment + * @return $this + */ + public function setNetworkTokenEnrollment($networkTokenEnrollment) + { + $this->container['networkTokenEnrollment'] = $networkTokenEnrollment; + + return $this; + } /** * Returns true if offset exists. False otherwise. * @param integer $offset Offset diff --git a/lib/Model/GenerateCaptureContextRequest.php b/lib/Model/GenerateCaptureContextRequest.php index 4ab4c4e9d..eeb37767d 100644 --- a/lib/Model/GenerateCaptureContextRequest.php +++ b/lib/Model/GenerateCaptureContextRequest.php @@ -57,7 +57,8 @@ class GenerateCaptureContextRequest implements ArrayAccess 'clientVersion' => 'string', 'targetOrigins' => 'string[]', 'allowedCardNetworks' => 'string[]', - 'allowedPaymentTypes' => 'string[]' + 'allowedPaymentTypes' => 'string[]', + 'transientTokenResponseOptions' => '\CyberSource\Model\Microformv2sessionsTransientTokenResponseOptions' ]; /** @@ -68,7 +69,8 @@ class GenerateCaptureContextRequest implements ArrayAccess 'clientVersion' => null, 'targetOrigins' => null, 'allowedCardNetworks' => null, - 'allowedPaymentTypes' => null + 'allowedPaymentTypes' => null, + 'transientTokenResponseOptions' => null ]; public static function swaggerTypes() @@ -89,7 +91,8 @@ public static function swaggerFormats() 'clientVersion' => 'clientVersion', 'targetOrigins' => 'targetOrigins', 'allowedCardNetworks' => 'allowedCardNetworks', - 'allowedPaymentTypes' => 'allowedPaymentTypes' + 'allowedPaymentTypes' => 'allowedPaymentTypes', + 'transientTokenResponseOptions' => 'transientTokenResponseOptions' ]; @@ -101,7 +104,8 @@ public static function swaggerFormats() 'clientVersion' => 'setClientVersion', 'targetOrigins' => 'setTargetOrigins', 'allowedCardNetworks' => 'setAllowedCardNetworks', - 'allowedPaymentTypes' => 'setAllowedPaymentTypes' + 'allowedPaymentTypes' => 'setAllowedPaymentTypes', + 'transientTokenResponseOptions' => 'setTransientTokenResponseOptions' ]; @@ -113,7 +117,8 @@ public static function swaggerFormats() 'clientVersion' => 'getClientVersion', 'targetOrigins' => 'getTargetOrigins', 'allowedCardNetworks' => 'getAllowedCardNetworks', - 'allowedPaymentTypes' => 'getAllowedPaymentTypes' + 'allowedPaymentTypes' => 'getAllowedPaymentTypes', + 'transientTokenResponseOptions' => 'getTransientTokenResponseOptions' ]; public static function attributeMap() @@ -151,6 +156,7 @@ public function __construct(array $data = null) $this->container['targetOrigins'] = isset($data['targetOrigins']) ? $data['targetOrigins'] : null; $this->container['allowedCardNetworks'] = isset($data['allowedCardNetworks']) ? $data['allowedCardNetworks'] : null; $this->container['allowedPaymentTypes'] = isset($data['allowedPaymentTypes']) ? $data['allowedPaymentTypes'] : null; + $this->container['transientTokenResponseOptions'] = isset($data['transientTokenResponseOptions']) ? $data['transientTokenResponseOptions'] : null; } /** @@ -231,7 +237,7 @@ public function getAllowedCardNetworks() /** * Sets allowedCardNetworks - * @param string[] $allowedCardNetworks The list of card networks you want to use for this Microform transaction. Microform currently supports the following card networks: - VISA - MASTERCARD - AMEX - CARNET - CARTESBANCAIRES - CUP - DINERSCLUB - DISCOVER - EFTPOS - ELO - JCB - JCREW - MADA - MAESTRO - MEEZA **Important:** - When integrating Microform (Accept Card) at least one card network should be specified in the allowedCardNetworks field in the capture context request. - When integrating Microform (Accept Check) the allowedCardNetworks field is not required in the capture context request. - When integrating both Microform (Accept Card) and Microform (Accept Check) at least one card network should be specified in the allowedCardNetworks field in the capture context request. + * @param string[] $allowedCardNetworks The list of card networks you want to use for this Microform transaction. Microform currently supports the following card networks: - VISA - MASTERCARD - AMEX - CARNET - CARTESBANCAIRES - CUP - DINERSCLUB - DISCOVER - EFTPOS - ELO - JCB - JCREW - MADA - MAESTRO - MEEZA **Important:** - When integrating Microform (Card) at least one card network should be specified in the allowedCardNetworks field in the capture context request. - When integrating Microform (ACH/Echeck) the allowedCardNetworks field is not required in the capture context request. - When integrating both Microform (Card) and Microform (ACH/Echeck) at least one card network should be specified in the allowedCardNetworks field in the capture context request. * @return $this */ public function setAllowedCardNetworks($allowedCardNetworks) @@ -261,6 +267,27 @@ public function setAllowedPaymentTypes($allowedPaymentTypes) return $this; } + + /** + * Gets transientTokenResponseOptions + * @return \CyberSource\Model\Microformv2sessionsTransientTokenResponseOptions + */ + public function getTransientTokenResponseOptions() + { + return $this->container['transientTokenResponseOptions']; + } + + /** + * Sets transientTokenResponseOptions + * @param \CyberSource\Model\Microformv2sessionsTransientTokenResponseOptions $transientTokenResponseOptions + * @return $this + */ + public function setTransientTokenResponseOptions($transientTokenResponseOptions) + { + $this->container['transientTokenResponseOptions'] = $transientTokenResponseOptions; + + return $this; + } /** * Returns true if offset exists. False otherwise. * @param integer $offset Offset diff --git a/lib/Model/GenerateUnifiedCheckoutCaptureContextRequest.php b/lib/Model/GenerateUnifiedCheckoutCaptureContextRequest.php index 420923b07..fe48a25c4 100644 --- a/lib/Model/GenerateUnifiedCheckoutCaptureContextRequest.php +++ b/lib/Model/GenerateUnifiedCheckoutCaptureContextRequest.php @@ -60,7 +60,8 @@ class GenerateUnifiedCheckoutCaptureContextRequest implements ArrayAccess 'country' => 'string', 'locale' => 'string', 'captureMandate' => '\CyberSource\Model\Upv1capturecontextsCaptureMandate', - 'orderInformation' => '\CyberSource\Model\Upv1capturecontextsOrderInformation' + 'orderInformation' => '\CyberSource\Model\Upv1capturecontextsOrderInformation', + 'transientTokenResponseOptions' => '\CyberSource\Model\Microformv2sessionsTransientTokenResponseOptions' ]; /** @@ -75,7 +76,8 @@ class GenerateUnifiedCheckoutCaptureContextRequest implements ArrayAccess 'country' => null, 'locale' => null, 'captureMandate' => null, - 'orderInformation' => null + 'orderInformation' => null, + 'transientTokenResponseOptions' => null ]; public static function swaggerTypes() @@ -100,7 +102,8 @@ public static function swaggerFormats() 'country' => 'country', 'locale' => 'locale', 'captureMandate' => 'captureMandate', - 'orderInformation' => 'orderInformation' + 'orderInformation' => 'orderInformation', + 'transientTokenResponseOptions' => 'transientTokenResponseOptions' ]; @@ -116,7 +119,8 @@ public static function swaggerFormats() 'country' => 'setCountry', 'locale' => 'setLocale', 'captureMandate' => 'setCaptureMandate', - 'orderInformation' => 'setOrderInformation' + 'orderInformation' => 'setOrderInformation', + 'transientTokenResponseOptions' => 'setTransientTokenResponseOptions' ]; @@ -132,7 +136,8 @@ public static function swaggerFormats() 'country' => 'getCountry', 'locale' => 'getLocale', 'captureMandate' => 'getCaptureMandate', - 'orderInformation' => 'getOrderInformation' + 'orderInformation' => 'getOrderInformation', + 'transientTokenResponseOptions' => 'getTransientTokenResponseOptions' ]; public static function attributeMap() @@ -174,6 +179,7 @@ public function __construct(array $data = null) $this->container['locale'] = isset($data['locale']) ? $data['locale'] : null; $this->container['captureMandate'] = isset($data['captureMandate']) ? $data['captureMandate'] : null; $this->container['orderInformation'] = isset($data['orderInformation']) ? $data['orderInformation'] : null; + $this->container['transientTokenResponseOptions'] = isset($data['transientTokenResponseOptions']) ? $data['transientTokenResponseOptions'] : null; } /** @@ -368,6 +374,27 @@ public function setOrderInformation($orderInformation) return $this; } + + /** + * Gets transientTokenResponseOptions + * @return \CyberSource\Model\Microformv2sessionsTransientTokenResponseOptions + */ + public function getTransientTokenResponseOptions() + { + return $this->container['transientTokenResponseOptions']; + } + + /** + * Sets transientTokenResponseOptions + * @param \CyberSource\Model\Microformv2sessionsTransientTokenResponseOptions $transientTokenResponseOptions + * @return $this + */ + public function setTransientTokenResponseOptions($transientTokenResponseOptions) + { + $this->container['transientTokenResponseOptions'] = $transientTokenResponseOptions; + + return $this; + } /** * Returns true if offset exists. False otherwise. * @param integer $offset Offset diff --git a/lib/Model/Microformv2sessionsTransientTokenResponseOptions.php b/lib/Model/Microformv2sessionsTransientTokenResponseOptions.php new file mode 100644 index 000000000..74e43a45d --- /dev/null +++ b/lib/Model/Microformv2sessionsTransientTokenResponseOptions.php @@ -0,0 +1,245 @@ + 'bool' + ]; + + /** + * Array of property to format mappings. Used for (de)serialization + * @var string[] + */ + protected static $swaggerFormats = [ + 'includeCardPrefix' => null + ]; + + public static function swaggerTypes() + { + return self::$swaggerTypes; + } + + public static function swaggerFormats() + { + return self::$swaggerFormats; + } + + /** + * Array of attributes where the key is the local name, and the value is the original name + * @var string[] + */ + protected static $attributeMap = [ + 'includeCardPrefix' => 'includeCardPrefix' + ]; + + + /** + * Array of attributes to setter functions (for deserialization of responses) + * @var string[] + */ + protected static $setters = [ + 'includeCardPrefix' => 'setIncludeCardPrefix' + ]; + + + /** + * Array of attributes to getter functions (for serialization of requests) + * @var string[] + */ + protected static $getters = [ + 'includeCardPrefix' => 'getIncludeCardPrefix' + ]; + + public static function attributeMap() + { + return self::$attributeMap; + } + + public static function setters() + { + return self::$setters; + } + + public static function getters() + { + return self::$getters; + } + + + + + + /** + * Associative array for storing property values + * @var mixed[] + */ + protected $container = []; + + /** + * Constructor + * @param mixed[] $data Associated array of property values initializing the model + */ + public function __construct(array $data = null) + { + $this->container['includeCardPrefix'] = isset($data['includeCardPrefix']) ? $data['includeCardPrefix'] : null; + } + + /** + * show all the invalid properties with reasons. + * + * @return array invalid properties with reasons + */ + public function listInvalidProperties() + { + $invalid_properties = []; + + return $invalid_properties; + } + + /** + * validate all the properties in the model + * return true if all passed + * + * @return bool True if all properties are valid + */ + public function valid() + { + + return true; + } + + + /** + * Gets includeCardPrefix + * @return bool + */ + public function getIncludeCardPrefix() + { + return $this->container['includeCardPrefix']; + } + + /** + * Sets includeCardPrefix + * @param bool $includeCardPrefix Use the transientTokenResponseOptions.includeCardPrefix field to choose your preferred card number prefix length: 6-digit, 8-digit, or no card number prefix. Possible values: - True - False

To select the type of card number prefix: - No field included: A 6-digit prefix is returned (default) - True: An 8-digit prefix is returned - False: No prefix is returned

The following conditions apply: - 8-digit card number prefixes only apply to Discover, JCB, Mastercard, UnionPay, and Visa brands with 16-digit card numbers or more. - Any card with less than 16-digit numbers will return a 6-digit prefix even when the transientTokenResponseOptions.includeCardPrefix field is set to true. - Any card brand other than Discover, JCB, Mastercard, UnionPay, or Visa will return a 6-digit prefix even when the transientTokenResponseOptions.includeCardPrefix field is set to true. - If any card brand is co-branded with Discover, JCB, Mastercard, UnionPay, or Visa, an 8-digit prefix will be returned if the transientTokenResponseOptions.includeCardPrefix field is set to true.

**Important:** If your application does NOT require a card number prefix for routing or identification purposes, set the transientTokenResponseOptions.includeCardPrefix field to False. This will minimize your personal data exposure. + * @return $this + */ + public function setIncludeCardPrefix($includeCardPrefix) + { + $this->container['includeCardPrefix'] = $includeCardPrefix; + + return $this; + } + /** + * Returns true if offset exists. False otherwise. + * @param integer $offset Offset + * @return boolean + */ + #[\ReturnTypeWillChange] + public function offsetExists($offset) + { + return isset($this->container[$offset]); + } + + /** + * Gets offset. + * @param integer $offset Offset + * @return mixed + */ + #[\ReturnTypeWillChange] + public function offsetGet($offset) + { + return isset($this->container[$offset]) ? $this->container[$offset] : null; + } + + /** + * Sets value based on offset. + * @param integer $offset Offset + * @param mixed $value Value to be set + * @return void + */ + #[\ReturnTypeWillChange] + public function offsetSet($offset, $value) + { + if (is_null($offset)) { + $this->container[] = $value; + } else { + $this->container[$offset] = $value; + } + } + + /** + * Unsets offset. + * @param integer $offset Offset + * @return void + */ + #[\ReturnTypeWillChange] + public function offsetUnset($offset) + { + unset($this->container[$offset]); + } + + /** + * Gets the string presentation of the object + * @return string + */ + public function __toString() + { + if (defined('JSON_PRETTY_PRINT')) { // use JSON pretty print + return json_encode(\CyberSource\ObjectSerializer::sanitizeForSerialization($this), JSON_PRETTY_PRINT); + } + + return json_encode(\CyberSource\ObjectSerializer::sanitizeForSerialization($this)); + } +} + + diff --git a/lib/Model/NetworkTokenEnrollment.php b/lib/Model/NetworkTokenEnrollment.php new file mode 100644 index 000000000..e300d435c --- /dev/null +++ b/lib/Model/NetworkTokenEnrollment.php @@ -0,0 +1,272 @@ + '\CyberSource\Model\TmsBusinessInformation', + 'networkTokenServices' => '\CyberSource\Model\NetworkTokenServicesEnablement' + ]; + + /** + * Array of property to format mappings. Used for (de)serialization + * @var string[] + */ + protected static $swaggerFormats = [ + 'businessInformation' => null, + 'networkTokenServices' => null + ]; + + public static function swaggerTypes() + { + return self::$swaggerTypes; + } + + public static function swaggerFormats() + { + return self::$swaggerFormats; + } + + /** + * Array of attributes where the key is the local name, and the value is the original name + * @var string[] + */ + protected static $attributeMap = [ + 'businessInformation' => 'businessInformation', + 'networkTokenServices' => 'networkTokenServices' + ]; + + + /** + * Array of attributes to setter functions (for deserialization of responses) + * @var string[] + */ + protected static $setters = [ + 'businessInformation' => 'setBusinessInformation', + 'networkTokenServices' => 'setNetworkTokenServices' + ]; + + + /** + * Array of attributes to getter functions (for serialization of requests) + * @var string[] + */ + protected static $getters = [ + 'businessInformation' => 'getBusinessInformation', + 'networkTokenServices' => 'getNetworkTokenServices' + ]; + + public static function attributeMap() + { + return self::$attributeMap; + } + + public static function setters() + { + return self::$setters; + } + + public static function getters() + { + return self::$getters; + } + + + + + + /** + * Associative array for storing property values + * @var mixed[] + */ + protected $container = []; + + /** + * Constructor + * @param mixed[] $data Associated array of property values initializing the model + */ + public function __construct(array $data = null) + { + $this->container['businessInformation'] = isset($data['businessInformation']) ? $data['businessInformation'] : null; + $this->container['networkTokenServices'] = isset($data['networkTokenServices']) ? $data['networkTokenServices'] : null; + } + + /** + * show all the invalid properties with reasons. + * + * @return array invalid properties with reasons + */ + public function listInvalidProperties() + { + $invalid_properties = []; + + return $invalid_properties; + } + + /** + * validate all the properties in the model + * return true if all passed + * + * @return bool True if all properties are valid + */ + public function valid() + { + + return true; + } + + + /** + * Gets businessInformation + * @return \CyberSource\Model\TmsBusinessInformation + */ + public function getBusinessInformation() + { + return $this->container['businessInformation']; + } + + /** + * Sets businessInformation + * @param \CyberSource\Model\TmsBusinessInformation $businessInformation + * @return $this + */ + public function setBusinessInformation($businessInformation) + { + $this->container['businessInformation'] = $businessInformation; + + return $this; + } + + /** + * Gets networkTokenServices + * @return \CyberSource\Model\NetworkTokenServicesEnablement + */ + public function getNetworkTokenServices() + { + return $this->container['networkTokenServices']; + } + + /** + * Sets networkTokenServices + * @param \CyberSource\Model\NetworkTokenServicesEnablement $networkTokenServices + * @return $this + */ + public function setNetworkTokenServices($networkTokenServices) + { + $this->container['networkTokenServices'] = $networkTokenServices; + + return $this; + } + /** + * Returns true if offset exists. False otherwise. + * @param integer $offset Offset + * @return boolean + */ + #[\ReturnTypeWillChange] + public function offsetExists($offset) + { + return isset($this->container[$offset]); + } + + /** + * Gets offset. + * @param integer $offset Offset + * @return mixed + */ + #[\ReturnTypeWillChange] + public function offsetGet($offset) + { + return isset($this->container[$offset]) ? $this->container[$offset] : null; + } + + /** + * Sets value based on offset. + * @param integer $offset Offset + * @param mixed $value Value to be set + * @return void + */ + #[\ReturnTypeWillChange] + public function offsetSet($offset, $value) + { + if (is_null($offset)) { + $this->container[] = $value; + } else { + $this->container[$offset] = $value; + } + } + + /** + * Unsets offset. + * @param integer $offset Offset + * @return void + */ + #[\ReturnTypeWillChange] + public function offsetUnset($offset) + { + unset($this->container[$offset]); + } + + /** + * Gets the string presentation of the object + * @return string + */ + public function __toString() + { + if (defined('JSON_PRETTY_PRINT')) { // use JSON pretty print + return json_encode(\CyberSource\ObjectSerializer::sanitizeForSerialization($this), JSON_PRETTY_PRINT); + } + + return json_encode(\CyberSource\ObjectSerializer::sanitizeForSerialization($this)); + } +} + + diff --git a/lib/Model/NetworkTokenServicesEnablement.php b/lib/Model/NetworkTokenServicesEnablement.php new file mode 100644 index 000000000..e7302b92d --- /dev/null +++ b/lib/Model/NetworkTokenServicesEnablement.php @@ -0,0 +1,272 @@ + '\CyberSource\Model\NetworkTokenServicesEnablementVisaTokenService', + 'mastercardDigitalEnablementService' => '\CyberSource\Model\NetworkTokenServicesEnablementMastercardDigitalEnablementService' + ]; + + /** + * Array of property to format mappings. Used for (de)serialization + * @var string[] + */ + protected static $swaggerFormats = [ + 'visaTokenService' => null, + 'mastercardDigitalEnablementService' => null + ]; + + public static function swaggerTypes() + { + return self::$swaggerTypes; + } + + public static function swaggerFormats() + { + return self::$swaggerFormats; + } + + /** + * Array of attributes where the key is the local name, and the value is the original name + * @var string[] + */ + protected static $attributeMap = [ + 'visaTokenService' => 'visaTokenService', + 'mastercardDigitalEnablementService' => 'mastercardDigitalEnablementService' + ]; + + + /** + * Array of attributes to setter functions (for deserialization of responses) + * @var string[] + */ + protected static $setters = [ + 'visaTokenService' => 'setVisaTokenService', + 'mastercardDigitalEnablementService' => 'setMastercardDigitalEnablementService' + ]; + + + /** + * Array of attributes to getter functions (for serialization of requests) + * @var string[] + */ + protected static $getters = [ + 'visaTokenService' => 'getVisaTokenService', + 'mastercardDigitalEnablementService' => 'getMastercardDigitalEnablementService' + ]; + + public static function attributeMap() + { + return self::$attributeMap; + } + + public static function setters() + { + return self::$setters; + } + + public static function getters() + { + return self::$getters; + } + + + + + + /** + * Associative array for storing property values + * @var mixed[] + */ + protected $container = []; + + /** + * Constructor + * @param mixed[] $data Associated array of property values initializing the model + */ + public function __construct(array $data = null) + { + $this->container['visaTokenService'] = isset($data['visaTokenService']) ? $data['visaTokenService'] : null; + $this->container['mastercardDigitalEnablementService'] = isset($data['mastercardDigitalEnablementService']) ? $data['mastercardDigitalEnablementService'] : null; + } + + /** + * show all the invalid properties with reasons. + * + * @return array invalid properties with reasons + */ + public function listInvalidProperties() + { + $invalid_properties = []; + + return $invalid_properties; + } + + /** + * validate all the properties in the model + * return true if all passed + * + * @return bool True if all properties are valid + */ + public function valid() + { + + return true; + } + + + /** + * Gets visaTokenService + * @return \CyberSource\Model\NetworkTokenServicesEnablementVisaTokenService + */ + public function getVisaTokenService() + { + return $this->container['visaTokenService']; + } + + /** + * Sets visaTokenService + * @param \CyberSource\Model\NetworkTokenServicesEnablementVisaTokenService $visaTokenService + * @return $this + */ + public function setVisaTokenService($visaTokenService) + { + $this->container['visaTokenService'] = $visaTokenService; + + return $this; + } + + /** + * Gets mastercardDigitalEnablementService + * @return \CyberSource\Model\NetworkTokenServicesEnablementMastercardDigitalEnablementService + */ + public function getMastercardDigitalEnablementService() + { + return $this->container['mastercardDigitalEnablementService']; + } + + /** + * Sets mastercardDigitalEnablementService + * @param \CyberSource\Model\NetworkTokenServicesEnablementMastercardDigitalEnablementService $mastercardDigitalEnablementService + * @return $this + */ + public function setMastercardDigitalEnablementService($mastercardDigitalEnablementService) + { + $this->container['mastercardDigitalEnablementService'] = $mastercardDigitalEnablementService; + + return $this; + } + /** + * Returns true if offset exists. False otherwise. + * @param integer $offset Offset + * @return boolean + */ + #[\ReturnTypeWillChange] + public function offsetExists($offset) + { + return isset($this->container[$offset]); + } + + /** + * Gets offset. + * @param integer $offset Offset + * @return mixed + */ + #[\ReturnTypeWillChange] + public function offsetGet($offset) + { + return isset($this->container[$offset]) ? $this->container[$offset] : null; + } + + /** + * Sets value based on offset. + * @param integer $offset Offset + * @param mixed $value Value to be set + * @return void + */ + #[\ReturnTypeWillChange] + public function offsetSet($offset, $value) + { + if (is_null($offset)) { + $this->container[] = $value; + } else { + $this->container[$offset] = $value; + } + } + + /** + * Unsets offset. + * @param integer $offset Offset + * @return void + */ + #[\ReturnTypeWillChange] + public function offsetUnset($offset) + { + unset($this->container[$offset]); + } + + /** + * Gets the string presentation of the object + * @return string + */ + public function __toString() + { + if (defined('JSON_PRETTY_PRINT')) { // use JSON pretty print + return json_encode(\CyberSource\ObjectSerializer::sanitizeForSerialization($this), JSON_PRETTY_PRINT); + } + + return json_encode(\CyberSource\ObjectSerializer::sanitizeForSerialization($this)); + } +} + + diff --git a/lib/Model/NetworkTokenServicesEnablementMastercardDigitalEnablementService.php b/lib/Model/NetworkTokenServicesEnablementMastercardDigitalEnablementService.php new file mode 100644 index 000000000..32591ea46 --- /dev/null +++ b/lib/Model/NetworkTokenServicesEnablementMastercardDigitalEnablementService.php @@ -0,0 +1,245 @@ + 'bool' + ]; + + /** + * Array of property to format mappings. Used for (de)serialization + * @var string[] + */ + protected static $swaggerFormats = [ + 'enrollment' => null + ]; + + public static function swaggerTypes() + { + return self::$swaggerTypes; + } + + public static function swaggerFormats() + { + return self::$swaggerFormats; + } + + /** + * Array of attributes where the key is the local name, and the value is the original name + * @var string[] + */ + protected static $attributeMap = [ + 'enrollment' => 'enrollment' + ]; + + + /** + * Array of attributes to setter functions (for deserialization of responses) + * @var string[] + */ + protected static $setters = [ + 'enrollment' => 'setEnrollment' + ]; + + + /** + * Array of attributes to getter functions (for serialization of requests) + * @var string[] + */ + protected static $getters = [ + 'enrollment' => 'getEnrollment' + ]; + + public static function attributeMap() + { + return self::$attributeMap; + } + + public static function setters() + { + return self::$setters; + } + + public static function getters() + { + return self::$getters; + } + + + + + + /** + * Associative array for storing property values + * @var mixed[] + */ + protected $container = []; + + /** + * Constructor + * @param mixed[] $data Associated array of property values initializing the model + */ + public function __construct(array $data = null) + { + $this->container['enrollment'] = isset($data['enrollment']) ? $data['enrollment'] : null; + } + + /** + * show all the invalid properties with reasons. + * + * @return array invalid properties with reasons + */ + public function listInvalidProperties() + { + $invalid_properties = []; + + return $invalid_properties; + } + + /** + * validate all the properties in the model + * return true if all passed + * + * @return bool True if all properties are valid + */ + public function valid() + { + + return true; + } + + + /** + * Gets enrollment + * @return bool + */ + public function getEnrollment() + { + return $this->container['enrollment']; + } + + /** + * Sets enrollment + * @param bool $enrollment Indicates if an enrollment to create a TRID for the MasterCard card association should be attempted + * @return $this + */ + public function setEnrollment($enrollment) + { + $this->container['enrollment'] = $enrollment; + + return $this; + } + /** + * Returns true if offset exists. False otherwise. + * @param integer $offset Offset + * @return boolean + */ + #[\ReturnTypeWillChange] + public function offsetExists($offset) + { + return isset($this->container[$offset]); + } + + /** + * Gets offset. + * @param integer $offset Offset + * @return mixed + */ + #[\ReturnTypeWillChange] + public function offsetGet($offset) + { + return isset($this->container[$offset]) ? $this->container[$offset] : null; + } + + /** + * Sets value based on offset. + * @param integer $offset Offset + * @param mixed $value Value to be set + * @return void + */ + #[\ReturnTypeWillChange] + public function offsetSet($offset, $value) + { + if (is_null($offset)) { + $this->container[] = $value; + } else { + $this->container[$offset] = $value; + } + } + + /** + * Unsets offset. + * @param integer $offset Offset + * @return void + */ + #[\ReturnTypeWillChange] + public function offsetUnset($offset) + { + unset($this->container[$offset]); + } + + /** + * Gets the string presentation of the object + * @return string + */ + public function __toString() + { + if (defined('JSON_PRETTY_PRINT')) { // use JSON pretty print + return json_encode(\CyberSource\ObjectSerializer::sanitizeForSerialization($this), JSON_PRETTY_PRINT); + } + + return json_encode(\CyberSource\ObjectSerializer::sanitizeForSerialization($this)); + } +} + + diff --git a/lib/Model/NetworkTokenServicesEnablementVisaTokenService.php b/lib/Model/NetworkTokenServicesEnablementVisaTokenService.php new file mode 100644 index 000000000..4955c89dc --- /dev/null +++ b/lib/Model/NetworkTokenServicesEnablementVisaTokenService.php @@ -0,0 +1,245 @@ + 'bool' + ]; + + /** + * Array of property to format mappings. Used for (de)serialization + * @var string[] + */ + protected static $swaggerFormats = [ + 'enrollment' => null + ]; + + public static function swaggerTypes() + { + return self::$swaggerTypes; + } + + public static function swaggerFormats() + { + return self::$swaggerFormats; + } + + /** + * Array of attributes where the key is the local name, and the value is the original name + * @var string[] + */ + protected static $attributeMap = [ + 'enrollment' => 'enrollment' + ]; + + + /** + * Array of attributes to setter functions (for deserialization of responses) + * @var string[] + */ + protected static $setters = [ + 'enrollment' => 'setEnrollment' + ]; + + + /** + * Array of attributes to getter functions (for serialization of requests) + * @var string[] + */ + protected static $getters = [ + 'enrollment' => 'getEnrollment' + ]; + + public static function attributeMap() + { + return self::$attributeMap; + } + + public static function setters() + { + return self::$setters; + } + + public static function getters() + { + return self::$getters; + } + + + + + + /** + * Associative array for storing property values + * @var mixed[] + */ + protected $container = []; + + /** + * Constructor + * @param mixed[] $data Associated array of property values initializing the model + */ + public function __construct(array $data = null) + { + $this->container['enrollment'] = isset($data['enrollment']) ? $data['enrollment'] : null; + } + + /** + * show all the invalid properties with reasons. + * + * @return array invalid properties with reasons + */ + public function listInvalidProperties() + { + $invalid_properties = []; + + return $invalid_properties; + } + + /** + * validate all the properties in the model + * return true if all passed + * + * @return bool True if all properties are valid + */ + public function valid() + { + + return true; + } + + + /** + * Gets enrollment + * @return bool + */ + public function getEnrollment() + { + return $this->container['enrollment']; + } + + /** + * Sets enrollment + * @param bool $enrollment Indicates if an enrollment to create a TRID for the Visa card association should be attempted + * @return $this + */ + public function setEnrollment($enrollment) + { + $this->container['enrollment'] = $enrollment; + + return $this; + } + /** + * Returns true if offset exists. False otherwise. + * @param integer $offset Offset + * @return boolean + */ + #[\ReturnTypeWillChange] + public function offsetExists($offset) + { + return isset($this->container[$offset]); + } + + /** + * Gets offset. + * @param integer $offset Offset + * @return mixed + */ + #[\ReturnTypeWillChange] + public function offsetGet($offset) + { + return isset($this->container[$offset]) ? $this->container[$offset] : null; + } + + /** + * Sets value based on offset. + * @param integer $offset Offset + * @param mixed $value Value to be set + * @return void + */ + #[\ReturnTypeWillChange] + public function offsetSet($offset, $value) + { + if (is_null($offset)) { + $this->container[] = $value; + } else { + $this->container[$offset] = $value; + } + } + + /** + * Unsets offset. + * @param integer $offset Offset + * @return void + */ + #[\ReturnTypeWillChange] + public function offsetUnset($offset) + { + unset($this->container[$offset]); + } + + /** + * Gets the string presentation of the object + * @return string + */ + public function __toString() + { + if (defined('JSON_PRETTY_PRINT')) { // use JSON pretty print + return json_encode(\CyberSource\ObjectSerializer::sanitizeForSerialization($this), JSON_PRETTY_PRINT); + } + + return json_encode(\CyberSource\ObjectSerializer::sanitizeForSerialization($this)); + } +} + + diff --git a/lib/Model/TmsBusinessInformation.php b/lib/Model/TmsBusinessInformation.php new file mode 100644 index 000000000..d5ca9ed2e --- /dev/null +++ b/lib/Model/TmsBusinessInformation.php @@ -0,0 +1,407 @@ + 'string', + 'doingBusinessAs' => 'string', + 'address' => '\CyberSource\Model\TmsBusinessInformationAddress', + 'websiteUrl' => 'string', + 'businessIdentificationType' => 'string', + 'businessIdentificationValue' => 'string', + 'acquirer' => '\CyberSource\Model\TmsBusinessInformationAcquirer' + ]; + + /** + * Array of property to format mappings. Used for (de)serialization + * @var string[] + */ + protected static $swaggerFormats = [ + 'name' => null, + 'doingBusinessAs' => null, + 'address' => null, + 'websiteUrl' => null, + 'businessIdentificationType' => null, + 'businessIdentificationValue' => null, + 'acquirer' => null + ]; + + public static function swaggerTypes() + { + return self::$swaggerTypes; + } + + public static function swaggerFormats() + { + return self::$swaggerFormats; + } + + /** + * Array of attributes where the key is the local name, and the value is the original name + * @var string[] + */ + protected static $attributeMap = [ + 'name' => 'name', + 'doingBusinessAs' => 'doingBusinessAs', + 'address' => 'address', + 'websiteUrl' => 'websiteUrl', + 'businessIdentificationType' => 'businessIdentificationType', + 'businessIdentificationValue' => 'businessIdentificationValue', + 'acquirer' => 'acquirer' + ]; + + + /** + * Array of attributes to setter functions (for deserialization of responses) + * @var string[] + */ + protected static $setters = [ + 'name' => 'setName', + 'doingBusinessAs' => 'setDoingBusinessAs', + 'address' => 'setAddress', + 'websiteUrl' => 'setWebsiteUrl', + 'businessIdentificationType' => 'setBusinessIdentificationType', + 'businessIdentificationValue' => 'setBusinessIdentificationValue', + 'acquirer' => 'setAcquirer' + ]; + + + /** + * Array of attributes to getter functions (for serialization of requests) + * @var string[] + */ + protected static $getters = [ + 'name' => 'getName', + 'doingBusinessAs' => 'getDoingBusinessAs', + 'address' => 'getAddress', + 'websiteUrl' => 'getWebsiteUrl', + 'businessIdentificationType' => 'getBusinessIdentificationType', + 'businessIdentificationValue' => 'getBusinessIdentificationValue', + 'acquirer' => 'getAcquirer' + ]; + + public static function attributeMap() + { + return self::$attributeMap; + } + + public static function setters() + { + return self::$setters; + } + + public static function getters() + { + return self::$getters; + } + + + + + + /** + * Associative array for storing property values + * @var mixed[] + */ + protected $container = []; + + /** + * Constructor + * @param mixed[] $data Associated array of property values initializing the model + */ + public function __construct(array $data = null) + { + $this->container['name'] = isset($data['name']) ? $data['name'] : null; + $this->container['doingBusinessAs'] = isset($data['doingBusinessAs']) ? $data['doingBusinessAs'] : null; + $this->container['address'] = isset($data['address']) ? $data['address'] : null; + $this->container['websiteUrl'] = isset($data['websiteUrl']) ? $data['websiteUrl'] : null; + $this->container['businessIdentificationType'] = isset($data['businessIdentificationType']) ? $data['businessIdentificationType'] : null; + $this->container['businessIdentificationValue'] = isset($data['businessIdentificationValue']) ? $data['businessIdentificationValue'] : null; + $this->container['acquirer'] = isset($data['acquirer']) ? $data['acquirer'] : null; + } + + /** + * show all the invalid properties with reasons. + * + * @return array invalid properties with reasons + */ + public function listInvalidProperties() + { + $invalid_properties = []; + + return $invalid_properties; + } + + /** + * validate all the properties in the model + * return true if all passed + * + * @return bool True if all properties are valid + */ + public function valid() + { + + return true; + } + + + /** + * Gets name + * @return string + */ + public function getName() + { + return $this->container['name']; + } + + /** + * Sets name + * @param string $name Name of the network token merchant. + * @return $this + */ + public function setName($name) + { + $this->container['name'] = $name; + + return $this; + } + + /** + * Gets doingBusinessAs + * @return string + */ + public function getDoingBusinessAs() + { + return $this->container['doingBusinessAs']; + } + + /** + * Sets doingBusinessAs + * @param string $doingBusinessAs Name the network token merchant does business as + * @return $this + */ + public function setDoingBusinessAs($doingBusinessAs) + { + $this->container['doingBusinessAs'] = $doingBusinessAs; + + return $this; + } + + /** + * Gets address + * @return \CyberSource\Model\TmsBusinessInformationAddress + */ + public function getAddress() + { + return $this->container['address']; + } + + /** + * Sets address + * @param \CyberSource\Model\TmsBusinessInformationAddress $address + * @return $this + */ + public function setAddress($address) + { + $this->container['address'] = $address; + + return $this; + } + + /** + * Gets websiteUrl + * @return string + */ + public function getWebsiteUrl() + { + return $this->container['websiteUrl']; + } + + /** + * Sets websiteUrl + * @param string $websiteUrl Website of network token merchant. + * @return $this + */ + public function setWebsiteUrl($websiteUrl) + { + $this->container['websiteUrl'] = $websiteUrl; + + return $this; + } + + /** + * Gets businessIdentificationType + * @return string + */ + public function getBusinessIdentificationType() + { + return $this->container['businessIdentificationType']; + } + + /** + * Sets businessIdentificationType + * @param string $businessIdentificationType The Identifier associated with the business type; required unless both acquirerId and acquirerMerchantId are provided. + * @return $this + */ + public function setBusinessIdentificationType($businessIdentificationType) + { + $this->container['businessIdentificationType'] = $businessIdentificationType; + + return $this; + } + + /** + * Gets businessIdentificationValue + * @return string + */ + public function getBusinessIdentificationValue() + { + return $this->container['businessIdentificationValue']; + } + + /** + * Sets businessIdentificationValue + * @param string $businessIdentificationValue The value associated with the business identifier type; required unless both acquirerId and acquirerMerchantId are provided. + * @return $this + */ + public function setBusinessIdentificationValue($businessIdentificationValue) + { + $this->container['businessIdentificationValue'] = $businessIdentificationValue; + + return $this; + } + + /** + * Gets acquirer + * @return \CyberSource\Model\TmsBusinessInformationAcquirer + */ + public function getAcquirer() + { + return $this->container['acquirer']; + } + + /** + * Sets acquirer + * @param \CyberSource\Model\TmsBusinessInformationAcquirer $acquirer + * @return $this + */ + public function setAcquirer($acquirer) + { + $this->container['acquirer'] = $acquirer; + + return $this; + } + /** + * Returns true if offset exists. False otherwise. + * @param integer $offset Offset + * @return boolean + */ + #[\ReturnTypeWillChange] + public function offsetExists($offset) + { + return isset($this->container[$offset]); + } + + /** + * Gets offset. + * @param integer $offset Offset + * @return mixed + */ + #[\ReturnTypeWillChange] + public function offsetGet($offset) + { + return isset($this->container[$offset]) ? $this->container[$offset] : null; + } + + /** + * Sets value based on offset. + * @param integer $offset Offset + * @param mixed $value Value to be set + * @return void + */ + #[\ReturnTypeWillChange] + public function offsetSet($offset, $value) + { + if (is_null($offset)) { + $this->container[] = $value; + } else { + $this->container[$offset] = $value; + } + } + + /** + * Unsets offset. + * @param integer $offset Offset + * @return void + */ + #[\ReturnTypeWillChange] + public function offsetUnset($offset) + { + unset($this->container[$offset]); + } + + /** + * Gets the string presentation of the object + * @return string + */ + public function __toString() + { + if (defined('JSON_PRETTY_PRINT')) { // use JSON pretty print + return json_encode(\CyberSource\ObjectSerializer::sanitizeForSerialization($this), JSON_PRETTY_PRINT); + } + + return json_encode(\CyberSource\ObjectSerializer::sanitizeForSerialization($this)); + } +} + + diff --git a/lib/Model/TmsBusinessInformationAcquirer.php b/lib/Model/TmsBusinessInformationAcquirer.php new file mode 100644 index 000000000..6e27fbc38 --- /dev/null +++ b/lib/Model/TmsBusinessInformationAcquirer.php @@ -0,0 +1,272 @@ + 'string', + 'acquirerMerchantId' => 'string' + ]; + + /** + * Array of property to format mappings. Used for (de)serialization + * @var string[] + */ + protected static $swaggerFormats = [ + 'acquirerId' => null, + 'acquirerMerchantId' => null + ]; + + public static function swaggerTypes() + { + return self::$swaggerTypes; + } + + public static function swaggerFormats() + { + return self::$swaggerFormats; + } + + /** + * Array of attributes where the key is the local name, and the value is the original name + * @var string[] + */ + protected static $attributeMap = [ + 'acquirerId' => 'acquirerId', + 'acquirerMerchantId' => 'acquirerMerchantId' + ]; + + + /** + * Array of attributes to setter functions (for deserialization of responses) + * @var string[] + */ + protected static $setters = [ + 'acquirerId' => 'setAcquirerId', + 'acquirerMerchantId' => 'setAcquirerMerchantId' + ]; + + + /** + * Array of attributes to getter functions (for serialization of requests) + * @var string[] + */ + protected static $getters = [ + 'acquirerId' => 'getAcquirerId', + 'acquirerMerchantId' => 'getAcquirerMerchantId' + ]; + + public static function attributeMap() + { + return self::$attributeMap; + } + + public static function setters() + { + return self::$setters; + } + + public static function getters() + { + return self::$getters; + } + + + + + + /** + * Associative array for storing property values + * @var mixed[] + */ + protected $container = []; + + /** + * Constructor + * @param mixed[] $data Associated array of property values initializing the model + */ + public function __construct(array $data = null) + { + $this->container['acquirerId'] = isset($data['acquirerId']) ? $data['acquirerId'] : null; + $this->container['acquirerMerchantId'] = isset($data['acquirerMerchantId']) ? $data['acquirerMerchantId'] : null; + } + + /** + * show all the invalid properties with reasons. + * + * @return array invalid properties with reasons + */ + public function listInvalidProperties() + { + $invalid_properties = []; + + return $invalid_properties; + } + + /** + * validate all the properties in the model + * return true if all passed + * + * @return bool True if all properties are valid + */ + public function valid() + { + + return true; + } + + + /** + * Gets acquirerId + * @return string + */ + public function getAcquirerId() + { + return $this->container['acquirerId']; + } + + /** + * Sets acquirerId + * @param string $acquirerId Acquirer ID; required unless both businessIdentificationType and businessIdentificationValue are provided. + * @return $this + */ + public function setAcquirerId($acquirerId) + { + $this->container['acquirerId'] = $acquirerId; + + return $this; + } + + /** + * Gets acquirerMerchantId + * @return string + */ + public function getAcquirerMerchantId() + { + return $this->container['acquirerMerchantId']; + } + + /** + * Sets acquirerMerchantId + * @param string $acquirerMerchantId Acquirer merchant ID; required unless both businessIdentificationType and businessIdentificationValue are provided. + * @return $this + */ + public function setAcquirerMerchantId($acquirerMerchantId) + { + $this->container['acquirerMerchantId'] = $acquirerMerchantId; + + return $this; + } + /** + * Returns true if offset exists. False otherwise. + * @param integer $offset Offset + * @return boolean + */ + #[\ReturnTypeWillChange] + public function offsetExists($offset) + { + return isset($this->container[$offset]); + } + + /** + * Gets offset. + * @param integer $offset Offset + * @return mixed + */ + #[\ReturnTypeWillChange] + public function offsetGet($offset) + { + return isset($this->container[$offset]) ? $this->container[$offset] : null; + } + + /** + * Sets value based on offset. + * @param integer $offset Offset + * @param mixed $value Value to be set + * @return void + */ + #[\ReturnTypeWillChange] + public function offsetSet($offset, $value) + { + if (is_null($offset)) { + $this->container[] = $value; + } else { + $this->container[$offset] = $value; + } + } + + /** + * Unsets offset. + * @param integer $offset Offset + * @return void + */ + #[\ReturnTypeWillChange] + public function offsetUnset($offset) + { + unset($this->container[$offset]); + } + + /** + * Gets the string presentation of the object + * @return string + */ + public function __toString() + { + if (defined('JSON_PRETTY_PRINT')) { // use JSON pretty print + return json_encode(\CyberSource\ObjectSerializer::sanitizeForSerialization($this), JSON_PRETTY_PRINT); + } + + return json_encode(\CyberSource\ObjectSerializer::sanitizeForSerialization($this)); + } +} + + diff --git a/lib/Model/TmsBusinessInformationAddress.php b/lib/Model/TmsBusinessInformationAddress.php new file mode 100644 index 000000000..580731cee --- /dev/null +++ b/lib/Model/TmsBusinessInformationAddress.php @@ -0,0 +1,272 @@ + 'string', + 'locality' => 'string' + ]; + + /** + * Array of property to format mappings. Used for (de)serialization + * @var string[] + */ + protected static $swaggerFormats = [ + 'country' => null, + 'locality' => null + ]; + + public static function swaggerTypes() + { + return self::$swaggerTypes; + } + + public static function swaggerFormats() + { + return self::$swaggerFormats; + } + + /** + * Array of attributes where the key is the local name, and the value is the original name + * @var string[] + */ + protected static $attributeMap = [ + 'country' => 'country', + 'locality' => 'locality' + ]; + + + /** + * Array of attributes to setter functions (for deserialization of responses) + * @var string[] + */ + protected static $setters = [ + 'country' => 'setCountry', + 'locality' => 'setLocality' + ]; + + + /** + * Array of attributes to getter functions (for serialization of requests) + * @var string[] + */ + protected static $getters = [ + 'country' => 'getCountry', + 'locality' => 'getLocality' + ]; + + public static function attributeMap() + { + return self::$attributeMap; + } + + public static function setters() + { + return self::$setters; + } + + public static function getters() + { + return self::$getters; + } + + + + + + /** + * Associative array for storing property values + * @var mixed[] + */ + protected $container = []; + + /** + * Constructor + * @param mixed[] $data Associated array of property values initializing the model + */ + public function __construct(array $data = null) + { + $this->container['country'] = isset($data['country']) ? $data['country'] : null; + $this->container['locality'] = isset($data['locality']) ? $data['locality'] : null; + } + + /** + * show all the invalid properties with reasons. + * + * @return array invalid properties with reasons + */ + public function listInvalidProperties() + { + $invalid_properties = []; + + return $invalid_properties; + } + + /** + * validate all the properties in the model + * return true if all passed + * + * @return bool True if all properties are valid + */ + public function valid() + { + + return true; + } + + + /** + * Gets country + * @return string + */ + public function getCountry() + { + return $this->container['country']; + } + + /** + * Sets country + * @param string $country Country of network token merchant. + * @return $this + */ + public function setCountry($country) + { + $this->container['country'] = $country; + + return $this; + } + + /** + * Gets locality + * @return string + */ + public function getLocality() + { + return $this->container['locality']; + } + + /** + * Sets locality + * @param string $locality City of network token merchant. + * @return $this + */ + public function setLocality($locality) + { + $this->container['locality'] = $locality; + + return $this; + } + /** + * Returns true if offset exists. False otherwise. + * @param integer $offset Offset + * @return boolean + */ + #[\ReturnTypeWillChange] + public function offsetExists($offset) + { + return isset($this->container[$offset]); + } + + /** + * Gets offset. + * @param integer $offset Offset + * @return mixed + */ + #[\ReturnTypeWillChange] + public function offsetGet($offset) + { + return isset($this->container[$offset]) ? $this->container[$offset] : null; + } + + /** + * Sets value based on offset. + * @param integer $offset Offset + * @param mixed $value Value to be set + * @return void + */ + #[\ReturnTypeWillChange] + public function offsetSet($offset, $value) + { + if (is_null($offset)) { + $this->container[] = $value; + } else { + $this->container[$offset] = $value; + } + } + + /** + * Unsets offset. + * @param integer $offset Offset + * @return void + */ + #[\ReturnTypeWillChange] + public function offsetUnset($offset) + { + unset($this->container[$offset]); + } + + /** + * Gets the string presentation of the object + * @return string + */ + public function __toString() + { + if (defined('JSON_PRETTY_PRINT')) { // use JSON pretty print + return json_encode(\CyberSource\ObjectSerializer::sanitizeForSerialization($this), JSON_PRETTY_PRINT); + } + + return json_encode(\CyberSource\ObjectSerializer::sanitizeForSerialization($this)); + } +} + + diff --git a/lib/Model/Upv1capturecontextsCaptureMandate.php b/lib/Model/Upv1capturecontextsCaptureMandate.php index 7507dcee0..f45419a3c 100644 --- a/lib/Model/Upv1capturecontextsCaptureMandate.php +++ b/lib/Model/Upv1capturecontextsCaptureMandate.php @@ -58,7 +58,9 @@ class Upv1capturecontextsCaptureMandate implements ArrayAccess 'requestPhone' => 'bool', 'requestShipping' => 'bool', 'shipToCountries' => 'string[]', - 'showAcceptedNetworkIcons' => 'bool' + 'showAcceptedNetworkIcons' => 'bool', + 'requestSaveCard' => 'bool', + 'comboCard' => 'bool' ]; /** @@ -71,7 +73,9 @@ class Upv1capturecontextsCaptureMandate implements ArrayAccess 'requestPhone' => null, 'requestShipping' => null, 'shipToCountries' => null, - 'showAcceptedNetworkIcons' => null + 'showAcceptedNetworkIcons' => null, + 'requestSaveCard' => null, + 'comboCard' => null ]; public static function swaggerTypes() @@ -94,7 +98,9 @@ public static function swaggerFormats() 'requestPhone' => 'requestPhone', 'requestShipping' => 'requestShipping', 'shipToCountries' => 'shipToCountries', - 'showAcceptedNetworkIcons' => 'showAcceptedNetworkIcons' + 'showAcceptedNetworkIcons' => 'showAcceptedNetworkIcons', + 'requestSaveCard' => 'requestSaveCard', + 'comboCard' => 'comboCard' ]; @@ -108,7 +114,9 @@ public static function swaggerFormats() 'requestPhone' => 'setRequestPhone', 'requestShipping' => 'setRequestShipping', 'shipToCountries' => 'setShipToCountries', - 'showAcceptedNetworkIcons' => 'setShowAcceptedNetworkIcons' + 'showAcceptedNetworkIcons' => 'setShowAcceptedNetworkIcons', + 'requestSaveCard' => 'setRequestSaveCard', + 'comboCard' => 'setComboCard' ]; @@ -122,7 +130,9 @@ public static function swaggerFormats() 'requestPhone' => 'getRequestPhone', 'requestShipping' => 'getRequestShipping', 'shipToCountries' => 'getShipToCountries', - 'showAcceptedNetworkIcons' => 'getShowAcceptedNetworkIcons' + 'showAcceptedNetworkIcons' => 'getShowAcceptedNetworkIcons', + 'requestSaveCard' => 'getRequestSaveCard', + 'comboCard' => 'getComboCard' ]; public static function attributeMap() @@ -162,6 +172,8 @@ public function __construct(array $data = null) $this->container['requestShipping'] = isset($data['requestShipping']) ? $data['requestShipping'] : null; $this->container['shipToCountries'] = isset($data['shipToCountries']) ? $data['shipToCountries'] : null; $this->container['showAcceptedNetworkIcons'] = isset($data['showAcceptedNetworkIcons']) ? $data['showAcceptedNetworkIcons'] : null; + $this->container['requestSaveCard'] = isset($data['requestSaveCard']) ? $data['requestSaveCard'] : null; + $this->container['comboCard'] = isset($data['comboCard']) ? $data['comboCard'] : null; } /** @@ -314,6 +326,48 @@ public function setShowAcceptedNetworkIcons($showAcceptedNetworkIcons) return $this; } + + /** + * Gets requestSaveCard + * @return bool + */ + public function getRequestSaveCard() + { + return $this->container['requestSaveCard']; + } + + /** + * Sets requestSaveCard + * @param bool $requestSaveCard Configure Unified Checkout to display the \"Save card for future use\" checkbox.
Configurable check box that will show in a Manual card entry flow to allow a Cardholder to give consent to store their manually entered credential with the Merchant that they are paying.
Applicable when manually entering the details and not enrolling in Click to Pay. Possible values: - True - False

**Use Cases:** **Offer consumers option to save their card in Unified Checkout:** - Include the captureMandate.requestSaveCard field in the capture context request and set it to true. - When set to true, this will show a checkbox with the message 'Save card for future use' in Unified Checkout. - When selected this provides a response in both the Transient Token and Get Credentials API response.

**Do not offer consumers the option to save their card in Unified Checkout:** - Include the captureMandate.requestSaveCard field in the capture context request and set it to false OR omit the field from the capture context request. - When set to false, the save card option is not shown to consumers when manually entering card details. + * @return $this + */ + public function setRequestSaveCard($requestSaveCard) + { + $this->container['requestSaveCard'] = $requestSaveCard; + + return $this; + } + + /** + * Gets comboCard + * @return bool + */ + public function getComboCard() + { + return $this->container['comboCard']; + } + + /** + * Sets comboCard + * @param bool $comboCard Configure Unified Checkout to display combo card at checkout.
A combo debit/credit card is a single card that functions both as a Debit/Credit card. Unified Checkout / Click to Pay Drop-in UI allows the Cardholder to choose whether they would like the transaction to be paid for using either debit or credit card. **Important:** This is applicable to Visa cards only. Possible values: - True - False

**Use Cases:** **Offer Combo Card at Checkout:** - Include the captureMandate.comboCard field in the capture context request and set it to true. - When set to true, Combo Card selection is shown at checkout

**Do not offer Combo Card at Checkout:** - Include the captureMandate.comboCard field in the capture context request and set it to false OR omit the field from the capture context request. - The Combo Card selection is not shown at checkout. + * @return $this + */ + public function setComboCard($comboCard) + { + $this->container['comboCard'] = $comboCard; + + return $this; + } /** * Returns true if offset exists. False otherwise. * @param integer $offset Offset diff --git a/lib/Utilities/JWEResponse/JWEUtility.php b/lib/Utilities/JWEResponse/JWEUtility.php index cf35fceaa..b6be0c524 100644 --- a/lib/Utilities/JWEResponse/JWEUtility.php +++ b/lib/Utilities/JWEResponse/JWEUtility.php @@ -8,9 +8,14 @@ class JWEUtility { /** - * @throws Exception + * @deprecated This method has been marked as Deprecated and will be removed in coming releases. Use decryptJWEResponseUsingPrivateKey(\$privateKey, \$encodedResponse) instead. */ public static function decryptJWEResponse($encodedResponse, MerchantConfiguration $merchantConfig) { + trigger_error("This method has been marked as Deprecated and will be removed in coming releases. Use Use decryptJWEResponseUsingPrivateKey(\$privateKey, \$encodedResponse) instead.", E_USER_DEPRECATED); return AuthJWEUtility::decryptJWEUsingPEM($merchantConfig, $encodedResponse); } + + public static function decryptJWEResponseUsingPrivateKey($privateKey, $encodedResponse) { + return AuthJWEUtility::decryptJWEUsingPrivateKey($privateKey, $encodedResponse); + } } diff --git a/test/Model/CommerceSolutionsProductsTokenManagementConfigurationInformationConfigurationsTest.php b/test/Model/CommerceSolutionsProductsTokenManagementConfigurationInformationConfigurationsTest.php index 14f43495a..6e921962e 100644 --- a/test/Model/CommerceSolutionsProductsTokenManagementConfigurationInformationConfigurationsTest.php +++ b/test/Model/CommerceSolutionsProductsTokenManagementConfigurationInformationConfigurationsTest.php @@ -89,4 +89,11 @@ public function testPropertyParentProfileId() public function testPropertyVault() { } + + /** + * Test attribute "networkTokenEnrollment" + */ + public function testPropertyNetworkTokenEnrollment() + { + } } diff --git a/test/Model/GenerateCaptureContextRequestTest.php b/test/Model/GenerateCaptureContextRequestTest.php index 8ea43374a..66ea73d89 100644 --- a/test/Model/GenerateCaptureContextRequestTest.php +++ b/test/Model/GenerateCaptureContextRequestTest.php @@ -103,4 +103,11 @@ public function testPropertyAllowedCardNetworks() public function testPropertyAllowedPaymentTypes() { } + + /** + * Test attribute "transientTokenResponseOptions" + */ + public function testPropertyTransientTokenResponseOptions() + { + } } diff --git a/test/Model/GenerateUnifiedCheckoutCaptureContextRequestTest.php b/test/Model/GenerateUnifiedCheckoutCaptureContextRequestTest.php index 44c7637b2..4085372c2 100644 --- a/test/Model/GenerateUnifiedCheckoutCaptureContextRequestTest.php +++ b/test/Model/GenerateUnifiedCheckoutCaptureContextRequestTest.php @@ -131,4 +131,11 @@ public function testPropertyCaptureMandate() public function testPropertyOrderInformation() { } + + /** + * Test attribute "transientTokenResponseOptions" + */ + public function testPropertyTransientTokenResponseOptions() + { + } } diff --git a/test/Model/Microformv2sessionsTransientTokenResponseOptionsTest.php b/test/Model/Microformv2sessionsTransientTokenResponseOptionsTest.php new file mode 100644 index 000000000..fbcb506b2 --- /dev/null +++ b/test/Model/Microformv2sessionsTransientTokenResponseOptionsTest.php @@ -0,0 +1,85 @@ +