Source code for worldline.acquiring.sdk.v1.domain.sub_operation
# -*- coding: utf-8 -*-
#
# This file was automatically generated.
#
from datetime import datetime
from typing import Optional
from .amount_data import AmountData
from worldline.acquiring.sdk.domain.data_object import DataObject
[docs]
class SubOperation(DataObject):
    __amount: Optional[AmountData] = None
    __authorization_code: Optional[str] = None
    __operation_id: Optional[str] = None
    __operation_timestamp: Optional[datetime] = None
    __operation_type: Optional[str] = None
    __response_code: Optional[str] = None
    __response_code_category: Optional[str] = None
    __response_code_description: Optional[str] = None
    @property
    def amount(self) -> Optional[AmountData]:
        """
        | Amount for the operation.
        Type: :class:`worldline.acquiring.sdk.v1.domain.amount_data.AmountData`
        """
        return self.__amount
    @amount.setter
    def amount(self, value: Optional[AmountData]) -> None:
        self.__amount = value
    @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 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 operation_timestamp(self) -> Optional[datetime]:
        """
        | Timestamp of the operation in ISO 8601 format (YYYY-MM-DDThh:mm:ss+TZD)
        | It can be expressed in merchant time zone (ex: 2023-10-10T08:00+02:00) or in UTC (ex: 2023-10-10T08:00Z) yyyy-MM-ddTHH:mm:ssZ
        Type: datetime
        """
        return self.__operation_timestamp
    @operation_timestamp.setter
    def operation_timestamp(self, value: Optional[datetime]) -> None:
        self.__operation_timestamp = value
    @property
    def operation_type(self) -> Optional[str]:
        """
        | The kind of operation.
        | Possible values are:
        
        * AUTHORIZATION
        * CAPTURE
        * REFUND
        * INCREMENT
        * AUTHORIZATION_REVERSAL
        Type: str
        """
        return self.__operation_type
    @operation_type.setter
    def operation_type(self, value: Optional[str]) -> None:
        self.__operation_type = value
    @property
    def response_code(self) -> Optional[str]:
        """
        | Numeric response code, e.g. 0, 5
        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
[docs]
    def to_dictionary(self) -> dict:
        dictionary = super(SubOperation, self).to_dictionary()
        if self.amount is not None:
            dictionary['amount'] = self.amount.to_dictionary()
        if self.authorization_code is not None:
            dictionary['authorizationCode'] = self.authorization_code
        if self.operation_id is not None:
            dictionary['operationId'] = self.operation_id
        if self.operation_timestamp is not None:
            dictionary['operationTimestamp'] = DataObject.format_datetime(self.operation_timestamp)
        if self.operation_type is not None:
            dictionary['operationType'] = self.operation_type
        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
        return dictionary 
[docs]
    def from_dictionary(self, dictionary: dict) -> 'SubOperation':
        super(SubOperation, self).from_dictionary(dictionary)
        if 'amount' in dictionary:
            if not isinstance(dictionary['amount'], dict):
                raise TypeError('value \'{}\' is not a dictionary'.format(dictionary['amount']))
            value = AmountData()
            self.amount = value.from_dictionary(dictionary['amount'])
        if 'authorizationCode' in dictionary:
            self.authorization_code = dictionary['authorizationCode']
        if 'operationId' in dictionary:
            self.operation_id = dictionary['operationId']
        if 'operationTimestamp' in dictionary:
            self.operation_timestamp = DataObject.parse_datetime(dictionary['operationTimestamp'])
        if 'operationType' in dictionary:
            self.operation_type = dictionary['operationType']
        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']
        return self