Source code for worldline.acquiring.sdk.v1.domain.api_refund_response
# -*- coding: utf-8 -*-
#
# This file was automatically generated.
#
from datetime import datetime
from typing import List, Optional
from .amount_data import AmountData
from .api_references_for_responses import ApiReferencesForResponses
from .card_payment_data_for_resource import CardPaymentDataForResource
from .emv_data_item import EmvDataItem
from worldline.acquiring.sdk.domain.data_object import DataObject
[docs]
class ApiRefundResponse(DataObject):
__authorization_code: Optional[str] = None
__card_payment_data: Optional[CardPaymentDataForResource] = None
__emv_data: Optional[List[EmvDataItem]] = None
__operation_id: Optional[str] = None
__referenced_payment_id: Optional[str] = None
__references: Optional[ApiReferencesForResponses] = None
__refund_id: Optional[str] = None
__responder: Optional[str] = None
__response_code: Optional[str] = None
__response_code_category: Optional[str] = None
__response_code_description: Optional[str] = None
__retry_after: Optional[str] = None
__status: Optional[str] = None
__status_timestamp: Optional[datetime] = None
__total_authorized_amount: Optional[AmountData] = None
@property
def authorization_code(self) -> Optional[str]:
"""
| Authorization approval code
Type: str
"""
return self.__authorization_code
@authorization_code.setter
def authorization_code(self, value: Optional[str]) -> None:
self.__authorization_code = value
@property
def card_payment_data(self) -> Optional[CardPaymentDataForResource]:
"""
Type: :class:`worldline.acquiring.sdk.v1.domain.card_payment_data_for_resource.CardPaymentDataForResource`
"""
return self.__card_payment_data
@card_payment_data.setter
def card_payment_data(self, value: Optional[CardPaymentDataForResource]) -> None:
self.__card_payment_data = value
@property
def emv_data(self) -> Optional[List[EmvDataItem]]:
"""
| EMV data of the card as tag/value pairs. It is needed when cardEntryMode is CHIP or CONTACTLESS.
Type: list[:class:`worldline.acquiring.sdk.v1.domain.emv_data_item.EmvDataItem`]
"""
return self.__emv_data
@emv_data.setter
def emv_data(self, value: Optional[List[EmvDataItem]]) -> None:
self.__emv_data = value
@property
def operation_id(self) -> Optional[str]:
"""
| A globally unique identifier of the operation, generated by you.
| We advise you to submit a UUID or an identifier composed of an arbitrary string and a UUID/URL-safe Base64 UUID (RFC 4648 ยง5).
| It's used to detect duplicate requests or to reference an operation in technical reversals.
Type: str
"""
return self.__operation_id
@operation_id.setter
def operation_id(self, value: Optional[str]) -> None:
self.__operation_id = value
@property
def referenced_payment_id(self) -> Optional[str]:
"""
| The identifier of the payment referenced by this refund.
Type: str
"""
return self.__referenced_payment_id
@referenced_payment_id.setter
def referenced_payment_id(self, value: Optional[str]) -> None:
self.__referenced_payment_id = value
@property
def references(self) -> Optional[ApiReferencesForResponses]:
"""
| A set of references returned in responses
Type: :class:`worldline.acquiring.sdk.v1.domain.api_references_for_responses.ApiReferencesForResponses`
"""
return self.__references
@references.setter
def references(self, value: Optional[ApiReferencesForResponses]) -> None:
self.__references = value
@property
def refund_id(self) -> Optional[str]:
"""
| the ID of the refund
Type: str
"""
return self.__refund_id
@refund_id.setter
def refund_id(self, value: Optional[str]) -> None:
self.__refund_id = value
@property
def responder(self) -> Optional[str]:
"""
| The party that originated the response Possible values are:
* WORLDLINE
* ISSUER
* SCHEME
* PARTNER
Type: str
"""
return self.__responder
@responder.setter
def responder(self, value: Optional[str]) -> None:
self.__responder = value
@property
def response_code(self) -> Optional[str]:
"""
| Numeric response code, e.g. 0000, 0005
Type: str
"""
return self.__response_code
@response_code.setter
def response_code(self, value: Optional[str]) -> None:
self.__response_code = value
@property
def response_code_category(self) -> Optional[str]:
"""
| Category of response code.
| Possible values are:
* APPROVED
* PARTIALLY_APPROVED
* DECLINED
Type: str
"""
return self.__response_code_category
@response_code_category.setter
def response_code_category(self, value: Optional[str]) -> None:
self.__response_code_category = value
@property
def response_code_description(self) -> Optional[str]:
"""
| Description of the response code
Type: str
"""
return self.__response_code_description
@response_code_description.setter
def response_code_description(self, value: Optional[str]) -> None:
self.__response_code_description = value
@property
def retry_after(self) -> Optional[str]:
"""
| The duration to wait after the initial submission before retrying the payment.
| Expressed using ISO 8601 duration format, ex: PT2H for 2 hours.
| This field is only present when the payment can be retried later.
| PT0 means that the payment can be retried immediately.
Type: str
"""
return self.__retry_after
@retry_after.setter
def retry_after(self, value: Optional[str]) -> None:
self.__retry_after = value
@property
def status(self) -> Optional[str]:
"""
| The status of the payment, refund or credit transfer
| Possible values are:
* AUTHORIZED
* NOT_AUTHORIZED
* PENDING
* PENDING_CAPTURE
* CONFIRMED
* REVERSED
* CANCELLED
Type: str
"""
return self.__status
@status.setter
def status(self, value: Optional[str]) -> None:
self.__status = value
@property
def status_timestamp(self) -> Optional[datetime]:
"""
| Timestamp of the status in format yyyy-MM-ddTHH:mm:ssZ
Type: datetime
"""
return self.__status_timestamp
@status_timestamp.setter
def status_timestamp(self, value: Optional[datetime]) -> None:
self.__status_timestamp = value
@property
def total_authorized_amount(self) -> Optional[AmountData]:
"""
| Amount for the operation.
Type: :class:`worldline.acquiring.sdk.v1.domain.amount_data.AmountData`
"""
return self.__total_authorized_amount
@total_authorized_amount.setter
def total_authorized_amount(self, value: Optional[AmountData]) -> None:
self.__total_authorized_amount = value
[docs]
def to_dictionary(self) -> dict:
dictionary = super(ApiRefundResponse, self).to_dictionary()
if self.authorization_code is not None:
dictionary['authorizationCode'] = self.authorization_code
if self.card_payment_data is not None:
dictionary['cardPaymentData'] = self.card_payment_data.to_dictionary()
if self.emv_data is not None:
dictionary['emvData'] = []
for element in self.emv_data:
if element is not None:
dictionary['emvData'].append(element.to_dictionary())
if self.operation_id is not None:
dictionary['operationId'] = self.operation_id
if self.referenced_payment_id is not None:
dictionary['referencedPaymentId'] = self.referenced_payment_id
if self.references is not None:
dictionary['references'] = self.references.to_dictionary()
if self.refund_id is not None:
dictionary['refundId'] = self.refund_id
if self.responder is not None:
dictionary['responder'] = self.responder
if self.response_code is not None:
dictionary['responseCode'] = self.response_code
if self.response_code_category is not None:
dictionary['responseCodeCategory'] = self.response_code_category
if self.response_code_description is not None:
dictionary['responseCodeDescription'] = self.response_code_description
if self.retry_after is not None:
dictionary['retryAfter'] = self.retry_after
if self.status is not None:
dictionary['status'] = self.status
if self.status_timestamp is not None:
dictionary['statusTimestamp'] = DataObject.format_datetime(self.status_timestamp)
if self.total_authorized_amount is not None:
dictionary['totalAuthorizedAmount'] = self.total_authorized_amount.to_dictionary()
return dictionary
[docs]
def from_dictionary(self, dictionary: dict) -> 'ApiRefundResponse':
super(ApiRefundResponse, self).from_dictionary(dictionary)
if 'authorizationCode' in dictionary:
self.authorization_code = dictionary['authorizationCode']
if 'cardPaymentData' in dictionary:
if not isinstance(dictionary['cardPaymentData'], dict):
raise TypeError('value \'{}\' is not a dictionary'.format(dictionary['cardPaymentData']))
value = CardPaymentDataForResource()
self.card_payment_data = value.from_dictionary(dictionary['cardPaymentData'])
if 'emvData' in dictionary:
if not isinstance(dictionary['emvData'], list):
raise TypeError('value \'{}\' is not a list'.format(dictionary['emvData']))
self.emv_data = []
for element in dictionary['emvData']:
value = EmvDataItem()
self.emv_data.append(value.from_dictionary(element))
if 'operationId' in dictionary:
self.operation_id = dictionary['operationId']
if 'referencedPaymentId' in dictionary:
self.referenced_payment_id = dictionary['referencedPaymentId']
if 'references' in dictionary:
if not isinstance(dictionary['references'], dict):
raise TypeError('value \'{}\' is not a dictionary'.format(dictionary['references']))
value = ApiReferencesForResponses()
self.references = value.from_dictionary(dictionary['references'])
if 'refundId' in dictionary:
self.refund_id = dictionary['refundId']
if 'responder' in dictionary:
self.responder = dictionary['responder']
if 'responseCode' in dictionary:
self.response_code = dictionary['responseCode']
if 'responseCodeCategory' in dictionary:
self.response_code_category = dictionary['responseCodeCategory']
if 'responseCodeDescription' in dictionary:
self.response_code_description = dictionary['responseCodeDescription']
if 'retryAfter' in dictionary:
self.retry_after = dictionary['retryAfter']
if 'status' in dictionary:
self.status = dictionary['status']
if 'statusTimestamp' in dictionary:
self.status_timestamp = DataObject.parse_datetime(dictionary['statusTimestamp'])
if 'totalAuthorizedAmount' in dictionary:
if not isinstance(dictionary['totalAuthorizedAmount'], dict):
raise TypeError('value \'{}\' is not a dictionary'.format(dictionary['totalAuthorizedAmount']))
value = AmountData()
self.total_authorized_amount = value.from_dictionary(dictionary['totalAuthorizedAmount'])
return self