box-node-sdk
Version:
Official SDK for Box Platform APIs
96 lines (95 loc) • 3.53 kB
text/typescript
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;
}