/* Options: Date: 2025-09-07 12:48:11 SwiftVersion: 6.0 Version: 8.81 Tip: To override a DTO option, remove "//" prefix before updating BaseUrl: https://account.servicestack.net //BaseClass: //AddModelExtensions: True //AddServiceStackTypes: True //MakePropertiesOptional: True IncludeTypes: QueryCustomers.* //ExcludeTypes: //ExcludeGenericBaseTypes: False //AddResponseStatus: False //AddImplicitVersion: //AddDescriptionAsComments: True //InitializeCollections: False //TreatTypesAsStrings: //DefaultImports: Foundation,ServiceStack */ import Foundation import ServiceStack // @Route("/Customer") // @Route("/Customer/{Id}") public class Customer : IAddress, Codable { public var id:Int? public var email:String? public var displayName:String? public var firstName:String? public var lastName:String? public var company:String? public var phoneNumber:String? public var addressLine1:String? public var addressLine2:String? public var addressCity:String? public var addressZip:String? public var addressState:String? public var addressCountry:String? public var stripeCustomerId:String? public var stripeCouponId:String? public var plan:String? public var createdDate:Date? public var isReferrer:Bool? public var orders:[Order]? public var subscriptions:[Subscription]? required public init(){} } // @Route("/query/customers") // @ValidateRequest(Validator="IsAdmin") // @AutoQueryViewer(DefaultFields="Id,Name,Email,DisplayName,FirstName,LastName,Company,CreatedDate,Plan,IsReferrer", DefaultSearchField="Email", DefaultSearchType="Contains", IconUrl="material-icons:person", Title="Customers") public class QueryCustomers : QueryDb, IReturn { public typealias Return = QueryResponse required public init(){ super.init() } required public init(from decoder: Decoder) throws { try super.init(from: decoder) } public override func encode(to encoder: Encoder) throws { try super.encode(to: encoder) } } public protocol IAddress { var addressLine1:String? { get set } var addressLine2:String? { get set } var addressCity:String? { get set } var addressZip:String? { get set } var addressState:String? { get set } var addressCountry:String? { get set } } public class Order : IAddress, Codable { public var id:Int? public var customerId:Int? public var productName:String? public var firstName:String? public var lastName:String? public var email:String? public var company:String? public var phoneNumber:String? public var addressLine1:String? public var addressLine2:String? public var addressCity:String? public var addressZip:String? public var addressState:String? public var addressCountry:String? public var agreeTerms:Bool? public var notes:String? public var last4:String? public var subTotal:Int? public var couponId:String? public var discount:Int? public var tax:Int? public var total:Int? public var itemQuantity:Int? public var authorizedQuantity:Int? public var subscriptionId:Int? public var licenseRef:String? public var paymentId:Int? public var emailId:Int? public var paid:Bool? public var createdDate:Date? public var modifiedDate:Date? public var modifiedBy:String? public var cancelledDate:Date? public var cancelledReason:String? public var ipAddress:String? public var orderDetails:[OrderDetail]? required public init(){} } public class Subscription : Codable { public var id:Int? public var customerId:Int? public var email:String? public var skuId:Int? public var skuName:String? public var skuType:SkuType? public var code:String? public var quantity:Int? public var supportQuantity:Int? public var total:Int? public var isPlan:Bool? public var isRenewal:Bool? public var subscriptionDurationDays:Int? public var renewalDate:Date? public var licenseRef:String? public var licenseName:String? public var licenseAddress:String? public var licenseType:LicenseType? public var expiryDate:Date? public var licenseKey:LicenseKey? public var licenseKeyText:String? public var createdDate:Date? public var modifiedDate:Date? public var cancelledDate:Date? public var stripeSubscriptionId:String? public var emailId:Int? public var emailRenewalId:Int? public var emailExpiredId:Int? public var renewalSubscriptionId:Int? public var externalRef:String? public var notes:String? public var error:String? required public init(){} }