MyApp

<back to all web services

CreateJobOffer

Talent
Requires Authentication

// @DataContract
export class AuditBase
{
    // @DataMember(Order=1)
    public createdDate: string;

    // @DataMember(Order=2)
    // @Required()
    public createdBy: string;

    // @DataMember(Order=3)
    public modifiedDate: string;

    // @DataMember(Order=4)
    // @Required()
    public modifiedBy: string;

    // @DataMember(Order=5)
    public deletedDate?: string;

    // @DataMember(Order=6)
    public deletedBy: string;

    public constructor(init?: Partial<AuditBase>) { (Object as any).assign(this, init); }
}

export class AppUser
{
    public id: string;
    public firstName?: string;
    public lastName?: string;
    public displayName?: string;
    public profileUrl?: string;

    public constructor(init?: Partial<AppUser>) { (Object as any).assign(this, init); }
}

export class JobOffer extends AuditBase
{
    public id: number;
    public salaryOffer: number;
    public currency: string;
    // @References("typeof(MyApp.ServiceModel.JobApplication)")
    public jobApplicationId: number;

    // @References("typeof(MyApp.ServiceModel.AppUser)")
    public appUserId: string;

    public appUser: AppUser;
    public notes: string;

    public constructor(init?: Partial<JobOffer>) { super(init); (Object as any).assign(this, init); }
}

export enum JobApplicationStatus
{
    Applied = 'Applied',
    PhoneScreening = 'PhoneScreening',
    PhoneScreeningCompleted = 'PhoneScreeningCompleted',
    Interview = 'Interview',
    InterviewCompleted = 'InterviewCompleted',
    Offer = 'Offer',
    Disqualified = 'Disqualified',
}

// @ValidateRequest(Validator="IsAuthenticated")
export class CreateJobOffer implements ICreateDb<JobOffer>
{
    // @Validate(Validator="GreaterThan(0)")
    public salaryOffer: number;

    public currency: string;
    // @Validate(Validator="GreaterThan(0)")
    public jobApplicationId: number;

    public applicationStatus: JobApplicationStatus;
    // @Validate(Validator="NotEmpty")
    public notes: string;

    public constructor(init?: Partial<CreateJobOffer>) { (Object as any).assign(this, init); }
}

TypeScript CreateJobOffer 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/CreateJobOffer HTTP/1.1 
Host: blazor-gallery.servicestack.net 
Accept: text/csv
Content-Type: text/csv
Content-Length: length

{"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"}