UNPKG

box-node-sdk

Version:

Official SDK for Box Platform APIs

96 lines (95 loc) 3.53 kB
import { serializeFileFull } from './fileFull'; import { deserializeFileFull } from './fileFull'; import { serializeFolderFull } from './folderFull'; import { deserializeFolderFull } from './folderFull'; import { serializeMetadataQueryResultItem } from './metadataQueryResultItem'; import { deserializeMetadataQueryResultItem } from './metadataQueryResultItem'; import { FileFull } from './fileFull'; import { FolderFull } from './folderFull'; import { MetadataQueryResultItem } from './metadataQueryResultItem'; import { BoxSdkError } from '../box/errors'; 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 interface MetadataQueryResults { /** * The mini representation of the files and folders that match the search * terms. * * By default, this endpoint returns only the most basic info about the * items. To get additional fields for each item, including any of the * metadata, use the `fields` attribute in the query. */ readonly entries?: readonly MetadataQueryResultItem[]; /** * The limit that was used for this search. This will be the same as the * `limit` query parameter unless that value exceeded the maximum value * allowed. */ readonly limit?: number; /** * The marker for the start of the next page of results. */ readonly nextMarker?: string; readonly rawData?: SerializedData; } export function serializeMetadataQueryResults( val: MetadataQueryResults, ): SerializedData { return { ['entries']: val.entries == void 0 ? val.entries : (val.entries.map(function ( item: MetadataQueryResultItem, ): SerializedData { return serializeMetadataQueryResultItem(item); }) as readonly any[]), ['limit']: val.limit, ['next_marker']: val.nextMarker, }; } export function deserializeMetadataQueryResults( val: SerializedData, ): MetadataQueryResults { if (!sdIsMap(val)) { throw new BoxSdkError({ message: 'Expecting a map for "MetadataQueryResults"', }); } if (!(val.entries == void 0) && !sdIsList(val.entries)) { throw new BoxSdkError({ message: 'Expecting array for "entries" of type "MetadataQueryResults"', }); } const entries: undefined | readonly MetadataQueryResultItem[] = val.entries == void 0 ? void 0 : sdIsList(val.entries) ? (val.entries.map(function ( itm: SerializedData, ): MetadataQueryResultItem { return deserializeMetadataQueryResultItem(itm); }) as readonly any[]) : []; if (!(val.limit == void 0) && !sdIsNumber(val.limit)) { throw new BoxSdkError({ message: 'Expecting number for "limit" of type "MetadataQueryResults"', }); } const limit: undefined | number = val.limit == void 0 ? void 0 : val.limit; if (!(val.next_marker == void 0) && !sdIsString(val.next_marker)) { throw new BoxSdkError({ message: 'Expecting string for "next_marker" of type "MetadataQueryResults"', }); } const nextMarker: undefined | string = val.next_marker == void 0 ? void 0 : val.next_marker; return { entries: entries, limit: limit, nextMarker: nextMarker, } satisfies MetadataQueryResults; }