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 .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 }