box-node-sdk
Version:
Official SDK for Box Platform APIs
883 lines (882 loc) • 29.2 kB
text/typescript
import { serializeFileVersionMini } from './fileVersionMini';
import { deserializeFileVersionMini } from './fileVersionMini';
import { serializeFolderMini } from './folderMini';
import { deserializeFolderMini } from './folderMini';
import { serializeUserMini } from './userMini';
import { deserializeUserMini } from './userMini';
import { serializeDateTime } from '../internal/utils';
import { deserializeDateTime } from '../internal/utils';
import { FileVersionMini } from './fileVersionMini';
import { FolderMini } from './folderMini';
import { UserMini } from './userMini';
import { BoxSdkError } from '../box/errors';
import { DateTime } from '../internal/utils';
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 type TrashFileRestoredTypeField = 'file';
export interface TrashFileRestoredPathCollectionField {
/**
* The number of folders in this list. */
readonly totalCount: number;
/**
* The parent folders for this item. */
readonly entries: readonly FolderMini[];
readonly rawData?: SerializedData;
}
export type TrashFileRestoredItemStatusField =
| 'active'
| 'trashed'
| 'deleted'
| string;
export class TrashFileRestored {
/**
* The unique identifier that represent a file.
*
* The ID for any file can be determined
* by visiting a file in the web application
* and copying the ID from the URL. For example,
* for the URL `https://*.app.box.com/files/123`
* the `file_id` is `123`. */
readonly id!: string;
/**
* The HTTP `etag` of this file. This can be used within some API
* endpoints in the `If-Match` and `If-None-Match` headers to only
* perform changes on the file if (no) changes have happened. */
readonly etag?: string | null;
/**
* The value will always be `file`. */
readonly type: TrashFileRestoredTypeField =
'file' as TrashFileRestoredTypeField;
readonly sequenceId!: string;
/**
* The name of the file. */
readonly name?: string;
/**
* The SHA1 hash of the file. This can be used to compare the contents
* of a file on Box with a local file. */
readonly sha1!: string;
readonly fileVersion?: FileVersionMini;
/**
* The optional description of this file. */
readonly description!: string;
/**
* The file size in bytes. Be careful parsing this integer as it can
* get very large and cause an integer overflow. */
readonly size!: number;
readonly pathCollection!: TrashFileRestoredPathCollectionField;
/**
* The date and time when the file was created on Box. */
readonly createdAt!: DateTime;
/**
* The date and time when the file was last updated on Box. */
readonly modifiedAt!: DateTime;
/**
* The time at which this file was put in the
* trash - becomes `null` after restore. */
readonly trashedAt?: string | null;
/**
* The time at which this file is expected to be purged
* from the trash - becomes `null` after restore. */
readonly purgedAt?: string | null;
/**
* The date and time at which this file was originally
* created, which might be before it was uploaded to Box. */
readonly contentCreatedAt?: DateTime | null;
/**
* The date and time at which this file was last updated,
* which might be before it was uploaded to Box. */
readonly contentModifiedAt?: DateTime | null;
readonly createdBy?: UserMini;
readonly modifiedBy!: UserMini;
readonly ownedBy!: UserMini;
/**
* The shared link for this file. This will
* be `null` if a file had been trashed, even though the original shared
* link does become active again. */
readonly sharedLink?: string | null;
readonly parent?: FolderMini;
/**
* Defines if this item has been deleted or not.
*
* * `active` when the item has is not in the trash
* * `trashed` when the item has been moved to the trash but not deleted
* * `deleted` when the item has been permanently deleted. */
readonly itemStatus!: TrashFileRestoredItemStatusField;
readonly rawData?: SerializedData;
constructor(
fields: Omit<TrashFileRestored, 'type'> &
Partial<Pick<TrashFileRestored, 'type'>>,
) {
if (fields.id !== undefined) {
this.id = fields.id;
}
if (fields.etag !== undefined) {
this.etag = fields.etag;
}
if (fields.type !== undefined) {
this.type = fields.type;
}
if (fields.sequenceId !== undefined) {
this.sequenceId = fields.sequenceId;
}
if (fields.name !== undefined) {
this.name = fields.name;
}
if (fields.sha1 !== undefined) {
this.sha1 = fields.sha1;
}
if (fields.fileVersion !== undefined) {
this.fileVersion = fields.fileVersion;
}
if (fields.description !== undefined) {
this.description = fields.description;
}
if (fields.size !== undefined) {
this.size = fields.size;
}
if (fields.pathCollection !== undefined) {
this.pathCollection = fields.pathCollection;
}
if (fields.createdAt !== undefined) {
this.createdAt = fields.createdAt;
}
if (fields.modifiedAt !== undefined) {
this.modifiedAt = fields.modifiedAt;
}
if (fields.trashedAt !== undefined) {
this.trashedAt = fields.trashedAt;
}
if (fields.purgedAt !== undefined) {
this.purgedAt = fields.purgedAt;
}
if (fields.contentCreatedAt !== undefined) {
this.contentCreatedAt = fields.contentCreatedAt;
}
if (fields.contentModifiedAt !== undefined) {
this.contentModifiedAt = fields.contentModifiedAt;
}
if (fields.createdBy !== undefined) {
this.createdBy = fields.createdBy;
}
if (fields.modifiedBy !== undefined) {
this.modifiedBy = fields.modifiedBy;
}
if (fields.ownedBy !== undefined) {
this.ownedBy = fields.ownedBy;
}
if (fields.sharedLink !== undefined) {
this.sharedLink = fields.sharedLink;
}
if (fields.parent !== undefined) {
this.parent = fields.parent;
}
if (fields.itemStatus !== undefined) {
this.itemStatus = fields.itemStatus;
}
if (fields.rawData !== undefined) {
this.rawData = fields.rawData;
}
}
}
export interface TrashFileRestoredInput {
/**
* The unique identifier that represent a file.
*
* The ID for any file can be determined
* by visiting a file in the web application
* and copying the ID from the URL. For example,
* for the URL `https://*.app.box.com/files/123`
* the `file_id` is `123`. */
readonly id: string;
/**
* The HTTP `etag` of this file. This can be used within some API
* endpoints in the `If-Match` and `If-None-Match` headers to only
* perform changes on the file if (no) changes have happened. */
readonly etag?: string | null;
/**
* The value will always be `file`. */
readonly type?: TrashFileRestoredTypeField;
readonly sequenceId: string;
/**
* The name of the file. */
readonly name?: string;
/**
* The SHA1 hash of the file. This can be used to compare the contents
* of a file on Box with a local file. */
readonly sha1: string;
readonly fileVersion?: FileVersionMini;
/**
* The optional description of this file. */
readonly description: string;
/**
* The file size in bytes. Be careful parsing this integer as it can
* get very large and cause an integer overflow. */
readonly size: number;
readonly pathCollection: TrashFileRestoredPathCollectionField;
/**
* The date and time when the file was created on Box. */
readonly createdAt: DateTime;
/**
* The date and time when the file was last updated on Box. */
readonly modifiedAt: DateTime;
/**
* The time at which this file was put in the
* trash - becomes `null` after restore. */
readonly trashedAt?: string | null;
/**
* The time at which this file is expected to be purged
* from the trash - becomes `null` after restore. */
readonly purgedAt?: string | null;
/**
* The date and time at which this file was originally
* created, which might be before it was uploaded to Box. */
readonly contentCreatedAt?: DateTime | null;
/**
* The date and time at which this file was last updated,
* which might be before it was uploaded to Box. */
readonly contentModifiedAt?: DateTime | null;
readonly createdBy?: UserMini;
readonly modifiedBy: UserMini;
readonly ownedBy: UserMini;
/**
* The shared link for this file. This will
* be `null` if a file had been trashed, even though the original shared
* link does become active again. */
readonly sharedLink?: string | null;
readonly parent?: FolderMini;
/**
* Defines if this item has been deleted or not.
*
* * `active` when the item has is not in the trash
* * `trashed` when the item has been moved to the trash but not deleted
* * `deleted` when the item has been permanently deleted. */
readonly itemStatus: TrashFileRestoredItemStatusField;
readonly rawData?: SerializedData;
}
export function serializeTrashFileRestoredTypeField(
val: TrashFileRestoredTypeField,
): SerializedData {
return val;
}
export function deserializeTrashFileRestoredTypeField(
val: SerializedData,
): TrashFileRestoredTypeField {
if (val == 'file') {
return val;
}
throw new BoxSdkError({
message: "Can't deserialize TrashFileRestoredTypeField",
});
}
export function serializeTrashFileRestoredPathCollectionField(
val: TrashFileRestoredPathCollectionField,
): SerializedData {
return {
['total_count']: val.totalCount,
['entries']: val.entries.map(function (item: FolderMini): SerializedData {
return serializeFolderMini(item);
}) as readonly any[],
};
}
export function deserializeTrashFileRestoredPathCollectionField(
val: SerializedData,
): TrashFileRestoredPathCollectionField {
if (!sdIsMap(val)) {
throw new BoxSdkError({
message: 'Expecting a map for "TrashFileRestoredPathCollectionField"',
});
}
if (val.total_count == void 0) {
throw new BoxSdkError({
message:
'Expecting "total_count" of type "TrashFileRestoredPathCollectionField" to be defined',
});
}
if (!sdIsNumber(val.total_count)) {
throw new BoxSdkError({
message:
'Expecting number for "total_count" of type "TrashFileRestoredPathCollectionField"',
});
}
const totalCount: number = val.total_count;
if (val.entries == void 0) {
throw new BoxSdkError({
message:
'Expecting "entries" of type "TrashFileRestoredPathCollectionField" to be defined',
});
}
if (!sdIsList(val.entries)) {
throw new BoxSdkError({
message:
'Expecting array for "entries" of type "TrashFileRestoredPathCollectionField"',
});
}
const entries: readonly FolderMini[] = sdIsList(val.entries)
? (val.entries.map(function (itm: SerializedData): FolderMini {
return deserializeFolderMini(itm);
}) as readonly any[])
: [];
return {
totalCount: totalCount,
entries: entries,
} satisfies TrashFileRestoredPathCollectionField;
}
export function serializeTrashFileRestoredItemStatusField(
val: TrashFileRestoredItemStatusField,
): SerializedData {
return val;
}
export function deserializeTrashFileRestoredItemStatusField(
val: SerializedData,
): TrashFileRestoredItemStatusField {
if (val == 'active') {
return val;
}
if (val == 'trashed') {
return val;
}
if (val == 'deleted') {
return val;
}
if (sdIsString(val)) {
return val;
}
throw new BoxSdkError({
message: "Can't deserialize TrashFileRestoredItemStatusField",
});
}
export function serializeTrashFileRestored(
val: TrashFileRestored,
): SerializedData {
return {
['id']: val.id,
['etag']: val.etag,
['type']: serializeTrashFileRestoredTypeField(val.type),
['sequence_id']: val.sequenceId,
['name']: val.name,
['sha1']: val.sha1,
['file_version']:
val.fileVersion == void 0
? val.fileVersion
: serializeFileVersionMini(val.fileVersion),
['description']: val.description,
['size']: val.size,
['path_collection']: serializeTrashFileRestoredPathCollectionField(
val.pathCollection,
),
['created_at']: serializeDateTime(val.createdAt),
['modified_at']: serializeDateTime(val.modifiedAt),
['trashed_at']: val.trashedAt,
['purged_at']: val.purgedAt,
['content_created_at']:
val.contentCreatedAt == void 0
? val.contentCreatedAt
: serializeDateTime(val.contentCreatedAt),
['content_modified_at']:
val.contentModifiedAt == void 0
? val.contentModifiedAt
: serializeDateTime(val.contentModifiedAt),
['created_by']:
val.createdBy == void 0
? val.createdBy
: serializeUserMini(val.createdBy),
['modified_by']: serializeUserMini(val.modifiedBy),
['owned_by']: serializeUserMini(val.ownedBy),
['shared_link']: val.sharedLink,
['parent']:
val.parent == void 0 ? val.parent : serializeFolderMini(val.parent),
['item_status']: serializeTrashFileRestoredItemStatusField(val.itemStatus),
};
}
export function deserializeTrashFileRestored(
val: SerializedData,
): TrashFileRestored {
if (!sdIsMap(val)) {
throw new BoxSdkError({
message: 'Expecting a map for "TrashFileRestored"',
});
}
if (val.id == void 0) {
throw new BoxSdkError({
message: 'Expecting "id" of type "TrashFileRestored" to be defined',
});
}
if (!sdIsString(val.id)) {
throw new BoxSdkError({
message: 'Expecting string for "id" of type "TrashFileRestored"',
});
}
const id: string = val.id;
if (!(val.etag == void 0) && !sdIsString(val.etag)) {
throw new BoxSdkError({
message: 'Expecting string for "etag" of type "TrashFileRestored"',
});
}
const etag: undefined | string = val.etag == void 0 ? void 0 : val.etag;
if (val.type == void 0) {
throw new BoxSdkError({
message: 'Expecting "type" of type "TrashFileRestored" to be defined',
});
}
const type: TrashFileRestoredTypeField =
deserializeTrashFileRestoredTypeField(val.type);
if (val.sequence_id == void 0) {
throw new BoxSdkError({
message:
'Expecting "sequence_id" of type "TrashFileRestored" to be defined',
});
}
if (!sdIsString(val.sequence_id)) {
throw new BoxSdkError({
message: 'Expecting string for "sequence_id" of type "TrashFileRestored"',
});
}
const sequenceId: string = val.sequence_id;
if (!(val.name == void 0) && !sdIsString(val.name)) {
throw new BoxSdkError({
message: 'Expecting string for "name" of type "TrashFileRestored"',
});
}
const name: undefined | string = val.name == void 0 ? void 0 : val.name;
if (val.sha1 == void 0) {
throw new BoxSdkError({
message: 'Expecting "sha1" of type "TrashFileRestored" to be defined',
});
}
if (!sdIsString(val.sha1)) {
throw new BoxSdkError({
message: 'Expecting string for "sha1" of type "TrashFileRestored"',
});
}
const sha1: string = val.sha1;
const fileVersion: undefined | FileVersionMini =
val.file_version == void 0
? void 0
: deserializeFileVersionMini(val.file_version);
if (val.description == void 0) {
throw new BoxSdkError({
message:
'Expecting "description" of type "TrashFileRestored" to be defined',
});
}
if (!sdIsString(val.description)) {
throw new BoxSdkError({
message: 'Expecting string for "description" of type "TrashFileRestored"',
});
}
const description: string = val.description;
if (val.size == void 0) {
throw new BoxSdkError({
message: 'Expecting "size" of type "TrashFileRestored" to be defined',
});
}
if (!sdIsNumber(val.size)) {
throw new BoxSdkError({
message: 'Expecting number for "size" of type "TrashFileRestored"',
});
}
const size: number = val.size;
if (val.path_collection == void 0) {
throw new BoxSdkError({
message:
'Expecting "path_collection" of type "TrashFileRestored" to be defined',
});
}
const pathCollection: TrashFileRestoredPathCollectionField =
deserializeTrashFileRestoredPathCollectionField(val.path_collection);
if (val.created_at == void 0) {
throw new BoxSdkError({
message:
'Expecting "created_at" of type "TrashFileRestored" to be defined',
});
}
if (!sdIsString(val.created_at)) {
throw new BoxSdkError({
message: 'Expecting string for "created_at" of type "TrashFileRestored"',
});
}
const createdAt: DateTime = deserializeDateTime(val.created_at);
if (val.modified_at == void 0) {
throw new BoxSdkError({
message:
'Expecting "modified_at" of type "TrashFileRestored" to be defined',
});
}
if (!sdIsString(val.modified_at)) {
throw new BoxSdkError({
message: 'Expecting string for "modified_at" of type "TrashFileRestored"',
});
}
const modifiedAt: DateTime = deserializeDateTime(val.modified_at);
if (!(val.trashed_at == void 0) && !sdIsString(val.trashed_at)) {
throw new BoxSdkError({
message: 'Expecting string for "trashed_at" of type "TrashFileRestored"',
});
}
const trashedAt: undefined | string =
val.trashed_at == void 0 ? void 0 : val.trashed_at;
if (!(val.purged_at == void 0) && !sdIsString(val.purged_at)) {
throw new BoxSdkError({
message: 'Expecting string for "purged_at" of type "TrashFileRestored"',
});
}
const purgedAt: undefined | string =
val.purged_at == void 0 ? void 0 : val.purged_at;
if (
!(val.content_created_at == void 0) &&
!sdIsString(val.content_created_at)
) {
throw new BoxSdkError({
message:
'Expecting string for "content_created_at" of type "TrashFileRestored"',
});
}
const contentCreatedAt: undefined | DateTime =
val.content_created_at == void 0
? void 0
: deserializeDateTime(val.content_created_at);
if (
!(val.content_modified_at == void 0) &&
!sdIsString(val.content_modified_at)
) {
throw new BoxSdkError({
message:
'Expecting string for "content_modified_at" of type "TrashFileRestored"',
});
}
const contentModifiedAt: undefined | DateTime =
val.content_modified_at == void 0
? void 0
: deserializeDateTime(val.content_modified_at);
const createdBy: undefined | UserMini =
val.created_by == void 0 ? void 0 : deserializeUserMini(val.created_by);
if (val.modified_by == void 0) {
throw new BoxSdkError({
message:
'Expecting "modified_by" of type "TrashFileRestored" to be defined',
});
}
const modifiedBy: UserMini = deserializeUserMini(val.modified_by);
if (val.owned_by == void 0) {
throw new BoxSdkError({
message: 'Expecting "owned_by" of type "TrashFileRestored" to be defined',
});
}
const ownedBy: UserMini = deserializeUserMini(val.owned_by);
if (!(val.shared_link == void 0) && !sdIsString(val.shared_link)) {
throw new BoxSdkError({
message: 'Expecting string for "shared_link" of type "TrashFileRestored"',
});
}
const sharedLink: undefined | string =
val.shared_link == void 0 ? void 0 : val.shared_link;
const parent: undefined | FolderMini =
val.parent == void 0 ? void 0 : deserializeFolderMini(val.parent);
if (val.item_status == void 0) {
throw new BoxSdkError({
message:
'Expecting "item_status" of type "TrashFileRestored" to be defined',
});
}
const itemStatus: TrashFileRestoredItemStatusField =
deserializeTrashFileRestoredItemStatusField(val.item_status);
return {
id: id,
etag: etag,
type: type,
sequenceId: sequenceId,
name: name,
sha1: sha1,
fileVersion: fileVersion,
description: description,
size: size,
pathCollection: pathCollection,
createdAt: createdAt,
modifiedAt: modifiedAt,
trashedAt: trashedAt,
purgedAt: purgedAt,
contentCreatedAt: contentCreatedAt,
contentModifiedAt: contentModifiedAt,
createdBy: createdBy,
modifiedBy: modifiedBy,
ownedBy: ownedBy,
sharedLink: sharedLink,
parent: parent,
itemStatus: itemStatus,
} satisfies TrashFileRestored;
}
export function serializeTrashFileRestoredInput(
val: TrashFileRestoredInput,
): SerializedData {
return {
['id']: val.id,
['etag']: val.etag,
['type']:
val.type == void 0
? val.type
: serializeTrashFileRestoredTypeField(val.type),
['sequence_id']: val.sequenceId,
['name']: val.name,
['sha1']: val.sha1,
['file_version']:
val.fileVersion == void 0
? val.fileVersion
: serializeFileVersionMini(val.fileVersion),
['description']: val.description,
['size']: val.size,
['path_collection']: serializeTrashFileRestoredPathCollectionField(
val.pathCollection,
),
['created_at']: serializeDateTime(val.createdAt),
['modified_at']: serializeDateTime(val.modifiedAt),
['trashed_at']: val.trashedAt,
['purged_at']: val.purgedAt,
['content_created_at']:
val.contentCreatedAt == void 0
? val.contentCreatedAt
: serializeDateTime(val.contentCreatedAt),
['content_modified_at']:
val.contentModifiedAt == void 0
? val.contentModifiedAt
: serializeDateTime(val.contentModifiedAt),
['created_by']:
val.createdBy == void 0
? val.createdBy
: serializeUserMini(val.createdBy),
['modified_by']: serializeUserMini(val.modifiedBy),
['owned_by']: serializeUserMini(val.ownedBy),
['shared_link']: val.sharedLink,
['parent']:
val.parent == void 0 ? val.parent : serializeFolderMini(val.parent),
['item_status']: serializeTrashFileRestoredItemStatusField(val.itemStatus),
};
}
export function deserializeTrashFileRestoredInput(
val: SerializedData,
): TrashFileRestoredInput {
if (!sdIsMap(val)) {
throw new BoxSdkError({
message: 'Expecting a map for "TrashFileRestoredInput"',
});
}
if (val.id == void 0) {
throw new BoxSdkError({
message: 'Expecting "id" of type "TrashFileRestoredInput" to be defined',
});
}
if (!sdIsString(val.id)) {
throw new BoxSdkError({
message: 'Expecting string for "id" of type "TrashFileRestoredInput"',
});
}
const id: string = val.id;
if (!(val.etag == void 0) && !sdIsString(val.etag)) {
throw new BoxSdkError({
message: 'Expecting string for "etag" of type "TrashFileRestoredInput"',
});
}
const etag: undefined | string = val.etag == void 0 ? void 0 : val.etag;
const type: undefined | TrashFileRestoredTypeField =
val.type == void 0
? void 0
: deserializeTrashFileRestoredTypeField(val.type);
if (val.sequence_id == void 0) {
throw new BoxSdkError({
message:
'Expecting "sequence_id" of type "TrashFileRestoredInput" to be defined',
});
}
if (!sdIsString(val.sequence_id)) {
throw new BoxSdkError({
message:
'Expecting string for "sequence_id" of type "TrashFileRestoredInput"',
});
}
const sequenceId: string = val.sequence_id;
if (!(val.name == void 0) && !sdIsString(val.name)) {
throw new BoxSdkError({
message: 'Expecting string for "name" of type "TrashFileRestoredInput"',
});
}
const name: undefined | string = val.name == void 0 ? void 0 : val.name;
if (val.sha1 == void 0) {
throw new BoxSdkError({
message:
'Expecting "sha1" of type "TrashFileRestoredInput" to be defined',
});
}
if (!sdIsString(val.sha1)) {
throw new BoxSdkError({
message: 'Expecting string for "sha1" of type "TrashFileRestoredInput"',
});
}
const sha1: string = val.sha1;
const fileVersion: undefined | FileVersionMini =
val.file_version == void 0
? void 0
: deserializeFileVersionMini(val.file_version);
if (val.description == void 0) {
throw new BoxSdkError({
message:
'Expecting "description" of type "TrashFileRestoredInput" to be defined',
});
}
if (!sdIsString(val.description)) {
throw new BoxSdkError({
message:
'Expecting string for "description" of type "TrashFileRestoredInput"',
});
}
const description: string = val.description;
if (val.size == void 0) {
throw new BoxSdkError({
message:
'Expecting "size" of type "TrashFileRestoredInput" to be defined',
});
}
if (!sdIsNumber(val.size)) {
throw new BoxSdkError({
message: 'Expecting number for "size" of type "TrashFileRestoredInput"',
});
}
const size: number = val.size;
if (val.path_collection == void 0) {
throw new BoxSdkError({
message:
'Expecting "path_collection" of type "TrashFileRestoredInput" to be defined',
});
}
const pathCollection: TrashFileRestoredPathCollectionField =
deserializeTrashFileRestoredPathCollectionField(val.path_collection);
if (val.created_at == void 0) {
throw new BoxSdkError({
message:
'Expecting "created_at" of type "TrashFileRestoredInput" to be defined',
});
}
if (!sdIsString(val.created_at)) {
throw new BoxSdkError({
message:
'Expecting string for "created_at" of type "TrashFileRestoredInput"',
});
}
const createdAt: DateTime = deserializeDateTime(val.created_at);
if (val.modified_at == void 0) {
throw new BoxSdkError({
message:
'Expecting "modified_at" of type "TrashFileRestoredInput" to be defined',
});
}
if (!sdIsString(val.modified_at)) {
throw new BoxSdkError({
message:
'Expecting string for "modified_at" of type "TrashFileRestoredInput"',
});
}
const modifiedAt: DateTime = deserializeDateTime(val.modified_at);
if (!(val.trashed_at == void 0) && !sdIsString(val.trashed_at)) {
throw new BoxSdkError({
message:
'Expecting string for "trashed_at" of type "TrashFileRestoredInput"',
});
}
const trashedAt: undefined | string =
val.trashed_at == void 0 ? void 0 : val.trashed_at;
if (!(val.purged_at == void 0) && !sdIsString(val.purged_at)) {
throw new BoxSdkError({
message:
'Expecting string for "purged_at" of type "TrashFileRestoredInput"',
});
}
const purgedAt: undefined | string =
val.purged_at == void 0 ? void 0 : val.purged_at;
if (
!(val.content_created_at == void 0) &&
!sdIsString(val.content_created_at)
) {
throw new BoxSdkError({
message:
'Expecting string for "content_created_at" of type "TrashFileRestoredInput"',
});
}
const contentCreatedAt: undefined | DateTime =
val.content_created_at == void 0
? void 0
: deserializeDateTime(val.content_created_at);
if (
!(val.content_modified_at == void 0) &&
!sdIsString(val.content_modified_at)
) {
throw new BoxSdkError({
message:
'Expecting string for "content_modified_at" of type "TrashFileRestoredInput"',
});
}
const contentModifiedAt: undefined | DateTime =
val.content_modified_at == void 0
? void 0
: deserializeDateTime(val.content_modified_at);
const createdBy: undefined | UserMini =
val.created_by == void 0 ? void 0 : deserializeUserMini(val.created_by);
if (val.modified_by == void 0) {
throw new BoxSdkError({
message:
'Expecting "modified_by" of type "TrashFileRestoredInput" to be defined',
});
}
const modifiedBy: UserMini = deserializeUserMini(val.modified_by);
if (val.owned_by == void 0) {
throw new BoxSdkError({
message:
'Expecting "owned_by" of type "TrashFileRestoredInput" to be defined',
});
}
const ownedBy: UserMini = deserializeUserMini(val.owned_by);
if (!(val.shared_link == void 0) && !sdIsString(val.shared_link)) {
throw new BoxSdkError({
message:
'Expecting string for "shared_link" of type "TrashFileRestoredInput"',
});
}
const sharedLink: undefined | string =
val.shared_link == void 0 ? void 0 : val.shared_link;
const parent: undefined | FolderMini =
val.parent == void 0 ? void 0 : deserializeFolderMini(val.parent);
if (val.item_status == void 0) {
throw new BoxSdkError({
message:
'Expecting "item_status" of type "TrashFileRestoredInput" to be defined',
});
}
const itemStatus: TrashFileRestoredItemStatusField =
deserializeTrashFileRestoredItemStatusField(val.item_status);
return {
id: id,
etag: etag,
type: type,
sequenceId: sequenceId,
name: name,
sha1: sha1,
fileVersion: fileVersion,
description: description,
size: size,
pathCollection: pathCollection,
createdAt: createdAt,
modifiedAt: modifiedAt,
trashedAt: trashedAt,
purgedAt: purgedAt,
contentCreatedAt: contentCreatedAt,
contentModifiedAt: contentModifiedAt,
createdBy: createdBy,
modifiedBy: modifiedBy,
ownedBy: ownedBy,
sharedLink: sharedLink,
parent: parent,
itemStatus: itemStatus,
} satisfies TrashFileRestoredInput;
}