POST | /v1/DisplayStockOverview | Filter Display Stock vehicle data with usedCode and MBUKSecured |
---|
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 VehicleDisplayStock:
vin: Optional[str] = None
vehicle_description: Optional[str] = None
commission_number: Optional[str] = None
retailer: Optional[str] = None
model: Optional[str] = None
fuel_type: Optional[str] = None
transmission: Optional[str] = None
colour: Optional[str] = None
actual_price: Optional[str] = None
gb_dest_date: Optional[datetime.datetime] = None
vehicle_usage: Optional[str] = None
under_offer: bool = False
is_sellable: bool = False
vehicle_type: Optional[str] = None
vid: Optional[str] = None
fin: Optional[str] = None
chassis_number: Optional[str] = None
line: Optional[str] = None
model_year: Optional[str] = None
model_year_code: Optional[str] = None
vehicle_class: Optional[str] = None
retail_price__ex_v_a_t: Optional[str] = None
retail_price__inc_v_a_t: Optional[str] = None
otr: Optional[str] = None
body_style: Optional[str] = None
product_range: Optional[str] = None
engine: Optional[str] = None
is_a_m_g: bool = False
colour_group: Optional[str] = None
upholstery: Optional[str] = None
packages: Optional[str] = None
nst: Optional[str] = None
b_m7_n_s_t: Optional[str] = None
acceleration: Optional[str] = None
boot_capacity: Optional[str] = None
top_speed: Optional[str] = None
drive_concept: Optional[str] = None
combustion_power_hp: Optional[str] = None
electric_power_kw: Optional[str] = None
electric_power_hp: Optional[str] = None
combined_power_kw: Optional[str] = None
combined_power_h_p: Optional[str] = None
electric_range: Optional[str] = None
electric_consumption: Optional[str] = None
emission_combined: Optional[str] = None
emission_extra_urban: Optional[str] = None
emission_urban: Optional[str] = None
emission: Optional[str] = None
emission_directive: Optional[str] = None
energy_efficiency_class: Optional[str] = None
wltp_combined: Optional[str] = None
wltp_low: Optional[str] = None
wltp_medium: Optional[str] = None
wltp_high: Optional[str] = None
wltp_extra_high: Optional[str] = None
wltp_emission_combined: Optional[str] = None
port_arrival_date: Optional[datetime.datetime] = None
creation_date: Optional[datetime.datetime] = None
last_updated: Optional[datetime.datetime] = None
is_display_stock: bool = False
display_stock_agent: Optional[str] = None
is_specialist_car: bool = False
account: Optional[str] = None
location: Optional[str] = None
cesar_id_ship_to_party: Optional[str] = None
vehicle_usage_code: Optional[str] = None
mbuk_secured: bool = False
is_allocated_to_back_order: bool = False
back_order_reference: Optional[str] = None
market_area_name: Optional[str] = None
market_area_id: Optional[int] = None
days_at_site: Optional[str] = None
@dataclass_json(letter_case=LetterCase.CAMEL, undefined=Undefined.EXCLUDE)
@dataclass
class DisplayStockOverviewResponse:
vehicles: List[VehicleDisplayStock] = field(default_factory=list)
@dataclass_json(letter_case=LetterCase.CAMEL, undefined=Undefined.EXCLUDE)
@dataclass
class DisplayStockOverviewRequest(IPost):
# @ApiMember(Description="Is vehicle secured", IsRequired=true)
is_secured: Optional[bool] = None
"""
Is vehicle secured
"""
# @ApiMember(Description="Usage codes", IsRequired=true)
usage_code: List[str] = field(default_factory=list)
"""
Usage codes
"""
Python DisplayStockOverviewRequest 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/DisplayStockOverview HTTP/1.1
Host: uat-api-vehicle-mgt-mb-dhc.rapp-customers.co.uk
Accept: text/jsv
Content-Type: text/jsv
Content-Length: length
{
isSecured: False,
usageCode:
[
String
]
}
HTTP/1.1 200 OK Content-Type: text/jsv Content-Length: length { vehicles: [ { vin: String, vehicleDescription: String, commissionNumber: String, retailer: String, model: String, fuelType: String, transmission: String, colour: String, actualPrice: String, gbDestDate: 0001-01-01, vehicleUsage: String, underOffer: False, isSellable: False, vehicleType: String, vid: String, fin: String, chassisNumber: String, line: String, modelYear: String, modelYearCode: String, vehicleClass: String, retailPrice_ExVAT: String, retailPrice_IncVAT: String, otr: String, bodyStyle: String, productRange: String, engine: String, isAMG: False, colourGroup: String, upholstery: String, packages: String, nst: String, bM7NST: String, acceleration: String, bootCapacity: String, topSpeed: String, driveConcept: String, combustionPowerHp: String, electricPowerKw: String, electricPowerHp: String, combinedPowerKw: String, combinedPowerHP: String, electricRange: String, electricConsumption: String, emissionCombined: String, emissionExtraUrban: String, emissionUrban: String, emission: String, emissionDirective: String, energyEfficiencyClass: String, wltpCombined: String, wltpLow: String, wltpMedium: String, wltpHigh: String, wltpExtraHigh: String, wltpEmissionCombined: String, portArrivalDate: 0001-01-01, creationDate: 0001-01-01, lastUpdated: 0001-01-01, isDisplayStock: False, displayStockAgent: String, isSpecialistCar: False, account: String, location: String, cesarIdShipToParty: String, vehicleUsageCode: String, mbukSecured: False, isAllocatedToBackOrder: False, backOrderReference: String, marketAreaName: String, marketAreaId: 0, daysAtSite: String } ] }