12345678910111213141516171819202122232425262728293031323334353637383940414243444546474849505152535455565758596061626364656667686970717273747576777879808182838485868788899091929394959697989910010110210310410510610710810911011111211311411511611711811912012112212312412512612712812913013113213313413513613713813914014114214314414514614714814915015115215315415515615715815916016116216316416516616716816917017117217317417517617717817918018118218318418518618718818919019119219319419519619719819920020120220320420520620720820921021121221321421521621721821922022122222322422522622722822923023123223323423523623723823924024124224324424524624724824925025125225325425525625725825926026126226326426526626726826927027127227327427527627727827928028128228328428528628728828929029129229329429529629729829930030130230330430530630730830931031131231331431531631731831932032132232332432532632732832933033133233333433533633733833934034134234334434534634734834935035135235335435535635735835936036136236336436536636736836937037137237337437537637737837938038138238338438538638738838939039139239339439539639739839940040140240340440540640740840941041141241341441541641741841942042142242342442542642742842943043143243343443543643743843944044144244344444544644744844945045145245345445545645745845946046146246346446546646746846947047147247347447547647747847948048148248348448548648748848949049149249349449549649749849950050150250350450550650750850951051151251351451551651751851952052152252352452552652752852953053153253353453553653753853954054154254354454554654754854955055155255355455555655755855956056156256356456556656756856957057157257357457557657757857958058158258358458558658758858959059159259359459559659759859960060160260360460560660760860961061161261361461561661761861962062162262362462562662762862963063163263363463563663763863964064164264364464564664764864965065165265365465565665765865966066166266366466566666766866967067167267367467567667767867968068168268368468568668768868969069169269369469569669769869970070170270370470570670770870971071171271371471571671771871972072172272372472572672772872973073173273373473573673773873974074174274374474574674774874975075175275375475575675775875976076176276376476576676776876977077177277377477577677777877978078178278378478578678778878979079179279379479579679779879980080180280380480580680780880981081181281381481581681781881982082182282382482582682782882983083183283383483583683783883984084184284384484584684784884985085185285385485585685785885986086186286386486586686786886987087187287387487587687787887988088188288388488588688788888989089189289389489589689789889990090190290390490590690790890991091191291391491591691791891992092192292392492592692792892993093193293393493593693793893994094194294394494594694794894995095195295395495595695795895996096196296396496596696796896997097197297397497597697797897998098198298398498598698798898999099199299399499599699799899910001001100210031004 |
- import firebase from '@firebase/app-compat';
- import * as exp from '@firebase/auth/internal';
- import { Component } from '@firebase/component';
- import { isBrowserExtension, getUA, isReactNative, isNode, isIndexedDBAvailable, isIE, FirebaseError } from '@firebase/util';
-
- var name = "@firebase/auth-compat";
- var version = "0.3.1";
-
-
- const CORDOVA_ONDEVICEREADY_TIMEOUT_MS = 1000;
- function _getCurrentScheme() {
- var _a;
- return ((_a = self === null || self === void 0 ? void 0 : self.location) === null || _a === void 0 ? void 0 : _a.protocol) || null;
- }
-
- function _isHttpOrHttps() {
- return _getCurrentScheme() === 'http:' || _getCurrentScheme() === 'https:';
- }
-
- function _isAndroidOrIosCordovaScheme(ua = getUA()) {
- return !!((_getCurrentScheme() === 'file:' ||
- _getCurrentScheme() === 'ionic:' ||
- _getCurrentScheme() === 'capacitor:') &&
- ua.toLowerCase().match(/iphone|ipad|ipod|android/));
- }
-
- function _isNativeEnvironment() {
- return isReactNative() || isNode();
- }
-
- function _isIe11() {
- return isIE() && (document === null || document === void 0 ? void 0 : document.documentMode) === 11;
- }
-
- function _isEdge(ua = getUA()) {
- return /Edge\/\d+/.test(ua);
- }
-
- function _isLocalStorageNotSynchronized(ua = getUA()) {
- return _isIe11() || _isEdge(ua);
- }
-
- function _isWebStorageSupported() {
- try {
- const storage = self.localStorage;
- const key = exp._generateEventId();
- if (storage) {
-
-
- storage['setItem'](key, '1');
- storage['removeItem'](key);
-
-
-
-
-
- if (_isLocalStorageNotSynchronized()) {
-
-
- return isIndexedDBAvailable();
- }
- return true;
- }
- }
- catch (e) {
-
-
- return _isWorker() && isIndexedDBAvailable();
- }
- return false;
- }
-
- function _isWorker() {
-
- return (typeof global !== 'undefined' &&
- 'WorkerGlobalScope' in global &&
- 'importScripts' in global);
- }
- function _isPopupRedirectSupported() {
- return ((_isHttpOrHttps() ||
- isBrowserExtension() ||
- _isAndroidOrIosCordovaScheme()) &&
-
-
- !_isNativeEnvironment() &&
-
-
- _isWebStorageSupported() &&
-
- !_isWorker());
- }
-
- function _isLikelyCordova() {
- return _isAndroidOrIosCordovaScheme() && typeof document !== 'undefined';
- }
- async function _isCordova() {
- if (!_isLikelyCordova()) {
- return false;
- }
- return new Promise(resolve => {
- const timeoutId = setTimeout(() => {
-
- resolve(false);
- }, CORDOVA_ONDEVICEREADY_TIMEOUT_MS);
- document.addEventListener('deviceready', () => {
- clearTimeout(timeoutId);
- resolve(true);
- });
- });
- }
- function _getSelfWindow() {
- return typeof window !== 'undefined' ? window : null;
- }
-
-
- const Persistence = {
- LOCAL: 'local',
- NONE: 'none',
- SESSION: 'session'
- };
- const _assert$3 = exp._assert;
- const PERSISTENCE_KEY = 'persistence';
-
- function _validatePersistenceArgument(auth, persistence) {
- _assert$3(Object.values(Persistence).includes(persistence), auth, "invalid-persistence-type" );
-
- if (isReactNative()) {
-
- _assert$3(persistence !== Persistence.SESSION, auth, "unsupported-persistence-type" );
- return;
- }
- if (isNode()) {
-
- _assert$3(persistence === Persistence.NONE, auth, "unsupported-persistence-type" );
- return;
- }
- if (_isWorker()) {
-
-
- _assert$3(persistence === Persistence.NONE ||
- (persistence === Persistence.LOCAL && isIndexedDBAvailable()), auth, "unsupported-persistence-type" );
- return;
- }
-
- _assert$3(persistence === Persistence.NONE || _isWebStorageSupported(), auth, "unsupported-persistence-type" );
- }
- async function _savePersistenceForRedirect(auth) {
- await auth._initializationPromise;
- const session = getSessionStorageIfAvailable();
- const key = exp._persistenceKeyName(PERSISTENCE_KEY, auth.config.apiKey, auth.name);
- if (session) {
- session.setItem(key, auth._getPersistence());
- }
- }
- function _getPersistencesFromRedirect(apiKey, appName) {
- const session = getSessionStorageIfAvailable();
- if (!session) {
- return [];
- }
- const key = exp._persistenceKeyName(PERSISTENCE_KEY, apiKey, appName);
- const persistence = session.getItem(key);
- switch (persistence) {
- case Persistence.NONE:
- return [exp.inMemoryPersistence];
- case Persistence.LOCAL:
- return [exp.indexedDBLocalPersistence, exp.browserSessionPersistence];
- case Persistence.SESSION:
- return [exp.browserSessionPersistence];
- default:
- return [];
- }
- }
-
- function getSessionStorageIfAvailable() {
- var _a;
- try {
- return ((_a = _getSelfWindow()) === null || _a === void 0 ? void 0 : _a.sessionStorage) || null;
- }
- catch (e) {
- return null;
- }
- }
-
-
- const _assert$2 = exp._assert;
-
- class CompatPopupRedirectResolver {
- constructor() {
-
- this.browserResolver = exp._getInstance(exp.browserPopupRedirectResolver);
- this.cordovaResolver = exp._getInstance(exp.cordovaPopupRedirectResolver);
-
- this.underlyingResolver = null;
- this._redirectPersistence = exp.browserSessionPersistence;
- this._completeRedirectFn = exp._getRedirectResult;
- this._overrideRedirectResult = exp._overrideRedirectResult;
- }
- async _initialize(auth) {
- await this.selectUnderlyingResolver();
- return this.assertedUnderlyingResolver._initialize(auth);
- }
- async _openPopup(auth, provider, authType, eventId) {
- await this.selectUnderlyingResolver();
- return this.assertedUnderlyingResolver._openPopup(auth, provider, authType, eventId);
- }
- async _openRedirect(auth, provider, authType, eventId) {
- await this.selectUnderlyingResolver();
- return this.assertedUnderlyingResolver._openRedirect(auth, provider, authType, eventId);
- }
- _isIframeWebStorageSupported(auth, cb) {
- this.assertedUnderlyingResolver._isIframeWebStorageSupported(auth, cb);
- }
- _originValidation(auth) {
- return this.assertedUnderlyingResolver._originValidation(auth);
- }
- get _shouldInitProactively() {
- return _isLikelyCordova() || this.browserResolver._shouldInitProactively;
- }
- get assertedUnderlyingResolver() {
- _assert$2(this.underlyingResolver, "internal-error" );
- return this.underlyingResolver;
- }
- async selectUnderlyingResolver() {
- if (this.underlyingResolver) {
- return;
- }
-
-
- const isCordova = await _isCordova();
- this.underlyingResolver = isCordova
- ? this.cordovaResolver
- : this.browserResolver;
- }
- }
-
-
- function unwrap(object) {
- return object.unwrap();
- }
- function wrapped(object) {
- return object.wrapped();
- }
-
-
- function credentialFromResponse(userCredential) {
- return credentialFromObject(userCredential);
- }
- function attachExtraErrorFields(auth, e) {
- var _a;
-
-
- const response = (_a = e.customData) === null || _a === void 0 ? void 0 : _a._tokenResponse;
- if ((e === null || e === void 0 ? void 0 : e.code) === 'auth/multi-factor-auth-required') {
- const mfaErr = e;
- mfaErr.resolver = new MultiFactorResolver(auth, exp.getMultiFactorResolver(auth, e));
- }
- else if (response) {
- const credential = credentialFromObject(e);
- const credErr = e;
- if (credential) {
- credErr.credential = credential;
- credErr.tenantId = response.tenantId || undefined;
- credErr.email = response.email || undefined;
- credErr.phoneNumber = response.phoneNumber || undefined;
- }
- }
- }
- function credentialFromObject(object) {
- const { _tokenResponse } = (object instanceof FirebaseError ? object.customData : object);
- if (!_tokenResponse) {
- return null;
- }
-
-
-
- if (!(object instanceof FirebaseError)) {
- if ('temporaryProof' in _tokenResponse && 'phoneNumber' in _tokenResponse) {
- return exp.PhoneAuthProvider.credentialFromResult(object);
- }
- }
- const providerId = _tokenResponse.providerId;
-
-
- if (!providerId || providerId === exp.ProviderId.PASSWORD) {
- return null;
- }
- let provider;
- switch (providerId) {
- case exp.ProviderId.GOOGLE:
- provider = exp.GoogleAuthProvider;
- break;
- case exp.ProviderId.FACEBOOK:
- provider = exp.FacebookAuthProvider;
- break;
- case exp.ProviderId.GITHUB:
- provider = exp.GithubAuthProvider;
- break;
- case exp.ProviderId.TWITTER:
- provider = exp.TwitterAuthProvider;
- break;
- default:
- const { oauthIdToken, oauthAccessToken, oauthTokenSecret, pendingToken, nonce } = _tokenResponse;
- if (!oauthAccessToken &&
- !oauthTokenSecret &&
- !oauthIdToken &&
- !pendingToken) {
- return null;
- }
-
- if (pendingToken) {
- if (providerId.startsWith('saml.')) {
- return exp.SAMLAuthCredential._create(providerId, pendingToken);
- }
- else {
-
- return exp.OAuthCredential._fromParams({
- providerId,
- signInMethod: providerId,
- pendingToken,
- idToken: oauthIdToken,
- accessToken: oauthAccessToken
- });
- }
- }
- return new exp.OAuthProvider(providerId).credential({
- idToken: oauthIdToken,
- accessToken: oauthAccessToken,
- rawNonce: nonce
- });
- }
- return object instanceof FirebaseError
- ? provider.credentialFromError(object)
- : provider.credentialFromResult(object);
- }
- function convertCredential(auth, credentialPromise) {
- return credentialPromise
- .catch(e => {
- if (e instanceof FirebaseError) {
- attachExtraErrorFields(auth, e);
- }
- throw e;
- })
- .then(credential => {
- const operationType = credential.operationType;
- const user = credential.user;
- return {
- operationType,
- credential: credentialFromResponse(credential),
- additionalUserInfo: exp.getAdditionalUserInfo(credential),
- user: User.getOrCreate(user)
- };
- });
- }
- async function convertConfirmationResult(auth, confirmationResultPromise) {
- const confirmationResultExp = await confirmationResultPromise;
- return {
- verificationId: confirmationResultExp.verificationId,
- confirm: (verificationCode) => convertCredential(auth, confirmationResultExp.confirm(verificationCode))
- };
- }
- class MultiFactorResolver {
- constructor(auth, resolver) {
- this.resolver = resolver;
- this.auth = wrapped(auth);
- }
- get session() {
- return this.resolver.session;
- }
- get hints() {
- return this.resolver.hints;
- }
- resolveSignIn(assertion) {
- return convertCredential(unwrap(this.auth), this.resolver.resolveSignIn(assertion));
- }
- }
-
-
- class User {
- constructor(_delegate) {
- this._delegate = _delegate;
- this.multiFactor = exp.multiFactor(_delegate);
- }
- static getOrCreate(user) {
- if (!User.USER_MAP.has(user)) {
- User.USER_MAP.set(user, new User(user));
- }
- return User.USER_MAP.get(user);
- }
- delete() {
- return this._delegate.delete();
- }
- reload() {
- return this._delegate.reload();
- }
- toJSON() {
- return this._delegate.toJSON();
- }
- getIdTokenResult(forceRefresh) {
- return this._delegate.getIdTokenResult(forceRefresh);
- }
- getIdToken(forceRefresh) {
- return this._delegate.getIdToken(forceRefresh);
- }
- linkAndRetrieveDataWithCredential(credential) {
- return this.linkWithCredential(credential);
- }
- async linkWithCredential(credential) {
- return convertCredential(this.auth, exp.linkWithCredential(this._delegate, credential));
- }
- async linkWithPhoneNumber(phoneNumber, applicationVerifier) {
- return convertConfirmationResult(this.auth, exp.linkWithPhoneNumber(this._delegate, phoneNumber, applicationVerifier));
- }
- async linkWithPopup(provider) {
- return convertCredential(this.auth, exp.linkWithPopup(this._delegate, provider, CompatPopupRedirectResolver));
- }
- async linkWithRedirect(provider) {
- await _savePersistenceForRedirect(exp._castAuth(this.auth));
- return exp.linkWithRedirect(this._delegate, provider, CompatPopupRedirectResolver);
- }
- reauthenticateAndRetrieveDataWithCredential(credential) {
- return this.reauthenticateWithCredential(credential);
- }
- async reauthenticateWithCredential(credential) {
- return convertCredential(this.auth, exp.reauthenticateWithCredential(this._delegate, credential));
- }
- reauthenticateWithPhoneNumber(phoneNumber, applicationVerifier) {
- return convertConfirmationResult(this.auth, exp.reauthenticateWithPhoneNumber(this._delegate, phoneNumber, applicationVerifier));
- }
- reauthenticateWithPopup(provider) {
- return convertCredential(this.auth, exp.reauthenticateWithPopup(this._delegate, provider, CompatPopupRedirectResolver));
- }
- async reauthenticateWithRedirect(provider) {
- await _savePersistenceForRedirect(exp._castAuth(this.auth));
- return exp.reauthenticateWithRedirect(this._delegate, provider, CompatPopupRedirectResolver);
- }
- sendEmailVerification(actionCodeSettings) {
- return exp.sendEmailVerification(this._delegate, actionCodeSettings);
- }
- async unlink(providerId) {
- await exp.unlink(this._delegate, providerId);
- return this;
- }
- updateEmail(newEmail) {
- return exp.updateEmail(this._delegate, newEmail);
- }
- updatePassword(newPassword) {
- return exp.updatePassword(this._delegate, newPassword);
- }
- updatePhoneNumber(phoneCredential) {
- return exp.updatePhoneNumber(this._delegate, phoneCredential);
- }
- updateProfile(profile) {
- return exp.updateProfile(this._delegate, profile);
- }
- verifyBeforeUpdateEmail(newEmail, actionCodeSettings) {
- return exp.verifyBeforeUpdateEmail(this._delegate, newEmail, actionCodeSettings);
- }
- get emailVerified() {
- return this._delegate.emailVerified;
- }
- get isAnonymous() {
- return this._delegate.isAnonymous;
- }
- get metadata() {
- return this._delegate.metadata;
- }
- get phoneNumber() {
- return this._delegate.phoneNumber;
- }
- get providerData() {
- return this._delegate.providerData;
- }
- get refreshToken() {
- return this._delegate.refreshToken;
- }
- get tenantId() {
- return this._delegate.tenantId;
- }
- get displayName() {
- return this._delegate.displayName;
- }
- get email() {
- return this._delegate.email;
- }
- get photoURL() {
- return this._delegate.photoURL;
- }
- get providerId() {
- return this._delegate.providerId;
- }
- get uid() {
- return this._delegate.uid;
- }
- get auth() {
- return this._delegate.auth;
- }
- }
-
-
- User.USER_MAP = new WeakMap();
-
-
- const _assert$1 = exp._assert;
- class Auth {
- constructor(app, provider) {
- this.app = app;
- if (provider.isInitialized()) {
- this._delegate = provider.getImmediate();
- this.linkUnderlyingAuth();
- return;
- }
- const { apiKey } = app.options;
-
- _assert$1(apiKey, "invalid-api-key" , {
- appName: app.name
- });
-
- _assert$1(apiKey, "invalid-api-key" , {
- appName: app.name
- });
-
- const resolver = typeof window !== 'undefined' ? CompatPopupRedirectResolver : undefined;
- this._delegate = provider.initialize({
- options: {
- persistence: buildPersistenceHierarchy(apiKey, app.name),
- popupRedirectResolver: resolver
- }
- });
- this._delegate._updateErrorMap(exp.debugErrorMap);
- this.linkUnderlyingAuth();
- }
- get emulatorConfig() {
- return this._delegate.emulatorConfig;
- }
- get currentUser() {
- if (!this._delegate.currentUser) {
- return null;
- }
- return User.getOrCreate(this._delegate.currentUser);
- }
- get languageCode() {
- return this._delegate.languageCode;
- }
- set languageCode(languageCode) {
- this._delegate.languageCode = languageCode;
- }
- get settings() {
- return this._delegate.settings;
- }
- get tenantId() {
- return this._delegate.tenantId;
- }
- set tenantId(tid) {
- this._delegate.tenantId = tid;
- }
- useDeviceLanguage() {
- this._delegate.useDeviceLanguage();
- }
- signOut() {
- return this._delegate.signOut();
- }
- useEmulator(url, options) {
- exp.connectAuthEmulator(this._delegate, url, options);
- }
- applyActionCode(code) {
- return exp.applyActionCode(this._delegate, code);
- }
- checkActionCode(code) {
- return exp.checkActionCode(this._delegate, code);
- }
- confirmPasswordReset(code, newPassword) {
- return exp.confirmPasswordReset(this._delegate, code, newPassword);
- }
- async createUserWithEmailAndPassword(email, password) {
- return convertCredential(this._delegate, exp.createUserWithEmailAndPassword(this._delegate, email, password));
- }
- fetchProvidersForEmail(email) {
- return this.fetchSignInMethodsForEmail(email);
- }
- fetchSignInMethodsForEmail(email) {
- return exp.fetchSignInMethodsForEmail(this._delegate, email);
- }
- isSignInWithEmailLink(emailLink) {
- return exp.isSignInWithEmailLink(this._delegate, emailLink);
- }
- async getRedirectResult() {
- _assert$1(_isPopupRedirectSupported(), this._delegate, "operation-not-supported-in-this-environment" );
- const credential = await exp.getRedirectResult(this._delegate, CompatPopupRedirectResolver);
- if (!credential) {
- return {
- credential: null,
- user: null
- };
- }
- return convertCredential(this._delegate, Promise.resolve(credential));
- }
-
-
-
- addFrameworkForLogging(framework) {
- exp.addFrameworkForLogging(this._delegate, framework);
- }
- onAuthStateChanged(nextOrObserver, errorFn, completed) {
- const { next, error, complete } = wrapObservers(nextOrObserver, errorFn, completed);
- return this._delegate.onAuthStateChanged(next, error, complete);
- }
- onIdTokenChanged(nextOrObserver, errorFn, completed) {
- const { next, error, complete } = wrapObservers(nextOrObserver, errorFn, completed);
- return this._delegate.onIdTokenChanged(next, error, complete);
- }
- sendSignInLinkToEmail(email, actionCodeSettings) {
- return exp.sendSignInLinkToEmail(this._delegate, email, actionCodeSettings);
- }
- sendPasswordResetEmail(email, actionCodeSettings) {
- return exp.sendPasswordResetEmail(this._delegate, email, actionCodeSettings || undefined);
- }
- async setPersistence(persistence) {
- _validatePersistenceArgument(this._delegate, persistence);
- let converted;
- switch (persistence) {
- case Persistence.SESSION:
- converted = exp.browserSessionPersistence;
- break;
- case Persistence.LOCAL:
-
- const isIndexedDBFullySupported = await exp
- ._getInstance(exp.indexedDBLocalPersistence)
- ._isAvailable();
- converted = isIndexedDBFullySupported
- ? exp.indexedDBLocalPersistence
- : exp.browserLocalPersistence;
- break;
- case Persistence.NONE:
- converted = exp.inMemoryPersistence;
- break;
- default:
- return exp._fail("argument-error" , {
- appName: this._delegate.name
- });
- }
- return this._delegate.setPersistence(converted);
- }
- signInAndRetrieveDataWithCredential(credential) {
- return this.signInWithCredential(credential);
- }
- signInAnonymously() {
- return convertCredential(this._delegate, exp.signInAnonymously(this._delegate));
- }
- signInWithCredential(credential) {
- return convertCredential(this._delegate, exp.signInWithCredential(this._delegate, credential));
- }
- signInWithCustomToken(token) {
- return convertCredential(this._delegate, exp.signInWithCustomToken(this._delegate, token));
- }
- signInWithEmailAndPassword(email, password) {
- return convertCredential(this._delegate, exp.signInWithEmailAndPassword(this._delegate, email, password));
- }
- signInWithEmailLink(email, emailLink) {
- return convertCredential(this._delegate, exp.signInWithEmailLink(this._delegate, email, emailLink));
- }
- signInWithPhoneNumber(phoneNumber, applicationVerifier) {
- return convertConfirmationResult(this._delegate, exp.signInWithPhoneNumber(this._delegate, phoneNumber, applicationVerifier));
- }
- async signInWithPopup(provider) {
- _assert$1(_isPopupRedirectSupported(), this._delegate, "operation-not-supported-in-this-environment" );
- return convertCredential(this._delegate, exp.signInWithPopup(this._delegate, provider, CompatPopupRedirectResolver));
- }
- async signInWithRedirect(provider) {
- _assert$1(_isPopupRedirectSupported(), this._delegate, "operation-not-supported-in-this-environment" );
- await _savePersistenceForRedirect(this._delegate);
- return exp.signInWithRedirect(this._delegate, provider, CompatPopupRedirectResolver);
- }
- updateCurrentUser(user) {
-
-
- return this._delegate.updateCurrentUser(user);
- }
- verifyPasswordResetCode(code) {
- return exp.verifyPasswordResetCode(this._delegate, code);
- }
- unwrap() {
- return this._delegate;
- }
- _delete() {
- return this._delegate._delete();
- }
- linkUnderlyingAuth() {
- this._delegate.wrapped = () => this;
- }
- }
- Auth.Persistence = Persistence;
- function wrapObservers(nextOrObserver, error, complete) {
- let next = nextOrObserver;
- if (typeof nextOrObserver !== 'function') {
- ({ next, error, complete } = nextOrObserver);
- }
-
- const oldNext = next;
- const newNext = (user) => oldNext(user && User.getOrCreate(user));
- return {
- next: newNext,
- error: error,
- complete
- };
- }
- function buildPersistenceHierarchy(apiKey, appName) {
-
-
-
-
- const persistences = _getPersistencesFromRedirect(apiKey, appName);
-
- if (typeof self !== 'undefined' &&
- !persistences.includes(exp.indexedDBLocalPersistence)) {
- persistences.push(exp.indexedDBLocalPersistence);
- }
-
- if (typeof window !== 'undefined') {
- for (const persistence of [
- exp.browserLocalPersistence,
- exp.browserSessionPersistence
- ]) {
- if (!persistences.includes(persistence)) {
- persistences.push(persistence);
- }
- }
- }
-
- if (!persistences.includes(exp.inMemoryPersistence)) {
- persistences.push(exp.inMemoryPersistence);
- }
- return persistences;
- }
-
-
- class PhoneAuthProvider {
- constructor() {
- this.providerId = 'phone';
-
-
- this._delegate = new exp.PhoneAuthProvider(unwrap(firebase.auth()));
- }
- static credential(verificationId, verificationCode) {
- return exp.PhoneAuthProvider.credential(verificationId, verificationCode);
- }
- verifyPhoneNumber(phoneInfoOptions, applicationVerifier) {
- return this._delegate.verifyPhoneNumber(
-
-
- phoneInfoOptions, applicationVerifier);
- }
- unwrap() {
- return this._delegate;
- }
- }
- PhoneAuthProvider.PHONE_SIGN_IN_METHOD = exp.PhoneAuthProvider.PHONE_SIGN_IN_METHOD;
- PhoneAuthProvider.PROVIDER_ID = exp.PhoneAuthProvider.PROVIDER_ID;
-
-
- const _assert = exp._assert;
- class RecaptchaVerifier {
- constructor(container, parameters, app = firebase.app()) {
- var _a;
-
- _assert((_a = app.options) === null || _a === void 0 ? void 0 : _a.apiKey, "invalid-api-key" , {
- appName: app.name
- });
- this._delegate = new exp.RecaptchaVerifier(container,
-
- parameters,
-
-
- app.auth());
- this.type = this._delegate.type;
- }
- clear() {
- this._delegate.clear();
- }
- render() {
- return this._delegate.render();
- }
- verify() {
- return this._delegate.verify();
- }
- }
-
-
- const AUTH_TYPE = 'auth-compat';
-
-
- function registerAuthCompat(instance) {
- instance.INTERNAL.registerComponent(new Component(AUTH_TYPE, container => {
-
- const app = container.getProvider('app-compat').getImmediate();
- const authProvider = container.getProvider('auth');
- return new Auth(app, authProvider);
- }, "PUBLIC" )
- .setServiceProps({
- ActionCodeInfo: {
- Operation: {
- EMAIL_SIGNIN: exp.ActionCodeOperation.EMAIL_SIGNIN,
- PASSWORD_RESET: exp.ActionCodeOperation.PASSWORD_RESET,
- RECOVER_EMAIL: exp.ActionCodeOperation.RECOVER_EMAIL,
- REVERT_SECOND_FACTOR_ADDITION: exp.ActionCodeOperation.REVERT_SECOND_FACTOR_ADDITION,
- VERIFY_AND_CHANGE_EMAIL: exp.ActionCodeOperation.VERIFY_AND_CHANGE_EMAIL,
- VERIFY_EMAIL: exp.ActionCodeOperation.VERIFY_EMAIL
- }
- },
- EmailAuthProvider: exp.EmailAuthProvider,
- FacebookAuthProvider: exp.FacebookAuthProvider,
- GithubAuthProvider: exp.GithubAuthProvider,
- GoogleAuthProvider: exp.GoogleAuthProvider,
- OAuthProvider: exp.OAuthProvider,
- SAMLAuthProvider: exp.SAMLAuthProvider,
- PhoneAuthProvider: PhoneAuthProvider,
- PhoneMultiFactorGenerator: exp.PhoneMultiFactorGenerator,
- RecaptchaVerifier: RecaptchaVerifier,
- TwitterAuthProvider: exp.TwitterAuthProvider,
- Auth,
- AuthCredential: exp.AuthCredential,
- Error: FirebaseError
- })
- .setInstantiationMode("LAZY" )
- .setMultipleInstances(false));
- instance.registerVersion(name, version);
- }
- registerAuthCompat(firebase);
|