POST | /v1/outrightpurchase/validate | Validate Outright Purchase |
---|
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
@dataclass_json(letter_case=LetterCase.CAMEL, undefined=Undefined.EXCLUDE)
@dataclass
class OutrightPurchaseDiscount:
baumuster_n_s_t: Optional[str] = None
discount_percentage: Decimal = decimal.Decimal(0)
@dataclass_json(letter_case=LetterCase.CAMEL, undefined=Undefined.EXCLUDE)
@dataclass
class OutrightPurchaseFleetCustomer:
customer_identifier: Optional[str] = None
company_name: Optional[str] = None
title: Optional[str] = None
first_name: Optional[str] = None
last_name: Optional[str] = None
email: Optional[str] = None
phone_number: Optional[str] = None
house_number: Optional[str] = None
address_line2: Optional[str] = None
town: Optional[str] = None
county: Optional[str] = None
post_code: Optional[str] = None
outright_purchase_customer_discounts: List[OutrightPurchaseDiscount] = field(default_factory=list)
import_sucessful: bool = False
is_eligible_c_o_p_converter: bool = False
@dataclass_json(letter_case=LetterCase.CAMEL, undefined=Undefined.EXCLUDE)
@dataclass
class ValidateOutRightPurchaseResponse:
outright_purchase_fleet_customer: Optional[OutrightPurchaseFleetCustomer] = None
is_back_order: Optional[bool] = None
@dataclass_json(letter_case=LetterCase.CAMEL, undefined=Undefined.EXCLUDE)
@dataclass
class ValidateOutRightPurchaseRequest(ValidateOutRightPurchaseRequest, IPost):
pass
Python ValidateOutRightPurchaseRequest DTOs
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 /v1/outrightpurchase/validate HTTP/1.1
Host: prod-api-agency-orch-mb-dhc.rapp-customers.co.uk
Accept: application/xml
Content-Type: application/xml
Content-Length: length
<ValidateOutRightPurchaseRequest xmlns:i="http://www.w3.org/2001/XMLSchema-instance" xmlns="http://schemas.datacontract.org/2004/07/Mercedes.Agency.Orchestration.API.ServiceModel.OutrightPurchases">
<Criteria xmlns:d2p1="http://schemas.datacontract.org/2004/07/Mercedes.Agency.API.Shared.POCO" xmlns="http://schemas.datacontract.org/2004/07/Mercedes.Agency.Orchestration.API.Clients.AgencyApi.Requests">
<d2p1:Bm7NST>String</d2p1:Bm7NST>
<d2p1:IsBackOrder>false</d2p1:IsBackOrder>
<d2p1:Reference>String</d2p1:Reference>
</Criteria>
</ValidateOutRightPurchaseRequest>
HTTP/1.1 200 OK Content-Type: application/xml Content-Length: length <ValidateOutRightPurchaseResponse xmlns:i="http://www.w3.org/2001/XMLSchema-instance" xmlns="http://schemas.datacontract.org/2004/07/Mercedes.Agency.Orchestration.API.Clients.AgencyApi.Responses"> <IsBackOrder>false</IsBackOrder> <OutrightPurchaseFleetCustomer xmlns:d2p1="http://schemas.datacontract.org/2004/07/Mercedes.Agency.API.Shared.POCO"> <d2p1:AddressLine2>String</d2p1:AddressLine2> <d2p1:CompanyName>String</d2p1:CompanyName> <d2p1:County>String</d2p1:County> <d2p1:CustomerIdentifier>String</d2p1:CustomerIdentifier> <d2p1:Email>String</d2p1:Email> <d2p1:FirstName>String</d2p1:FirstName> <d2p1:HouseNumber>String</d2p1:HouseNumber> <d2p1:ImportSucessful>false</d2p1:ImportSucessful> <d2p1:IsEligibleCOPConverter>false</d2p1:IsEligibleCOPConverter> <d2p1:LastName>String</d2p1:LastName> <d2p1:OutrightPurchaseCustomerDiscounts> <d2p1:OutrightPurchaseDiscount> <d2p1:BaumusterNST>String</d2p1:BaumusterNST> <d2p1:DiscountPercentage>0</d2p1:DiscountPercentage> </d2p1:OutrightPurchaseDiscount> </d2p1:OutrightPurchaseCustomerDiscounts> <d2p1:PhoneNumber>String</d2p1:PhoneNumber> <d2p1:PostCode>String</d2p1:PostCode> <d2p1:Title>String</d2p1:Title> <d2p1:Town>String</d2p1:Town> </OutrightPurchaseFleetCustomer> </ValidateOutRightPurchaseResponse>