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 .jsv suffix or ?format=jsv
The following are sample HTTP requests and responses. The placeholders shown need to be replaced with actual values.
POST /jsv/reply/QueryJobApplicationComments HTTP/1.1
Host: blazor-gallery.servicestack.net
Accept: text/jsv
Content-Type: text/jsv
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/jsv
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-01,
createdBy: String,
modifiedDate: 0001-01-01,
modifiedBy: String,
deletedDate: 0001-01-01,
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
}
}
}