box-node-sdk
Version:
Official SDK for Box Platform APIs
494 lines (487 loc) • 16.8 kB
text/typescript
import { serializeWatermark } from '../schemas/watermark';
import { deserializeWatermark } from '../schemas/watermark';
import { serializeClientError } from '../schemas/clientError';
import { deserializeClientError } from '../schemas/clientError';
import { ResponseFormat } from '../networking/fetchOptions';
import { Watermark } from '../schemas/watermark';
import { ClientError } from '../schemas/clientError';
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 GetFolderWatermarkOptionals {
readonly headers: GetFolderWatermarkHeaders = new GetFolderWatermarkHeaders(
{},
);
readonly cancellationToken?: CancellationToken = void 0;
constructor(
fields: Omit<GetFolderWatermarkOptionals, 'headers' | 'cancellationToken'> &
Partial<
Pick<GetFolderWatermarkOptionals, 'headers' | 'cancellationToken'>
>,
) {
if (fields.headers !== undefined) {
this.headers = fields.headers;
}
if (fields.cancellationToken !== undefined) {
this.cancellationToken = fields.cancellationToken;
}
}
}
export interface GetFolderWatermarkOptionalsInput {
readonly headers?: GetFolderWatermarkHeaders;
readonly cancellationToken?: CancellationToken;
}
export class UpdateFolderWatermarkOptionals {
readonly headers: UpdateFolderWatermarkHeaders =
new UpdateFolderWatermarkHeaders({});
readonly cancellationToken?: CancellationToken = void 0;
constructor(
fields: Omit<
UpdateFolderWatermarkOptionals,
'headers' | 'cancellationToken'
> &
Partial<
Pick<UpdateFolderWatermarkOptionals, 'headers' | 'cancellationToken'>
>,
) {
if (fields.headers !== undefined) {
this.headers = fields.headers;
}
if (fields.cancellationToken !== undefined) {
this.cancellationToken = fields.cancellationToken;
}
}
}
export interface UpdateFolderWatermarkOptionalsInput {
readonly headers?: UpdateFolderWatermarkHeaders;
readonly cancellationToken?: CancellationToken;
}
export class DeleteFolderWatermarkOptionals {
readonly headers: DeleteFolderWatermarkHeaders =
new DeleteFolderWatermarkHeaders({});
readonly cancellationToken?: CancellationToken = void 0;
constructor(
fields: Omit<
DeleteFolderWatermarkOptionals,
'headers' | 'cancellationToken'
> &
Partial<
Pick<DeleteFolderWatermarkOptionals, 'headers' | 'cancellationToken'>
>,
) {
if (fields.headers !== undefined) {
this.headers = fields.headers;
}
if (fields.cancellationToken !== undefined) {
this.cancellationToken = fields.cancellationToken;
}
}
}
export interface DeleteFolderWatermarkOptionalsInput {
readonly headers?: DeleteFolderWatermarkHeaders;
readonly cancellationToken?: CancellationToken;
}
export class GetFolderWatermarkHeaders {
/**
* Extra headers that will be included in the HTTP request. */
readonly extraHeaders?: {
readonly [key: string]: undefined | string;
} = {};
constructor(
fields: Omit<GetFolderWatermarkHeaders, 'extraHeaders'> &
Partial<Pick<GetFolderWatermarkHeaders, 'extraHeaders'>>,
) {
if (fields.extraHeaders !== undefined) {
this.extraHeaders = fields.extraHeaders;
}
}
}
export interface GetFolderWatermarkHeadersInput {
/**
* Extra headers that will be included in the HTTP request. */
readonly extraHeaders?: {
readonly [key: string]: undefined | string;
};
}
export type UpdateFolderWatermarkRequestBodyWatermarkImprintField =
| 'default'
| string;
export class UpdateFolderWatermarkRequestBodyWatermarkField {
/**
* The type of watermark to apply.
*
* Currently only supports one option. */
readonly imprint: UpdateFolderWatermarkRequestBodyWatermarkImprintField =
'default' as UpdateFolderWatermarkRequestBodyWatermarkImprintField;
readonly rawData?: SerializedData;
constructor(
fields: Omit<UpdateFolderWatermarkRequestBodyWatermarkField, 'imprint'> &
Partial<Pick<UpdateFolderWatermarkRequestBodyWatermarkField, 'imprint'>>,
) {
if (fields.imprint !== undefined) {
this.imprint = fields.imprint;
}
if (fields.rawData !== undefined) {
this.rawData = fields.rawData;
}
}
}
export interface UpdateFolderWatermarkRequestBodyWatermarkFieldInput {
/**
* The type of watermark to apply.
*
* Currently only supports one option. */
readonly imprint?: UpdateFolderWatermarkRequestBodyWatermarkImprintField;
readonly rawData?: SerializedData;
}
export interface UpdateFolderWatermarkRequestBody {
/**
* The watermark to imprint on the folder. */
readonly watermark: UpdateFolderWatermarkRequestBodyWatermarkField;
readonly rawData?: SerializedData;
}
export class UpdateFolderWatermarkHeaders {
/**
* Extra headers that will be included in the HTTP request. */
readonly extraHeaders?: {
readonly [key: string]: undefined | string;
} = {};
constructor(
fields: Omit<UpdateFolderWatermarkHeaders, 'extraHeaders'> &
Partial<Pick<UpdateFolderWatermarkHeaders, 'extraHeaders'>>,
) {
if (fields.extraHeaders !== undefined) {
this.extraHeaders = fields.extraHeaders;
}
}
}
export interface UpdateFolderWatermarkHeadersInput {
/**
* Extra headers that will be included in the HTTP request. */
readonly extraHeaders?: {
readonly [key: string]: undefined | string;
};
}
export class DeleteFolderWatermarkHeaders {
/**
* Extra headers that will be included in the HTTP request. */
readonly extraHeaders?: {
readonly [key: string]: undefined | string;
} = {};
constructor(
fields: Omit<DeleteFolderWatermarkHeaders, 'extraHeaders'> &
Partial<Pick<DeleteFolderWatermarkHeaders, 'extraHeaders'>>,
) {
if (fields.extraHeaders !== undefined) {
this.extraHeaders = fields.extraHeaders;
}
}
}
export interface DeleteFolderWatermarkHeadersInput {
/**
* Extra headers that will be included in the HTTP request. */
readonly extraHeaders?: {
readonly [key: string]: undefined | string;
};
}
export class FolderWatermarksManager {
readonly auth?: Authentication;
readonly networkSession: NetworkSession = new NetworkSession({});
constructor(
fields: Omit<
FolderWatermarksManager,
| 'networkSession'
| 'getFolderWatermark'
| 'updateFolderWatermark'
| 'deleteFolderWatermark'
> &
Partial<Pick<FolderWatermarksManager, 'networkSession'>>,
) {
if (fields.auth !== undefined) {
this.auth = fields.auth;
}
if (fields.networkSession !== undefined) {
this.networkSession = fields.networkSession;
}
}
/**
* Retrieve the watermark for a folder.
* @param {string} folderId The unique identifier that represent a folder.
The ID for any folder can be determined
by visiting this folder in the web application
and copying the ID from the URL. For example,
for the URL `https://*.app.box.com/folder/123`
the `folder_id` is `123`.
The root folder of a Box account is
always represented by the ID `0`.
Example: "12345"
* @param {GetFolderWatermarkOptionalsInput} optionalsInput
* @returns {Promise<Watermark>}
*/
async getFolderWatermark(
folderId: string,
optionalsInput: GetFolderWatermarkOptionalsInput = {},
): Promise<Watermark> {
const optionals: GetFolderWatermarkOptionals =
new GetFolderWatermarkOptionals({
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/folders/',
(toString(folderId) as string)!,
'/watermark',
) as string,
method: 'GET',
headers: headersMap,
responseFormat: 'json' as ResponseFormat,
auth: this.auth,
networkSession: this.networkSession,
cancellationToken: cancellationToken,
}),
);
return {
...deserializeWatermark(response.data!),
rawData: response.data!,
};
}
/**
* Applies or update a watermark on a folder.
* @param {string} folderId The unique identifier that represent a folder.
The ID for any folder can be determined
by visiting this folder in the web application
and copying the ID from the URL. For example,
for the URL `https://*.app.box.com/folder/123`
the `folder_id` is `123`.
The root folder of a Box account is
always represented by the ID `0`.
Example: "12345"
* @param {UpdateFolderWatermarkRequestBody} requestBody Request body of updateFolderWatermark method
* @param {UpdateFolderWatermarkOptionalsInput} optionalsInput
* @returns {Promise<Watermark>}
*/
async updateFolderWatermark(
folderId: string,
requestBody: UpdateFolderWatermarkRequestBody,
optionalsInput: UpdateFolderWatermarkOptionalsInput = {},
): Promise<Watermark> {
const optionals: UpdateFolderWatermarkOptionals =
new UpdateFolderWatermarkOptionals({
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/folders/',
(toString(folderId) as string)!,
'/watermark',
) as string,
method: 'PUT',
headers: headersMap,
data: serializeUpdateFolderWatermarkRequestBody(requestBody),
contentType: 'application/json',
responseFormat: 'json' as ResponseFormat,
auth: this.auth,
networkSession: this.networkSession,
cancellationToken: cancellationToken,
}),
);
return {
...deserializeWatermark(response.data!),
rawData: response.data!,
};
}
/**
* Removes the watermark from a folder.
* @param {string} folderId The unique identifier that represent a folder.
The ID for any folder can be determined
by visiting this folder in the web application
and copying the ID from the URL. For example,
for the URL `https://*.app.box.com/folder/123`
the `folder_id` is `123`.
The root folder of a Box account is
always represented by the ID `0`.
Example: "12345"
* @param {DeleteFolderWatermarkOptionalsInput} optionalsInput
* @returns {Promise<undefined>}
*/
async deleteFolderWatermark(
folderId: string,
optionalsInput: DeleteFolderWatermarkOptionalsInput = {},
): Promise<undefined> {
const optionals: DeleteFolderWatermarkOptionals =
new DeleteFolderWatermarkOptionals({
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/folders/',
(toString(folderId) as string)!,
'/watermark',
) as string,
method: 'DELETE',
headers: headersMap,
responseFormat: 'no_content' as ResponseFormat,
auth: this.auth,
networkSession: this.networkSession,
cancellationToken: cancellationToken,
}),
);
return void 0;
}
}
export interface FolderWatermarksManagerInput {
readonly auth?: Authentication;
readonly networkSession?: NetworkSession;
}
export function serializeUpdateFolderWatermarkRequestBodyWatermarkImprintField(
val: UpdateFolderWatermarkRequestBodyWatermarkImprintField,
): SerializedData {
return val;
}
export function deserializeUpdateFolderWatermarkRequestBodyWatermarkImprintField(
val: SerializedData,
): UpdateFolderWatermarkRequestBodyWatermarkImprintField {
if (val == 'default') {
return val;
}
if (sdIsString(val)) {
return val;
}
throw new BoxSdkError({
message:
"Can't deserialize UpdateFolderWatermarkRequestBodyWatermarkImprintField",
});
}
export function serializeUpdateFolderWatermarkRequestBodyWatermarkField(
val: UpdateFolderWatermarkRequestBodyWatermarkField,
): SerializedData {
return {
['imprint']: serializeUpdateFolderWatermarkRequestBodyWatermarkImprintField(
val.imprint,
),
};
}
export function deserializeUpdateFolderWatermarkRequestBodyWatermarkField(
val: SerializedData,
): UpdateFolderWatermarkRequestBodyWatermarkField {
if (!sdIsMap(val)) {
throw new BoxSdkError({
message:
'Expecting a map for "UpdateFolderWatermarkRequestBodyWatermarkField"',
});
}
if (val.imprint == void 0) {
throw new BoxSdkError({
message:
'Expecting "imprint" of type "UpdateFolderWatermarkRequestBodyWatermarkField" to be defined',
});
}
const imprint: UpdateFolderWatermarkRequestBodyWatermarkImprintField =
deserializeUpdateFolderWatermarkRequestBodyWatermarkImprintField(
val.imprint,
);
return {
imprint: imprint,
} satisfies UpdateFolderWatermarkRequestBodyWatermarkField;
}
export function serializeUpdateFolderWatermarkRequestBodyWatermarkFieldInput(
val: UpdateFolderWatermarkRequestBodyWatermarkFieldInput,
): SerializedData {
return {
['imprint']:
val.imprint == void 0
? val.imprint
: serializeUpdateFolderWatermarkRequestBodyWatermarkImprintField(
val.imprint,
),
};
}
export function deserializeUpdateFolderWatermarkRequestBodyWatermarkFieldInput(
val: SerializedData,
): UpdateFolderWatermarkRequestBodyWatermarkFieldInput {
if (!sdIsMap(val)) {
throw new BoxSdkError({
message:
'Expecting a map for "UpdateFolderWatermarkRequestBodyWatermarkFieldInput"',
});
}
const imprint:
| undefined
| UpdateFolderWatermarkRequestBodyWatermarkImprintField =
val.imprint == void 0
? void 0
: deserializeUpdateFolderWatermarkRequestBodyWatermarkImprintField(
val.imprint,
);
return {
imprint: imprint,
} satisfies UpdateFolderWatermarkRequestBodyWatermarkFieldInput;
}
export function serializeUpdateFolderWatermarkRequestBody(
val: UpdateFolderWatermarkRequestBody,
): SerializedData {
return {
['watermark']: serializeUpdateFolderWatermarkRequestBodyWatermarkField(
val.watermark,
),
};
}
export function deserializeUpdateFolderWatermarkRequestBody(
val: SerializedData,
): UpdateFolderWatermarkRequestBody {
if (!sdIsMap(val)) {
throw new BoxSdkError({
message: 'Expecting a map for "UpdateFolderWatermarkRequestBody"',
});
}
if (val.watermark == void 0) {
throw new BoxSdkError({
message:
'Expecting "watermark" of type "UpdateFolderWatermarkRequestBody" to be defined',
});
}
const watermark: UpdateFolderWatermarkRequestBodyWatermarkField =
deserializeUpdateFolderWatermarkRequestBodyWatermarkField(val.watermark);
return { watermark: watermark } satisfies UpdateFolderWatermarkRequestBody;
}