Mercedes.Agency.Orchestration.API

<back to all web services

ValidateOutRightPurchaseRequest

OutrightPurchase
Requires Authentication
The following routes are available for this service:
POST/v1/outrightpurchase/validateValidate 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

HTTP + 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
}