MyApp

<back to all web services

CreateInterview

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 enum JobApplicationStatus
{
    Applied = 'Applied',
    PhoneScreening = 'PhoneScreening',
    PhoneScreeningCompleted = 'PhoneScreeningCompleted',
    Interview = 'Interview',
    InterviewCompleted = 'InterviewCompleted',
    Offer = 'Offer',
    Disqualified = 'Disqualified',
}

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

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

    public appUser: AppUser;
    public applicationStatus?: JobApplicationStatus;
    public notes: string;

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

// @ValidateRequest(Validator="IsAuthenticated")
export class CreateInterview implements ICreateDb<Interview>
{
    // @Validate(Validator="NotNull")
    public bookingTime: string;

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

    // @Validate(Validator="GreaterThan(0)", Message="An employee to perform interview must be selected.")
    public appUserId: string;

    public applicationStatus: JobApplicationStatus;

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

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

{
	bookingTime: 0001-01-01,
	jobApplicationId: 0,
	appUserId: String,
	applicationStatus: Applied
}
HTTP/1.1 200 OK
Content-Type: text/jsv
Content-Length: length

{
	id: 0,
	bookingTime: 0001-01-01,
	jobApplicationId: 0,
	appUserId: String,
	appUser: 
	{
		id: String,
		firstName: String,
		lastName: String,
		displayName: String,
		profileUrl: String
	},
	applicationStatus: Applied,
	notes: String,
	createdDate: 0001-01-01,
	createdBy: String,
	modifiedDate: 0001-01-01,
	modifiedBy: String,
	deletedDate: 0001-01-01,
	deletedBy: String
}