Security News
pnpm 10.0.0 Blocks Lifecycle Scripts by Default
pnpm 10 blocks lifecycle scripts by default to improve security, addressing supply chain attack risks but sparking debate over compatibility and workflow changes.
@myinterview/global-api-sdk
Advanced tools
You can see the full typed documentation here.
This project requires NodeJS (version 8 or later) and NPM. Node and NPM are really easy to install. To make sure you have them available on your machine, try running the following command.
$ npm -v && node -v
6.4.1
v8.16.0
npm i @myinterview/global-api-sdk
import { GlobalApi } from '@myinterview/global-api-sdk';
GlobalApi.setConfig({
secret: 'yoursecret',
companyId: 'yourcompanyid',
accessKey: 'youraccesskey',
});
To use the SDK you have to set the configuration with the keys provided by myinterview prior use of the classes.
This call will populate the headers you need to connect to the global API service it will return an object that you can use in you request.
import { GlobalApi } from '@myinterview/global-api-sdk';
GlobalApi.populateHeaders({
secret: 'yoursecret',
companyId: 'yourcompanyid',
accessKey: 'youraccesskey',
});
It will return:
{
'x-myinterview-timestamp': 'headTimestamp',
'x-myinterview-key': 'headKey',
'x-myinterview-signed': 'headSigned'
}
interface IApiResponseObj<T = any> {
statusCode: number;
errorCode: number;
statusReason: string;
callId: string;
data?: T;
time: Date | number;
}
IApiResponseObj
Type | Field | Description |
---|---|---|
number | statusCode | Status code of the response |
number | errorCode | Internal error code |
string | statusReason | Info message of the response |
string | callId | Internal call ID |
any | data | This field contain the data required based on the request |
Date / number | time | Timestamp |
This is the response object you will receive from the SDK the content of data will change based on your request.
interface IApiErrorObj {
errorMessage: string | ValidationError[];
errorDetails?: string;
statusCode: number;
errorCode: number;
statusReason: string;
callId?: string;
time: Date | number;
}
IApiResponseObj
Type | Field | Description |
---|---|---|
string | errorMessage | Error message |
string / undefined | errorDetails | Error message details |
number | statusCode | Status code of the response |
number | errorCode | Internal error code |
string | statusReason | Info message of the response |
string | callId | Internal call ID |
Date / number | time | Timestamp |
This is the error response object you will receive from the SDK.
You can catch the error the same way you catch error normally.
try {
const res = await GAVideos.getVideoPersonality("");
} catch (error) {
// The error will be of type IApiErrorObj the definition is above.
console.log(error)
}
GAVideos.getVideoPersonality("").then((res) => {
// Type IApiResponseObj
}).catch((error) => {
// The error will be of type IApiErrorObj the definition is above.
console.log(error)
})
import { GACandidates } from '@myinterview/global-api-sdk';
interface IBody {
job_id: string;
communication?: boolean;
deadlineDate?: Date | string | number;
timezoneForInvite?: string;
candidates: {
username?: string;
email: string;
phone?: string;
status?: string;
reminders?: {
Content: string;
companyName: string;
greetings?: string;
isSent: boolean;
reminderDate: Date | string;
timezone: string;
}[];
type?: string;
candidate_id?: string;
apiKey?: string;
jobTitle?: string;
urlStart?: string;
}[];
};
await GACandidates.createBulkCandidates(body);
createBulkCandidatesBody
Type | Field | Description |
---|---|---|
string | job_id | ID of the job to connect the candidate |
boolean / undefined | communication | Flag to send mails with the creation |
Date / string / number / undefined | deadlineDate | Deadline date for the candidate/s |
string / undefined | timezoneForInvite | Timezone for the deadline |
Array of candidate object | candidates | Array of candidate objects definition is above in the interface |
This call will create one or more candidates and connect them to your Job.
interface IBody {
id: string; // You have to provide the id of the candidate
status?: string;
username?: string;
deadline?: string | Date | number;
timezoneForInvite?: string;
};
await GACandidates.updateCandidate(body);
updateCandidateBody
Type | Field | Description |
---|---|---|
string | id | ID of the candidate |
string / undefined | status | Status of the candidate |
string / undefined | username | Username of the candidate |
Date / string / number / undefined | deadline | Deadline date for the candidate/s |
string / undefined | timezoneForInvite | Timezone for the deadline |
import { GACompanies } from '@myinterview/global-api-sdk';
const res: IApiResponseObj<ICompany> = await GACompanies.getCompanyInfo();
const companyInfo = res.data;
const res: IApiResponseObj<ITemplate[]> = await GACompanies.getCompanyTemplates();
const templates = res.data;
interface IBody {
id?: string | number;
hideQuestions?: boolean;
name: string;
questions: {
numOfRetakes: number;
partDuration: number;
question: string;
timeLimit?: number;
videoQuestion?: string;
}[];
intoductionURL?: string;
}[]
await GACompanies.createCompanyTemplateBulk(body);
createCompanyTemplateBulkBody
Type | Field | Description |
---|---|---|
string | id | ID of the company template |
boolean / undefined | hideQuestions | hideQuestions flag |
string | name | Name of the template |
string / undefined | intoductionURL | Url of the introduction video on the application page |
Array of job questions | questions | Array of job questions objects definition is above in the interface |
import { GAJobs } from '@myinterview/global-api-sdk';
const res: IApiResponseObj<IJob[]> = await GAJobs.getJobs();
const jobs = res.data;
const ids: string[];
const res: IApiResponseObj<IJob[]> = await GAJobs.getJobsWithIds(ids);
const jobs = res.data;
const id: string;
const res: IApiResponseObj<IJob> = await GAJobs.getJob(id);
const job = res.data;
interface IBody {
title: string;
language?: string;
overlay?: string;
termsUrl?: string;
privacyUrl?: string;
backgroundImage?: string;
transcriptLanguage?: string;
config?: IJobConfig;
deadlineDate?: string | Date | number;
experience?: string;
jobDescription?: string;
logo?: string;
questions?: IQuestion[];
skills?: string[];
introVideo?: string;
}
await GAJobs.createJob(body);
createJobBody
Type | Field | Description |
---|---|---|
string | title | Title of the job |
string / undefined | language | Language of the job |
string / undefined | overlay | Overlay of the of the application page (Value in Color Hexa #000000) |
string / undefined | termsUrl | Url of the Terms of Service |
string / undefined | privacyUrl | Url of the Privacy |
string / undefined | backgroundImage | Background Image of the of the application page |
string / undefined | transcriptLanguage | Language of the transcript video |
Config Object | config | Configuration object definition is above in the interface |
Date / string / number / undefined | deadlineDate | Deadline date for the job |
string / undefined | experience | experience of the job |
string / undefined | jobDescription | Job description |
string / undefined | logo | Logo |
Array of job questions | questions | Array of job questions objects definition is above in the interface |
Array of string / undefined | skills | skills |
string / undefined | introVideo | introduction video for application page |
interface IBody {
job_id: string; // REQUIRED !
language?: string;
overlay?: string;
termsUrl?: string;
privacyUrl?: string;
backgroundImage?: string;
transcriptLanguage?: string;
title?: string;
config?: IJobConfig;
deadlineDate?: string | Date | number;
experience?: string;
jobDescription?: string;
logo?: string;
questions?: IQuestion[];
skills?: string[];
introVideo?: string;
}
await GAJobs.updateJob(body);
updateJobBody
Type | Field | Description |
---|---|---|
string | job_id | ID of the job |
string | title | Title of the job |
string / undefined | language | Language of the job |
string / undefined | overlay | Overlay of the of the application page (Value in Color Hexa #000000) |
string / undefined | termsUrl | Url of the Terms of Service |
string / undefined | privacyUrl | Url of the Privacy |
string / undefined | backgroundImage | Background Image of the of the application page |
string / undefined | transcriptLanguage | Language of the transcript video |
Config Object | config | Configuration object definition is above in the interface |
Date / string / number / undefined | deadlineDate | Deadline date for the job |
string / undefined | experience | experience of the job |
string / undefined | jobDescription | Job description |
string / undefined | logo | Logo |
Array of job questions | questions | Array of job questions objects definition is above in the interface |
Array of string / undefined | skills | skills |
string / undefined | introVideo | introduction video for application page |
import { GAVideos } from '@myinterview/global-api-sdk';
const id: string;
const res: IApiResponseObj<IVideo> = await GAVideos.getVideo(id);
const video = res.data;
const id: string;
const res: IApiResponseObj<IPersonality> = await GAVideos.getVideoPersonality(id);
const personality = res.data;
FAQs
SDK to access myInterview Global API
The npm package @myinterview/global-api-sdk receives a total of 0 weekly downloads. As such, @myinterview/global-api-sdk popularity was classified as not popular.
We found that @myinterview/global-api-sdk demonstrated a not healthy version release cadence and project activity because the last version was released a year ago. It has 7 open source maintainers collaborating on the project.
Did you know?
Socket for GitHub automatically highlights issues in each pull request and monitors the health of all your open source dependencies. Discover the contents of your packages and block harmful activity before you install or update your dependencies.
Security News
pnpm 10 blocks lifecycle scripts by default to improve security, addressing supply chain attack risks but sparking debate over compatibility and workflow changes.
Product
Socket now supports uv.lock files to ensure consistent, secure dependency resolution for Python projects and enhance supply chain security.
Research
Security News
Socket researchers have discovered multiple malicious npm packages targeting Solana private keys, abusing Gmail to exfiltrate the data and drain Solana wallets.