import Foundation
import ServiceStack
// @ValidateRequest(Validator="IsAuthenticated")
public class QueryJobApplicationComments : QueryDb<JobApplicationComment>
{
public var jobApplicationId:Int?
required public init(){ super.init() }
private enum CodingKeys : String, CodingKey {
case jobApplicationId
}
required public init(from decoder: Decoder) throws {
try super.init(from: decoder)
let container = try decoder.container(keyedBy: CodingKeys.self)
jobApplicationId = try container.decodeIfPresent(Int.self, forKey: .jobApplicationId)
}
public override func encode(to encoder: Encoder) throws {
try super.encode(to: encoder)
var container = encoder.container(keyedBy: CodingKeys.self)
if jobApplicationId != nil { try container.encode(jobApplicationId, forKey: .jobApplicationId) }
}
}
public class JobApplicationComment : AuditBase
{
public var id:Int
// @References(typeof(AppUser))
public var appUserId:String
public var appUser:AppUser
// @References(typeof(JobApplication))
public var jobApplicationId:Int
public var comment:String
required public init(){ super.init() }
private enum CodingKeys : String, CodingKey {
case id
case appUserId
case appUser
case jobApplicationId
case comment
}
required public init(from decoder: Decoder) throws {
try super.init(from: decoder)
let container = try decoder.container(keyedBy: CodingKeys.self)
id = try container.decodeIfPresent(Int.self, forKey: .id)
appUserId = try container.decodeIfPresent(String.self, forKey: .appUserId)
appUser = try container.decodeIfPresent(AppUser.self, forKey: .appUser)
jobApplicationId = try container.decodeIfPresent(Int.self, forKey: .jobApplicationId)
comment = try container.decodeIfPresent(String.self, forKey: .comment)
}
public override func encode(to encoder: Encoder) throws {
try super.encode(to: encoder)
var container = encoder.container(keyedBy: CodingKeys.self)
if id != nil { try container.encode(id, forKey: .id) }
if appUserId != nil { try container.encode(appUserId, forKey: .appUserId) }
if appUser != nil { try container.encode(appUser, forKey: .appUser) }
if jobApplicationId != nil { try container.encode(jobApplicationId, forKey: .jobApplicationId) }
if comment != nil { try container.encode(comment, forKey: .comment) }
}
}
public class AppUser : Codable
{
public var id:String
public var firstName:String
public var lastName:String
public var displayName:String
public var profileUrl:String
required public init(){}
}
public class Todo : Codable
{
public var id:Int
public var text:String
public var isFinished:Bool
required public init(){}
}
Swift QueryJobApplicationComments DTOs
To override the Content-type in your clients, use the HTTP Accept Header, append the .csv suffix or ?format=csv
The following are sample HTTP requests and responses. The placeholders shown need to be replaced with actual values.
POST /csv/reply/QueryJobApplicationComments HTTP/1.1
Host: blazor-gallery.servicestack.net
Accept: text/csv
Content-Type: text/csv
Content-Length: length
{"jobApplicationId":0,"skip":0,"take":0,"orderBy":"String","orderByDesc":"String","include":"String","fields":"String","meta":{"String":"String"}}
HTTP/1.1 200 OK Content-Type: text/csv Content-Length: length {"offset":0,"total":0,"results":[{"id":0,"appUserId":"String","appUser":{"id":"String","firstName":"String","lastName":"String","displayName":"String","profileUrl":"String"},"jobApplicationId":0,"comment":"String","createdDate":"0001-01-01T00:00:00","createdBy":"String","modifiedDate":"0001-01-01T00:00:00","modifiedBy":"String","deletedDate":"0001-01-01T00:00:00","deletedBy":"String"}],"meta":{"String":"String"},"responseStatus":{"errorCode":"String","message":"String","stackTrace":"String","errors":[{"errorCode":"String","fieldName":"String","message":"String","meta":{"String":"String"}}],"meta":{"String":"String"}}}