| POST | /v1/configurator | Validate and save a car configurator code for a back order | This endpoint calls Agency API to validate and save a car configurator code for a back order. The code is validated and saved in the database and returns a response from a third party CCS which provides car configuration details. These get saved to open search and returned to the front-end |
|---|
import java.math.*
import java.util.*
import java.io.InputStream
import net.servicestack.client.*
open class CarConfiguratorRequest : IPost
{
/**
* Configurator code
*/
@ApiMember(Description="Configurator code", IsRequired=true)
open var ConfiguratorCode:String? = null
}
open class CarConfiguratorResponse
{
open var Name:String? = null
open var KeyInformation:KeyInformation? = null
open var OrderingOptions:OrderingOptions? = null
open var ResponseStatus:ResponseStatus? = null
open var ConfiguratorCode:String? = null
}
open class KeyInformation
{
open var BM7NST:String? = null
open var ConfigurationDate:String? = null
open var ModelYear:String? = null
open var HalfYear:String? = null
}
open class OrderingOptions
{
open var Interior:ArrayList<String>? = null
open var Exterior:ArrayList<String>? = null
open var Options:ArrayList<String>? = null
open var WheelOptions:ArrayList<EquipmentCache> = ArrayList<EquipmentCache>()
open var TrimOptions:ArrayList<EquipmentCache> = ArrayList<EquipmentCache>()
open var OptionCodes:ArrayList<EquipmentCache> = ArrayList<EquipmentCache>()
}
open class EquipmentCache
{
open var Code:String? = null
open var Description:String? = null
open var StandardFlag:String? = null
open var Price:BigDecimal? = null
open var Category:String? = null
open var Importance:String? = null
}
Kotlin CarConfiguratorRequest 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/configurator HTTP/1.1
Host: prod-api-agency-orch-mb-dhc.rapp-customers.co.uk
Accept: text/jsv
Content-Type: text/jsv
Content-Length: length
{
ConfiguratorCode: String
}
HTTP/1.1 200 OK
Content-Type: text/jsv
Content-Length: length
{
Name: String,
KeyInformation:
{
BM7NST: String,
ConfigurationDate: String,
ModelYear: String,
HalfYear: String
},
OrderingOptions:
{
Interior:
[
String
],
Exterior:
[
String
],
Options:
[
String
],
WheelOptions:
[
{
Code: String,
Description: String,
StandardFlag: String,
Price: 0,
Category: String,
Importance: String
}
],
TrimOptions:
[
{
Code: String,
Description: String,
StandardFlag: String,
Price: 0,
Category: String,
Importance: String
}
],
OptionCodes:
[
{
Code: String,
Description: String,
StandardFlag: String,
Price: 0,
Category: String,
Importance: String
}
]
},
ResponseStatus:
{
ErrorCode: String,
Message: String,
StackTrace: String,
Errors:
[
{
ErrorCode: String,
FieldName: String,
Message: String,
Meta:
{
String: String
}
}
],
Meta:
{
String: String
}
},
ConfiguratorCode: String
}