MyApp

<back to all web services

UpdateJobOffer

Talent
Requires Authentication
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(){}
}


Swift UpdateJobOffer DTOs

To override the Content-type in your clients, use the HTTP Accept Header, append the .csv suffix or ?format=csv

HTTP + 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"}