| POST | /v1/outrightpurchase/validate | Validate Outright Purchase | 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 .jsv suffix or ?format=jsv
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: text/jsv
Content-Type: text/jsv
Content-Length: length
{
Criteria:
{
Reference: String,
Bm7NST: String,
IsBackOrder: False
}
}
HTTP/1.1 200 OK
Content-Type: text/jsv
Content-Length: length
{
OutrightPurchaseFleetCustomer:
{
CustomerIdentifier: String,
CompanyName: String,
Title: String,
FirstName: String,
LastName: String,
Email: String,
PhoneNumber: String,
HouseNumber: String,
AddressLine2: String,
Town: String,
County: String,
PostCode: String,
OutrightPurchaseCustomerDiscounts:
[
{
BaumusterNST: String,
DiscountPercentage: 0
}
],
ImportSucessful: False,
IsEligibleCOPConverter: False
},
IsBackOrder: False
}