box-node-sdk
Version:
Official SDK for Box Platform APIs
493 lines (492 loc) • 17.6 kB
text/typescript
import { serializeSignRequest } from '../schemas/signRequest';
import { deserializeSignRequest } from '../schemas/signRequest';
import { serializeClientError } from '../schemas/clientError';
import { deserializeClientError } from '../schemas/clientError';
import { serializeSignRequests } from '../schemas/signRequests';
import { deserializeSignRequests } from '../schemas/signRequests';
import { serializeSignRequestCreateRequest } from '../schemas/signRequestCreateRequest';
import { deserializeSignRequestCreateRequest } from '../schemas/signRequestCreateRequest';
import { ResponseFormat } from '../networking/fetchOptions';
import { SignRequest } from '../schemas/signRequest';
import { ClientError } from '../schemas/clientError';
import { SignRequests } from '../schemas/signRequests';
import { SignRequestCreateRequest } from '../schemas/signRequestCreateRequest';
import { BoxSdkError } from '../box/errors';
import { Authentication } from '../networking/auth';
import { NetworkSession } from '../networking/network';
import { FetchOptions } from '../networking/fetchOptions';
import { FetchResponse } from '../networking/fetchResponse';
import { prepareParams } from '../internal/utils';
import { toString } from '../internal/utils';
import { ByteStream } from '../internal/utils';
import { CancellationToken } from '../internal/utils';
import { sdToJson } from '../serialization/json';
import { SerializedData } from '../serialization/json';
import { sdIsEmpty } from '../serialization/json';
import { sdIsBoolean } from '../serialization/json';
import { sdIsNumber } from '../serialization/json';
import { sdIsString } from '../serialization/json';
import { sdIsList } from '../serialization/json';
import { sdIsMap } from '../serialization/json';
export class CancelSignRequestOptionals {
readonly headers: CancelSignRequestHeaders = new CancelSignRequestHeaders({});
readonly cancellationToken?: CancellationToken = void 0;
constructor(
fields: Omit<CancelSignRequestOptionals, 'headers' | 'cancellationToken'> &
Partial<
Pick<CancelSignRequestOptionals, 'headers' | 'cancellationToken'>
>,
) {
if (fields.headers !== undefined) {
this.headers = fields.headers;
}
if (fields.cancellationToken !== undefined) {
this.cancellationToken = fields.cancellationToken;
}
}
}
export interface CancelSignRequestOptionalsInput {
readonly headers?: CancelSignRequestHeaders;
readonly cancellationToken?: CancellationToken;
}
export class ResendSignRequestOptionals {
readonly headers: ResendSignRequestHeaders = new ResendSignRequestHeaders({});
readonly cancellationToken?: CancellationToken = void 0;
constructor(
fields: Omit<ResendSignRequestOptionals, 'headers' | 'cancellationToken'> &
Partial<
Pick<ResendSignRequestOptionals, 'headers' | 'cancellationToken'>
>,
) {
if (fields.headers !== undefined) {
this.headers = fields.headers;
}
if (fields.cancellationToken !== undefined) {
this.cancellationToken = fields.cancellationToken;
}
}
}
export interface ResendSignRequestOptionalsInput {
readonly headers?: ResendSignRequestHeaders;
readonly cancellationToken?: CancellationToken;
}
export class GetSignRequestByIdOptionals {
readonly headers: GetSignRequestByIdHeaders = new GetSignRequestByIdHeaders(
{},
);
readonly cancellationToken?: CancellationToken = void 0;
constructor(
fields: Omit<GetSignRequestByIdOptionals, 'headers' | 'cancellationToken'> &
Partial<
Pick<GetSignRequestByIdOptionals, 'headers' | 'cancellationToken'>
>,
) {
if (fields.headers !== undefined) {
this.headers = fields.headers;
}
if (fields.cancellationToken !== undefined) {
this.cancellationToken = fields.cancellationToken;
}
}
}
export interface GetSignRequestByIdOptionalsInput {
readonly headers?: GetSignRequestByIdHeaders;
readonly cancellationToken?: CancellationToken;
}
export class CreateSignRequestOptionals {
readonly headers: CreateSignRequestHeaders = new CreateSignRequestHeaders({});
readonly cancellationToken?: CancellationToken = void 0;
constructor(
fields: Omit<CreateSignRequestOptionals, 'headers' | 'cancellationToken'> &
Partial<
Pick<CreateSignRequestOptionals, 'headers' | 'cancellationToken'>
>,
) {
if (fields.headers !== undefined) {
this.headers = fields.headers;
}
if (fields.cancellationToken !== undefined) {
this.cancellationToken = fields.cancellationToken;
}
}
}
export interface CreateSignRequestOptionalsInput {
readonly headers?: CreateSignRequestHeaders;
readonly cancellationToken?: CancellationToken;
}
export class CancelSignRequestHeaders {
/**
* Extra headers that will be included in the HTTP request. */
readonly extraHeaders?: {
readonly [key: string]: undefined | string;
} = {};
constructor(
fields: Omit<CancelSignRequestHeaders, 'extraHeaders'> &
Partial<Pick<CancelSignRequestHeaders, 'extraHeaders'>>,
) {
if (fields.extraHeaders !== undefined) {
this.extraHeaders = fields.extraHeaders;
}
}
}
export interface CancelSignRequestHeadersInput {
/**
* Extra headers that will be included in the HTTP request. */
readonly extraHeaders?: {
readonly [key: string]: undefined | string;
};
}
export class ResendSignRequestHeaders {
/**
* Extra headers that will be included in the HTTP request. */
readonly extraHeaders?: {
readonly [key: string]: undefined | string;
} = {};
constructor(
fields: Omit<ResendSignRequestHeaders, 'extraHeaders'> &
Partial<Pick<ResendSignRequestHeaders, 'extraHeaders'>>,
) {
if (fields.extraHeaders !== undefined) {
this.extraHeaders = fields.extraHeaders;
}
}
}
export interface ResendSignRequestHeadersInput {
/**
* Extra headers that will be included in the HTTP request. */
readonly extraHeaders?: {
readonly [key: string]: undefined | string;
};
}
export class GetSignRequestByIdHeaders {
/**
* Extra headers that will be included in the HTTP request. */
readonly extraHeaders?: {
readonly [key: string]: undefined | string;
} = {};
constructor(
fields: Omit<GetSignRequestByIdHeaders, 'extraHeaders'> &
Partial<Pick<GetSignRequestByIdHeaders, 'extraHeaders'>>,
) {
if (fields.extraHeaders !== undefined) {
this.extraHeaders = fields.extraHeaders;
}
}
}
export interface GetSignRequestByIdHeadersInput {
/**
* Extra headers that will be included in the HTTP request. */
readonly extraHeaders?: {
readonly [key: string]: undefined | string;
};
}
export interface GetSignRequestsQueryParams {
/**
* Defines the position marker at which to begin returning results. This is
* used when paginating using marker-based pagination.
*
* This requires `usemarker` to be set to `true`. */
readonly marker?: string;
/**
* The maximum number of items to return per page. */
readonly limit?: number;
/**
* A list of sender emails to filter the signature requests by sender.
* If provided, `shared_requests` must be set to `true`. */
readonly senders?: readonly string[];
/**
* If set to `true`, only includes requests that user is not an owner,
* but user is a collaborator. Collaborator access is determined by the
* user access level of the sign files of the request.
* Default is `false`. Must be set to `true` if `senders` are provided. */
readonly sharedRequests?: boolean;
}
export class GetSignRequestsHeaders {
/**
* Extra headers that will be included in the HTTP request. */
readonly extraHeaders?: {
readonly [key: string]: undefined | string;
} = {};
constructor(
fields: Omit<GetSignRequestsHeaders, 'extraHeaders'> &
Partial<Pick<GetSignRequestsHeaders, 'extraHeaders'>>,
) {
if (fields.extraHeaders !== undefined) {
this.extraHeaders = fields.extraHeaders;
}
}
}
export interface GetSignRequestsHeadersInput {
/**
* Extra headers that will be included in the HTTP request. */
readonly extraHeaders?: {
readonly [key: string]: undefined | string;
};
}
export class CreateSignRequestHeaders {
/**
* Extra headers that will be included in the HTTP request. */
readonly extraHeaders?: {
readonly [key: string]: undefined | string;
} = {};
constructor(
fields: Omit<CreateSignRequestHeaders, 'extraHeaders'> &
Partial<Pick<CreateSignRequestHeaders, 'extraHeaders'>>,
) {
if (fields.extraHeaders !== undefined) {
this.extraHeaders = fields.extraHeaders;
}
}
}
export interface CreateSignRequestHeadersInput {
/**
* Extra headers that will be included in the HTTP request. */
readonly extraHeaders?: {
readonly [key: string]: undefined | string;
};
}
export class SignRequestsManager {
readonly auth?: Authentication;
readonly networkSession: NetworkSession = new NetworkSession({});
constructor(
fields: Omit<
SignRequestsManager,
| 'networkSession'
| 'cancelSignRequest'
| 'resendSignRequest'
| 'getSignRequestById'
| 'getSignRequests'
| 'createSignRequest'
> &
Partial<Pick<SignRequestsManager, 'networkSession'>>,
) {
if (fields.auth !== undefined) {
this.auth = fields.auth;
}
if (fields.networkSession !== undefined) {
this.networkSession = fields.networkSession;
}
}
/**
* Cancels a sign request.
* @param {string} signRequestId The ID of the signature request.
Example: "33243242"
* @param {CancelSignRequestOptionalsInput} optionalsInput
* @returns {Promise<SignRequest>}
*/
async cancelSignRequest(
signRequestId: string,
optionalsInput: CancelSignRequestOptionalsInput = {},
): Promise<SignRequest> {
const optionals: CancelSignRequestOptionals =
new CancelSignRequestOptionals({
headers: optionalsInput.headers,
cancellationToken: optionalsInput.cancellationToken,
});
const headers: any = optionals.headers;
const cancellationToken: any = optionals.cancellationToken;
const headersMap: {
readonly [key: string]: string;
} = prepareParams({ ...{}, ...headers.extraHeaders });
const response: FetchResponse =
await this.networkSession.networkClient.fetch(
new FetchOptions({
url: ''.concat(
this.networkSession.baseUrls.baseUrl,
'/2.0/sign_requests/',
(toString(signRequestId) as string)!,
'/cancel',
) as string,
method: 'POST',
headers: headersMap,
responseFormat: 'json' as ResponseFormat,
auth: this.auth,
networkSession: this.networkSession,
cancellationToken: cancellationToken,
}),
);
return {
...deserializeSignRequest(response.data!),
rawData: response.data!,
};
}
/**
* Resends a signature request email to all outstanding signers.
* @param {string} signRequestId The ID of the signature request.
Example: "33243242"
* @param {ResendSignRequestOptionalsInput} optionalsInput
* @returns {Promise<undefined>}
*/
async resendSignRequest(
signRequestId: string,
optionalsInput: ResendSignRequestOptionalsInput = {},
): Promise<undefined> {
const optionals: ResendSignRequestOptionals =
new ResendSignRequestOptionals({
headers: optionalsInput.headers,
cancellationToken: optionalsInput.cancellationToken,
});
const headers: any = optionals.headers;
const cancellationToken: any = optionals.cancellationToken;
const headersMap: {
readonly [key: string]: string;
} = prepareParams({ ...{}, ...headers.extraHeaders });
const response: FetchResponse =
await this.networkSession.networkClient.fetch(
new FetchOptions({
url: ''.concat(
this.networkSession.baseUrls.baseUrl,
'/2.0/sign_requests/',
(toString(signRequestId) as string)!,
'/resend',
) as string,
method: 'POST',
headers: headersMap,
responseFormat: 'no_content' as ResponseFormat,
auth: this.auth,
networkSession: this.networkSession,
cancellationToken: cancellationToken,
}),
);
return void 0;
}
/**
* Gets a sign request by ID.
* @param {string} signRequestId The ID of the signature request.
Example: "33243242"
* @param {GetSignRequestByIdOptionalsInput} optionalsInput
* @returns {Promise<SignRequest>}
*/
async getSignRequestById(
signRequestId: string,
optionalsInput: GetSignRequestByIdOptionalsInput = {},
): Promise<SignRequest> {
const optionals: GetSignRequestByIdOptionals =
new GetSignRequestByIdOptionals({
headers: optionalsInput.headers,
cancellationToken: optionalsInput.cancellationToken,
});
const headers: any = optionals.headers;
const cancellationToken: any = optionals.cancellationToken;
const headersMap: {
readonly [key: string]: string;
} = prepareParams({ ...{}, ...headers.extraHeaders });
const response: FetchResponse =
await this.networkSession.networkClient.fetch(
new FetchOptions({
url: ''.concat(
this.networkSession.baseUrls.baseUrl,
'/2.0/sign_requests/',
(toString(signRequestId) as string)!,
) as string,
method: 'GET',
headers: headersMap,
responseFormat: 'json' as ResponseFormat,
auth: this.auth,
networkSession: this.networkSession,
cancellationToken: cancellationToken,
}),
);
return {
...deserializeSignRequest(response.data!),
rawData: response.data!,
};
}
/**
* Gets signature requests created by a user. If the `sign_files` and/or
* `parent_folder` are deleted, the signature request will not return in the list.
* @param {GetSignRequestsQueryParams} queryParams Query parameters of getSignRequests method
* @param {GetSignRequestsHeadersInput} headersInput Headers of getSignRequests method
* @param {CancellationToken} cancellationToken Token used for request cancellation.
* @returns {Promise<SignRequests>}
*/
async getSignRequests(
queryParams: GetSignRequestsQueryParams = {} satisfies GetSignRequestsQueryParams,
headersInput: GetSignRequestsHeadersInput = new GetSignRequestsHeaders({}),
cancellationToken?: CancellationToken,
): Promise<SignRequests> {
const headers: GetSignRequestsHeaders = new GetSignRequestsHeaders({
extraHeaders: headersInput.extraHeaders,
});
const queryParamsMap: {
readonly [key: string]: string;
} = prepareParams({
['marker']: toString(queryParams.marker) as string,
['limit']: toString(queryParams.limit) as string,
['senders']: queryParams.senders
? queryParams.senders.map(toString).join(',')
: undefined,
['shared_requests']: toString(queryParams.sharedRequests) as string,
});
const headersMap: {
readonly [key: string]: string;
} = prepareParams({ ...{}, ...headers.extraHeaders });
const response: FetchResponse =
await this.networkSession.networkClient.fetch(
new FetchOptions({
url: ''.concat(
this.networkSession.baseUrls.baseUrl,
'/2.0/sign_requests',
) as string,
method: 'GET',
params: queryParamsMap,
headers: headersMap,
responseFormat: 'json' as ResponseFormat,
auth: this.auth,
networkSession: this.networkSession,
cancellationToken: cancellationToken,
}),
);
return {
...deserializeSignRequests(response.data!),
rawData: response.data!,
};
}
/**
* Creates a signature request. This involves preparing a document for signing and
* sending the signature request to signers.
* @param {SignRequestCreateRequest} requestBody Request body of createSignRequest method
* @param {CreateSignRequestOptionalsInput} optionalsInput
* @returns {Promise<SignRequest>}
*/
async createSignRequest(
requestBody: SignRequestCreateRequest,
optionalsInput: CreateSignRequestOptionalsInput = {},
): Promise<SignRequest> {
const optionals: CreateSignRequestOptionals =
new CreateSignRequestOptionals({
headers: optionalsInput.headers,
cancellationToken: optionalsInput.cancellationToken,
});
const headers: any = optionals.headers;
const cancellationToken: any = optionals.cancellationToken;
const headersMap: {
readonly [key: string]: string;
} = prepareParams({ ...{}, ...headers.extraHeaders });
const response: FetchResponse =
await this.networkSession.networkClient.fetch(
new FetchOptions({
url: ''.concat(
this.networkSession.baseUrls.baseUrl,
'/2.0/sign_requests',
) as string,
method: 'POST',
headers: headersMap,
data: serializeSignRequestCreateRequest(requestBody),
contentType: 'application/json',
responseFormat: 'json' as ResponseFormat,
auth: this.auth,
networkSession: this.networkSession,
cancellationToken: cancellationToken,
}),
);
return {
...deserializeSignRequest(response.data!),
rawData: response.data!,
};
}
}
export interface SignRequestsManagerInput {
readonly auth?: Authentication;
readonly networkSession?: NetworkSession;
}