import Foundation
import ServiceStack
// @ValidateRequest(Validator="IsAuthenticated")
public class QueryPhoneScreens : QueryDb<PhoneScreen>
{
public var id:Int?
public var jobApplicationId:Int?
required public init(){ super.init() }
private enum CodingKeys : String, CodingKey {
case id
case jobApplicationId
}
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)
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 id != nil { try container.encode(id, forKey: .id) }
if jobApplicationId != nil { try container.encode(jobApplicationId, forKey: .jobApplicationId) }
}
}
public class PhoneScreen : 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 applicationStatus:JobApplicationStatus?
public var notes:String
required public init(){ super.init() }
private enum CodingKeys : String, CodingKey {
case id
case appUserId
case appUser
case jobApplicationId
case applicationStatus
case notes
}
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)
applicationStatus = try container.decodeIfPresent(JobApplicationStatus.self, forKey: .applicationStatus)
notes = try container.decodeIfPresent(String.self, forKey: .notes)
}
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 applicationStatus != nil { try container.encode(applicationStatus, forKey: .applicationStatus) }
if notes != nil { try container.encode(notes, forKey: .notes) }
}
}
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 enum JobApplicationStatus : String, Codable
{
case Applied
case PhoneScreening
case PhoneScreeningCompleted
case Interview
case InterviewCompleted
case Offer
case Disqualified
}
public class Todo : Codable
{
public var id:Int
public var text:String
public var isFinished:Bool
required public init(){}
}
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/QueryPhoneScreens HTTP/1.1
Host: blazor-gallery.servicestack.net
Accept: text/jsv
Content-Type: text/jsv
Content-Length: length
{
id: 0,
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, applicationStatus: Applied, notes: 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 } } }