You can use the APIs below to interface with Xendit's PaymentMethodApi
.
To start using the API, you need to configure the secret key and initiate the client instance.
import time
import xendit
from xendit.apis import PaymentMethodApi
# See configuration.py for a list of all supported configuration parameters.
xendit.set_api_key('XENDIT API KEY')
# Enter a context with an instance of the API client
api_client = xendit.ApiClient()
# Create an instance of the API class
api_instance = PaymentMethodApi(api_client)
All URIs are relative to https://api.xendit.co
Method | HTTP request | Description |
---|---|---|
create_payment_method | POST /v2/payment_methods | Creates payment method |
get_payment_method_by_id | GET /v2/payment_methods/{paymentMethodId} | Get payment method by ID |
get_payments_by_payment_method_id | GET /v2/payment_methods/{paymentMethodId}/payments | Returns payments with matching PaymentMethodID. |
patch_payment_method | PATCH /v2/payment_methods/{paymentMethodId} | Patch payment methods |
get_all_payment_methods | GET /v2/payment_methods | Get all payment methods by filters |
expire_payment_method | POST /v2/payment_methods/{paymentMethodId}/expire | Expires a payment method |
auth_payment_method | POST /v2/payment_methods/{paymentMethodId}/auth | Validate a payment method's linking OTP |
simulate_payment | POST /v2/payment_methods/{paymentMethodId}/payments/simulate | Makes payment with matching PaymentMethodID. |
PaymentMethod create_payment_method()
Creates payment method
Name | Value |
---|---|
Function Name | create_payment_method |
Request Parameters | CreatePaymentMethodRequestParams |
Return Type | PaymentMethod |
Name | Type | Required | Default |
---|---|---|---|
for_user_id | str | ||
payment_method_parameters | PaymentMethodParameters |
import time
import xendit
from xendit.apis import PaymentMethodApi
from xendit.payment_method.model.get_all_payment_methods403_response import GetAllPaymentMethods403Response
from xendit.payment_method.model.get_all_payment_methods400_response import GetAllPaymentMethods400Response
from xendit.payment_method.model.get_all_payment_methods404_response import GetAllPaymentMethods404Response
from xendit.payment_method.model.create_payment_method503_response import CreatePaymentMethod503Response
from xendit.payment_method.model.payment_method_parameters import PaymentMethodParameters
from xendit.payment_method.model.payment_method import PaymentMethod
from xendit.payment_method.model.create_payment_method409_response import CreatePaymentMethod409Response
from xendit.payment_method.model.get_all_payment_methods_default_response import GetAllPaymentMethodsDefaultResponse
from pprint import pprint
# See configuration.py for a list of all supported configuration parameters.
xendit.set_api_key('XENDIT API KEY')
# Enter a context with an instance of the API client
api_client = xendit.ApiClient()
# Create an instance of the API class
api_instance = PaymentMethodApi(api_client)
for_user_id = "5f9a3fbd571a1c4068aa40cf" # str
payment_method_parameters = {
"type" : "EWALLET",
"reusability" : "MULTIPLE_USE",
"customer" : {
"reference_id" : "customer-123",
"type" : "INDIVIDUAL",
"individual_detail" : {
"given_names" : "John",
"surname" : "Doe"
}
},
"ewallet" : {
"channel_code" : "OVO",
"channel_properties" : {
"success_return_url" : "https://redirect.me/success",
"failure_return_url" : "https://redirect.me/failure",
"cancel_return_url" : "https://redirect.me/cancel"
}
},
"metadata" : {
"sku" : "example-1234"
}
} # PaymentMethodParameters
# example passing only required values which don't have defaults set
# and optional values
try:
# Creates payment method
api_response = api_instance.create_payment_method(for_user_id=for_user_id, payment_method_parameters=payment_method_parameters)
pprint(api_response)
except xendit.XenditSdkException as e:
print("Exception when calling PaymentMethodApi->create_payment_method: %s\n" % e)
import time
import xendit
from xendit.apis import PaymentMethodApi
from xendit.payment_method.model.get_all_payment_methods403_response import GetAllPaymentMethods403Response
from xendit.payment_method.model.get_all_payment_methods400_response import GetAllPaymentMethods400Response
from xendit.payment_method.model.get_all_payment_methods404_response import GetAllPaymentMethods404Response
from xendit.payment_method.model.create_payment_method503_response import CreatePaymentMethod503Response
from xendit.payment_method.model.payment_method_parameters import PaymentMethodParameters
from xendit.payment_method.model.payment_method import PaymentMethod
from xendit.payment_method.model.create_payment_method409_response import CreatePaymentMethod409Response
from xendit.payment_method.model.get_all_payment_methods_default_response import GetAllPaymentMethodsDefaultResponse
from pprint import pprint
# See configuration.py for a list of all supported configuration parameters.
xendit.set_api_key('XENDIT API KEY')
# Enter a context with an instance of the API client
api_client = xendit.ApiClient()
# Create an instance of the API class
api_instance = PaymentMethodApi(api_client)
for_user_id = "5f9a3fbd571a1c4068aa40cf" # str
payment_method_parameters = {
"type" : "DIRECT_DEBIT",
"direct_debit" : {
"channel_code" : "BPI",
"channel_properties" : {
"success_return_url" : "https://redirect.me/success",
"failure_return_url" : "https://redirect.me/failure"
}
},
"reusability" : "MULTIPLE_USE",
"customer" : {
"reference_id" : "customer-123",
"type" : "INDIVIDUAL",
"individual_detail" : {
"given_names" : "John",
"surname" : "Doe"
}
},
"email" : "[email protected]",
"mobile_number" : 628774494404
} # PaymentMethodParameters
# example passing only required values which don't have defaults set
# and optional values
try:
# Creates payment method
api_response = api_instance.create_payment_method(for_user_id=for_user_id, payment_method_parameters=payment_method_parameters)
pprint(api_response)
except xendit.XenditSdkException as e:
print("Exception when calling PaymentMethodApi->create_payment_method: %s\n" % e)
PaymentMethod get_payment_method_by_id(payment_method_id)
Get payment method by ID
Name | Value |
---|---|
Function Name | get_payment_method_by_id |
Request Parameters | GetPaymentMethodByIdRequestParams |
Return Type | PaymentMethod |
Name | Type | Required | Default |
---|---|---|---|
payment_method_id | str | ☑️ | |
for_user_id | str |
import time
import xendit
from xendit.apis import PaymentMethodApi
from xendit.payment_method.model.get_all_payment_methods403_response import GetAllPaymentMethods403Response
from xendit.payment_method.model.get_all_payment_methods400_response import GetAllPaymentMethods400Response
from xendit.payment_method.model.get_all_payment_methods404_response import GetAllPaymentMethods404Response
from xendit.payment_method.model.payment_method import PaymentMethod
from xendit.payment_method.model.get_all_payment_methods_default_response import GetAllPaymentMethodsDefaultResponse
from pprint import pprint
# See configuration.py for a list of all supported configuration parameters.
xendit.set_api_key('XENDIT API KEY')
# Enter a context with an instance of the API client
api_client = xendit.ApiClient()
# Create an instance of the API class
api_instance = PaymentMethodApi(api_client)
payment_method_id = "pm-1fdaf346-dd2e-4b6c-b938-124c7167a822" # str
for_user_id = "5f9a3fbd571a1c4068aa40cf" # str
# example passing only required values which don't have defaults set
try:
# Get payment method by ID
api_response = api_instance.get_payment_method_by_id(payment_method_id)
pprint(api_response)
except xendit.XenditSdkException as e:
print("Exception when calling PaymentMethodApi->get_payment_method_by_id: %s\n" % e)
# example passing only required values which don't have defaults set
# and optional values
try:
# Get payment method by ID
api_response = api_instance.get_payment_method_by_id(payment_method_id, for_user_id=for_user_id)
pprint(api_response)
except xendit.XenditSdkException as e:
print("Exception when calling PaymentMethodApi->get_payment_method_by_id: %s\n" % e)
{str: (bool, date, datetime, dict, float, int, list, str, none_type)} get_payments_by_payment_method_id(payment_method_id)
Returns payments with matching PaymentMethodID.
Name | Value |
---|---|
Function Name | get_payments_by_payment_method_id |
Request Parameters | GetPaymentsByPaymentMethodIdRequestParams |
Return Type | {str: (bool, date, datetime, dict, float, int, list, str, none_type)} |
Name | Type | Required | Default |
---|---|---|---|
payment_method_id | str | ☑️ | |
for_user_id | str | ||
payment_request_id | [str] | ||
payment_method_id2 | [str] | ||
reference_id | [str] | ||
payment_method_type | [PaymentMethodType] | ||
channel_code | [str] | ||
status | [str] | ||
currency | [str] | ||
created_gte | datetime | ||
created_lte | datetime | ||
updated_gte | datetime | ||
updated_lte | datetime | ||
limit | int |
import time
import xendit
from xendit.apis import PaymentMethodApi
from xendit.payment_method.model.get_all_payment_methods403_response import GetAllPaymentMethods403Response
from xendit.payment_method.model.get_all_payment_methods400_response import GetAllPaymentMethods400Response
from xendit.payment_method.model.get_all_payment_methods404_response import GetAllPaymentMethods404Response
from xendit.payment_method.model.create_payment_method503_response import CreatePaymentMethod503Response
from xendit.payment_method.model.payment_method_type import PaymentMethodType
from xendit.payment_method.model.get_all_payment_methods_default_response import GetAllPaymentMethodsDefaultResponse
from pprint import pprint
# See configuration.py for a list of all supported configuration parameters.
xendit.set_api_key('XENDIT API KEY')
# Enter a context with an instance of the API client
api_client = xendit.ApiClient()
# Create an instance of the API class
api_instance = PaymentMethodApi(api_client)
payment_method_id = "pm-1fdaf346-dd2e-4b6c-b938-124c7167a822" # str
for_user_id = "5f9a3fbd571a1c4068aa40cf" # str
payment_request_id = [
"payment_request_id_example",
] # [str]
payment_method_id2 = [
"payment_method_id_example",
] # [str]
reference_id = [
"reference_id_example",
] # [str]
payment_method_type = [
PaymentMethodType("CARD"),
] # [PaymentMethodType]
channel_code = [
"channel_code_example",
] # [str]
status = [
"status_example",
] # [str]
currency = [
"currency_example",
] # [str]
created_gte = dateutil_parser('2016-08-29T09:12:33.001Z') # datetime
created_lte = dateutil_parser('2016-08-29T09:12:33.001Z') # datetime
updated_gte = dateutil_parser('2016-08-29T09:12:33.001Z') # datetime
updated_lte = dateutil_parser('2016-08-29T09:12:33.001Z') # datetime
limit = 1 # int
# example passing only required values which don't have defaults set
try:
# Returns payments with matching PaymentMethodID.
api_response = api_instance.get_payments_by_payment_method_id(payment_method_id)
pprint(api_response)
except xendit.XenditSdkException as e:
print("Exception when calling PaymentMethodApi->get_payments_by_payment_method_id: %s\n" % e)
# example passing only required values which don't have defaults set
# and optional values
try:
# Returns payments with matching PaymentMethodID.
api_response = api_instance.get_payments_by_payment_method_id(payment_method_id, for_user_id=for_user_id, payment_request_id=payment_request_id, payment_method_id2=payment_method_id2, reference_id=reference_id, payment_method_type=payment_method_type, channel_code=channel_code, status=status, currency=currency, created_gte=created_gte, created_lte=created_lte, updated_gte=updated_gte, updated_lte=updated_lte, limit=limit)
pprint(api_response)
except xendit.XenditSdkException as e:
print("Exception when calling PaymentMethodApi->get_payments_by_payment_method_id: %s\n" % e)
PaymentMethod patch_payment_method(payment_method_id)
Patch payment methods
Name | Value |
---|---|
Function Name | patch_payment_method |
Request Parameters | PatchPaymentMethodRequestParams |
Return Type | PaymentMethod |
Name | Type | Required | Default |
---|---|---|---|
payment_method_id | str | ☑️ | |
for_user_id | str | ||
payment_method_update_parameters | PaymentMethodUpdateParameters |
import time
import xendit
from xendit.apis import PaymentMethodApi
from xendit.payment_method.model.get_all_payment_methods403_response import GetAllPaymentMethods403Response
from xendit.payment_method.model.get_all_payment_methods400_response import GetAllPaymentMethods400Response
from xendit.payment_method.model.get_all_payment_methods404_response import GetAllPaymentMethods404Response
from xendit.payment_method.model.payment_method import PaymentMethod
from xendit.payment_method.model.payment_method_update_parameters import PaymentMethodUpdateParameters
from xendit.payment_method.model.get_all_payment_methods_default_response import GetAllPaymentMethodsDefaultResponse
from pprint import pprint
# See configuration.py for a list of all supported configuration parameters.
xendit.set_api_key('XENDIT API KEY')
# Enter a context with an instance of the API client
api_client = xendit.ApiClient()
# Create an instance of the API class
api_instance = PaymentMethodApi(api_client)
payment_method_id = "pm-1fdaf346-dd2e-4b6c-b938-124c7167a822" # str
for_user_id = "5f9a3fbd571a1c4068aa40cf" # str
payment_method_update_parameters = PaymentMethodUpdateParameters(
description="description_example",
reference_id="reference_id_example",
reusability=PaymentMethodReusability("MULTIPLE_USE"),
status=PaymentMethodStatus("ACTIVE"),
over_the_counter=OverTheCounterUpdateParameters(
amount=3.14,
channel_properties=OverTheCounterChannelPropertiesUpdate(
customer_name="Rika Sutanto",
expires_at=dateutil_parser('2022-01-01T00:00:00Z'),
),
),
virtual_account=VirtualAccountUpdateParameters(
amount=3.14,
min_amount=1,
max_amount=1,
channel_properties=VirtualAccountChannelPropertiesPatch(
expires_at=dateutil_parser('2022-01-01T00:00:00Z'),
suggested_amount=100000,
),
alternative_display_types=[
"QR_STRING",
],
),
) # PaymentMethodUpdateParameters
# example passing only required values which don't have defaults set
try:
# Patch payment methods
api_response = api_instance.patch_payment_method(payment_method_id)
pprint(api_response)
except xendit.XenditSdkException as e:
print("Exception when calling PaymentMethodApi->patch_payment_method: %s\n" % e)
# example passing only required values which don't have defaults set
# and optional values
try:
# Patch payment methods
api_response = api_instance.patch_payment_method(payment_method_id, for_user_id=for_user_id, payment_method_update_parameters=payment_method_update_parameters)
pprint(api_response)
except xendit.XenditSdkException as e:
print("Exception when calling PaymentMethodApi->patch_payment_method: %s\n" % e)
PaymentMethodList get_all_payment_methods()
Get all payment methods by filters
Name | Value |
---|---|
Function Name | get_all_payment_methods |
Request Parameters | GetAllPaymentMethodsRequestParams |
Return Type | PaymentMethodList |
Name | Type | Required | Default |
---|---|---|---|
for_user_id | str | ||
id | [str] | ||
type | [str] | ||
status | [PaymentMethodStatus] | ||
reusability | PaymentMethodReusability | ||
customer_id | str | ||
reference_id | str | ||
after_id | str | ||
before_id | str | ||
limit | int |
import time
import xendit
from xendit.apis import PaymentMethodApi
from xendit.payment_method.model.get_all_payment_methods403_response import GetAllPaymentMethods403Response
from xendit.payment_method.model.payment_method_status import PaymentMethodStatus
from xendit.payment_method.model.payment_method_reusability import PaymentMethodReusability
from xendit.payment_method.model.get_all_payment_methods400_response import GetAllPaymentMethods400Response
from xendit.payment_method.model.get_all_payment_methods404_response import GetAllPaymentMethods404Response
from xendit.payment_method.model.get_all_payment_methods_default_response import GetAllPaymentMethodsDefaultResponse
from xendit.payment_method.model.payment_method_list import PaymentMethodList
from pprint import pprint
# See configuration.py for a list of all supported configuration parameters.
xendit.set_api_key('XENDIT API KEY')
# Enter a context with an instance of the API client
api_client = xendit.ApiClient()
# Create an instance of the API class
api_instance = PaymentMethodApi(api_client)
for_user_id = "5f9a3fbd571a1c4068aa40cf" # str
id = [
"id_example",
] # [str]
type = [
"type_example",
] # [str]
status = [
PaymentMethodStatus("ACTIVE"),
] # [PaymentMethodStatus]
reusability = PaymentMethodReusability("MULTIPLE_USE") # PaymentMethodReusability
customer_id = "customer_id_example" # str
reference_id = "reference_id_example" # str
after_id = "after_id_example" # str
before_id = "before_id_example" # str
limit = 1 # int
# example passing only required values which don't have defaults set
# and optional values
try:
# Get all payment methods by filters
api_response = api_instance.get_all_payment_methods(for_user_id=for_user_id, id=id, type=type, status=status, reusability=reusability, customer_id=customer_id, reference_id=reference_id, after_id=after_id, before_id=before_id, limit=limit)
pprint(api_response)
except xendit.XenditSdkException as e:
print("Exception when calling PaymentMethodApi->get_all_payment_methods: %s\n" % e)
PaymentMethod expire_payment_method(payment_method_id)
Expires a payment method
Name | Value |
---|---|
Function Name | expire_payment_method |
Request Parameters | ExpirePaymentMethodRequestParams |
Return Type | PaymentMethod |
Name | Type | Required | Default |
---|---|---|---|
payment_method_id | str | ☑️ | |
for_user_id | str | ||
payment_method_expire_parameters | PaymentMethodExpireParameters |
import time
import xendit
from xendit.apis import PaymentMethodApi
from xendit.payment_method.model.get_all_payment_methods403_response import GetAllPaymentMethods403Response
from xendit.payment_method.model.get_all_payment_methods400_response import GetAllPaymentMethods400Response
from xendit.payment_method.model.get_all_payment_methods404_response import GetAllPaymentMethods404Response
from xendit.payment_method.model.create_payment_method503_response import CreatePaymentMethod503Response
from xendit.payment_method.model.payment_method import PaymentMethod
from xendit.payment_method.model.get_all_payment_methods_default_response import GetAllPaymentMethodsDefaultResponse
from xendit.payment_method.model.payment_method_expire_parameters import PaymentMethodExpireParameters
from pprint import pprint
# See configuration.py for a list of all supported configuration parameters.
xendit.set_api_key('XENDIT API KEY')
# Enter a context with an instance of the API client
api_client = xendit.ApiClient()
# Create an instance of the API class
api_instance = PaymentMethodApi(api_client)
payment_method_id = "pm-1fdaf346-dd2e-4b6c-b938-124c7167a822" # str
for_user_id = "5f9a3fbd571a1c4068aa40cf" # str
payment_method_expire_parameters = PaymentMethodExpireParameters(
success_return_url="success_return_url_example",
failure_return_url="failure_return_url_example",
) # PaymentMethodExpireParameters
# example passing only required values which don't have defaults set
try:
# Expires a payment method
api_response = api_instance.expire_payment_method(payment_method_id)
pprint(api_response)
except xendit.XenditSdkException as e:
print("Exception when calling PaymentMethodApi->expire_payment_method: %s\n" % e)
# example passing only required values which don't have defaults set
# and optional values
try:
# Expires a payment method
api_response = api_instance.expire_payment_method(payment_method_id, for_user_id=for_user_id, payment_method_expire_parameters=payment_method_expire_parameters)
pprint(api_response)
except xendit.XenditSdkException as e:
print("Exception when calling PaymentMethodApi->expire_payment_method: %s\n" % e)
PaymentMethod auth_payment_method(payment_method_id)
Validate a payment method's linking OTP
Name | Value |
---|---|
Function Name | auth_payment_method |
Request Parameters | AuthPaymentMethodRequestParams |
Return Type | PaymentMethod |
Name | Type | Required | Default |
---|---|---|---|
payment_method_id | str | ☑️ | |
for_user_id | str | ||
payment_method_auth_parameters | PaymentMethodAuthParameters |
import time
import xendit
from xendit.apis import PaymentMethodApi
from xendit.payment_method.model.get_all_payment_methods403_response import GetAllPaymentMethods403Response
from xendit.payment_method.model.get_all_payment_methods400_response import GetAllPaymentMethods400Response
from xendit.payment_method.model.get_all_payment_methods404_response import GetAllPaymentMethods404Response
from xendit.payment_method.model.create_payment_method503_response import CreatePaymentMethod503Response
from xendit.payment_method.model.payment_method import PaymentMethod
from xendit.payment_method.model.create_payment_method409_response import CreatePaymentMethod409Response
from xendit.payment_method.model.payment_method_auth_parameters import PaymentMethodAuthParameters
from xendit.payment_method.model.get_all_payment_methods_default_response import GetAllPaymentMethodsDefaultResponse
from pprint import pprint
# See configuration.py for a list of all supported configuration parameters.
xendit.set_api_key('XENDIT API KEY')
# Enter a context with an instance of the API client
api_client = xendit.ApiClient()
# Create an instance of the API class
api_instance = PaymentMethodApi(api_client)
payment_method_id = "pm-1fdaf346-dd2e-4b6c-b938-124c7167a822" # str
for_user_id = "5f9a3fbd571a1c4068aa40cf" # str
payment_method_auth_parameters = PaymentMethodAuthParameters(
auth_code="auth_code_example",
) # PaymentMethodAuthParameters
# example passing only required values which don't have defaults set
try:
# Validate a payment method's linking OTP
api_response = api_instance.auth_payment_method(payment_method_id)
pprint(api_response)
except xendit.XenditSdkException as e:
print("Exception when calling PaymentMethodApi->auth_payment_method: %s\n" % e)
# example passing only required values which don't have defaults set
# and optional values
try:
# Validate a payment method's linking OTP
api_response = api_instance.auth_payment_method(payment_method_id, for_user_id=for_user_id, payment_method_auth_parameters=payment_method_auth_parameters)
pprint(api_response)
except xendit.XenditSdkException as e:
print("Exception when calling PaymentMethodApi->auth_payment_method: %s\n" % e)
simulate_payment(payment_method_id)
Makes payment with matching PaymentMethodID.
Name | Value |
---|---|
Function Name | simulate_payment |
Request Parameters | SimulatePaymentRequestParams |
Return Type | void (empty response body) |
Name | Type | Required | Default |
---|---|---|---|
payment_method_id | str | ☑️ | |
simulate_payment_request | SimulatePaymentRequest |
import time
import xendit
from xendit.apis import PaymentMethodApi
from xendit.payment_method.model.get_all_payment_methods403_response import GetAllPaymentMethods403Response
from xendit.payment_method.model.get_all_payment_methods400_response import GetAllPaymentMethods400Response
from xendit.payment_method.model.get_all_payment_methods404_response import GetAllPaymentMethods404Response
from xendit.payment_method.model.create_payment_method503_response import CreatePaymentMethod503Response
from xendit.payment_method.model.simulate_payment_request import SimulatePaymentRequest
from xendit.payment_method.model.get_all_payment_methods_default_response import GetAllPaymentMethodsDefaultResponse
from pprint import pprint
# See configuration.py for a list of all supported configuration parameters.
xendit.set_api_key('XENDIT API KEY')
# Enter a context with an instance of the API client
api_client = xendit.ApiClient()
# Create an instance of the API class
api_instance = PaymentMethodApi(api_client)
payment_method_id = "pm-1fdaf346-dd2e-4b6c-b938-124c7167a822" # str
simulate_payment_request = SimulatePaymentRequest(
amount=3.14,
) # SimulatePaymentRequest
# example passing only required values which don't have defaults set
try:
# Makes payment with matching PaymentMethodID.
api_instance.simulate_payment(payment_method_id)
except xendit.XenditSdkException as e:
print("Exception when calling PaymentMethodApi->simulate_payment: %s\n" % e)
# example passing only required values which don't have defaults set
# and optional values
try:
# Makes payment with matching PaymentMethodID.
api_instance.simulate_payment(payment_method_id, simulate_payment_request=simulate_payment_request)
except xendit.XenditSdkException as e:
print("Exception when calling PaymentMethodApi->simulate_payment: %s\n" % e)
Use the following callback objects provided by Xendit to receive callbacks (also known as webhooks) that Xendit sends you on events, such as successful payments. Note that the example is meant to illustrate the contents of the callback object -- you will not need to instantiate these objects in practice
Callback for active or expired E-Wallet or Direct Debit account linking, Virtual Accounts or QR strings
Model Documentation: PaymentMethodCallback
Note that the example is meant to illustrate the contents of the callback object -- you will not need to instantiate these objects in practice
import xendit
from xendit.payment_method.model import PaymentMethodCallback
import json
from pprint import pprint
payment_method_callback_obj = {
"event" : "payment_method.activated",
"data" : {
"id" : "pm-6ff0b6f2-f5de-457f-b08f-bc98fbae485a",
"card" : null,
"type" : "DIRECT_DEBIT",
"status" : "ACTIVE",
"country" : "PH",
"created" : "2022-08-12T13:30:26.579048Z",
"ewallet" : null,
"qr_code" : null,
"updated" : "2022-08-12T13:30:58.908220358Z",
"metadata" : null,
"customer_id" : "e2878b4c-d57e-4a2c-922d-c0313c2800a3",
"description" : null,
"reusability" : "MULTIPLE_USE",
"direct_debit" : {
"type" : "BANK_ACCOUNT",
"debit_card" : null,
"bank_account" : {
"bank_account_hash" : "b4dfa99c9b60c77f2e3962b73c098945",
"masked_bank_account_number" : "XXXXXX1234"
},
"channel_code" : "BPI",
"channel_properties" : {
"failure_return_url" : "https://your-redirect-website.com/failure",
"success_return_url" : "https://your-redirect-website.com/success"
}
},
"failure_code" : null,
"reference_id" : "620b9df4-fe69-4bfd-b9d4-5cba6861db8a",
"virtual_account" : null,
"over_the_counter" : null,
"billing_information" : null,
"direct_bank_transfer" : null
},
"created" : "2022-08-12T13:30:59.074277334Z",
"business_id" : "5f27a14a9bf05c73dd040bc8"
}
payment_method_callback_json = json.dumps(payment_method_callback_obj)
You may then use the callback object in your webhook or callback handler like so,
def SimulatePaymentMethodCallback(payment_method_callback_json) {
callback_obj = PaymentMethodCallback(**json.loads(payment_method_callback_json))
// do things here with the callback
}