import Foundation
import ServiceStack
// @ValidateRequest(Validator="IsAuthenticated")
public class UpdateJobOffer : IPatchDb<JobOffer>, Codable
{
public var id:Int?
public var salaryOffer:Int?
public var currency:String
public var jobApplicationId:Int?
public var applicationStatus:JobApplicationStatus?
public var notes: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 JobOffer : AuditBase
{
public var id:Int
public var salaryOffer:Int
public var currency:String
// @References(typeof(JobApplication))
public var jobApplicationId:Int
// @References(typeof(AppUser))
public var appUserId:String
public var appUser:AppUser
public var notes:String
required public init(){ super.init() }
private enum CodingKeys : String, CodingKey {
case id
case salaryOffer
case currency
case jobApplicationId
case appUserId
case appUser
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)
salaryOffer = try container.decodeIfPresent(Int.self, forKey: .salaryOffer)
currency = try container.decodeIfPresent(String.self, forKey: .currency)
jobApplicationId = try container.decodeIfPresent(Int.self, forKey: .jobApplicationId)
appUserId = try container.decodeIfPresent(String.self, forKey: .appUserId)
appUser = try container.decodeIfPresent(AppUser.self, forKey: .appUser)
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 salaryOffer != nil { try container.encode(salaryOffer, forKey: .salaryOffer) }
if currency != nil { try container.encode(currency, forKey: .currency) }
if jobApplicationId != nil { try container.encode(jobApplicationId, forKey: .jobApplicationId) }
if appUserId != nil { try container.encode(appUserId, forKey: .appUserId) }
if appUser != nil { try container.encode(appUser, forKey: .appUser) }
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(){}
}
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/UpdateJobOffer HTTP/1.1
Host: blazor-gallery.servicestack.net
Accept: text/csv
Content-Type: text/csv
Content-Length: length
{"id":0,"salaryOffer":0,"currency":"String","jobApplicationId":0,"applicationStatus":"Applied","notes":"String"}
HTTP/1.1 200 OK Content-Type: text/csv Content-Length: length {"id":0,"salaryOffer":0,"currency":"String","jobApplicationId":0,"appUserId":"String","appUser":{"id":"String","firstName":"String","lastName":"String","displayName":"String","profileUrl":"String"},"notes":"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"}