POST | /licenses/dibscallback/ | Save Dibs Callback | This service is used for the DIBS callback. |
---|
import datetime
import decimal
from marshmallow.fields import *
from servicestack import *
from typing import *
from dataclasses import dataclass, field
from dataclasses_json import dataclass_json, LetterCase, Undefined, config
from enum import Enum, IntEnum
class DibStatus(str, Enum):
SUCCESS = 'Success'
CANCELLED = 'Cancelled'
@dataclass_json(letter_case=LetterCase.CAMEL, undefined=Undefined.EXCLUDE)
@dataclass
class DibsCallbackDto:
# @ApiMember(DataType="string", Description="The company id to save the credit card to", IsRequired=true)
company_id: Optional[str] = None
"""
The company id to save the credit card to
"""
# @ApiMember(DataType="string", Description="The dibs card expiration date (yymm)", IsRequired=true)
cardexpdate: Optional[str] = None
"""
The dibs card expiration date (yymm)
"""
# @ApiMember(DataType="string", Description="The dibs transact id", IsRequired=true)
transact: Optional[str] = None
"""
The dibs transact id
"""
# @ApiMember(DataType="string", Description="The dibs card number (masked)", IsRequired=true)
cardnomask: Optional[str] = None
"""
The dibs card number (masked)
"""
# @ApiMember(DataType="string", Description="The dibs paytype", IsRequired=true)
paytype: Optional[str] = None
"""
The dibs paytype
"""
# @ApiMember(DataType="string", Description="The dibs currency", IsRequired=true)
currency: Optional[str] = None
"""
The dibs currency
"""
# @ApiMember(DataType="string", Description="The dibs acquirer", IsRequired=true)
acquirer: Optional[str] = None
"""
The dibs acquirer
"""
# @ApiMember(DataType="string", Description="The dibs approval code", IsRequired=true)
approvalcode: Optional[str] = None
"""
The dibs approval code
"""
# @ApiMember(DataType="string", Description="The dibs status code", IsRequired=true)
statuscode: Optional[str] = None
"""
The dibs status code
"""
# @ApiMember(DataType="string", Description="The dibs amount", IsRequired=true)
amount: Optional[str] = None
"""
The dibs amount
"""
# @ApiMember(DataType="uri", Description="The redirect url to send user back to after added creditcard", IsRequired=true)
redirect_url: Optional[str] = None
"""
The redirect url to send user back to after added creditcard
"""
# @ApiMember(DataType="string", Description="The unique token for this request", IsRequired=true)
token: Optional[str] = None
"""
The unique token for this request
"""
# @ApiMember(DataType="enum", Description="status of the callback url", IsRequired=true)
status: Optional[DibStatus] = None
"""
status of the callback url
"""
To override the Content-type in your clients, use the HTTP Accept Header, append the .xml suffix or ?format=xml
The following are sample HTTP requests and responses. The placeholders shown need to be replaced with actual values.
POST /licenses/dibscallback/ HTTP/1.1
Host: api.bokamera.se
Accept: application/xml
Content-Type: application/xml
Content-Length: length
<DibsCallbackDto xmlns:i="http://www.w3.org/2001/XMLSchema-instance" xmlns="http://schemas.datacontract.org/2004/07/BokaMera.API.ServiceModel.Dtos">
<CompanyId>00000000-0000-0000-0000-000000000000</CompanyId>
<RedirectUrl>String</RedirectUrl>
<Status>Success</Status>
<Token>String</Token>
<acquirer>String</acquirer>
<amount>String</amount>
<approvalcode>String</approvalcode>
<cardexpdate>String</cardexpdate>
<cardnomask>String</cardnomask>
<currency>String</currency>
<paytype>String</paytype>
<statuscode>String</statuscode>
<transact>String</transact>
</DibsCallbackDto>
HTTP/1.1 200 OK Content-Type: application/xml Content-Length: length <z:anyType xmlns:i="http://www.w3.org/2001/XMLSchema-instance" xmlns:z="http://schemas.microsoft.com/2003/10/Serialization/" />