mirror of
https://github.com/musix-org/musix-oss
synced 2025-07-01 17:03:38 +00:00
Updated
This commit is contained in:
1129
node_modules/@firebase/installations/dist/index.cjs.js
generated
vendored
Normal file
1129
node_modules/@firebase/installations/dist/index.cjs.js
generated
vendored
Normal file
File diff suppressed because it is too large
Load Diff
1
node_modules/@firebase/installations/dist/index.cjs.js.map
generated
vendored
Normal file
1
node_modules/@firebase/installations/dist/index.cjs.js.map
generated
vendored
Normal file
File diff suppressed because one or more lines are too long
1123
node_modules/@firebase/installations/dist/index.esm.js
generated
vendored
Normal file
1123
node_modules/@firebase/installations/dist/index.esm.js
generated
vendored
Normal file
File diff suppressed because it is too large
Load Diff
1
node_modules/@firebase/installations/dist/index.esm.js.map
generated
vendored
Normal file
1
node_modules/@firebase/installations/dist/index.esm.js.map
generated
vendored
Normal file
File diff suppressed because one or more lines are too long
885
node_modules/@firebase/installations/dist/index.esm2017.js
generated
vendored
Normal file
885
node_modules/@firebase/installations/dist/index.esm2017.js
generated
vendored
Normal file
@ -0,0 +1,885 @@
|
||||
import firebase from '@firebase/app';
|
||||
import { ErrorFactory, FirebaseError } from '@firebase/util';
|
||||
import { openDb } from 'idb';
|
||||
|
||||
const version = "0.2.6";
|
||||
|
||||
/**
|
||||
* @license
|
||||
* Copyright 2019 Google Inc.
|
||||
*
|
||||
* 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.
|
||||
*/
|
||||
const PENDING_TIMEOUT_MS = 10000;
|
||||
const PACKAGE_VERSION = `w:${version}`;
|
||||
const INTERNAL_AUTH_VERSION = 'FIS_v2';
|
||||
const INSTALLATIONS_API_URL = 'https://firebaseinstallations.googleapis.com/v1';
|
||||
const TOKEN_EXPIRATION_BUFFER = 60 * 60 * 1000; // One hour
|
||||
const SERVICE = 'installations';
|
||||
const SERVICE_NAME = 'Installations';
|
||||
|
||||
/**
|
||||
* @license
|
||||
* Copyright 2019 Google Inc.
|
||||
*
|
||||
* 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.
|
||||
*/
|
||||
const ERROR_DESCRIPTION_MAP = {
|
||||
["missing-app-config-values" /* MISSING_APP_CONFIG_VALUES */]: 'Missing App configuration values.',
|
||||
["create-installation-failed" /* CREATE_INSTALLATION_FAILED */]: 'Could not register Firebase Installation.',
|
||||
["generate-token-failed" /* GENERATE_TOKEN_FAILED */]: 'Could not generate Auth Token.',
|
||||
["not-registered" /* NOT_REGISTERED */]: 'Firebase Installation is not registered.',
|
||||
["installation-not-found" /* INSTALLATION_NOT_FOUND */]: 'Firebase Installation not found.',
|
||||
["request-failed" /* REQUEST_FAILED */]: '{$requestName} request failed with error "{$serverCode} {$serverStatus}: {$serverMessage}"',
|
||||
["app-offline" /* APP_OFFLINE */]: 'Could not process request. Application offline.',
|
||||
["delete-pending-registration" /* DELETE_PENDING_REGISTRATION */]: "Can't delete installation while there is a pending registration request."
|
||||
};
|
||||
const ERROR_FACTORY = new ErrorFactory(SERVICE, SERVICE_NAME, ERROR_DESCRIPTION_MAP);
|
||||
/** Returns true if error is a FirebaseError that is based on an error from the server. */
|
||||
function isServerError(error) {
|
||||
return (error instanceof FirebaseError &&
|
||||
error.code.includes("request-failed" /* REQUEST_FAILED */));
|
||||
}
|
||||
|
||||
/**
|
||||
* @license
|
||||
* Copyright 2019 Google Inc.
|
||||
*
|
||||
* 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.
|
||||
*/
|
||||
function extractAppConfig(app) {
|
||||
if (!app || !app.options) {
|
||||
throw ERROR_FACTORY.create("missing-app-config-values" /* MISSING_APP_CONFIG_VALUES */);
|
||||
}
|
||||
const appName = app.name;
|
||||
const { projectId, apiKey, appId } = app.options;
|
||||
if (!appName || !projectId || !apiKey || !appId) {
|
||||
throw ERROR_FACTORY.create("missing-app-config-values" /* MISSING_APP_CONFIG_VALUES */);
|
||||
}
|
||||
return { appName, projectId, apiKey, appId };
|
||||
}
|
||||
|
||||
/**
|
||||
* @license
|
||||
* Copyright 2019 Google Inc.
|
||||
*
|
||||
* 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.
|
||||
*/
|
||||
function getInstallationsEndpoint({ projectId }) {
|
||||
return `${INSTALLATIONS_API_URL}/projects/${projectId}/installations`;
|
||||
}
|
||||
function extractAuthTokenInfoFromResponse(response) {
|
||||
return {
|
||||
token: response.token,
|
||||
requestStatus: 2 /* COMPLETED */,
|
||||
expiresIn: getExpiresInFromResponseExpiresIn(response.expiresIn),
|
||||
creationTime: Date.now()
|
||||
};
|
||||
}
|
||||
async function getErrorFromResponse(requestName, response) {
|
||||
const responseJson = await response.json();
|
||||
const errorData = responseJson.error;
|
||||
return ERROR_FACTORY.create("request-failed" /* REQUEST_FAILED */, {
|
||||
requestName,
|
||||
serverCode: errorData.code,
|
||||
serverMessage: errorData.message,
|
||||
serverStatus: errorData.status
|
||||
});
|
||||
}
|
||||
function getHeaders({ apiKey }) {
|
||||
return new Headers({
|
||||
'Content-Type': 'application/json',
|
||||
Accept: 'application/json',
|
||||
'x-goog-api-key': apiKey
|
||||
});
|
||||
}
|
||||
function getHeadersWithAuth(appConfig, { refreshToken }) {
|
||||
const headers = getHeaders(appConfig);
|
||||
headers.append('Authorization', getAuthorizationHeader(refreshToken));
|
||||
return headers;
|
||||
}
|
||||
/**
|
||||
* Calls the passed in fetch wrapper and returns the response.
|
||||
* If the returned response has a status of 5xx, re-runs the function once and
|
||||
* returns the response.
|
||||
*/
|
||||
async function retryIfServerError(fn) {
|
||||
const result = await fn();
|
||||
if (result.status >= 500 && result.status < 600) {
|
||||
// Internal Server Error. Retry request.
|
||||
return fn();
|
||||
}
|
||||
return result;
|
||||
}
|
||||
function getExpiresInFromResponseExpiresIn(responseExpiresIn) {
|
||||
// This works because the server will never respond with fractions of a second.
|
||||
return Number(responseExpiresIn.replace('s', '000'));
|
||||
}
|
||||
function getAuthorizationHeader(refreshToken) {
|
||||
return `${INTERNAL_AUTH_VERSION} ${refreshToken}`;
|
||||
}
|
||||
|
||||
/**
|
||||
* @license
|
||||
* Copyright 2019 Google Inc.
|
||||
*
|
||||
* 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.
|
||||
*/
|
||||
async function createInstallation(appConfig, { fid }) {
|
||||
const endpoint = getInstallationsEndpoint(appConfig);
|
||||
const headers = getHeaders(appConfig);
|
||||
const body = {
|
||||
fid,
|
||||
authVersion: INTERNAL_AUTH_VERSION,
|
||||
appId: appConfig.appId,
|
||||
sdkVersion: PACKAGE_VERSION
|
||||
};
|
||||
const request = {
|
||||
method: 'POST',
|
||||
headers,
|
||||
body: JSON.stringify(body)
|
||||
};
|
||||
const response = await retryIfServerError(() => fetch(endpoint, request));
|
||||
if (response.ok) {
|
||||
const responseValue = await response.json();
|
||||
const registeredInstallationEntry = {
|
||||
fid: responseValue.fid || fid,
|
||||
registrationStatus: 2 /* COMPLETED */,
|
||||
refreshToken: responseValue.refreshToken,
|
||||
authToken: extractAuthTokenInfoFromResponse(responseValue.authToken)
|
||||
};
|
||||
return registeredInstallationEntry;
|
||||
}
|
||||
else {
|
||||
throw await getErrorFromResponse('Create Installation', response);
|
||||
}
|
||||
}
|
||||
|
||||
/**
|
||||
* @license
|
||||
* Copyright 2019 Google Inc.
|
||||
*
|
||||
* 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.
|
||||
*/
|
||||
/** Returns a promise that resolves after given time passes. */
|
||||
function sleep(ms) {
|
||||
return new Promise(resolve => {
|
||||
setTimeout(resolve, ms);
|
||||
});
|
||||
}
|
||||
|
||||
/**
|
||||
* @license
|
||||
* Copyright 2019 Google Inc.
|
||||
*
|
||||
* 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.
|
||||
*/
|
||||
function bufferToBase64UrlSafe(array) {
|
||||
const b64 = btoa(String.fromCharCode(...array));
|
||||
return b64.replace(/\+/g, '-').replace(/\//g, '_');
|
||||
}
|
||||
|
||||
/**
|
||||
* @license
|
||||
* Copyright 2019 Google Inc.
|
||||
*
|
||||
* 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.
|
||||
*/
|
||||
const VALID_FID_PATTERN = /^[cdef][\w-]{21}$/;
|
||||
const INVALID_FID = '';
|
||||
/**
|
||||
* Generates a new FID using random values from Web Crypto API.
|
||||
* Returns an empty string if FID generation fails for any reason.
|
||||
*/
|
||||
function generateFid() {
|
||||
try {
|
||||
// A valid FID has exactly 22 base64 characters, which is 132 bits, or 16.5
|
||||
// bytes. our implementation generates a 17 byte array instead.
|
||||
const fidByteArray = new Uint8Array(17);
|
||||
const crypto = self.crypto || self.msCrypto;
|
||||
crypto.getRandomValues(fidByteArray);
|
||||
// Replace the first 4 random bits with the constant FID header of 0b0111.
|
||||
fidByteArray[0] = 0b01110000 + (fidByteArray[0] % 0b00010000);
|
||||
const fid = encode(fidByteArray);
|
||||
return VALID_FID_PATTERN.test(fid) ? fid : INVALID_FID;
|
||||
}
|
||||
catch (_a) {
|
||||
// FID generation errored
|
||||
return INVALID_FID;
|
||||
}
|
||||
}
|
||||
/** Converts a FID Uint8Array to a base64 string representation. */
|
||||
function encode(fidByteArray) {
|
||||
const b64String = bufferToBase64UrlSafe(fidByteArray);
|
||||
// Remove the 23rd character that was added because of the extra 4 bits at the
|
||||
// end of our 17 byte array, and the '=' padding.
|
||||
return b64String.substr(0, 22);
|
||||
}
|
||||
|
||||
/**
|
||||
* @license
|
||||
* Copyright 2019 Google Inc.
|
||||
*
|
||||
* 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.
|
||||
*/
|
||||
const DATABASE_NAME = 'firebase-installations-database';
|
||||
const DATABASE_VERSION = 1;
|
||||
const OBJECT_STORE_NAME = 'firebase-installations-store';
|
||||
let dbPromise = null;
|
||||
function getDbPromise() {
|
||||
if (!dbPromise) {
|
||||
dbPromise = openDb(DATABASE_NAME, DATABASE_VERSION, upgradeDB => {
|
||||
// We don't use 'break' in this switch statement, the fall-through
|
||||
// behavior is what we want, because if there are multiple versions between
|
||||
// the old version and the current version, we want ALL the migrations
|
||||
// that correspond to those versions to run, not only the last one.
|
||||
// eslint-disable-next-line default-case
|
||||
switch (upgradeDB.oldVersion) {
|
||||
case 0:
|
||||
upgradeDB.createObjectStore(OBJECT_STORE_NAME);
|
||||
}
|
||||
});
|
||||
}
|
||||
return dbPromise;
|
||||
}
|
||||
/** Assigns or overwrites the record for the given key with the given value. */
|
||||
async function set(appConfig, value) {
|
||||
const key = getKey(appConfig);
|
||||
const db = await getDbPromise();
|
||||
const tx = db.transaction(OBJECT_STORE_NAME, 'readwrite');
|
||||
await tx.objectStore(OBJECT_STORE_NAME).put(value, key);
|
||||
await tx.complete;
|
||||
return value;
|
||||
}
|
||||
/** Removes record(s) from the objectStore that match the given key. */
|
||||
async function remove(appConfig) {
|
||||
const key = getKey(appConfig);
|
||||
const db = await getDbPromise();
|
||||
const tx = db.transaction(OBJECT_STORE_NAME, 'readwrite');
|
||||
await tx.objectStore(OBJECT_STORE_NAME).delete(key);
|
||||
await tx.complete;
|
||||
}
|
||||
/**
|
||||
* Atomically updates a record with the result of updateFn, which gets
|
||||
* called with the current value. If newValue is undefined, the record is
|
||||
* deleted instead.
|
||||
* @return Updated value
|
||||
*/
|
||||
async function update(appConfig, updateFn) {
|
||||
const key = getKey(appConfig);
|
||||
const db = await getDbPromise();
|
||||
const tx = db.transaction(OBJECT_STORE_NAME, 'readwrite');
|
||||
const store = tx.objectStore(OBJECT_STORE_NAME);
|
||||
const oldValue = await store.get(key);
|
||||
const newValue = updateFn(oldValue);
|
||||
if (newValue === oldValue) {
|
||||
return newValue;
|
||||
}
|
||||
if (newValue === undefined) {
|
||||
await store.delete(key);
|
||||
}
|
||||
else {
|
||||
await store.put(newValue, key);
|
||||
}
|
||||
await tx.complete;
|
||||
return newValue;
|
||||
}
|
||||
function getKey(appConfig) {
|
||||
return `${appConfig.appName}!${appConfig.appId}`;
|
||||
}
|
||||
|
||||
/**
|
||||
* @license
|
||||
* Copyright 2019 Google Inc.
|
||||
*
|
||||
* 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.
|
||||
*/
|
||||
/**
|
||||
* Updates and returns the InstallationEntry from the database.
|
||||
* Also triggers a registration request if it is necessary and possible.
|
||||
*/
|
||||
async function getInstallationEntry(appConfig) {
|
||||
let registrationPromise;
|
||||
const installationEntry = await update(appConfig, (oldEntry) => {
|
||||
const installationEntry = updateOrCreateInstallationEntry(oldEntry);
|
||||
const entryWithPromise = triggerRegistrationIfNecessary(appConfig, installationEntry);
|
||||
registrationPromise = entryWithPromise.registrationPromise;
|
||||
return entryWithPromise.installationEntry;
|
||||
});
|
||||
if (installationEntry.fid === INVALID_FID) {
|
||||
// FID generation failed. Waiting for the FID from the server.
|
||||
return { installationEntry: await registrationPromise };
|
||||
}
|
||||
return {
|
||||
installationEntry,
|
||||
registrationPromise
|
||||
};
|
||||
}
|
||||
function updateOrCreateInstallationEntry(oldEntry) {
|
||||
const entry = oldEntry || {
|
||||
fid: generateFid(),
|
||||
registrationStatus: 0 /* NOT_STARTED */
|
||||
};
|
||||
if (hasInstallationRequestTimedOut(entry)) {
|
||||
return {
|
||||
fid: entry.fid,
|
||||
registrationStatus: 0 /* NOT_STARTED */
|
||||
};
|
||||
}
|
||||
return entry;
|
||||
}
|
||||
/**
|
||||
* If the Firebase Installation is not registered yet, this will trigger the registration
|
||||
* and return an InProgressInstallationEntry.
|
||||
*/
|
||||
function triggerRegistrationIfNecessary(appConfig, installationEntry) {
|
||||
if (installationEntry.registrationStatus === 0 /* NOT_STARTED */) {
|
||||
if (!navigator.onLine) {
|
||||
// Registration required but app is offline.
|
||||
const registrationPromiseWithError = Promise.reject(ERROR_FACTORY.create("app-offline" /* APP_OFFLINE */));
|
||||
return {
|
||||
installationEntry,
|
||||
registrationPromise: registrationPromiseWithError
|
||||
};
|
||||
}
|
||||
// Try registering. Change status to IN_PROGRESS.
|
||||
const inProgressEntry = {
|
||||
fid: installationEntry.fid,
|
||||
registrationStatus: 1 /* IN_PROGRESS */,
|
||||
registrationTime: Date.now()
|
||||
};
|
||||
const registrationPromise = registerInstallation(appConfig, inProgressEntry);
|
||||
return { installationEntry: inProgressEntry, registrationPromise };
|
||||
}
|
||||
else if (installationEntry.registrationStatus === 1 /* IN_PROGRESS */) {
|
||||
return {
|
||||
installationEntry,
|
||||
registrationPromise: waitUntilFidRegistration(appConfig)
|
||||
};
|
||||
}
|
||||
else {
|
||||
return { installationEntry };
|
||||
}
|
||||
}
|
||||
/** This will be executed only once for each new Firebase Installation. */
|
||||
async function registerInstallation(appConfig, installationEntry) {
|
||||
try {
|
||||
const registeredInstallationEntry = await createInstallation(appConfig, installationEntry);
|
||||
return set(appConfig, registeredInstallationEntry);
|
||||
}
|
||||
catch (e) {
|
||||
if (isServerError(e) && e.serverCode === 409) {
|
||||
// Server returned a "FID can not be used" error.
|
||||
// Generate a new ID next time.
|
||||
await remove(appConfig);
|
||||
}
|
||||
else {
|
||||
// Registration failed. Set FID as not registered.
|
||||
await set(appConfig, {
|
||||
fid: installationEntry.fid,
|
||||
registrationStatus: 0 /* NOT_STARTED */
|
||||
});
|
||||
}
|
||||
throw e;
|
||||
}
|
||||
}
|
||||
/** Call if FID registration is pending. */
|
||||
async function waitUntilFidRegistration(appConfig) {
|
||||
// Unfortunately, there is no way of reliably observing when a value in
|
||||
// IndexedDB changes (yet, see https://github.com/WICG/indexed-db-observers),
|
||||
// so we need to poll.
|
||||
let entry = await updateInstallationRequest(appConfig);
|
||||
while (entry.registrationStatus === 1 /* IN_PROGRESS */) {
|
||||
// createInstallation request still in progress.
|
||||
await sleep(100);
|
||||
entry = await updateInstallationRequest(appConfig);
|
||||
}
|
||||
if (entry.registrationStatus === 0 /* NOT_STARTED */) {
|
||||
throw ERROR_FACTORY.create("create-installation-failed" /* CREATE_INSTALLATION_FAILED */);
|
||||
}
|
||||
return entry;
|
||||
}
|
||||
/**
|
||||
* Called only if there is a CreateInstallation request in progress.
|
||||
*
|
||||
* Updates the InstallationEntry in the DB based on the status of the
|
||||
* CreateInstallation request.
|
||||
*
|
||||
* Returns the updated InstallationEntry.
|
||||
*/
|
||||
function updateInstallationRequest(appConfig) {
|
||||
return update(appConfig, (oldEntry) => {
|
||||
if (!oldEntry) {
|
||||
throw ERROR_FACTORY.create("installation-not-found" /* INSTALLATION_NOT_FOUND */);
|
||||
}
|
||||
if (hasInstallationRequestTimedOut(oldEntry)) {
|
||||
return {
|
||||
fid: oldEntry.fid,
|
||||
registrationStatus: 0 /* NOT_STARTED */
|
||||
};
|
||||
}
|
||||
return oldEntry;
|
||||
});
|
||||
}
|
||||
function hasInstallationRequestTimedOut(installationEntry) {
|
||||
return (installationEntry.registrationStatus === 1 /* IN_PROGRESS */ &&
|
||||
installationEntry.registrationTime + PENDING_TIMEOUT_MS < Date.now());
|
||||
}
|
||||
|
||||
/**
|
||||
* @license
|
||||
* Copyright 2019 Google Inc.
|
||||
*
|
||||
* 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.
|
||||
*/
|
||||
async function generateAuthToken(appConfig, installationEntry) {
|
||||
const endpoint = getGenerateAuthTokenEndpoint(appConfig, installationEntry);
|
||||
const headers = getHeadersWithAuth(appConfig, installationEntry);
|
||||
const body = {
|
||||
installation: {
|
||||
sdkVersion: PACKAGE_VERSION
|
||||
}
|
||||
};
|
||||
const request = {
|
||||
method: 'POST',
|
||||
headers,
|
||||
body: JSON.stringify(body)
|
||||
};
|
||||
const response = await retryIfServerError(() => fetch(endpoint, request));
|
||||
if (response.ok) {
|
||||
const responseValue = await response.json();
|
||||
const completedAuthToken = extractAuthTokenInfoFromResponse(responseValue);
|
||||
return completedAuthToken;
|
||||
}
|
||||
else {
|
||||
throw await getErrorFromResponse('Generate Auth Token', response);
|
||||
}
|
||||
}
|
||||
function getGenerateAuthTokenEndpoint(appConfig, { fid }) {
|
||||
return `${getInstallationsEndpoint(appConfig)}/${fid}/authTokens:generate`;
|
||||
}
|
||||
|
||||
/**
|
||||
* @license
|
||||
* Copyright 2019 Google Inc.
|
||||
*
|
||||
* 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.
|
||||
*/
|
||||
/**
|
||||
* Returns a valid authentication token for the installation. Generates a new
|
||||
* token if one doesn't exist, is expired or about to expire.
|
||||
*
|
||||
* Should only be called if the Firebase Installation is registered.
|
||||
*/
|
||||
async function refreshAuthToken(appConfig) {
|
||||
let tokenPromise;
|
||||
const entry = await update(appConfig, (oldEntry) => {
|
||||
if (!isEntryRegistered(oldEntry)) {
|
||||
throw ERROR_FACTORY.create("not-registered" /* NOT_REGISTERED */);
|
||||
}
|
||||
const oldAuthToken = oldEntry.authToken;
|
||||
if (isAuthTokenValid(oldAuthToken)) {
|
||||
// There is a valid token in the DB.
|
||||
return oldEntry;
|
||||
}
|
||||
else if (oldAuthToken.requestStatus === 1 /* IN_PROGRESS */) {
|
||||
// There already is a token request in progress.
|
||||
tokenPromise = waitUntilAuthTokenRequest(appConfig);
|
||||
return oldEntry;
|
||||
}
|
||||
else {
|
||||
// No token or token expired.
|
||||
if (!navigator.onLine) {
|
||||
throw ERROR_FACTORY.create("app-offline" /* APP_OFFLINE */);
|
||||
}
|
||||
const inProgressEntry = makeAuthTokenRequestInProgressEntry(oldEntry);
|
||||
tokenPromise = fetchAuthTokenFromServer(appConfig, inProgressEntry);
|
||||
return inProgressEntry;
|
||||
}
|
||||
});
|
||||
const authToken = tokenPromise
|
||||
? await tokenPromise
|
||||
: entry.authToken;
|
||||
return authToken.token;
|
||||
}
|
||||
/**
|
||||
* Call only if FID is registered and Auth Token request is in progress.
|
||||
*/
|
||||
async function waitUntilAuthTokenRequest(appConfig) {
|
||||
// Unfortunately, there is no way of reliably observing when a value in
|
||||
// IndexedDB changes (yet, see https://github.com/WICG/indexed-db-observers),
|
||||
// so we need to poll.
|
||||
let entry = await updateAuthTokenRequest(appConfig);
|
||||
while (entry.authToken.requestStatus === 1 /* IN_PROGRESS */) {
|
||||
// generateAuthToken still in progress.
|
||||
await sleep(100);
|
||||
entry = await updateAuthTokenRequest(appConfig);
|
||||
}
|
||||
const authToken = entry.authToken;
|
||||
if (authToken.requestStatus === 0 /* NOT_STARTED */) {
|
||||
throw ERROR_FACTORY.create("generate-token-failed" /* GENERATE_TOKEN_FAILED */);
|
||||
}
|
||||
else {
|
||||
return authToken;
|
||||
}
|
||||
}
|
||||
/**
|
||||
* Called only if there is a GenerateAuthToken request in progress.
|
||||
*
|
||||
* Updates the InstallationEntry in the DB based on the status of the
|
||||
* GenerateAuthToken request.
|
||||
*
|
||||
* Returns the updated InstallationEntry.
|
||||
*/
|
||||
function updateAuthTokenRequest(appConfig) {
|
||||
return update(appConfig, (oldEntry) => {
|
||||
if (!isEntryRegistered(oldEntry)) {
|
||||
throw ERROR_FACTORY.create("not-registered" /* NOT_REGISTERED */);
|
||||
}
|
||||
const oldAuthToken = oldEntry.authToken;
|
||||
if (hasAuthTokenRequestTimedOut(oldAuthToken)) {
|
||||
return Object.assign({}, oldEntry, { authToken: { requestStatus: 0 /* NOT_STARTED */ } });
|
||||
}
|
||||
return oldEntry;
|
||||
});
|
||||
}
|
||||
async function fetchAuthTokenFromServer(appConfig, installationEntry) {
|
||||
try {
|
||||
const authToken = await generateAuthToken(appConfig, installationEntry);
|
||||
const updatedInstallationEntry = Object.assign({}, installationEntry, { authToken });
|
||||
await set(appConfig, updatedInstallationEntry);
|
||||
return authToken;
|
||||
}
|
||||
catch (e) {
|
||||
if (isServerError(e) && (e.serverCode === 401 || e.serverCode === 404)) {
|
||||
// Server returned a "FID not found" or a "Invalid authentication" error.
|
||||
// Generate a new ID next time.
|
||||
await remove(appConfig);
|
||||
}
|
||||
else {
|
||||
const updatedInstallationEntry = Object.assign({}, installationEntry, { authToken: { requestStatus: 0 /* NOT_STARTED */ } });
|
||||
await set(appConfig, updatedInstallationEntry);
|
||||
}
|
||||
throw e;
|
||||
}
|
||||
}
|
||||
function isEntryRegistered(installationEntry) {
|
||||
return (installationEntry !== undefined &&
|
||||
installationEntry.registrationStatus === 2 /* COMPLETED */);
|
||||
}
|
||||
function isAuthTokenValid(authToken) {
|
||||
return (authToken.requestStatus === 2 /* COMPLETED */ &&
|
||||
!isAuthTokenExpired(authToken));
|
||||
}
|
||||
function isAuthTokenExpired(authToken) {
|
||||
const now = Date.now();
|
||||
return (now < authToken.creationTime ||
|
||||
authToken.creationTime + authToken.expiresIn < now + TOKEN_EXPIRATION_BUFFER);
|
||||
}
|
||||
/** Returns an updated InstallationEntry with an InProgressAuthToken. */
|
||||
function makeAuthTokenRequestInProgressEntry(oldEntry) {
|
||||
const inProgressAuthToken = {
|
||||
requestStatus: 1 /* IN_PROGRESS */,
|
||||
requestTime: Date.now()
|
||||
};
|
||||
return Object.assign({}, oldEntry, { authToken: inProgressAuthToken });
|
||||
}
|
||||
function hasAuthTokenRequestTimedOut(authToken) {
|
||||
return (authToken.requestStatus === 1 /* IN_PROGRESS */ &&
|
||||
authToken.requestTime + PENDING_TIMEOUT_MS < Date.now());
|
||||
}
|
||||
|
||||
/**
|
||||
* @license
|
||||
* Copyright 2019 Google Inc.
|
||||
*
|
||||
* 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.
|
||||
*/
|
||||
async function getId(app) {
|
||||
const appConfig = extractAppConfig(app);
|
||||
const { installationEntry, registrationPromise } = await getInstallationEntry(appConfig);
|
||||
if (registrationPromise) {
|
||||
// Suppress registration errors as they are not a problem for getId.
|
||||
registrationPromise.catch(() => { });
|
||||
}
|
||||
if (installationEntry.registrationStatus === 2 /* COMPLETED */) {
|
||||
// If the installation is already registered, update the authentication
|
||||
// token if needed. Suppress errors as they are not relevant to getId.
|
||||
refreshAuthToken(appConfig).catch(() => { });
|
||||
}
|
||||
return installationEntry.fid;
|
||||
}
|
||||
|
||||
/**
|
||||
* @license
|
||||
* Copyright 2019 Google Inc.
|
||||
*
|
||||
* 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.
|
||||
*/
|
||||
async function getToken(app) {
|
||||
const appConfig = extractAppConfig(app);
|
||||
await completeInstallationRegistration(appConfig);
|
||||
// At this point we either have a Registered Installation in the DB, or we've
|
||||
// already thrown an error.
|
||||
return refreshAuthToken(appConfig);
|
||||
}
|
||||
async function completeInstallationRegistration(appConfig) {
|
||||
const { installationEntry, registrationPromise } = await getInstallationEntry(appConfig);
|
||||
if (registrationPromise) {
|
||||
// A createInstallation request is in progress. Wait until it finishes.
|
||||
await registrationPromise;
|
||||
}
|
||||
else if (installationEntry.registrationStatus !== 2 /* COMPLETED */) {
|
||||
// Installation ID can't be registered.
|
||||
throw ERROR_FACTORY.create("create-installation-failed" /* CREATE_INSTALLATION_FAILED */);
|
||||
}
|
||||
}
|
||||
|
||||
/**
|
||||
* @license
|
||||
* Copyright 2019 Google Inc.
|
||||
*
|
||||
* 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.
|
||||
*/
|
||||
async function deleteInstallation(appConfig, installationEntry) {
|
||||
const endpoint = getDeleteEndpoint(appConfig, installationEntry);
|
||||
const headers = getHeadersWithAuth(appConfig, installationEntry);
|
||||
const request = {
|
||||
method: 'DELETE',
|
||||
headers
|
||||
};
|
||||
const response = await retryIfServerError(() => fetch(endpoint, request));
|
||||
if (!response.ok) {
|
||||
throw await getErrorFromResponse('Delete Installation', response);
|
||||
}
|
||||
}
|
||||
function getDeleteEndpoint(appConfig, { fid }) {
|
||||
return `${getInstallationsEndpoint(appConfig)}/${fid}`;
|
||||
}
|
||||
|
||||
/**
|
||||
* @license
|
||||
* Copyright 2019 Google Inc.
|
||||
*
|
||||
* 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.
|
||||
*/
|
||||
async function deleteInstallation$1(app) {
|
||||
const appConfig = extractAppConfig(app);
|
||||
const entry = await update(appConfig, (oldEntry) => {
|
||||
if (oldEntry && oldEntry.registrationStatus === 0 /* NOT_STARTED */) {
|
||||
// Delete the unregistered entry without sending a deleteInstallation request.
|
||||
return undefined;
|
||||
}
|
||||
return oldEntry;
|
||||
});
|
||||
if (entry) {
|
||||
if (entry.registrationStatus === 1 /* IN_PROGRESS */) {
|
||||
// Can't delete while trying to register.
|
||||
throw ERROR_FACTORY.create("delete-pending-registration" /* DELETE_PENDING_REGISTRATION */);
|
||||
}
|
||||
else if (entry.registrationStatus === 2 /* COMPLETED */) {
|
||||
if (!navigator.onLine) {
|
||||
throw ERROR_FACTORY.create("app-offline" /* APP_OFFLINE */);
|
||||
}
|
||||
else {
|
||||
await deleteInstallation(appConfig, entry);
|
||||
await remove(appConfig);
|
||||
}
|
||||
}
|
||||
}
|
||||
}
|
||||
|
||||
/**
|
||||
* @license
|
||||
* Copyright 2019 Google Inc.
|
||||
*
|
||||
* 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.
|
||||
*/
|
||||
function registerInstallations(instance) {
|
||||
const installationsName = 'installations';
|
||||
const factoryMethod = app => {
|
||||
// Throws if app isn't configured properly.
|
||||
extractAppConfig(app);
|
||||
return {
|
||||
app,
|
||||
getId: () => getId(app),
|
||||
getToken: () => getToken(app),
|
||||
delete: () => deleteInstallation$1(app)
|
||||
};
|
||||
};
|
||||
instance.INTERNAL.registerService(installationsName, factoryMethod);
|
||||
}
|
||||
registerInstallations(firebase);
|
||||
|
||||
export { registerInstallations };
|
||||
//# sourceMappingURL=index.esm2017.js.map
|
1
node_modules/@firebase/installations/dist/index.esm2017.js.map
generated
vendored
Normal file
1
node_modules/@firebase/installations/dist/index.esm2017.js.map
generated
vendored
Normal file
File diff suppressed because one or more lines are too long
38
node_modules/@firebase/installations/dist/src/api/common.d.ts
generated
vendored
Normal file
38
node_modules/@firebase/installations/dist/src/api/common.d.ts
generated
vendored
Normal file
@ -0,0 +1,38 @@
|
||||
/**
|
||||
* @license
|
||||
* Copyright 2019 Google Inc.
|
||||
*
|
||||
* 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 { FirebaseError } from '@firebase/util';
|
||||
import { GenerateAuthTokenResponse } from '../interfaces/api-response';
|
||||
import { AppConfig } from '../interfaces/app-config';
|
||||
import { CompletedAuthToken, RegisteredInstallationEntry } from '../interfaces/installation-entry';
|
||||
export declare function getInstallationsEndpoint({ projectId }: AppConfig): string;
|
||||
export declare function extractAuthTokenInfoFromResponse(response: GenerateAuthTokenResponse): CompletedAuthToken;
|
||||
export declare function getErrorFromResponse(requestName: string, response: Response): Promise<FirebaseError>;
|
||||
export declare function getHeaders({ apiKey }: AppConfig): Headers;
|
||||
export declare function getHeadersWithAuth(appConfig: AppConfig, { refreshToken }: RegisteredInstallationEntry): Headers;
|
||||
export interface ErrorResponse {
|
||||
error: {
|
||||
code: number;
|
||||
message: string;
|
||||
status: string;
|
||||
};
|
||||
}
|
||||
/**
|
||||
* Calls the passed in fetch wrapper and returns the response.
|
||||
* If the returned response has a status of 5xx, re-runs the function once and
|
||||
* returns the response.
|
||||
*/
|
||||
export declare function retryIfServerError(fn: () => Promise<Response>): Promise<Response>;
|
19
node_modules/@firebase/installations/dist/src/api/create-installation.d.ts
generated
vendored
Normal file
19
node_modules/@firebase/installations/dist/src/api/create-installation.d.ts
generated
vendored
Normal file
@ -0,0 +1,19 @@
|
||||
/**
|
||||
* @license
|
||||
* Copyright 2019 Google Inc.
|
||||
*
|
||||
* 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 { AppConfig } from '../interfaces/app-config';
|
||||
import { InProgressInstallationEntry, RegisteredInstallationEntry } from '../interfaces/installation-entry';
|
||||
export declare function createInstallation(appConfig: AppConfig, { fid }: InProgressInstallationEntry): Promise<RegisteredInstallationEntry>;
|
19
node_modules/@firebase/installations/dist/src/api/delete-installation.d.ts
generated
vendored
Normal file
19
node_modules/@firebase/installations/dist/src/api/delete-installation.d.ts
generated
vendored
Normal file
@ -0,0 +1,19 @@
|
||||
/**
|
||||
* @license
|
||||
* Copyright 2019 Google Inc.
|
||||
*
|
||||
* 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 { AppConfig } from '../interfaces/app-config';
|
||||
import { RegisteredInstallationEntry } from '../interfaces/installation-entry';
|
||||
export declare function deleteInstallation(appConfig: AppConfig, installationEntry: RegisteredInstallationEntry): Promise<void>;
|
19
node_modules/@firebase/installations/dist/src/api/generate-auth-token.d.ts
generated
vendored
Normal file
19
node_modules/@firebase/installations/dist/src/api/generate-auth-token.d.ts
generated
vendored
Normal file
@ -0,0 +1,19 @@
|
||||
/**
|
||||
* @license
|
||||
* Copyright 2019 Google Inc.
|
||||
*
|
||||
* 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 { AppConfig } from '../interfaces/app-config';
|
||||
import { CompletedAuthToken, RegisteredInstallationEntry } from '../interfaces/installation-entry';
|
||||
export declare function generateAuthToken(appConfig: AppConfig, installationEntry: RegisteredInstallationEntry): Promise<CompletedAuthToken>;
|
18
node_modules/@firebase/installations/dist/src/functions/delete-installation.d.ts
generated
vendored
Normal file
18
node_modules/@firebase/installations/dist/src/functions/delete-installation.d.ts
generated
vendored
Normal file
@ -0,0 +1,18 @@
|
||||
/**
|
||||
* @license
|
||||
* Copyright 2019 Google Inc.
|
||||
*
|
||||
* 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';
|
||||
export declare function deleteInstallation(app: FirebaseApp): Promise<void>;
|
18
node_modules/@firebase/installations/dist/src/functions/get-id.d.ts
generated
vendored
Normal file
18
node_modules/@firebase/installations/dist/src/functions/get-id.d.ts
generated
vendored
Normal file
@ -0,0 +1,18 @@
|
||||
/**
|
||||
* @license
|
||||
* Copyright 2019 Google Inc.
|
||||
*
|
||||
* 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';
|
||||
export declare function getId(app: FirebaseApp): Promise<string>;
|
18
node_modules/@firebase/installations/dist/src/functions/get-token.d.ts
generated
vendored
Normal file
18
node_modules/@firebase/installations/dist/src/functions/get-token.d.ts
generated
vendored
Normal file
@ -0,0 +1,18 @@
|
||||
/**
|
||||
* @license
|
||||
* Copyright 2019 Google Inc.
|
||||
*
|
||||
* 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';
|
||||
export declare function getToken(app: FirebaseApp): Promise<string>;
|
19
node_modules/@firebase/installations/dist/src/functions/index.d.ts
generated
vendored
Normal file
19
node_modules/@firebase/installations/dist/src/functions/index.d.ts
generated
vendored
Normal file
@ -0,0 +1,19 @@
|
||||
/**
|
||||
* @license
|
||||
* Copyright 2019 Google Inc.
|
||||
*
|
||||
* 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.
|
||||
*/
|
||||
export { getId } from './get-id';
|
||||
export { getToken } from './get-token';
|
||||
export { deleteInstallation } from './delete-installation';
|
17
node_modules/@firebase/installations/dist/src/helpers/buffer-to-base64-url-safe.d.ts
generated
vendored
Normal file
17
node_modules/@firebase/installations/dist/src/helpers/buffer-to-base64-url-safe.d.ts
generated
vendored
Normal file
@ -0,0 +1,17 @@
|
||||
/**
|
||||
* @license
|
||||
* Copyright 2019 Google Inc.
|
||||
*
|
||||
* 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.
|
||||
*/
|
||||
export declare function bufferToBase64UrlSafe(array: Uint8Array): string;
|
19
node_modules/@firebase/installations/dist/src/helpers/extract-app-config.d.ts
generated
vendored
Normal file
19
node_modules/@firebase/installations/dist/src/helpers/extract-app-config.d.ts
generated
vendored
Normal file
@ -0,0 +1,19 @@
|
||||
/**
|
||||
* @license
|
||||
* Copyright 2019 Google Inc.
|
||||
*
|
||||
* 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 { AppConfig } from '../interfaces/app-config';
|
||||
export declare function extractAppConfig(app: FirebaseApp): AppConfig;
|
23
node_modules/@firebase/installations/dist/src/helpers/generate-fid.d.ts
generated
vendored
Normal file
23
node_modules/@firebase/installations/dist/src/helpers/generate-fid.d.ts
generated
vendored
Normal file
@ -0,0 +1,23 @@
|
||||
/**
|
||||
* @license
|
||||
* Copyright 2019 Google Inc.
|
||||
*
|
||||
* 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.
|
||||
*/
|
||||
export declare const VALID_FID_PATTERN: RegExp;
|
||||
export declare const INVALID_FID = "";
|
||||
/**
|
||||
* Generates a new FID using random values from Web Crypto API.
|
||||
* Returns an empty string if FID generation fails for any reason.
|
||||
*/
|
||||
export declare function generateFid(): string;
|
27
node_modules/@firebase/installations/dist/src/helpers/get-installation-entry.d.ts
generated
vendored
Normal file
27
node_modules/@firebase/installations/dist/src/helpers/get-installation-entry.d.ts
generated
vendored
Normal file
@ -0,0 +1,27 @@
|
||||
/**
|
||||
* @license
|
||||
* Copyright 2019 Google Inc.
|
||||
*
|
||||
* 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 { AppConfig } from '../interfaces/app-config';
|
||||
import { InstallationEntry, RegisteredInstallationEntry } from '../interfaces/installation-entry';
|
||||
export interface InstallationEntryWithRegistrationPromise {
|
||||
installationEntry: InstallationEntry;
|
||||
registrationPromise?: Promise<RegisteredInstallationEntry>;
|
||||
}
|
||||
/**
|
||||
* Updates and returns the InstallationEntry from the database.
|
||||
* Also triggers a registration request if it is necessary and possible.
|
||||
*/
|
||||
export declare function getInstallationEntry(appConfig: AppConfig): Promise<InstallationEntryWithRegistrationPromise>;
|
31
node_modules/@firebase/installations/dist/src/helpers/idb-manager.d.ts
generated
vendored
Normal file
31
node_modules/@firebase/installations/dist/src/helpers/idb-manager.d.ts
generated
vendored
Normal file
@ -0,0 +1,31 @@
|
||||
/**
|
||||
* @license
|
||||
* Copyright 2019 Google Inc.
|
||||
*
|
||||
* 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 { AppConfig } from '../interfaces/app-config';
|
||||
/** Gets record(s) from the objectStore that match the given key. */
|
||||
export declare function get(appConfig: AppConfig): Promise<unknown>;
|
||||
/** Assigns or overwrites the record for the given key with the given value. */
|
||||
export declare function set<ValueType>(appConfig: AppConfig, value: ValueType): Promise<ValueType>;
|
||||
/** Removes record(s) from the objectStore that match the given key. */
|
||||
export declare function remove(appConfig: AppConfig): Promise<void>;
|
||||
/**
|
||||
* Atomically updates a record with the result of updateFn, which gets
|
||||
* called with the current value. If newValue is undefined, the record is
|
||||
* deleted instead.
|
||||
* @return Updated value
|
||||
*/
|
||||
export declare function update<OldType, NewType>(appConfig: AppConfig, updateFn: (previousValue: OldType | undefined) => NewType): Promise<NewType>;
|
||||
export declare function clear(): Promise<void>;
|
24
node_modules/@firebase/installations/dist/src/helpers/refresh-auth-token.d.ts
generated
vendored
Normal file
24
node_modules/@firebase/installations/dist/src/helpers/refresh-auth-token.d.ts
generated
vendored
Normal file
@ -0,0 +1,24 @@
|
||||
/**
|
||||
* @license
|
||||
* Copyright 2019 Google Inc.
|
||||
*
|
||||
* 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 { AppConfig } from '../interfaces/app-config';
|
||||
/**
|
||||
* Returns a valid authentication token for the installation. Generates a new
|
||||
* token if one doesn't exist, is expired or about to expire.
|
||||
*
|
||||
* Should only be called if the Firebase Installation is registered.
|
||||
*/
|
||||
export declare function refreshAuthToken(appConfig: AppConfig): Promise<string>;
|
30
node_modules/@firebase/installations/dist/src/index.d.ts
generated
vendored
Normal file
30
node_modules/@firebase/installations/dist/src/index.d.ts
generated
vendored
Normal file
@ -0,0 +1,30 @@
|
||||
/**
|
||||
* @license
|
||||
* Copyright 2019 Google Inc.
|
||||
*
|
||||
* 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 { _FirebaseNamespace } from '@firebase/app-types/private';
|
||||
import { FirebaseInstallations } from '@firebase/installations-types';
|
||||
export declare function registerInstallations(instance: _FirebaseNamespace): void;
|
||||
/**
|
||||
* Define extension behavior of `registerInstallations`
|
||||
*/
|
||||
declare module '@firebase/app-types' {
|
||||
interface FirebaseNamespace {
|
||||
installations(app?: FirebaseApp): FirebaseInstallations;
|
||||
}
|
||||
interface FirebaseApp {
|
||||
installations(): FirebaseInstallations;
|
||||
}
|
||||
}
|
31
node_modules/@firebase/installations/dist/src/interfaces/api-response.d.ts
generated
vendored
Normal file
31
node_modules/@firebase/installations/dist/src/interfaces/api-response.d.ts
generated
vendored
Normal file
@ -0,0 +1,31 @@
|
||||
/**
|
||||
* @license
|
||||
* Copyright 2019 Google Inc.
|
||||
*
|
||||
* 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.
|
||||
*/
|
||||
export interface CreateInstallationResponse {
|
||||
readonly refreshToken: string;
|
||||
readonly authToken: GenerateAuthTokenResponse;
|
||||
readonly fid?: string;
|
||||
}
|
||||
export interface GenerateAuthTokenResponse {
|
||||
readonly token: string;
|
||||
/**
|
||||
* Encoded as a string with the suffix 's' (indicating seconds), preceded by
|
||||
* the number of seconds.
|
||||
*
|
||||
* Example: "604800s".
|
||||
*/
|
||||
readonly expiresIn: string;
|
||||
}
|
22
node_modules/@firebase/installations/dist/src/interfaces/app-config.d.ts
generated
vendored
Normal file
22
node_modules/@firebase/installations/dist/src/interfaces/app-config.d.ts
generated
vendored
Normal file
@ -0,0 +1,22 @@
|
||||
/**
|
||||
* @license
|
||||
* Copyright 2019 Google Inc.
|
||||
*
|
||||
* 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.
|
||||
*/
|
||||
export interface AppConfig {
|
||||
readonly appName: string;
|
||||
readonly projectId: string;
|
||||
readonly apiKey: string;
|
||||
readonly appId: string;
|
||||
}
|
85
node_modules/@firebase/installations/dist/src/interfaces/installation-entry.d.ts
generated
vendored
Normal file
85
node_modules/@firebase/installations/dist/src/interfaces/installation-entry.d.ts
generated
vendored
Normal file
@ -0,0 +1,85 @@
|
||||
/**
|
||||
* @license
|
||||
* Copyright 2019 Google Inc.
|
||||
*
|
||||
* 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.
|
||||
*/
|
||||
/** Status of a server request. */
|
||||
export declare const enum RequestStatus {
|
||||
NOT_STARTED = 0,
|
||||
IN_PROGRESS = 1,
|
||||
COMPLETED = 2
|
||||
}
|
||||
export interface NotStartedAuthToken {
|
||||
readonly requestStatus: RequestStatus.NOT_STARTED;
|
||||
}
|
||||
export interface InProgressAuthToken {
|
||||
readonly requestStatus: RequestStatus.IN_PROGRESS;
|
||||
/**
|
||||
* Unix timestamp when the current generateAuthRequest was initiated.
|
||||
* Used for figuring out how long the request status has been IN_PROGRESS.
|
||||
*/
|
||||
readonly requestTime: number;
|
||||
}
|
||||
export interface CompletedAuthToken {
|
||||
readonly requestStatus: RequestStatus.COMPLETED;
|
||||
/**
|
||||
* Firebase Installations Authentication Token.
|
||||
* Only exists if requestStatus is COMPLETED.
|
||||
*/
|
||||
readonly token: string;
|
||||
/**
|
||||
* Unix timestamp when Authentication Token was created.
|
||||
* Only exists if requestStatus is COMPLETED.
|
||||
*/
|
||||
readonly creationTime: number;
|
||||
/**
|
||||
* Authentication Token time to live duration in milliseconds.
|
||||
* Only exists if requestStatus is COMPLETED.
|
||||
*/
|
||||
readonly expiresIn: number;
|
||||
}
|
||||
export declare type AuthToken = NotStartedAuthToken | InProgressAuthToken | CompletedAuthToken;
|
||||
export interface UnregisteredInstallationEntry {
|
||||
/** Status of the Firebase Installation registration on the server. */
|
||||
readonly registrationStatus: RequestStatus.NOT_STARTED;
|
||||
/** Firebase Installation ID */
|
||||
readonly fid: string;
|
||||
}
|
||||
export interface InProgressInstallationEntry {
|
||||
/** Status of the Firebase Installation registration on the server. */
|
||||
readonly registrationStatus: RequestStatus.IN_PROGRESS;
|
||||
/**
|
||||
* Unix timestamp that shows the time when the current createInstallation
|
||||
* request was initiated.
|
||||
* Used for figuring out how long the registration status has been PENDING.
|
||||
*/
|
||||
readonly registrationTime: number;
|
||||
/** Firebase Installation ID */
|
||||
readonly fid: string;
|
||||
}
|
||||
export interface RegisteredInstallationEntry {
|
||||
/** Status of the Firebase Installation registration on the server. */
|
||||
readonly registrationStatus: RequestStatus.COMPLETED;
|
||||
/** Firebase Installation ID */
|
||||
readonly fid: string;
|
||||
/**
|
||||
* Refresh Token returned from the server.
|
||||
* Used for authenticating generateAuthToken requests.
|
||||
*/
|
||||
readonly refreshToken: string;
|
||||
/** Firebase Installation Authentication Token. */
|
||||
readonly authToken: AuthToken;
|
||||
}
|
||||
/** Firebase Installation ID and related data in the database. */
|
||||
export declare type InstallationEntry = UnregisteredInstallationEntry | InProgressInstallationEntry | RegisteredInstallationEntry;
|
23
node_modules/@firebase/installations/dist/src/util/constants.d.ts
generated
vendored
Normal file
23
node_modules/@firebase/installations/dist/src/util/constants.d.ts
generated
vendored
Normal file
@ -0,0 +1,23 @@
|
||||
/**
|
||||
* @license
|
||||
* Copyright 2019 Google Inc.
|
||||
*
|
||||
* 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.
|
||||
*/
|
||||
export declare const PENDING_TIMEOUT_MS = 10000;
|
||||
export declare const PACKAGE_VERSION: string;
|
||||
export declare const INTERNAL_AUTH_VERSION = "FIS_v2";
|
||||
export declare const INSTALLATIONS_API_URL = "https://firebaseinstallations.googleapis.com/v1";
|
||||
export declare const TOKEN_EXPIRATION_BUFFER: number;
|
||||
export declare const SERVICE = "installations";
|
||||
export declare const SERVICE_NAME = "Installations";
|
42
node_modules/@firebase/installations/dist/src/util/errors.d.ts
generated
vendored
Normal file
42
node_modules/@firebase/installations/dist/src/util/errors.d.ts
generated
vendored
Normal file
@ -0,0 +1,42 @@
|
||||
/**
|
||||
* @license
|
||||
* Copyright 2019 Google Inc.
|
||||
*
|
||||
* 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 { ErrorFactory, FirebaseError } from '@firebase/util';
|
||||
export declare const enum ErrorCode {
|
||||
MISSING_APP_CONFIG_VALUES = "missing-app-config-values",
|
||||
CREATE_INSTALLATION_FAILED = "create-installation-failed",
|
||||
GENERATE_TOKEN_FAILED = "generate-token-failed",
|
||||
NOT_REGISTERED = "not-registered",
|
||||
INSTALLATION_NOT_FOUND = "installation-not-found",
|
||||
REQUEST_FAILED = "request-failed",
|
||||
APP_OFFLINE = "app-offline",
|
||||
DELETE_PENDING_REGISTRATION = "delete-pending-registration"
|
||||
}
|
||||
interface ErrorParams {
|
||||
[ErrorCode.REQUEST_FAILED]: {
|
||||
requestName: string;
|
||||
} & ServerErrorData;
|
||||
}
|
||||
export declare const ERROR_FACTORY: ErrorFactory<ErrorCode, ErrorParams>;
|
||||
export interface ServerErrorData {
|
||||
serverCode: number;
|
||||
serverMessage: string;
|
||||
serverStatus: string;
|
||||
}
|
||||
export declare type ServerError = FirebaseError & ServerErrorData;
|
||||
/** Returns true if error is a FirebaseError that is based on an error from the server. */
|
||||
export declare function isServerError(error: unknown): error is ServerError;
|
||||
export {};
|
18
node_modules/@firebase/installations/dist/src/util/sleep.d.ts
generated
vendored
Normal file
18
node_modules/@firebase/installations/dist/src/util/sleep.d.ts
generated
vendored
Normal file
@ -0,0 +1,18 @@
|
||||
/**
|
||||
* @license
|
||||
* Copyright 2019 Google Inc.
|
||||
*
|
||||
* 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.
|
||||
*/
|
||||
/** Returns a promise that resolves after given time passes. */
|
||||
export declare function sleep(ms: number): Promise<void>;
|
Reference in New Issue
Block a user