UNPKG

box-node-sdk

Version:

Official SDK for Box Platform APIs

503 lines (502 loc) 18.5 kB
import { serializeCollaborationAllowlistEntries } from '../schemas/collaborationAllowlistEntries'; import { deserializeCollaborationAllowlistEntries } from '../schemas/collaborationAllowlistEntries'; import { serializeClientError } from '../schemas/clientError'; import { deserializeClientError } from '../schemas/clientError'; import { serializeCollaborationAllowlistEntry } from '../schemas/collaborationAllowlistEntry'; import { deserializeCollaborationAllowlistEntry } from '../schemas/collaborationAllowlistEntry'; import { ResponseFormat } from '../networking/fetchOptions'; import { CollaborationAllowlistEntries } from '../schemas/collaborationAllowlistEntries'; import { ClientError } from '../schemas/clientError'; import { CollaborationAllowlistEntry } from '../schemas/collaborationAllowlistEntry'; 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 CreateCollaborationWhitelistEntryOptionals { readonly headers: CreateCollaborationWhitelistEntryHeaders = new CreateCollaborationWhitelistEntryHeaders({}); readonly cancellationToken?: CancellationToken = void 0; constructor( fields: Omit< CreateCollaborationWhitelistEntryOptionals, 'headers' | 'cancellationToken' > & Partial< Pick< CreateCollaborationWhitelistEntryOptionals, 'headers' | 'cancellationToken' > >, ) { if (fields.headers !== undefined) { this.headers = fields.headers; } if (fields.cancellationToken !== undefined) { this.cancellationToken = fields.cancellationToken; } } } export interface CreateCollaborationWhitelistEntryOptionalsInput { readonly headers?: CreateCollaborationWhitelistEntryHeaders; readonly cancellationToken?: CancellationToken; } export class GetCollaborationWhitelistEntryByIdOptionals { readonly headers: GetCollaborationWhitelistEntryByIdHeaders = new GetCollaborationWhitelistEntryByIdHeaders({}); readonly cancellationToken?: CancellationToken = void 0; constructor( fields: Omit< GetCollaborationWhitelistEntryByIdOptionals, 'headers' | 'cancellationToken' > & Partial< Pick< GetCollaborationWhitelistEntryByIdOptionals, 'headers' | 'cancellationToken' > >, ) { if (fields.headers !== undefined) { this.headers = fields.headers; } if (fields.cancellationToken !== undefined) { this.cancellationToken = fields.cancellationToken; } } } export interface GetCollaborationWhitelistEntryByIdOptionalsInput { readonly headers?: GetCollaborationWhitelistEntryByIdHeaders; readonly cancellationToken?: CancellationToken; } export class DeleteCollaborationWhitelistEntryByIdOptionals { readonly headers: DeleteCollaborationWhitelistEntryByIdHeaders = new DeleteCollaborationWhitelistEntryByIdHeaders({}); readonly cancellationToken?: CancellationToken = void 0; constructor( fields: Omit< DeleteCollaborationWhitelistEntryByIdOptionals, 'headers' | 'cancellationToken' > & Partial< Pick< DeleteCollaborationWhitelistEntryByIdOptionals, 'headers' | 'cancellationToken' > >, ) { if (fields.headers !== undefined) { this.headers = fields.headers; } if (fields.cancellationToken !== undefined) { this.cancellationToken = fields.cancellationToken; } } } export interface DeleteCollaborationWhitelistEntryByIdOptionalsInput { readonly headers?: DeleteCollaborationWhitelistEntryByIdHeaders; readonly cancellationToken?: CancellationToken; } export interface GetCollaborationWhitelistEntriesQueryParams { /** * 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; } export class GetCollaborationWhitelistEntriesHeaders { /** * Extra headers that will be included in the HTTP request. */ readonly extraHeaders?: { readonly [key: string]: undefined | string; } = {}; constructor( fields: Omit<GetCollaborationWhitelistEntriesHeaders, 'extraHeaders'> & Partial<Pick<GetCollaborationWhitelistEntriesHeaders, 'extraHeaders'>>, ) { if (fields.extraHeaders !== undefined) { this.extraHeaders = fields.extraHeaders; } } } export interface GetCollaborationWhitelistEntriesHeadersInput { /** * Extra headers that will be included in the HTTP request. */ readonly extraHeaders?: { readonly [key: string]: undefined | string; }; } export type CreateCollaborationWhitelistEntryRequestBodyDirectionField = | 'inbound' | 'outbound' | 'both' | string; export interface CreateCollaborationWhitelistEntryRequestBody { /** * The domain to add to the list of allowed domains. */ readonly domain: string; /** * The direction in which to allow collaborations. */ readonly direction: CreateCollaborationWhitelistEntryRequestBodyDirectionField; readonly rawData?: SerializedData; } export class CreateCollaborationWhitelistEntryHeaders { /** * Extra headers that will be included in the HTTP request. */ readonly extraHeaders?: { readonly [key: string]: undefined | string; } = {}; constructor( fields: Omit<CreateCollaborationWhitelistEntryHeaders, 'extraHeaders'> & Partial<Pick<CreateCollaborationWhitelistEntryHeaders, 'extraHeaders'>>, ) { if (fields.extraHeaders !== undefined) { this.extraHeaders = fields.extraHeaders; } } } export interface CreateCollaborationWhitelistEntryHeadersInput { /** * Extra headers that will be included in the HTTP request. */ readonly extraHeaders?: { readonly [key: string]: undefined | string; }; } export class GetCollaborationWhitelistEntryByIdHeaders { /** * Extra headers that will be included in the HTTP request. */ readonly extraHeaders?: { readonly [key: string]: undefined | string; } = {}; constructor( fields: Omit<GetCollaborationWhitelistEntryByIdHeaders, 'extraHeaders'> & Partial<Pick<GetCollaborationWhitelistEntryByIdHeaders, 'extraHeaders'>>, ) { if (fields.extraHeaders !== undefined) { this.extraHeaders = fields.extraHeaders; } } } export interface GetCollaborationWhitelistEntryByIdHeadersInput { /** * Extra headers that will be included in the HTTP request. */ readonly extraHeaders?: { readonly [key: string]: undefined | string; }; } export class DeleteCollaborationWhitelistEntryByIdHeaders { /** * Extra headers that will be included in the HTTP request. */ readonly extraHeaders?: { readonly [key: string]: undefined | string; } = {}; constructor( fields: Omit<DeleteCollaborationWhitelistEntryByIdHeaders, 'extraHeaders'> & Partial< Pick<DeleteCollaborationWhitelistEntryByIdHeaders, 'extraHeaders'> >, ) { if (fields.extraHeaders !== undefined) { this.extraHeaders = fields.extraHeaders; } } } export interface DeleteCollaborationWhitelistEntryByIdHeadersInput { /** * Extra headers that will be included in the HTTP request. */ readonly extraHeaders?: { readonly [key: string]: undefined | string; }; } export class CollaborationAllowlistEntriesManager { readonly auth?: Authentication; readonly networkSession: NetworkSession = new NetworkSession({}); constructor( fields: Omit< CollaborationAllowlistEntriesManager, | 'networkSession' | 'getCollaborationWhitelistEntries' | 'createCollaborationWhitelistEntry' | 'getCollaborationWhitelistEntryById' | 'deleteCollaborationWhitelistEntryById' > & Partial<Pick<CollaborationAllowlistEntriesManager, 'networkSession'>>, ) { if (fields.auth !== undefined) { this.auth = fields.auth; } if (fields.networkSession !== undefined) { this.networkSession = fields.networkSession; } } /** * Returns the list domains that have been deemed safe to create collaborations * for within the current enterprise. * @param {GetCollaborationWhitelistEntriesQueryParams} queryParams Query parameters of getCollaborationWhitelistEntries method * @param {GetCollaborationWhitelistEntriesHeadersInput} headersInput Headers of getCollaborationWhitelistEntries method * @param {CancellationToken} cancellationToken Token used for request cancellation. * @returns {Promise<CollaborationAllowlistEntries>} */ async getCollaborationWhitelistEntries( queryParams: GetCollaborationWhitelistEntriesQueryParams = {} satisfies GetCollaborationWhitelistEntriesQueryParams, headersInput: GetCollaborationWhitelistEntriesHeadersInput = new GetCollaborationWhitelistEntriesHeaders( {}, ), cancellationToken?: CancellationToken, ): Promise<CollaborationAllowlistEntries> { const headers: GetCollaborationWhitelistEntriesHeaders = new GetCollaborationWhitelistEntriesHeaders({ extraHeaders: headersInput.extraHeaders, }); const queryParamsMap: { readonly [key: string]: string; } = prepareParams({ ['marker']: toString(queryParams.marker) 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/collaboration_whitelist_entries', ) as string, method: 'GET', params: queryParamsMap, headers: headersMap, responseFormat: 'json' as ResponseFormat, auth: this.auth, networkSession: this.networkSession, cancellationToken: cancellationToken, }), ); return { ...deserializeCollaborationAllowlistEntries(response.data!), rawData: response.data!, }; } /** * Creates a new entry in the list of allowed domains to allow * collaboration for. * @param {CreateCollaborationWhitelistEntryRequestBody} requestBody Request body of createCollaborationWhitelistEntry method * @param {CreateCollaborationWhitelistEntryOptionalsInput} optionalsInput * @returns {Promise<CollaborationAllowlistEntry>} */ async createCollaborationWhitelistEntry( requestBody: CreateCollaborationWhitelistEntryRequestBody, optionalsInput: CreateCollaborationWhitelistEntryOptionalsInput = {}, ): Promise<CollaborationAllowlistEntry> { const optionals: CreateCollaborationWhitelistEntryOptionals = new CreateCollaborationWhitelistEntryOptionals({ 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/collaboration_whitelist_entries', ) as string, method: 'POST', headers: headersMap, data: serializeCreateCollaborationWhitelistEntryRequestBody( requestBody, ), contentType: 'application/json', responseFormat: 'json' as ResponseFormat, auth: this.auth, networkSession: this.networkSession, cancellationToken: cancellationToken, }), ); return { ...deserializeCollaborationAllowlistEntry(response.data!), rawData: response.data!, }; } /** * Returns a domain that has been deemed safe to create collaborations * for within the current enterprise. * @param {string} collaborationWhitelistEntryId The ID of the entry in the list. Example: "213123" * @param {GetCollaborationWhitelistEntryByIdOptionalsInput} optionalsInput * @returns {Promise<CollaborationAllowlistEntry>} */ async getCollaborationWhitelistEntryById( collaborationWhitelistEntryId: string, optionalsInput: GetCollaborationWhitelistEntryByIdOptionalsInput = {}, ): Promise<CollaborationAllowlistEntry> { const optionals: GetCollaborationWhitelistEntryByIdOptionals = new GetCollaborationWhitelistEntryByIdOptionals({ 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/collaboration_whitelist_entries/', (toString(collaborationWhitelistEntryId) as string)!, ) as string, method: 'GET', headers: headersMap, responseFormat: 'json' as ResponseFormat, auth: this.auth, networkSession: this.networkSession, cancellationToken: cancellationToken, }), ); return { ...deserializeCollaborationAllowlistEntry(response.data!), rawData: response.data!, }; } /** * Removes a domain from the list of domains that have been deemed safe to create * collaborations for within the current enterprise. * @param {string} collaborationWhitelistEntryId The ID of the entry in the list. Example: "213123" * @param {DeleteCollaborationWhitelistEntryByIdOptionalsInput} optionalsInput * @returns {Promise<undefined>} */ async deleteCollaborationWhitelistEntryById( collaborationWhitelistEntryId: string, optionalsInput: DeleteCollaborationWhitelistEntryByIdOptionalsInput = {}, ): Promise<undefined> { const optionals: DeleteCollaborationWhitelistEntryByIdOptionals = new DeleteCollaborationWhitelistEntryByIdOptionals({ 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/collaboration_whitelist_entries/', (toString(collaborationWhitelistEntryId) as string)!, ) as string, method: 'DELETE', headers: headersMap, responseFormat: 'no_content' as ResponseFormat, auth: this.auth, networkSession: this.networkSession, cancellationToken: cancellationToken, }), ); return void 0; } } export interface CollaborationAllowlistEntriesManagerInput { readonly auth?: Authentication; readonly networkSession?: NetworkSession; } export function serializeCreateCollaborationWhitelistEntryRequestBodyDirectionField( val: CreateCollaborationWhitelistEntryRequestBodyDirectionField, ): SerializedData { return val; } export function deserializeCreateCollaborationWhitelistEntryRequestBodyDirectionField( val: SerializedData, ): CreateCollaborationWhitelistEntryRequestBodyDirectionField { if (val == 'inbound') { return val; } if (val == 'outbound') { return val; } if (val == 'both') { return val; } if (sdIsString(val)) { return val; } throw new BoxSdkError({ message: "Can't deserialize CreateCollaborationWhitelistEntryRequestBodyDirectionField", }); } export function serializeCreateCollaborationWhitelistEntryRequestBody( val: CreateCollaborationWhitelistEntryRequestBody, ): SerializedData { return { ['domain']: val.domain, ['direction']: serializeCreateCollaborationWhitelistEntryRequestBodyDirectionField( val.direction, ), }; } export function deserializeCreateCollaborationWhitelistEntryRequestBody( val: SerializedData, ): CreateCollaborationWhitelistEntryRequestBody { if (!sdIsMap(val)) { throw new BoxSdkError({ message: 'Expecting a map for "CreateCollaborationWhitelistEntryRequestBody"', }); } if (val.domain == void 0) { throw new BoxSdkError({ message: 'Expecting "domain" of type "CreateCollaborationWhitelistEntryRequestBody" to be defined', }); } if (!sdIsString(val.domain)) { throw new BoxSdkError({ message: 'Expecting string for "domain" of type "CreateCollaborationWhitelistEntryRequestBody"', }); } const domain: string = val.domain; if (val.direction == void 0) { throw new BoxSdkError({ message: 'Expecting "direction" of type "CreateCollaborationWhitelistEntryRequestBody" to be defined', }); } const direction: CreateCollaborationWhitelistEntryRequestBodyDirectionField = deserializeCreateCollaborationWhitelistEntryRequestBodyDirectionField( val.direction, ); return { domain: domain, direction: direction, } satisfies CreateCollaborationWhitelistEntryRequestBody; }