| GET | /api/DeliveryTickets |
|---|
import Foundation
import ServiceStack
/**
* DeliveryTicketsRequires active-e 3rd Party E-Commerce or active-e Vortx E-Commerce.
*/
// @DataContract
public class DeliveryTicketsRequest : BaseSecureRequest
{
// @DataMember
public var dateFrom:Date?
// @DataMember
public var dateTo:Date?
// @DataMember
public var district:String
// @DataMember
public var school:String
// @DataMember
public var locationId:Int?
/**
* Type of Ticket. Valid types are Service Ticket, Sales Invoice, Layaway, Loaner, Short Term Rental, Contract, Delayed Delivery, and Approval
*/
// @DataMember
// @ApiMember(DataType="string", Description="Type of Ticket. Valid types are Service Ticket, Sales Invoice, Layaway, Loaner, Short Term Rental, Contract, Delayed Delivery, and Approval", IsRequired=true, Name="TicketType", ParameterType="query")
public var ticketType:String
// @DataMember
public var employeeLanId:String
// @DataMember
public var deliveryEmployeeLanId:String
// @DataMember
public var refNumber:String
// @DataMember
public var includeItems:Bool
required public init(){ super.init() }
private enum CodingKeys : String, CodingKey {
case dateFrom
case dateTo
case district
case school
case locationId
case ticketType
case employeeLanId
case deliveryEmployeeLanId
case refNumber
case includeItems
}
required public init(from decoder: Decoder) throws {
try super.init(from: decoder)
let container = try decoder.container(keyedBy: CodingKeys.self)
dateFrom = try container.decodeIfPresent(Date.self, forKey: .dateFrom)
dateTo = try container.decodeIfPresent(Date.self, forKey: .dateTo)
district = try container.decodeIfPresent(String.self, forKey: .district)
school = try container.decodeIfPresent(String.self, forKey: .school)
locationId = try container.decodeIfPresent(Int.self, forKey: .locationId)
ticketType = try container.decodeIfPresent(String.self, forKey: .ticketType)
employeeLanId = try container.decodeIfPresent(String.self, forKey: .employeeLanId)
deliveryEmployeeLanId = try container.decodeIfPresent(String.self, forKey: .deliveryEmployeeLanId)
refNumber = try container.decodeIfPresent(String.self, forKey: .refNumber)
includeItems = try container.decodeIfPresent(Bool.self, forKey: .includeItems)
}
public override func encode(to encoder: Encoder) throws {
try super.encode(to: encoder)
var container = encoder.container(keyedBy: CodingKeys.self)
if dateFrom != nil { try container.encode(dateFrom, forKey: .dateFrom) }
if dateTo != nil { try container.encode(dateTo, forKey: .dateTo) }
if district != nil { try container.encode(district, forKey: .district) }
if school != nil { try container.encode(school, forKey: .school) }
if locationId != nil { try container.encode(locationId, forKey: .locationId) }
if ticketType != nil { try container.encode(ticketType, forKey: .ticketType) }
if employeeLanId != nil { try container.encode(employeeLanId, forKey: .employeeLanId) }
if deliveryEmployeeLanId != nil { try container.encode(deliveryEmployeeLanId, forKey: .deliveryEmployeeLanId) }
if refNumber != nil { try container.encode(refNumber, forKey: .refNumber) }
if includeItems != nil { try container.encode(includeItems, forKey: .includeItems) }
}
}
// @DataContract
public class BaseSecureRequest : BaseRequest
{
/**
* The Login Token return by the Security API. Required for secured calls.
*/
// @DataMember
// @ApiMember(DataType="string", Description="The Login Token return by the Security API. Required for secured calls.", Name="Token", ParameterType="Header")
public var token:String
required public init(){ super.init() }
private enum CodingKeys : String, CodingKey {
case token
}
required public init(from decoder: Decoder) throws {
try super.init(from: decoder)
let container = try decoder.container(keyedBy: CodingKeys.self)
token = try container.decodeIfPresent(String.self, forKey: .token)
}
public override func encode(to encoder: Encoder) throws {
try super.encode(to: encoder)
var container = encoder.container(keyedBy: CodingKeys.self)
if token != nil { try container.encode(token, forKey: .token) }
}
}
// @DataContract
public class BaseRequest : Codable
{
/**
* This is your AIM API Key provided by Tri-Tech
*/
// @DataMember
// @ApiMember(DataType="string", Description="This is your AIM API Key provided by Tri-Tech", IsRequired=true, Name="ApiKey", ParameterType="Header")
public var apiKey:String
/**
* The OAuthToken token return by AeServices30
*/
// @DataMember
// @ApiMember(DataType="string", Description="The OAuthToken token return by AeServices30", IsRequired=true, Name="OAuthToken", ParameterType="Header")
public var oAuthToken:String
/**
* The Device ID of the Mobile Device. Not used for non-mobile devices.
*/
// @DataMember
// @ApiMember(DataType="string", Description="The Device ID of the Mobile Device. Not used for non-mobile devices.", Name="DeviceId", ParameterType="Header")
public var deviceId:String
/**
* An identifier for your integration
*/
// @DataMember
// @ApiMember(DataType="string", Description="An identifier for your integration", IsRequired=true, Name="AppId", ParameterType="Header")
public var appId:String
required public init(){}
}
// @DataContract
public class DeliveryTicketsResponse : BaseResponse
{
// @DataMember
public var tickets:[DeliveryTicket] = []
required public init(){ super.init() }
private enum CodingKeys : String, CodingKey {
case tickets
}
required public init(from decoder: Decoder) throws {
try super.init(from: decoder)
let container = try decoder.container(keyedBy: CodingKeys.self)
tickets = try container.decodeIfPresent([DeliveryTicket].self, forKey: .tickets) ?? []
}
public override func encode(to encoder: Encoder) throws {
try super.encode(to: encoder)
var container = encoder.container(keyedBy: CodingKeys.self)
if tickets.count > 0 { try container.encode(tickets, forKey: .tickets) }
}
}
// @DataContract
public class BaseResponse : Codable
{
/**
*
*/
// @DataMember
// @ApiMember(DataType="BaseResponseResult", Description="", Name="Status", ParameterType="body")
public var status:BaseResponseResult
required public init(){}
}
// @DataContract
public class BaseResponseResult : Codable
{
/**
*
*/
// @DataMember
// @ApiMember(DataType="string", Description="", Name="StatusCode", ParameterType="body")
public var statusCode:String
/**
*
*/
// @DataMember
// @ApiMember(DataType="string", Description="", Name="Login", ParameterType="body")
public var login:String
/**
*
*/
// @DataMember
// @ApiMember(DataType="string", Description="", Name="ErrorCode", ParameterType="body")
public var errorCode:String
/**
*
*/
// @DataMember
// @ApiMember(DataType="string", Description="", Name="ErrorDisplayText", ParameterType="body")
public var errorDisplayText:String
/**
*
*/
// @DataMember
// @ApiMember(DataType="string", Description="", Name="ErrorMessage", ParameterType="body")
public var errorMessage:String
/**
*
*/
// @DataMember
// @ApiMember(DataType="string", Description="", ExcludeInSchema=true, Name="DomainName", ParameterType="body")
public var domainName:String
/**
*
*/
// @DataMember
// @ApiMember(DataType="string", Description="", ExcludeInSchema=true, Name="IPAddress", ParameterType="body")
public var ipAddress:String
required public init(){}
}
// @DataContract
public class DeliveryTicket : Codable
{
// @DataMember
public var refNumber:String
// @DataMember
public var date:Date
// @DataMember
public var accountNumber:Int
// @DataMember
public var name:String
// @DataMember
public var address:String
// @DataMember
public var address2:String
// @DataMember
public var city:String
// @DataMember
public var state:String
// @DataMember
public var zipCode:String
// @DataMember
public var student:String
// @DataMember
public var contact:String
// @DataMember
public var delivered:Bool
// @DataMember
public var district:String
// @DataMember
public var school:String
// @DataMember
public var deliveryEmployee:String
// @DataMember
public var timeFrame:String
// @DataMember
public var createdDate:Date
// @DataMember
public var dependentAttributes:[DependentAttribute] = []
// @DataMember
public var ticketType:String
// @DataMember
public var hasImages:Bool
// @DataMember
public var hasSignature:Bool
// @DataMember
public var base64Signature:String
// @DataMember
public var notes:String
// @DataMember
public var images:[Base64Image] = []
// @DataMember
public var deliveryItems:[DeliveryItem] = []
required public init(){}
}
// @DataContract
public class DependentAttribute : Codable
{
// @DataMember
public var attribute:String
// @DataMember
public var attributeValue:String
required public init(){}
}
// @DataContract
public class Base64Image : Codable
{
// @DataMember
public var data:String
// @DataMember
public var fileName:String
required public init(){}
}
// @DataContract
public class DeliveryItem : Codable
{
// @DataMember
public var quantity:Double
// @DataMember
public var item:String
// @DataMember
public var Description:String
required public init(){}
}
Swift DeliveryTicketsRequest 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.
GET /api/DeliveryTickets HTTP/1.1 Host: active-ewebservice.biz Accept: application/xml
HTTP/1.1 200 OK
Content-Type: application/xml
Content-Length: length
<DeliveryTicketsResponse xmlns:i="http://www.w3.org/2001/XMLSchema-instance" xmlns="http://schemas.datacontract.org/2004/07/AIM.WebService">
<Status>
<DomainName>String</DomainName>
<ErrorCode>String</ErrorCode>
<ErrorDisplayText>String</ErrorDisplayText>
<ErrorMessage>String</ErrorMessage>
<IpAddress>String</IpAddress>
<Login>String</Login>
<StatusCode>String</StatusCode>
</Status>
<Tickets>
<DeliveryTicket>
<AccountNumber>0</AccountNumber>
<Address>String</Address>
<Address2>String</Address2>
<Base64Signature>String</Base64Signature>
<City>String</City>
<Contact>String</Contact>
<CreatedDate>0001-01-01T00:00:00</CreatedDate>
<Date>0001-01-01T00:00:00</Date>
<Delivered>false</Delivered>
<DeliveryEmployee>String</DeliveryEmployee>
<DeliveryItems>
<DeliveryItem>
<Description>String</Description>
<Item>String</Item>
<Quantity>0</Quantity>
</DeliveryItem>
</DeliveryItems>
<DependentAttributes>
<DependentAttribute>
<Attribute>String</Attribute>
<AttributeValue>String</AttributeValue>
</DependentAttribute>
</DependentAttributes>
<District>String</District>
<HasImages>false</HasImages>
<HasSignature>false</HasSignature>
<Images>
<Base64Image>
<Data>String</Data>
<FileName>String</FileName>
</Base64Image>
</Images>
<Name>String</Name>
<Notes>String</Notes>
<RefNumber>String</RefNumber>
<School>String</School>
<State>String</State>
<Student>String</Student>
<TicketType>String</TicketType>
<TimeFrame>String</TimeFrame>
<ZipCode>String</ZipCode>
</DeliveryTicket>
</Tickets>
</DeliveryTicketsResponse>