UNPKG

box-node-sdk

Version:

Official SDK for Box Platform APIs

373 lines (372 loc) 13.2 kB
import { serializeCollections } from '../schemas/collections'; import { deserializeCollections } from '../schemas/collections'; import { serializeClientError } from '../schemas/clientError'; import { deserializeClientError } from '../schemas/clientError'; import { serializeItemsOffsetPaginated } from '../schemas/itemsOffsetPaginated'; import { deserializeItemsOffsetPaginated } from '../schemas/itemsOffsetPaginated'; import { serializeCollection } from '../schemas/collection'; import { deserializeCollection } from '../schemas/collection'; import { ResponseFormat } from '../networking/fetchOptions'; import { Collections } from '../schemas/collections'; import { ClientError } from '../schemas/clientError'; import { ItemsOffsetPaginated } from '../schemas/itemsOffsetPaginated'; import { Collection } from '../schemas/collection'; 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 GetCollectionItemsOptionals { readonly queryParams: GetCollectionItemsQueryParams = {} satisfies GetCollectionItemsQueryParams; readonly headers: GetCollectionItemsHeaders = new GetCollectionItemsHeaders( {}, ); readonly cancellationToken?: CancellationToken = void 0; constructor( fields: Omit< GetCollectionItemsOptionals, 'queryParams' | 'headers' | 'cancellationToken' > & Partial< Pick< GetCollectionItemsOptionals, 'queryParams' | 'headers' | 'cancellationToken' > >, ) { if (fields.queryParams !== undefined) { this.queryParams = fields.queryParams; } if (fields.headers !== undefined) { this.headers = fields.headers; } if (fields.cancellationToken !== undefined) { this.cancellationToken = fields.cancellationToken; } } } export interface GetCollectionItemsOptionalsInput { readonly queryParams?: GetCollectionItemsQueryParams; readonly headers?: GetCollectionItemsHeaders; readonly cancellationToken?: CancellationToken; } export class GetCollectionByIdOptionals { readonly headers: GetCollectionByIdHeaders = new GetCollectionByIdHeaders({}); readonly cancellationToken?: CancellationToken = void 0; constructor( fields: Omit<GetCollectionByIdOptionals, 'headers' | 'cancellationToken'> & Partial< Pick<GetCollectionByIdOptionals, 'headers' | 'cancellationToken'> >, ) { if (fields.headers !== undefined) { this.headers = fields.headers; } if (fields.cancellationToken !== undefined) { this.cancellationToken = fields.cancellationToken; } } } export interface GetCollectionByIdOptionalsInput { readonly headers?: GetCollectionByIdHeaders; readonly cancellationToken?: CancellationToken; } export interface GetCollectionsQueryParams { /** * A comma-separated list of attributes to include in the * response. This can be used to request fields that are * not normally returned in a standard response. * * Be aware that specifying this parameter will have the * effect that none of the standard fields are returned in * the response unless explicitly specified, instead only * fields for the mini representation are returned, additional * to the fields requested. */ readonly fields?: readonly string[]; /** * The offset of the item at which to begin the response. * * Queries with offset parameter value * exceeding 10000 will be rejected * with a 400 response. */ readonly offset?: number; /** * The maximum number of items to return per page. */ readonly limit?: number; } export class GetCollectionsHeaders { /** * Extra headers that will be included in the HTTP request. */ readonly extraHeaders?: { readonly [key: string]: undefined | string; } = {}; constructor( fields: Omit<GetCollectionsHeaders, 'extraHeaders'> & Partial<Pick<GetCollectionsHeaders, 'extraHeaders'>>, ) { if (fields.extraHeaders !== undefined) { this.extraHeaders = fields.extraHeaders; } } } export interface GetCollectionsHeadersInput { /** * Extra headers that will be included in the HTTP request. */ readonly extraHeaders?: { readonly [key: string]: undefined | string; }; } export interface GetCollectionItemsQueryParams { /** * A comma-separated list of attributes to include in the * response. This can be used to request fields that are * not normally returned in a standard response. * * Be aware that specifying this parameter will have the * effect that none of the standard fields are returned in * the response unless explicitly specified, instead only * fields for the mini representation are returned, additional * to the fields requested. */ readonly fields?: readonly string[]; /** * The offset of the item at which to begin the response. * * Queries with offset parameter value * exceeding 10000 will be rejected * with a 400 response. */ readonly offset?: number; /** * The maximum number of items to return per page. */ readonly limit?: number; } export class GetCollectionItemsHeaders { /** * Extra headers that will be included in the HTTP request. */ readonly extraHeaders?: { readonly [key: string]: undefined | string; } = {}; constructor( fields: Omit<GetCollectionItemsHeaders, 'extraHeaders'> & Partial<Pick<GetCollectionItemsHeaders, 'extraHeaders'>>, ) { if (fields.extraHeaders !== undefined) { this.extraHeaders = fields.extraHeaders; } } } export interface GetCollectionItemsHeadersInput { /** * Extra headers that will be included in the HTTP request. */ readonly extraHeaders?: { readonly [key: string]: undefined | string; }; } export class GetCollectionByIdHeaders { /** * Extra headers that will be included in the HTTP request. */ readonly extraHeaders?: { readonly [key: string]: undefined | string; } = {}; constructor( fields: Omit<GetCollectionByIdHeaders, 'extraHeaders'> & Partial<Pick<GetCollectionByIdHeaders, 'extraHeaders'>>, ) { if (fields.extraHeaders !== undefined) { this.extraHeaders = fields.extraHeaders; } } } export interface GetCollectionByIdHeadersInput { /** * Extra headers that will be included in the HTTP request. */ readonly extraHeaders?: { readonly [key: string]: undefined | string; }; } export class CollectionsManager { readonly auth?: Authentication; readonly networkSession: NetworkSession = new NetworkSession({}); constructor( fields: Omit< CollectionsManager, | 'networkSession' | 'getCollections' | 'getCollectionItems' | 'getCollectionById' > & Partial<Pick<CollectionsManager, 'networkSession'>>, ) { if (fields.auth !== undefined) { this.auth = fields.auth; } if (fields.networkSession !== undefined) { this.networkSession = fields.networkSession; } } /** * Retrieves all collections for a given user. * * Currently, only the `favorites` collection * is supported. * @param {GetCollectionsQueryParams} queryParams Query parameters of getCollections method * @param {GetCollectionsHeadersInput} headersInput Headers of getCollections method * @param {CancellationToken} cancellationToken Token used for request cancellation. * @returns {Promise<Collections>} */ async getCollections( queryParams: GetCollectionsQueryParams = {} satisfies GetCollectionsQueryParams, headersInput: GetCollectionsHeadersInput = new GetCollectionsHeaders({}), cancellationToken?: CancellationToken, ): Promise<Collections> { const headers: GetCollectionsHeaders = new GetCollectionsHeaders({ extraHeaders: headersInput.extraHeaders, }); const queryParamsMap: { readonly [key: string]: string; } = prepareParams({ ['fields']: queryParams.fields ? queryParams.fields.map(toString).join(',') : undefined, ['offset']: toString(queryParams.offset) as string, ['limit']: toString(queryParams.limit) 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/collections', ) as string, method: 'GET', params: queryParamsMap, headers: headersMap, responseFormat: 'json' as ResponseFormat, auth: this.auth, networkSession: this.networkSession, cancellationToken: cancellationToken, }), ); return { ...deserializeCollections(response.data!), rawData: response.data!, }; } /** * Retrieves the files and/or folders contained within * this collection. * @param {string} collectionId The ID of the collection. Example: "926489" * @param {GetCollectionItemsOptionalsInput} optionalsInput * @returns {Promise<ItemsOffsetPaginated>} */ async getCollectionItems( collectionId: string, optionalsInput: GetCollectionItemsOptionalsInput = {}, ): Promise<ItemsOffsetPaginated> { const optionals: GetCollectionItemsOptionals = new GetCollectionItemsOptionals({ queryParams: optionalsInput.queryParams, headers: optionalsInput.headers, cancellationToken: optionalsInput.cancellationToken, }); const queryParams: any = optionals.queryParams; const headers: any = optionals.headers; const cancellationToken: any = optionals.cancellationToken; const queryParamsMap: { readonly [key: string]: string; } = prepareParams({ ['fields']: queryParams.fields ? queryParams.fields.map(toString).join(',') : undefined, ['offset']: toString(queryParams.offset) as string, ['limit']: toString(queryParams.limit) 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/collections/', (toString(collectionId) as string)!, '/items', ) as string, method: 'GET', params: queryParamsMap, headers: headersMap, responseFormat: 'json' as ResponseFormat, auth: this.auth, networkSession: this.networkSession, cancellationToken: cancellationToken, }), ); return { ...deserializeItemsOffsetPaginated(response.data!), rawData: response.data!, }; } /** * Retrieves a collection by its ID. * @param {string} collectionId The ID of the collection. Example: "926489" * @param {GetCollectionByIdOptionalsInput} optionalsInput * @returns {Promise<Collection>} */ async getCollectionById( collectionId: string, optionalsInput: GetCollectionByIdOptionalsInput = {}, ): Promise<Collection> { const optionals: GetCollectionByIdOptionals = new GetCollectionByIdOptionals({ 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/collections/', (toString(collectionId) as string)!, ) as string, method: 'GET', headers: headersMap, responseFormat: 'json' as ResponseFormat, auth: this.auth, networkSession: this.networkSession, cancellationToken: cancellationToken, }), ); return { ...deserializeCollection(response.data!), rawData: response.data!, }; } } export interface CollectionsManagerInput { readonly auth?: Authentication; readonly networkSession?: NetworkSession; }