MyApp

<back to all web services

UpdateJobOffer

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 UpdateJobOffer implements IPatchDb<JobOffer>
{
    public id?: number;
    public salaryOffer?: number;
    public currency: string;
    public jobApplicationId?: number;
    public applicationStatus?: JobApplicationStatus;
    public notes?: string;

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

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

{
	id: 0,
	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
}