This site requires javascript to be enabled.

  • Search AI-powered

Results for

xxx

Get payment product

GET https://{domainname}/client/v1/{customerId}/products/{paymentProductId}

Products

Through this API you can retrieve details of the payment products that are configured for your account.

Request

Use this API if you are just interested in one payment product or if you have filtered out the fields in the Get payment products call and you want to retrieve the field details on a single payment product. By doing it in this two-step process you will reduce the amount of data that needs to be transported back to your client, but you will have to make two calls. Usually the performance penalty is bigger when you need to do multiple calls with a small response package than one call with a bigger response package. You are however free to choose the best solution for your use case. You can submit additional details on the transaction as filters. In that case, the payment product is returned only if it matches the filters, otherwise a 400 response is returned.

Query parameters

Query parameters for this method

Property Type Required Repeat Details
countryCode string yes no read close
close

Description

ISO 3166-1 alpha-2 country code
currencyCode string yes no read close
close

Description

Three-letter ISO currency code representing the currency for the amount
locale string no no read close
close

Description

Locale used in the GUI towards the consumer. Please make sure that a language pack is configured for the locale you are submitting. If you submit a locale that is not setup on your account we will use the default language pack for your account. You can easily upload additional language packs and set the default language pack in the Configuration Center.
amount integer no no read close
close

Description

Amount in cents and always having 2 decimals
isRecurring boolean no no read close
close

Description

This allows you to filter payment products based on their support for recurring or not
  • true
  • false
isInstallments boolean no no read close
close

Description

This allows you to filter payment products based on their support for installments or not
  • true
  • false
If this is omitted all payment products are returned.
hide string no yes read close
close

Description

Allows you to hide elements from the response, reducing the amount of data that needs to be returned to your client. Possible options are:
  • fields - Don't return any data on fields of the payment product
  • accountsOnFile - Don't return any accounts on file data
  • translations - Don't return any label texts associated with the payment products
forceBasicFlow boolean no no read close
close

Description

Relevant only for payment product 3012 (Bancontact). A boolean that indicates if you want to force the response to return the fields of the basic flow. This can be useful in corner cases where you have enabled the enhanced flow which supports payment with the Bancontact app, but need access to the product fields without creating a payment first.

Request example

SDK: iOS

This scenario you will probably use the most

  • // In order to call this method, you must initialize the Connect SDK first.
    WCPaymentAmountOfMoney *amount = [[WCPaymentAmountOfMoney alloc] initWithTotalAmount:1000 currencyCode:@"EUR"];
    WCPaymentContext *context = [[WCPaymentContext alloc] initWithAmountOfMoney:amount isRecurring:true countryCode:@"NL"];
    NSString *paymentProductId = @"1";
    
    [session paymentProductWithId:paymentProductId context:context success:^(WCPaymentProduct *paymentProduct) {
        // Process WCPaymentProduct object
    } failure:^(NSError *error) {
        // Indicate that an error occurred
    }];
    

Responses

Please find below an overview of the possible responses.

Response 200 - OKPaymentProductResponse

The response contains the details of just one payment product

Properties
Property Type Required Details
close

Description

List of tokens for that payment product
close
  • SDK Object type
    AccountOnFile
close

Description

Array containing the details of the stored token
close
  • SDK Object type
    AccountOnFileAttribute
close

Description

Name of the key or property
close

Description

The reason why the status is MUST_WRITE. Currently only "IN_THE_PAST" is possible as value (for expiry date), but this can be extended with new values in the future.
close

Description

Possible values:
  • READ_ONLY - attribute cannot be updated and should be presented in that way to the user
  • CAN_WRITE - attribute can be updated and should be presented as an editable field, for example an expiration date that will expire very soon
  • MUST_WRITE - attribute should be updated and must be presented as an editable field, for example an expiration date that has already expired
Any updated values that are entered for CAN_WRITE or MUST_WRITE will be used to update the values stored in the token.
close

Description

Value of the key or property
close

Description

Object containing information for the client on how best to display this field
  • SDK Object type
    AccountOnFileDisplayHints
close

Description

Array of attribute keys and their mask
close
  • SDK Object type
    LabelTemplateElement
close

Description

Name of the attribute that is shown to the customer on selection pages or screens
close

Description

Regular mask for the attributeKey
Note: The mask is optional as not every field has a mask
close

Description

Partial URL that you can reference for the image of this payment product. You can use our server-side resize functionality by appending '?size={{width}}x{{height}}' to the full URL, where width and height are specified in pixels. The resized image will always keep its correct aspect ratio.
close

Description

ID of the account on file record
close

Description

Payment product identifier
Please see payment products for a full overview of possible values.
close

Description

ISO 3166-1 alpha-2 country code which indicates the most likely country code of the acquirer that will process the transaction. For Google Pay (paymentProductId 320) transactions this acquirerCountry is should be provided in the transactionInfo.countryCode for merchants that use an acquirer that is based in one of the European Economic Area (EEA) countries to make sure the transaction is compliant with the PSD2 Strong Customer Authentication (SCA) requirements. More information on Strong Customer Authentication compliance for Google Pay can be found at https://developers.google.com/pay/api/web/guides/resources/sca
close

Description

Indicates if the product supports installments
  • true - This payment supports installments
  • false - This payment does not support installments
close

Description

Indicates if the product supports recurring payments
  • true - This payment product supports recurring payments
  • false - This payment product does not support recurring transactions and can only be used for one-off payments
close

Description

Indicates if the payment details can be tokenized for future re-use
  • true - Payment details from payments done with this payment product can be tokenized for future re-use
  • false - Payment details from payments done with this payment product can not be tokenized
close

Description

Indicates if the payment product supports 3D Security (mandatory, optional or not needed).
  • SDK Object type
    AuthenticationIndicator
close

Description

The name of the indicator as to how it is mapped in the response.
close

Description

The name of the value as to how it is mapped in the response.
close

Description

Indicates if the payment details can be automatically tokenized for future re-use
  • true - Payment details from payments done with this payment product can be automatically tokenized for future re-use
  • false - Payment details from payments done with this payment product can not be automatically tokenized
close

Description

This property is only relevant for payment products that use third party redirects. This property indicates if the third party disallows their payment pages to be embedded in an iframe using the X-Frame-Options header.
  • true - the third party allows their payment pages to be embedded in an iframe.
  • false - the third party disallows their payment pages to be embedded in an iframe.
close

Description

Indicates if device fingerprint is enabled for the product
  • true
  • false
close

Description

Object containing display hints like the order of the product when shown in a list, the name of the product and the logo
  • SDK Object type
    PaymentProductDisplayHints
close

Description

Determines the order in which the payment products and groups should be shown (sorted ascending)
close

Description

Name of the payment product or group based on the locale that was included in the request
close

Description

Partial URL that you can reference for the image of this payment product or group. You can use our server-side resize functionality by appending '?size={{width}}x{{height}}' to the full URL, where width and height are specified in pixels. The resized image will always keep its correct aspect ratio.
close

Description

Object containing all the fields and their details that are associated with this payment product. If you are not interested in the data on the fields you should have us filter them our (using filter=fields in the query-string)
close
  • SDK Object type
    PaymentProductField
close

Description

Object containing data restrictions that apply to this field, like minimum and/or maximum length
  • SDK Object type
    PaymentProductFieldDataRestrictions
close

Description

  • true - Indicates that this field is required
  • false - Indicates that this field is optional
close

Description

Object containing the details of the validations on the field
  • SDK Object type
    PaymentProductFieldValidators
close

Description

Indicates the requiredness of the field based on the fiscalnumber for Boleto Bancario
  • SDK Object type
    BoletoBancarioRequirednessValidator
close

Description

When performing a payment with Boleto Bancario, some values are only required when the fiscalnumber has a specific length. The length the fiscalnumber has to have to make the field required is defined here. For example the CompanyName is required when the fiscalnumber is a CNPJ. The firstname and surname are required when the fiscalnumber is a CPF.
close

Description

Indicates that the content should be validated against the rules for an email address
  • SDK Object type
    EmptyValidator
close

Description

Indicates that the content should be validated against the rules for an expiration date (it should be in the future)
  • SDK Object type
    EmptyValidator
close

Description

Indicates that content should be one of the, in this object, listed items
  • SDK Object type
    FixedListValidator
close

Description

List of the allowed values that the field will be validated against
close

Description

Indicates that the content of this (iban) field needs to validated against format checks and modulo check (as described in ISO 7064)
  • SDK Object type
    EmptyValidator
close

Description

Indicates that the content needs to be validated against length criteria defined in this object
  • SDK Object type
    LengthValidator
close

Description

The maximum allowed length
close

Description

The minimum allowed length
close

Description

Indicates that the content needs to be validated using a LUHN check
  • SDK Object type
    EmptyValidator
close

Description

Indicates that the content needs to be validated against a, in this object, defined range
  • SDK Object type
    RangeValidator
close

Description

Upper value of the range that is still valid
close

Description

Lower value of the range that is still valid
close

Description

A string representing the regular expression to check
  • SDK Object type
    RegularExpressionValidator
close

Description

Contains the regular expression that the value of the field needs to be validated against
close

Description

Indicates that the content needs to be validated as per the Chinese resident identity number format
  • SDK Object type
    EmptyValidator
close

Description

Indicates that the content should be validated as such that the customer has accepted the field as if they were terms and conditions of a service
  • SDK Object type
    EmptyValidator
close

Description

Object containing display hints for this field, like the order, mask, preferred keyboard
  • SDK Object type
    PaymentProductFieldDisplayHints
close

Description

  • true - Indicates that this field is advised to be captured to increase the success rates even-though it isn't marked as required. Please note that making the field required could hurt the success rates negatively. This boolean only indicates our advise to always show this field to the customer.
  • false - Indicates that this field is not to be shown unless it is a required field.
close

Description

The order in which the fields should be shown (ascending)
close

Description

Object detailing the type of form element that should be used to present the field
  • SDK Object type
    PaymentProductFieldFormElement
close

Description

Type of form element to be used. The following types can be returned:
  • text - A normal text input field
  • list - A list of values that the customer needs to choose from, is detailed in the valueMapping array
  • currency - Currency fields should be split into two fields, with the second one being specifically for the cents
  • boolean - Boolean fields should offer the customer a choice, like accepting the terms and conditions of a product.
  • date - let the customer pick a date.
close

Description

An array of values and displayNames that should be used to populate the list object in the GUI
close
  • SDK Object type
    ValueMappingElement
close

Description

List of extra data of the value.
close
  • SDK Object type
    PaymentProductFieldDisplayElement
close

Description

The ID of the display element.
close

Description

The label of the display element.
close

Description

The type of the display element. Indicates how the value should be presented. Possible values are:
  • STRING - as plain text
  • CURRENCY - as an amount in cents displayed with a decimal separator and the currency of the payment
  • PERCENTAGE - as a number with a percentage sign
  • INTEGER - as an integer
  • URI - as a link
close

Description

the value of the display element.
close
Deprecated: Use displayElements instead with ID 'displayName'

Description

Key name
close

Description

Value corresponding to the key
close

Description

Label/Name of the field to be used in the user interface
close

Description

Link that should be used to replace the '{link}' variable in the label.
close

Description

A mask that can be used in the input field. You can use it to inject additional characters to provide a better user experience and to restrict the accepted character set (illegal characters will be ignored during typing).
* is used for wildcards (and also chars)
9 is used for numbers
Everything outside {{ and }} is used as-is.
close

Description

  • true - The data in this field should be obfuscated as it is entered, just like a password field
  • false - The data in this field does not need to be obfuscated
close

Description

A placeholder value for the form element
close

Description

The type of keyboard that can best be used to fill out the value of this field. Possible values are:
  • PhoneNumberKeyboard - Keyboard that is normally used to enter phone numbers
  • StringKeyboard - Keyboard that is used to enter strings
  • IntegerKeyboard - Keyboard that is used to enter only numerical values
  • EmailAddressKeyboard - Keyboard that allows easier entry of email addresses
close

Description

Object that contains an optional tooltip to assist the customer
  • SDK Object type
    PaymentProductFieldTooltip
close

Description

Relative URL that can be used to retrieve an image for the tooltip image.
close

Description

A text explaining the field in more detail. This is meant to be used for displaying to the customer.
close

Description

The ID of the field
close

Description

The type of field, possible values are:
  • string - Any UTF-8 chracters
  • numericstring - A string that consisting only of numbers. Note that you should strip out anything that is not a digit, but leading zeros are allowed
  • date - Date in the format DDMMYYYY
  • expirydate - Expiration date in the format MMYY
  • integer - An integer
  • boolean - A boolean
close

Description

Indicates that the product can be used in a get customer details call and that when that call is done the field should be supplied as (one of the) key(s) with a valid value.
close

Description

If one or more of the payment product fields could not be constructed, no payment product fields will be returned and a message will be present in this field stating why.
close

Description

The ID of the payment product in our system
close

Description

Indicates if the payment product supports 3D-Secure.
close

Description

This property indicates if the payment product requires JavaScript to be enabled on the customer's browser. This is usually only true if the payment product depends on a third party JavaScript integration.
  • true - the payment product requires JavaScript to be enabled.
  • false - the payment product does not require JavaScript to be enabled. This is the default value of the property is not present.
close

Description

Maximum amount in EUR cents (using 2 decimals, so 1 EUR becomes 100 cents) for transactions done with this payment product
close

Description

Minimum amount in EUR cents (using 2 decimals, so 1 EUR becomes 100 cents) for transactions done with this payment product
close

Description

This provides insight into the level of support for payments using a device with a smaller screen size. You can for instance use this to rank payment products differently on devices with a smaller screen. Possible values are:
  • NO_SUPPORT - The payment product does not work at all on a mobile device
  • BASIC_SUPPORT - The payment product has not optimized its user experience for mobile devices
  • OPTIMISED_SUPPORT - The payment product offers a user experience that has been optimized for mobile devices
close

Description

Payment method identifier used by the our payment engine with the following possible values:
  • bankRefund
  • bankTransfer
  • card
  • cash
  • directDebit
  • eInvoice
  • invoice
  • redirect
close

Description

Apple Pay (payment product 302) specific details.
  • SDK Object type
    PaymentProduct302SpecificData
  • Property is part of a group
    Learn more

    Properties that make up a group are mutually exclusive, which means you can only include one of each group in any given call.

    If there are multiple groups at one level in the object hierarchy we use numbers to distinguish groups from one another.

close

Description

The networks that can be used in the current payment context. The strings that represent the networks in the array are identical to the strings that Apple uses in their documentation. For instance: "Visa".
close

Description

Google Pay (payment product 320) specific details.
  • SDK Object type
    PaymentProduct320SpecificData
  • Property is part of a group
    Learn more

    Properties that make up a group are mutually exclusive, which means you can only include one of each group in any given call.

    If there are multiple groups at one level in the object hierarchy we use numbers to distinguish groups from one another.

close

Description

The GlobalCollect gateway identifier. You should use this when creating a tokenization specification.
close

Description

The networks that can be used in the current payment context. The strings that represent the networks in the array are identical to the strings that Google uses in their documentation. For instance: "VISA".
close

Description

WeChat Pay (payment product 863) specific details.
  • SDK Object type
    PaymentProduct863SpecificData
  • Property is part of a group
    Learn more

    Properties that make up a group are mutually exclusive, which means you can only include one of each group in any given call.

    If there are multiple groups at one level in the object hierarchy we use numbers to distinguish groups from one another.

close

Description

The WeChat Pay integration types that can be used in the current payment context. Possible values:
  • desktopQRCode - used on desktops, the customer opens the WeChat app by scanning a QR code.
  • urlIntent - used in mobile apps or on mobile web pages, the customer opens the WeChat app using a URL intent.
  • nativeInApp - used in mobile apps that use the WeChat Pay SDK.
close

Description

The payment product group that has this payment product, if there is any. Not populated otherwise. Currently only one payment product group is supported:
  • cards
close

Description

Indicates whether the payment product supports mandates.
close

Description

Indicates whether the payment product requires redirection to a third party to complete the payment. You can use this to filter out products that require a redirect if you don't want to support that.
  • true - Redirection is required
  • false - No redirection is required

Response example

SDK: iOS

This scenario you will probably use the most

  • {
        "allowsRecurring" : true,
        "allowsTokenization" : true,
        "displayHints" : {
            "displayOrder" : 20,
            "label" : "Visa",
            "logo" : "/templates/master/global/css/img/ppimages/pp_logo_1_v1.png"
        },
        "fields" : [
            {
                "dataRestrictions" : {
                    "isRequired" : true,
                    "validators" : {
                        "length" : {
                            "maxLength" : 19,
                            "minLength" : 12
                        },
                        "luhn" : { }
                    }
                },
                "displayHints" : {
                    "displayOrder" : 10,
                    "formElement" : {
                        "type" : "text"
                    },
                    "label" : "Card number:",
                    "mask" : "{{9999}} {{9999}} {{9999}} {{9999}} {{999}}",
                    "obfuscate" : false,
                    "placeholderLabel" : "**** **** **** ****",
                    "preferredInputType" : "IntegerKeyboard"
                },
                "id" : "cardNumber",
                "type" : "numericstring"
            },
            {
                "dataRestrictions" : {
                    "isRequired" : true,
                    "validators" : {
                        "expirationDate" : { },
                        "length" : {
                            "maxLength" : 4,
                            "minLength" : 4
                        },
                        "regularExpression" : {
                            "regularExpression" : "(?:0[1-9]|1[0-2])[0-9]{2}"
                        }
                    }
                },
                "displayHints" : {
                    "displayOrder" : 20,
                    "formElement" : {
                        "type" : "text"
                    },
                    "label" : "Expiry date:",
                    "mask" : "{{99}}/{{99}}",
                    "obfuscate" : false,
                    "placeholderLabel" : "MM/YY",
                    "preferredInputType" : "IntegerKeyboard"
                },
                "id" : "expiryDate",
                "type" : "expirydate"
            },
            {
                "dataRestrictions" : {
                    "isRequired" : false,
                    "validators" : {
                        "length" : {
                            "maxLength" : 4,
                            "minLength" : 3
                        },
                        "regularExpression" : {
                            "regularExpression" : "^[0-9]{3}[0-9]?$"
                        }
                    }
                },
                "displayHints" : {
                    "displayOrder" : 24,
                    "formElement" : {
                        "type" : "text"
                    },
                    "label" : "CVV:",
                    "mask" : "{{9999}}",
                    "obfuscate" : false,
                    "placeholderLabel" : "123",
                    "preferredInputType" : "IntegerKeyboard",
                    "tooltip" : {
                        "image" : "/templates/master/global/css/img/ppimages/ppf_cvv_v1.png",
                        "label" : "The CVV is a 3 or 4 digit code embossed or imprinted on your card."
                    }
                },
                "id" : "cvv",
                "type" : "numericstring"
            }
        ],
        "id" : 1,
        "maxAmount" : 1000000,
        "mobileIntegrationLevel" : "OPTIMISED_SUPPORT",
        "paymentMethod" : "card",
        "paymentProductGroup" : "cards"
    }
    

Response 400 - Bad requestErrorResponse

There was an error in the request, or the paymentProductId you submitted does not exist or does not meet the filters you submitted.

Properties
Property Type Required Details
close

Description

Unique reference, for debugging purposes, of this error response
close

Description

List of one or more errors
close
  • SDK Object type
    APIError
close

Description

Category the error belongs to. The category should give an indication of the type of error you are dealing with. Possible values:
  • CONNECT\_PLATFORM\_ERROR - indicating that a functional error has occurred in the Connect platform.
  • PAYMENT\_PLATFORM\_ERROR - indicating that a functional error has occurred in the Payment platform.
  • IO\_ERROR - indicating that a technical error has occurred within the Connect platform or between Connect and any of the payment platforms or third party systems.
close

Description

Error code
close

Description

HTTP status code for this error that can be used to determine the type of error
close

Description

ID of the error. This is a short human-readable message that briefly describes the error.
close

Description

Human-readable error message that is not meant to be relayed to customer as it might tip off people who are trying to commit fraud
close

Description

Returned only if the error relates to a value that was missing or incorrect.
Contains a location path to the value as a JSonata query.
Some common examples:
  • a.b selects the value of property b of root property a,
  • a[1] selects the first element of the array in root property a,
  • a[b='some value'] selects all elements of the array in root property a that have a property b with value 'some value'.
close

Description

ID of the request that can be used for debugging purposes

Response example

SDK: iOS

This scenario you will probably use the most

  • {
        "errorId" : "657b10da-d2f9-4088-a948-bf190ef516b1-00000213",
        "errors" : [
            {
                "code" : "1070",
                "message" : "UNKNOWN_PAYMENT_PRODUCT_ID"
            }
        ]
    }