MyApp

<back to all web services

CreateJobOffer

Talent
Requires Authentication
import Foundation
import ServiceStack

// @ValidateRequest(Validator="IsAuthenticated")
public class CreateJobOffer : ICreateDb<JobOffer>, Codable
{
    // @Validate(Validator="GreaterThan(0)")
    public var salaryOffer:Int

    public var currency:String
    // @Validate(Validator="GreaterThan(0)")
    public var jobApplicationId:Int

    public var applicationStatus:JobApplicationStatus
    // @Validate(Validator="NotEmpty")
    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 CreateJobOffer DTOs

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

HTTP + JSV

The following are sample HTTP requests and responses. The placeholders shown need to be replaced with actual values.

POST /jsv/reply/CreateJobOffer HTTP/1.1 
Host: blazor-gallery.servicestack.net 
Accept: text/jsv
Content-Type: text/jsv
Content-Length: length

{
	salaryOffer: 0,
	currency: String,
	jobApplicationId: 0,
	applicationStatus: Applied,
	notes: String
}
HTTP/1.1 200 OK
Content-Type: text/jsv
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-01,
	createdBy: String,
	modifiedDate: 0001-01-01,
	modifiedBy: String,
	deletedDate: 0001-01-01,
	deletedBy: String
}