@firebase/storage-types
Version:
@firebase/storage Types
203 lines (185 loc) • 5.5 kB
TypeScript
/**
* @license
* Copyright 2017 Google LLC
*
* Licensed under the Apache License, Version 2.0 (the "License");
* you may not use this file except in compliance with the License.
* You may obtain a copy of the License at
*
* http://www.apache.org/licenses/LICENSE-2.0
*
* Unless required by applicable law or agreed to in writing, software
* distributed under the License is distributed on an "AS IS" BASIS,
* WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
* See the License for the specific language governing permissions and
* limitations under the License.
*/
import { FirebaseApp } from '@firebase/app-types';
import {
CompleteFn,
EmulatorMockTokenOptions,
FirebaseError,
NextFn,
Unsubscribe
} from '@firebase/util';
export interface FullMetadata extends UploadMetadata {
bucket: string;
fullPath: string;
generation: string;
metageneration: string;
name: string;
size: number;
timeCreated: string;
updated: string;
}
export interface Reference {
bucket: string;
child(path: string): Reference;
delete(): Promise<void>;
fullPath: string;
getDownloadURL(): Promise<string>;
getMetadata(): Promise<FullMetadata>;
name: string;
parent: Reference | null;
put(
data: Blob | Uint8Array | ArrayBuffer,
metadata?: UploadMetadata
): UploadTask;
putString(
data: string,
format?: StringFormat,
metadata?: UploadMetadata
): UploadTask;
root: Reference;
storage: FirebaseStorage;
toString(): string;
updateMetadata(metadata: SettableMetadata): Promise<FullMetadata>;
listAll(): Promise<ListResult>;
list(options?: ListOptions): Promise<ListResult>;
}
export interface ListResult {
prefixes: Reference[];
items: Reference[];
nextPageToken: string | null;
}
export interface ListOptions {
maxResults?: number | null;
pageToken?: string | null;
}
export interface SettableMetadata {
cacheControl?: string | null;
contentDisposition?: string | null;
contentEncoding?: string | null;
contentLanguage?: string | null;
contentType?: string | null;
customMetadata?: {
[/* warning: coerced from ? */ key: string]: string;
} | null;
}
export type StringFormat = string;
export type TaskEvent = string;
export type TaskState = string;
export interface UploadMetadata extends SettableMetadata {
md5Hash?: string | null;
}
export interface StorageObserver<T> {
next?: NextFn<T> | null;
error?: (error: FirebaseStorageError) => void | null;
complete?: CompleteFn | null;
}
export enum StorageErrorCode {
UNKNOWN = 'unknown',
OBJECT_NOT_FOUND = 'object-not-found',
BUCKET_NOT_FOUND = 'bucket-not-found',
PROJECT_NOT_FOUND = 'project-not-found',
QUOTA_EXCEEDED = 'quota-exceeded',
UNAUTHENTICATED = 'unauthenticated',
UNAUTHORIZED = 'unauthorized',
UNAUTHORIZED_APP = 'unauthorized-app',
RETRY_LIMIT_EXCEEDED = 'retry-limit-exceeded',
INVALID_CHECKSUM = 'invalid-checksum',
CANCELED = 'canceled',
INVALID_EVENT_NAME = 'invalid-event-name',
INVALID_URL = 'invalid-url',
INVALID_DEFAULT_BUCKET = 'invalid-default-bucket',
NO_DEFAULT_BUCKET = 'no-default-bucket',
CANNOT_SLICE_BLOB = 'cannot-slice-blob',
SERVER_FILE_WRONG_SIZE = 'server-file-wrong-size',
NO_DOWNLOAD_URL = 'no-download-url',
INVALID_ARGUMENT = 'invalid-argument',
INVALID_ARGUMENT_COUNT = 'invalid-argument-count',
APP_DELETED = 'app-deleted',
INVALID_ROOT_OPERATION = 'invalid-root-operation',
INVALID_FORMAT = 'invalid-format',
INTERNAL_ERROR = 'internal-error',
UNSUPPORTED_ENVIRONMENT = 'unsupported-environment'
}
export interface FirebaseStorageError extends FirebaseError {
/**
* Stores custom error data unique to the `StorageError`.
*/
customData: {
serverResponse: string | null;
};
get status(): number;
set status(status: number);
/**
* Compares a `StorageErrorCode` against this error's code, filtering out the prefix.
*/
_codeEquals(code: StorageErrorCode): boolean;
/**
* Optional response message that was added by the server.
*/
get serverResponse(): null | string;
set serverResponse(serverResponse: string | null);
}
export interface UploadTask {
cancel(): boolean;
catch(onRejected: (error: FirebaseStorageError) => any): Promise<any>;
on(
event: TaskEvent,
nextOrObserver?:
| StorageObserver<UploadTaskSnapshot>
| null
| ((snapshot: UploadTaskSnapshot) => any),
error?: ((a: FirebaseStorageError) => any) | null,
complete?: Unsubscribe | null
): Function;
pause(): boolean;
resume(): boolean;
snapshot: UploadTaskSnapshot;
then(
onFulfilled?: ((snapshot: UploadTaskSnapshot) => any) | null,
onRejected?: ((error: FirebaseStorageError) => any) | null
): Promise<any>;
}
export interface UploadTaskSnapshot {
bytesTransferred: number;
metadata: FullMetadata;
ref: Reference;
state: TaskState;
task: UploadTask;
totalBytes: number;
}
export class FirebaseStorage {
private constructor();
app: FirebaseApp;
maxOperationRetryTime: number;
maxUploadRetryTime: number;
ref(path?: string): Reference;
refFromURL(url: string): Reference;
setMaxOperationRetryTime(time: number): void;
setMaxUploadRetryTime(time: number): void;
useEmulator(
host: string,
port: number,
options?: {
mockUserToken?: EmulatorMockTokenOptions | string;
}
): void;
}
declare module '@firebase/component' {
interface NameServiceMapping {
'storage-compat': FirebaseStorage;
}
}