/* Options: Date: 2025-05-10 01:24:43 SwiftVersion: 5.0 Version: 8.40 Tip: To override a DTO option, remove "//" prefix before updating BaseUrl: https://active-ewebservice.biz/aeservices30/api //BaseClass: //AddModelExtensions: True //AddServiceStackTypes: True IncludeTypes: ScheduledExchangesPostRequest.* //ExcludeTypes: //ExcludeGenericBaseTypes: False //AddResponseStatus: False //AddImplicitVersion: //AddDescriptionAsComments: True //InitializeCollections: True //TreatTypesAsStrings: //DefaultImports: Foundation,ServiceStack */ import Foundation import ServiceStack /** * ScheduledExchangesRequires active-e Contracts Service. */ // @Route("/ScheduledExchanges", "POST") // @DataContract public class ScheduledExchangesPostRequest : BaseSecureRequest, IReturn { public typealias Return = ScheduledExchangesPostResponse // @DataMember public var acct:Int // @DataMember public var sub:Int // @DataMember public var exchangedItemID:Int // @DataMember public var postingDate:Date // @DataMember public var scheduledDate:Date // @DataMember public var newSku:String // @DataMember public var optionId:Int? // @DataMember public var exchangeNotes:String // @DataMember public var processed:Bool? // @DataMember public var statusId:Int? /** * Key/Value pair only. The 'Encrypted' proprety is not used for this API call. */ // @DataMember // @ApiMember(DataType="array", Description="Key/Value pair only. The 'Encrypted' proprety is not used for this API call.", Name="FormInputList", ParameterType="query") public var formInputList:[FormInput] = [] required public init(){ super.init() } private enum CodingKeys : String, CodingKey { case acct case sub case exchangedItemID case postingDate case scheduledDate case newSku case optionId case exchangeNotes case processed case statusId case formInputList } required public init(from decoder: Decoder) throws { try super.init(from: decoder) let container = try decoder.container(keyedBy: CodingKeys.self) acct = try container.decodeIfPresent(Int.self, forKey: .acct) sub = try container.decodeIfPresent(Int.self, forKey: .sub) exchangedItemID = try container.decodeIfPresent(Int.self, forKey: .exchangedItemID) postingDate = try container.decodeIfPresent(Date.self, forKey: .postingDate) scheduledDate = try container.decodeIfPresent(Date.self, forKey: .scheduledDate) newSku = try container.decodeIfPresent(String.self, forKey: .newSku) optionId = try container.decodeIfPresent(Int.self, forKey: .optionId) exchangeNotes = try container.decodeIfPresent(String.self, forKey: .exchangeNotes) processed = try container.decodeIfPresent(Bool.self, forKey: .processed) statusId = try container.decodeIfPresent(Int.self, forKey: .statusId) formInputList = try container.decodeIfPresent([FormInput].self, forKey: .formInputList) ?? [] } public override func encode(to encoder: Encoder) throws { try super.encode(to: encoder) var container = encoder.container(keyedBy: CodingKeys.self) if acct != nil { try container.encode(acct, forKey: .acct) } if sub != nil { try container.encode(sub, forKey: .sub) } if exchangedItemID != nil { try container.encode(exchangedItemID, forKey: .exchangedItemID) } if postingDate != nil { try container.encode(postingDate, forKey: .postingDate) } if scheduledDate != nil { try container.encode(scheduledDate, forKey: .scheduledDate) } if newSku != nil { try container.encode(newSku, forKey: .newSku) } if optionId != nil { try container.encode(optionId, forKey: .optionId) } if exchangeNotes != nil { try container.encode(exchangeNotes, forKey: .exchangeNotes) } if processed != nil { try container.encode(processed, forKey: .processed) } if statusId != nil { try container.encode(statusId, forKey: .statusId) } if formInputList.count > 0 { try container.encode(formInputList, forKey: .formInputList) } } } // @DataContract public class ScheduledExchangesPostResponse : BaseResponse { // @DataMember public var exchangeID:Int? required public init(){ super.init() } private enum CodingKeys : String, CodingKey { case exchangeID } required public init(from decoder: Decoder) throws { try super.init(from: decoder) let container = try decoder.container(keyedBy: CodingKeys.self) exchangeID = try container.decodeIfPresent(Int.self, forKey: .exchangeID) } public override func encode(to encoder: Encoder) throws { try super.encode(to: encoder) var container = encoder.container(keyedBy: CodingKeys.self) if exchangeID != nil { try container.encode(exchangeID, forKey: .exchangeID) } } } // @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 // @DataMember // @ApiMember(DataType="string", Name="OAuthToken", ParameterType="header") public var oAuthToken:String required public init(){} } // @DataContract public class BaseSecureRequest : BaseRequest { /** * */ // @DataMember // @ApiMember(DataType="string", Description="", Name="Token", ParameterType="Header") public var token:String /** * */ // @DataMember // @ApiMember(DataType="string", Description="", Name="DeviceId", ParameterType="Header") public var deviceId:String /** * */ // @DataMember // @ApiMember(DataType="string", Description="", IsRequired=true, Name="AppId", ParameterType="Header") public var appId:String required public init(){ super.init() } private enum CodingKeys : String, CodingKey { case token case deviceId case appId } 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) deviceId = try container.decodeIfPresent(String.self, forKey: .deviceId) appId = try container.decodeIfPresent(String.self, forKey: .appId) } 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) } if deviceId != nil { try container.encode(deviceId, forKey: .deviceId) } if appId != nil { try container.encode(appId, forKey: .appId) } } } // @DataContract(Name="FormInput") public class FormInput : Codable { /** * Field Name of the Input Field */ // @DataMember // @ApiMember(DataType="string", Description="Field Name of the Input Field", IsRequired=true, Name="Key", ParameterType="query") public var key:String /** * Value of the Input Field. */ // @DataMember // @ApiMember(DataType="string", Description="Value of the Input Field.", IsRequired=true, Name="Value", ParameterType="query") public var value:String /** * Whether or not the field is encryped with the C2B encryption key. */ // @DataMember // @ApiMember(DataType="boolean", Description="Whether or not the field is encryped with the C2B encryption key.", IsRequired=true, Name="Encrypted", ParameterType="query") public var encrypted:Bool required public init(){} } // @DataContract public class BaseResponse : Codable { /** * */ // @DataMember // @ApiMember(DataType="BaseResponseResult", Description="", Name="Status", ParameterType="body") public var status:BaseResponseResult required public init(){} }