Mercedes.Agency.Orchestration.API

<back to all web services

UpdateBackOrderRequest

BackOrder
Requires Authentication
The following routes are available for this service:
PUT/v1/backorder/{Guid}Update Back Order by Guid
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 UpdateBackOrderResponse:
    pass


@dataclass_json(letter_case=LetterCase.CAMEL, undefined=Undefined.EXCLUDE)
@dataclass
class JsonVersion(IJsonVersion):
    version: int = 0


@dataclass_json(letter_case=LetterCase.CAMEL, undefined=Undefined.EXCLUDE)
@dataclass
class CriteriaModel:
    description: Optional[str] = None
    id: int = 0


@dataclass_json(letter_case=LetterCase.CAMEL, undefined=Undefined.EXCLUDE)
@dataclass
class CriteriaDifference:
    model: bool = False
    transmission: bool = False
    fuel: bool = False
    upholstery: bool = False
    equipment: bool = False
    line: bool = False
    body_style: bool = False
    colour_group: bool = False
    packages: bool = False
    engine: bool = False
    additional_information: bool = False
    url_referrer: bool = False
    preferred_delivery_date: bool = False
    is_smart: bool = False
    is_specialised: bool = False


@dataclass_json(letter_case=LetterCase.CAMEL, undefined=Undefined.EXCLUDE)
@dataclass
class CriteriaBase(JsonVersion):
    transmission: List[str] = field(default_factory=list)
    fuel: List[str] = field(default_factory=list)
    upholstery: List[str] = field(default_factory=list)
    equipment: List[str] = field(default_factory=list)
    line: List[str] = field(default_factory=list)
    body_style: List[str] = field(default_factory=list)
    colour_group: List[str] = field(default_factory=list)
    packages: List[str] = field(default_factory=list)
    model: List[CriteriaModel] = field(default_factory=list)
    url_referrer: Optional[str] = None
    preferred_delivery_date: Optional[str] = None
    # @ApiMember(ExcludeInSchema=true)
    is_new_model: bool = False

    # @ApiMember(ExcludeInSchema=true)
    is_smart: bool = False

    # @ApiMember(ExcludeInSchema=true)
    is_specialised: bool = False

    # @ApiMember(ExcludeInSchema=true)
    criteria_difference: Optional[CriteriaDifference] = None


@dataclass_json(letter_case=LetterCase.CAMEL, undefined=Undefined.EXCLUDE)
@dataclass
class V2EngineCriteria:
    badge: Optional[str] = None
    brand: Optional[str] = None


@dataclass_json(letter_case=LetterCase.CAMEL, undefined=Undefined.EXCLUDE)
@dataclass
class V2Criteria(CriteriaBase):
    engine: List[V2EngineCriteria] = field(default_factory=list)


@dataclass_json(letter_case=LetterCase.CAMEL, undefined=Undefined.EXCLUDE)
@dataclass
class UpdateBackOrderRequest(IPut):
    guid: Optional[str] = None
    agent_criteria: Optional[V2Criteria] = None
    additional_information: Optional[str] = None
    config_code: Optional[str] = None
    motability_pricing_id: Optional[int] = None
    assistance_provider_id: Optional[int] = None
    assistance_detail: Optional[str] = None
    is_c_o_p_converter: bool = False
    configurator_code: Optional[str] = None
    is_one_admin_update: bool = False

Python UpdateBackOrderRequest 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.

PUT /v1/backorder/{Guid} HTTP/1.1 
Host: prod-api-agency-orch-mb-dhc.rapp-customers.co.uk 
Accept: text/jsv
Content-Type: text/jsv
Content-Length: length

{
	Guid: 00000000000000000000000000000000,
	AgentCriteria: 
	{
		Engine: 
		[
			{
				Badge: String,
				Brand: String
			}
		],
		Transmission: 
		[
			String
		],
		Fuel: 
		[
			String
		],
		Upholstery: 
		[
			String
		],
		Equipment: 
		[
			String
		],
		Line: 
		[
			String
		],
		BodyStyle: 
		[
			String
		],
		ColourGroup: 
		[
			String
		],
		Packages: 
		[
			String
		],
		Model: 
		[
			{
				Description: String,
				Id: 0
			}
		],
		UrlReferrer: String,
		PreferredDeliveryDate: String,
		IsNewModel: False,
		IsSmart: False,
		IsSpecialised: False,
		CriteriaDifference: 
		{
			Model: False,
			Transmission: False,
			Fuel: False,
			Upholstery: False,
			Equipment: False,
			Line: False,
			BodyStyle: False,
			ColourGroup: False,
			Packages: False,
			Engine: False,
			AdditionalInformation: False,
			UrlReferrer: False,
			PreferredDeliveryDate: False,
			IsSmart: False,
			IsSpecialised: False
		},
		Version: 0
	},
	AdditionalInformation: String,
	ConfigCode: String,
	MotabilityPricingId: 0,
	AssistanceProviderId: 0,
	AssistanceDetail: String,
	IsCOPConverter: False,
	ConfiguratorCode: String,
	IsOneAdminUpdate: False
}
HTTP/1.1 200 OK
Content-Type: text/jsv
Content-Length: length

{
	
}