| POST | /quote/order | Provide a quoteId to create an order. This will bill the order to your account. |
|---|
import 'package:servicestack/servicestack.dart';
class ApiServiceRequest implements IServiceRequest, IHasApiKey, IConvertible
{
/**
* The API Key required for authentication
*/
// @ApiMember(DataType="string", Description="The API Key required for authentication", IsRequired=true)
String? ApiKey;
ApiServiceRequest({this.ApiKey});
ApiServiceRequest.fromJson(Map<String, dynamic> json) { fromMap(json); }
fromMap(Map<String, dynamic> json) {
ApiKey = json['ApiKey'];
return this;
}
Map<String, dynamic> toJson() => {
'ApiKey': ApiKey
};
getTypeName() => "ApiServiceRequest";
TypeContext? context = _ctx;
}
class ApiServiceResponse implements IServiceResponse, IConvertible
{
/**
* Information about the response.
*/
// @ApiMember(Description="Information about the response.", IsRequired=true)
String? Description;
/**
* Heading or summary of the response.
*/
// @ApiMember(Description="Heading or summary of the response.", IsRequired=true)
String? Heading;
/**
* Did the intended operation for this response complete successfully?
*/
// @ApiMember(DataType="boolean", Description="Did the intended operation for this response complete successfully?", IsRequired=true)
bool? WasSuccessful;
ApiServiceResponse({this.Description,this.Heading,this.WasSuccessful});
ApiServiceResponse.fromJson(Map<String, dynamic> json) { fromMap(json); }
fromMap(Map<String, dynamic> json) {
Description = json['Description'];
Heading = json['Heading'];
WasSuccessful = json['WasSuccessful'];
return this;
}
Map<String, dynamic> toJson() => {
'Description': Description,
'Heading': Heading,
'WasSuccessful': WasSuccessful
};
getTypeName() => "ApiServiceResponse";
TypeContext? context = _ctx;
}
class PlaceOrderFromQuoteResponse extends ApiServiceResponse implements IConvertible
{
/**
* The ID of the order.
*/
// @ApiMember(Description="The ID of the order.")
String? OrderId;
/**
* User friendly waybill number
*/
// @ApiMember(Description="User friendly waybill number")
String? WayBill;
PlaceOrderFromQuoteResponse({this.OrderId,this.WayBill});
PlaceOrderFromQuoteResponse.fromJson(Map<String, dynamic> json) { fromMap(json); }
fromMap(Map<String, dynamic> json) {
super.fromMap(json);
OrderId = json['OrderId'];
WayBill = json['WayBill'];
return this;
}
Map<String, dynamic> toJson() => super.toJson()..addAll({
'OrderId': OrderId,
'WayBill': WayBill
});
getTypeName() => "PlaceOrderFromQuoteResponse";
TypeContext? context = _ctx;
}
class PlaceOrderFromQuote extends ApiServiceRequest implements ILogRequest, IConvertible
{
/**
* Optionally provide your own reference identifier
*/
// @ApiMember(Description="Optionally provide your own reference identifier")
String? ClientReference;
/**
* The quote the order is for
*/
// @ApiMember(Description="The quote the order is for", IsRequired=true)
String? QuoteId;
/**
* Set this to true to prevent creating an order and billing for it
*/
// @ApiMember(Description="Set this to true to prevent creating an order and billing for it", IsRequired=true)
bool? Test;
/**
* Is your account allows Urgent Orders, you can use this flag to indicate when an Order is urgent.
*/
// @ApiMember(Description="Is your account allows Urgent Orders, you can use this flag to indicate when an Order is urgent.")
bool? IsUrgent;
PlaceOrderFromQuote({this.ClientReference,this.QuoteId,this.Test,this.IsUrgent});
PlaceOrderFromQuote.fromJson(Map<String, dynamic> json) { fromMap(json); }
fromMap(Map<String, dynamic> json) {
super.fromMap(json);
ClientReference = json['ClientReference'];
QuoteId = json['QuoteId'];
Test = json['Test'];
IsUrgent = json['IsUrgent'];
return this;
}
Map<String, dynamic> toJson() => super.toJson()..addAll({
'ClientReference': ClientReference,
'QuoteId': QuoteId,
'Test': Test,
'IsUrgent': IsUrgent
});
getTypeName() => "PlaceOrderFromQuote";
TypeContext? context = _ctx;
}
TypeContext _ctx = TypeContext(library: 'api.1fetch.co.za', types: <String, TypeInfo> {
'ApiServiceRequest': TypeInfo(TypeOf.Class, create:() => ApiServiceRequest()),
'ApiServiceResponse': TypeInfo(TypeOf.Class, create:() => ApiServiceResponse()),
'PlaceOrderFromQuoteResponse': TypeInfo(TypeOf.Class, create:() => PlaceOrderFromQuoteResponse()),
'PlaceOrderFromQuote': TypeInfo(TypeOf.Class, create:() => PlaceOrderFromQuote()),
});
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 /quote/order HTTP/1.1
Host: api.1fetch.co.za
Accept: application/xml
Content-Type: application/xml
Content-Length: length
<PlaceOrderFromQuote xmlns:i="http://www.w3.org/2001/XMLSchema-instance" xmlns="http://schemas.datacontract.org/2004/07/WebService.ClientServiceModel">
<ApiKey xmlns="http://schemas.datacontract.org/2004/07/WebService.ClientServiceModel.Base">String</ApiKey>
<ClientReference>String</ClientReference>
<IsUrgent>false</IsUrgent>
<QuoteId>00000000-0000-0000-0000-000000000000</QuoteId>
<Test>false</Test>
</PlaceOrderFromQuote>
HTTP/1.1 200 OK Content-Type: application/xml Content-Length: length <PlaceOrderFromQuoteResponse xmlns:i="http://www.w3.org/2001/XMLSchema-instance" xmlns="http://schemas.datacontract.org/2004/07/WebService.ClientServiceModel"> <Description xmlns="http://schemas.datacontract.org/2004/07/WebService.ClientServiceModel.Base">String</Description> <Heading xmlns="http://schemas.datacontract.org/2004/07/WebService.ClientServiceModel.Base">String</Heading> <WasSuccessful xmlns="http://schemas.datacontract.org/2004/07/WebService.ClientServiceModel.Base">false</WasSuccessful> <OrderId>00000000-0000-0000-0000-000000000000</OrderId> <WayBill>String</WayBill> </PlaceOrderFromQuoteResponse>