/* Options: Date: 2025-09-03 20:29:30 SwiftVersion: 5.0 Version: 6.10 Tip: To override a DTO option, remove "//" prefix before updating BaseUrl: https://foundrystage-api-app.azurewebsites.net //BaseClass: //AddModelExtensions: True //AddServiceStackTypes: True IncludeTypes: SearchAllUsersRequest.* //ExcludeTypes: //ExcludeGenericBaseTypes: False //AddResponseStatus: False //AddImplicitVersion: //AddDescriptionAsComments: True //InitializeCollections: True //TreatTypesAsStrings: //DefaultImports: Foundation,ServiceStack */ import Foundation import ServiceStack // @Route("/users/all", "GET") public class SearchAllUsersRequest : SearchOperationTenanted, IReturn { public typealias Return = SearchAllUsersResponse 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 class SearchAllUsersResponse : Codable { public var responseStatus:ResponseStatus? public var userDetails:[UserDetails] = [] required public init(){} } public class GetOperationUnTenanted : IHasGetOptions, IGet, Codable { public var embed:String? required public init(){} } public protocol IHasGetOptions { var embed:String? { get set } } public class SearchOperationUnTenanted : GetOperationUnTenanted, IHasSearchOptions { public var distinct:String? public var limit:Int? public var offset:Int? public var sort:String? public var filter:String? required public init(){ super.init() } private enum CodingKeys : String, CodingKey { case distinct case limit case offset case sort case filter } required public init(from decoder: Decoder) throws { try super.init(from: decoder) let container = try decoder.container(keyedBy: CodingKeys.self) distinct = try container.decodeIfPresent(String.self, forKey: .distinct) limit = try container.decodeIfPresent(Int.self, forKey: .limit) offset = try container.decodeIfPresent(Int.self, forKey: .offset) sort = try container.decodeIfPresent(String.self, forKey: .sort) filter = try container.decodeIfPresent(String.self, forKey: .filter) } public override func encode(to encoder: Encoder) throws { try super.encode(to: encoder) var container = encoder.container(keyedBy: CodingKeys.self) if distinct != nil { try container.encode(distinct, forKey: .distinct) } if limit != nil { try container.encode(limit, forKey: .limit) } if offset != nil { try container.encode(offset, forKey: .offset) } if sort != nil { try container.encode(sort, forKey: .sort) } if filter != nil { try container.encode(filter, forKey: .filter) } } } public protocol IHasSearchOptions : IHasGetOptions { var limit:Int? { get set } var offset:Int? { get set } var sort:String? { get set } var filter:String? { get set } } public protocol ITenantedRequest { var organisationId:String? { get set } } public class SearchOperationTenanted : SearchOperationUnTenanted, ITenantedRequest { public var organisationId:String? required public init(){ super.init() } private enum CodingKeys : String, CodingKey { case organisationId } required public init(from decoder: Decoder) throws { try super.init(from: decoder) let container = try decoder.container(keyedBy: CodingKeys.self) organisationId = try container.decodeIfPresent(String.self, forKey: .organisationId) } public override func encode(to encoder: Encoder) throws { try super.encode(to: encoder) var container = encoder.container(keyedBy: CodingKeys.self) if organisationId != nil { try container.encode(organisationId, forKey: .organisationId) } } } public class UserDetails : UserAccountMembership { public var lastLoginDate:Date? public var twoFactorEnabled:Bool? public var name:String? required public init(){ super.init() } private enum CodingKeys : String, CodingKey { case lastLoginDate case twoFactorEnabled case name } required public init(from decoder: Decoder) throws { try super.init(from: decoder) let container = try decoder.container(keyedBy: CodingKeys.self) lastLoginDate = try container.decodeIfPresent(Date.self, forKey: .lastLoginDate) twoFactorEnabled = try container.decodeIfPresent(Bool.self, forKey: .twoFactorEnabled) name = try container.decodeIfPresent(String.self, forKey: .name) } public override func encode(to encoder: Encoder) throws { try super.encode(to: encoder) var container = encoder.container(keyedBy: CodingKeys.self) if lastLoginDate != nil { try container.encode(lastLoginDate, forKey: .lastLoginDate) } if twoFactorEnabled != nil { try container.encode(twoFactorEnabled, forKey: .twoFactorEnabled) } if name != nil { try container.encode(name, forKey: .name) } } } public protocol IIdentifiableResource { var id:String? { get set } } public enum AccountType : String, Codable { case Person case Machine } public enum AccountStatus : String, Codable { case Shadowed case Registered } public class UserAccountMembership : IIdentifiableResource, Codable { public var userId:String? public var userEmailAddress:String? public var status:AccountStatus? public var type:AccountType? public var roles:[String] = [] public var id:String? public var organisationId:String? required public init(){} }