| 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.*;
public class dtos
{
public static class CarConfiguratorRequest implements IPost
{
/**
* Configurator code
*/
@ApiMember(Description="Configurator code", IsRequired=true)
public String ConfiguratorCode = null;
public String getConfiguratorCode() { return ConfiguratorCode; }
public CarConfiguratorRequest setConfiguratorCode(String value) { this.ConfiguratorCode = value; return this; }
}
public static class CarConfiguratorResponse
{
public String Name = null;
public KeyInformation KeyInformation = null;
public OrderingOptions OrderingOptions = null;
public ResponseStatus ResponseStatus = null;
public String ConfiguratorCode = null;
public String getName() { return Name; }
public CarConfiguratorResponse setName(String value) { this.Name = value; return this; }
public KeyInformation getKeyInformation() { return KeyInformation; }
public CarConfiguratorResponse setKeyInformation(KeyInformation value) { this.KeyInformation = value; return this; }
public OrderingOptions getOrderingOptions() { return OrderingOptions; }
public CarConfiguratorResponse setOrderingOptions(OrderingOptions value) { this.OrderingOptions = value; return this; }
public ResponseStatus getResponseStatus() { return ResponseStatus; }
public CarConfiguratorResponse setResponseStatus(ResponseStatus value) { this.ResponseStatus = value; return this; }
public String getConfiguratorCode() { return ConfiguratorCode; }
public CarConfiguratorResponse setConfiguratorCode(String value) { this.ConfiguratorCode = value; return this; }
}
public static class KeyInformation
{
public String BM7NST = null;
public String ConfigurationDate = null;
public String ModelYear = null;
public String HalfYear = null;
public String getBM7NST() { return BM7NST; }
public KeyInformation setBM7NST(String value) { this.BM7NST = value; return this; }
public String getConfigurationDate() { return ConfigurationDate; }
public KeyInformation setConfigurationDate(String value) { this.ConfigurationDate = value; return this; }
public String getModelYear() { return ModelYear; }
public KeyInformation setModelYear(String value) { this.ModelYear = value; return this; }
public String getHalfYear() { return HalfYear; }
public KeyInformation setHalfYear(String value) { this.HalfYear = value; return this; }
}
public static class OrderingOptions
{
public ArrayList<String> Interior = null;
public ArrayList<String> Exterior = null;
public ArrayList<String> Options = null;
public ArrayList<String> getInterior() { return Interior; }
public OrderingOptions setInterior(ArrayList<String> value) { this.Interior = value; return this; }
public ArrayList<String> getExterior() { return Exterior; }
public OrderingOptions setExterior(ArrayList<String> value) { this.Exterior = value; return this; }
public ArrayList<String> getOptions() { return Options; }
public OrderingOptions setOptions(ArrayList<String> value) { this.Options = value; return this; }
}
}
Java CarConfiguratorRequest DTOs
To override the Content-type in your clients, use the HTTP Accept Header, append the .xml suffix or ?format=xml
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: application/xml
Content-Type: application/xml
Content-Length: length
<CarConfiguratorRequest xmlns:i="http://www.w3.org/2001/XMLSchema-instance" xmlns="http://schemas.datacontract.org/2004/07/Mercedes.Agency.Orchestration.API.ServiceModel.BackOrders.CarConfigurator">
<ConfiguratorCode>String</ConfiguratorCode>
</CarConfiguratorRequest>
HTTP/1.1 200 OK
Content-Type: application/xml
Content-Length: length
<CarConfiguratorResponse xmlns:i="http://www.w3.org/2001/XMLSchema-instance" xmlns="http://schemas.datacontract.org/2004/07/Mercedes.Agency.API.Shared.POCO.CarConfigurator">
<ConfiguratorCode>String</ConfiguratorCode>
<KeyInformation>
<BM7NST>String</BM7NST>
<ConfigurationDate>String</ConfigurationDate>
<HalfYear>String</HalfYear>
<ModelYear>String</ModelYear>
</KeyInformation>
<Name>String</Name>
<OrderingOptions>
<Exterior xmlns:d3p1="http://schemas.microsoft.com/2003/10/Serialization/Arrays">
<d3p1:string>String</d3p1:string>
</Exterior>
<Interior xmlns:d3p1="http://schemas.microsoft.com/2003/10/Serialization/Arrays">
<d3p1:string>String</d3p1:string>
</Interior>
<Options xmlns:d3p1="http://schemas.microsoft.com/2003/10/Serialization/Arrays">
<d3p1:string>String</d3p1:string>
</Options>
</OrderingOptions>
<ResponseStatus xmlns:d2p1="http://schemas.servicestack.net/types">
<d2p1:ErrorCode>String</d2p1:ErrorCode>
<d2p1:Message>String</d2p1:Message>
<d2p1:StackTrace>String</d2p1:StackTrace>
<d2p1:Errors>
<d2p1:ResponseError>
<d2p1:ErrorCode>String</d2p1:ErrorCode>
<d2p1:FieldName>String</d2p1:FieldName>
<d2p1:Message>String</d2p1:Message>
<d2p1:Meta xmlns:d5p1="http://schemas.microsoft.com/2003/10/Serialization/Arrays">
<d5p1:KeyValueOfstringstring>
<d5p1:Key>String</d5p1:Key>
<d5p1:Value>String</d5p1:Value>
</d5p1:KeyValueOfstringstring>
</d2p1:Meta>
</d2p1:ResponseError>
</d2p1:Errors>
<d2p1:Meta xmlns:d3p1="http://schemas.microsoft.com/2003/10/Serialization/Arrays">
<d3p1:KeyValueOfstringstring>
<d3p1:Key>String</d3p1:Key>
<d3p1:Value>String</d3p1:Value>
</d3p1:KeyValueOfstringstring>
</d2p1:Meta>
</ResponseStatus>
</CarConfiguratorResponse>