| GET,OPTIONS | /portal/{Token}/quote |
|---|
import Foundation
import ServiceStack
public class PortalQuoteRequest : Codable
{
public var token:String
required public init(){}
}
public class PortalQuoteResponse : Codable
{
public var responseStatus:ResponseStatus
public var name:String
public var status:String
public var currency:String
public var total:Double
public var notes:String
public var fromName:String
public var fromAddress:String
public var toName:String
public var toAddress:String
public var expiresAt:Date?
public var isLocked:Bool
public var finalPriceAfterCompletion:Bool
public var approvedByName:String
public var approvedAt:Date?
public var declinedByName:String
public var declinedAt:Date?
public var declineReason:String
public var lineItems:[QuoteItem] = []
required public init(){}
}
public class QuoteItem : Codable
{
public var quoteItemID:Int
public var quoteID:Int
public var itemType:String
public var sourceRefId:Int?
public var jobID:Int?
public var name:String
public var Description:String
public var quantity:Double?
public var unitPrice:Double?
public var isTaxable:Bool?
public var displayOrder:Int?
public var isDeleted:Bool?
required public init(){}
}
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.
GET /portal/{Token}/quote HTTP/1.1
Host: api.dev.dynamics.trendsic.com
Accept: text/jsv
HTTP/1.1 200 OK
Content-Type: text/jsv
Content-Length: length
{
ResponseStatus:
{
ErrorCode: String,
Message: String,
StackTrace: String,
Errors:
[
{
ErrorCode: String,
FieldName: String,
Message: String,
Meta:
{
String: String
}
}
],
Meta:
{
String: String
}
},
Name: String,
Status: String,
Currency: String,
Total: 0,
Notes: String,
FromName: String,
FromAddress: String,
ToName: String,
ToAddress: String,
ExpiresAt: 0001-01-01,
IsLocked: False,
FinalPriceAfterCompletion: False,
ApprovedByName: String,
ApprovedAt: 0001-01-01,
DeclinedByName: String,
DeclinedAt: 0001-01-01,
DeclineReason: String,
LineItems:
[
{
QuoteItemID: 0,
QuoteID: 0,
ItemType: String,
SourceRefId: 0,
JobID: 0,
Name: String,
Description: String,
Quantity: 0,
UnitPrice: 0,
IsTaxable: False,
DisplayOrder: 0,
IsDeleted: False
}
]
}