/* Options: Date: 2024-09-21 00:48:28 SwiftVersion: 5.0 Version: 8.30 Tip: To override a DTO option, remove "//" prefix before updating BaseUrl: https://active-ewebservice.biz/aeservices30/api //BaseClass: //AddModelExtensions: True //AddServiceStackTypes: True IncludeTypes: ScanForImportRequest.* //ExcludeTypes: //ExcludeGenericBaseTypes: False //AddResponseStatus: False //AddImplicitVersion: //AddDescriptionAsComments: True //InitializeCollections: True //TreatTypesAsStrings: //DefaultImports: Foundation,ServiceStack */ import Foundation import ServiceStack /** * ScanForImportRequires active-e Inventory Service */ // @Route("/ScanForImport", "POST") // @DataContract public class ScanForImportRequest : BaseSecureRequest, IReturn { public typealias Return = ScanForImportResponse // @DataMember public var Description:String // @DataMember public var items:[ScanItem] = [] // @DataMember public var receiveInventoryMode:Bool? // @DataMember public var appendMode:Bool? required public init(){ super.init() } private enum CodingKeys : String, CodingKey { case Description case items case receiveInventoryMode case appendMode } required public init(from decoder: Decoder) throws { try super.init(from: decoder) let container = try decoder.container(keyedBy: CodingKeys.self) Description = try container.decodeIfPresent(String.self, forKey: .Description) items = try container.decodeIfPresent([ScanItem].self, forKey: .items) ?? [] receiveInventoryMode = try container.decodeIfPresent(Bool.self, forKey: .receiveInventoryMode) appendMode = try container.decodeIfPresent(Bool.self, forKey: .appendMode) } public override func encode(to encoder: Encoder) throws { try super.encode(to: encoder) var container = encoder.container(keyedBy: CodingKeys.self) if Description != nil { try container.encode(Description, forKey: .Description) } if items.count > 0 { try container.encode(items, forKey: .items) } if receiveInventoryMode != nil { try container.encode(receiveInventoryMode, forKey: .receiveInventoryMode) } if appendMode != nil { try container.encode(appendMode, forKey: .appendMode) } } } // @DataContract public class ScanForImportResponse : BaseResponse { // @DataMember public var errorItems:[ScanErrorItem] = [] required public init(){ super.init() } private enum CodingKeys : String, CodingKey { case errorItems } required public init(from decoder: Decoder) throws { try super.init(from: decoder) let container = try decoder.container(keyedBy: CodingKeys.self) errorItems = try container.decodeIfPresent([ScanErrorItem].self, forKey: .errorItems) ?? [] } public override func encode(to encoder: Encoder) throws { try super.encode(to: encoder) var container = encoder.container(keyedBy: CodingKeys.self) if errorItems.count > 0 { try container.encode(errorItems, forKey: .errorItems) } } } // @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 public class ScanItem : IScanItem, Codable { // @DataMember public var skuPk:Int? // @DataMember public var sasPk:Int? // @DataMember public var sku:String // @DataMember public var serial:String // @DataMember public var quantity:Double // @DataMember public var exceptionInfo:ExceptionInfo required public init(){} } // @DataContract public class ScanErrorItem : IScanItem, Codable { // @DataMember public var skuPk:Int? // @DataMember public var sasPk:Int? // @DataMember public var sku:String // @DataMember public var serial:String // @DataMember public var quantity:Double // @DataMember public var exceptionInfo:ExceptionInfo // @DataMember public var errorMessage:String required public init(){} } // @DataContract public class ExceptionInfo : Codable { // @DataMember public var barcode:String // @DataMember public var Description:String // @DataMember public var base64Image:String // @DataMember public var category:Int // @DataMember public var subCategory:Int? required public init(){} } public protocol IScanItem { var skuPk:Int? { get set } var sasPk:Int? { get set } var sku:String { get set } var serial:String { get set } var quantity:Double { get set } var exceptionInfo:ExceptionInfo { get set } } // @DataContract public class BaseResponse : Codable { /** * */ // @DataMember // @ApiMember(DataType="BaseResponseResult", Description="", Name="Status", ParameterType="body") public var status:BaseResponseResult required public init(){} }