/* Options: Date: 2024-11-24 14:35:25 SwiftVersion: 5.0 Version: 6.50 Tip: To override a DTO option, remove "//" prefix before updating BaseUrl: https://clubready.com/api/current //BaseClass: //AddModelExtensions: True //AddServiceStackTypes: True IncludeTypes: CreateUserNotesRequest.* //ExcludeTypes: //ExcludeGenericBaseTypes: False //AddResponseStatus: False //AddImplicitVersion: //AddDescriptionAsComments: True //InitializeCollections: True //TreatTypesAsStrings: //DefaultImports: Foundation,ServiceStack */ import Foundation import ServiceStack // @Route("/users/notes/create", "POST") public class CreateUserNotesRequest : CreateUserNotesRequestDto, IReturn, IRestrictedApiRequest { public typealias Return = CreateUserNotesResponse /** * Api Key - grants access to resources */ // @ApiMember(DataType="string", Description="Api Key - grants access to resources", IsRequired=true, Name="ApiKey", ParameterType="query") public var apiKey:String /** * ClubReady Club ID (StoreID internally) */ // @ApiMember(DataType="integer", Description="ClubReady Club ID (StoreID internally)", IsRequired=true, Name="StoreId", ParameterType="query") public var storeId:Int? /** * Notes are being posted by this ClubReady User ID. */ // @ApiMember(DataType="integer", Description="Notes are being posted by this ClubReady User ID.", Name="PostedBy", ParameterType="query") public var postedBy:Int? /** * Create notes */ // @ApiMember(Description="Create notes", IsRequired=true, Name="UserNotes") public var userNotes:[SubmittedNote] = [] public var restrictedId:Int? public var restrictedResourceType:RestrictedResourceType required public init(){ super.init() } private enum CodingKeys : String, CodingKey { case apiKey case storeId case postedBy case userNotes case restrictedId case restrictedResourceType } required public init(from decoder: Decoder) throws { try super.init(from: decoder) let container = try decoder.container(keyedBy: CodingKeys.self) apiKey = try container.decodeIfPresent(String.self, forKey: .apiKey) storeId = try container.decodeIfPresent(Int.self, forKey: .storeId) postedBy = try container.decodeIfPresent(Int.self, forKey: .postedBy) userNotes = try container.decodeIfPresent([SubmittedNote].self, forKey: .userNotes) ?? [] restrictedId = try container.decodeIfPresent(Int.self, forKey: .restrictedId) restrictedResourceType = try container.decodeIfPresent(RestrictedResourceType.self, forKey: .restrictedResourceType) } public override func encode(to encoder: Encoder) throws { try super.encode(to: encoder) var container = encoder.container(keyedBy: CodingKeys.self) if apiKey != nil { try container.encode(apiKey, forKey: .apiKey) } if storeId != nil { try container.encode(storeId, forKey: .storeId) } if postedBy != nil { try container.encode(postedBy, forKey: .postedBy) } if userNotes.count > 0 { try container.encode(userNotes, forKey: .userNotes) } if restrictedId != nil { try container.encode(restrictedId, forKey: .restrictedId) } if restrictedResourceType != nil { try container.encode(restrictedResourceType, forKey: .restrictedResourceType) } } } public class CreateUserNotesResponse : CreateUserNotesResponseDto { public var noteIds:[Int] = [] required public init(){ super.init() } private enum CodingKeys : String, CodingKey { case noteIds } required public init(from decoder: Decoder) throws { try super.init(from: decoder) let container = try decoder.container(keyedBy: CodingKeys.self) noteIds = try container.decodeIfPresent([Int].self, forKey: .noteIds) ?? [] } public override func encode(to encoder: Encoder) throws { try super.encode(to: encoder) var container = encoder.container(keyedBy: CodingKeys.self) if noteIds.count > 0 { try container.encode(noteIds, forKey: .noteIds) } } } public enum RestrictedResourceType : String, Codable { case Store case Chain case User case Undefined } public protocol IRestrictedApiRequest : IApiKeyEndpoint { var restrictedId:Int? { get set } var restrictedResourceType:RestrictedResourceType { get set } } public protocol IApiKeyEndpoint { var apiKey:String { get set } } public class ApiDtoBase : Codable { public var apiKey:String public var storeId:Int? public var chainId:Int? required public init(){} } public class SubmittedNote : Codable { public var userId:Int public var subject:String public var text:String required public init(){} } public class CreateUserNotesRequestDto : ApiDtoBase { public var postedBy:Int? public var userNotes:[SubmittedNote] = [] required public init(){ super.init() } private enum CodingKeys : String, CodingKey { case postedBy case userNotes } required public init(from decoder: Decoder) throws { try super.init(from: decoder) let container = try decoder.container(keyedBy: CodingKeys.self) postedBy = try container.decodeIfPresent(Int.self, forKey: .postedBy) userNotes = try container.decodeIfPresent([SubmittedNote].self, forKey: .userNotes) ?? [] } public override func encode(to encoder: Encoder) throws { try super.encode(to: encoder) var container = encoder.container(keyedBy: CodingKeys.self) if postedBy != nil { try container.encode(postedBy, forKey: .postedBy) } if userNotes.count > 0 { try container.encode(userNotes, forKey: .userNotes) } } } public class CreateUserNotesResponseDto : ApiResponseBase { public var noteIds:[Int] = [] required public init(){ super.init() } private enum CodingKeys : String, CodingKey { case noteIds } required public init(from decoder: Decoder) throws { try super.init(from: decoder) let container = try decoder.container(keyedBy: CodingKeys.self) noteIds = try container.decodeIfPresent([Int].self, forKey: .noteIds) ?? [] } public override func encode(to encoder: Encoder) throws { try super.encode(to: encoder) var container = encoder.container(keyedBy: CodingKeys.self) if noteIds.count > 0 { try container.encode(noteIds, forKey: .noteIds) } } } public class ApiResponseBase : Codable { public var success:Bool public var message:String required public init(){} }