UNPKG

box-node-sdk

Version:

Official SDK for Box Platform APIs

494 lines (487 loc) 16.8 kB
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; }