@angular/fire
Version:
The official library for Firebase and Angular
166 lines • 13.7 kB
JavaScript
/**
* @fileoverview added by tsickle
* @suppress {checkTypes,extraRequire,missingOverride,missingReturn,unusedPrivateMembers,uselessCode} checked by tsc
*/
import { Inject, Injectable, NgZone, Optional } from '@angular/core';
import { Router } from '@angular/router';
import { Observable, of, pipe } from 'rxjs';
import { map, observeOn, shareReplay, switchMap, take } from 'rxjs/operators';
import { ɵAngularFireSchedulers, FIREBASE_OPTIONS, FIREBASE_APP_NAME, ɵfirebaseAppFactory, ɵkeepUnstableUntilFirstFactory } from '@angular/fire';
import * as i0 from "@angular/core";
import * as i1 from "@angular/fire";
import * as i2 from "@angular/router";
const ɵ0 = /**
* @param {?} user
* @return {?}
*/
user => !!user;
/** @type {?} */
export const loggedIn = map((ɵ0));
export class AngularFireAuthGuard {
/**
* @param {?} options
* @param {?} nameOrConfig
* @param {?} zone
* @param {?} router
*/
constructor(options, nameOrConfig, zone, router) {
this.router = router;
this.canActivate = (/**
* @param {?} next
* @param {?} state
* @return {?}
*/
(next, state) => {
/** @type {?} */
const authPipeFactory = (/** @type {?} */ (next.data.authGuardPipe)) || ((/**
* @return {?}
*/
() => loggedIn));
return this.authState.pipe(take(1), authPipeFactory(next, state), map((/**
* @param {?} can
* @return {?}
*/
can => typeof can === 'boolean' ? can : this.router.createUrlTree((/** @type {?} */ (can))))));
});
/** @type {?} */
const schedulers = new ɵAngularFireSchedulers(zone);
/** @type {?} */
const keepUnstableUntilFirst = ɵkeepUnstableUntilFirstFactory(schedulers);
/** @type {?} */
const auth = of(undefined).pipe(observeOn(new ɵAngularFireSchedulers(zone).outsideAngular), switchMap((/**
* @return {?}
*/
() => zone.runOutsideAngular((/**
* @return {?}
*/
() => import('firebase/auth'))))), map((/**
* @return {?}
*/
() => ɵfirebaseAppFactory(options, zone, nameOrConfig))), map((/**
* @param {?} app
* @return {?}
*/
app => zone.runOutsideAngular((/**
* @return {?}
*/
() => app.auth())))), shareReplay({ bufferSize: 1, refCount: false }));
this.authState = auth.pipe(switchMap((/**
* @param {?} auth
* @return {?}
*/
auth => new Observable(auth.onAuthStateChanged.bind(auth)))), keepUnstableUntilFirst);
}
}
AngularFireAuthGuard.decorators = [
{ type: Injectable, args: [{
providedIn: 'any'
},] }
];
/** @nocollapse */
AngularFireAuthGuard.ctorParameters = () => [
{ type: undefined, decorators: [{ type: Inject, args: [FIREBASE_OPTIONS,] }] },
{ type: undefined, decorators: [{ type: Optional }, { type: Inject, args: [FIREBASE_APP_NAME,] }] },
{ type: NgZone },
{ type: Router }
];
/** @nocollapse */ AngularFireAuthGuard.ɵprov = i0.ɵɵdefineInjectable({ factory: function AngularFireAuthGuard_Factory() { return new AngularFireAuthGuard(i0.ɵɵinject(i1.FIREBASE_OPTIONS), i0.ɵɵinject(i1.FIREBASE_APP_NAME, 8), i0.ɵɵinject(i0.NgZone), i0.ɵɵinject(i2.Router)); }, token: AngularFireAuthGuard, providedIn: "any" });
if (false) {
/** @type {?} */
AngularFireAuthGuard.prototype.authState;
/** @type {?} */
AngularFireAuthGuard.prototype.canActivate;
/**
* @type {?}
* @private
*/
AngularFireAuthGuard.prototype.router;
}
/** @type {?} */
export const canActivate = (/**
* @param {?} pipe
* @return {?}
*/
(pipe) => ({
canActivate: [AngularFireAuthGuard], data: { authGuardPipe: pipe }
}));
const ɵ1 = /**
* @param {?} user
* @return {?}
*/
user => !!user && !user.isAnonymous;
/** @type {?} */
export const isNotAnonymous = map((ɵ1));
const ɵ2 = /**
* @param {?} user
* @return {?}
*/
(user) => user ? user.getIdTokenResult() : of(null);
/** @type {?} */
export const idTokenResult = switchMap((ɵ2));
const ɵ3 = /**
* @param {?} user
* @return {?}
*/
user => !!user && user.emailVerified;
/** @type {?} */
export const emailVerified = map((ɵ3));
const ɵ4 = /**
* @param {?} idTokenResult
* @return {?}
*/
idTokenResult => idTokenResult ? idTokenResult.claims : [];
/** @type {?} */
export const customClaims = pipe(idTokenResult, map((ɵ4)));
/** @type {?} */
export const hasCustomClaim = (/**
* @param {?} claim
* @return {?}
*/
(claim) => pipe(customClaims, map((/**
* @param {?} claims
* @return {?}
*/
claims => claims.hasOwnProperty(claim)))));
/** @type {?} */
export const redirectUnauthorizedTo = (/**
* @param {?} redirect
* @return {?}
*/
(redirect) => pipe(loggedIn, map((/**
* @param {?} loggedIn
* @return {?}
*/
loggedIn => loggedIn || redirect))));
/** @type {?} */
export const redirectLoggedInTo = (/**
* @param {?} redirect
* @return {?}
*/
(redirect) => pipe(loggedIn, map((/**
* @param {?} loggedIn
* @return {?}
*/
loggedIn => loggedIn && redirect || true))));
export { ɵ0, ɵ1, ɵ2, ɵ3, ɵ4 };
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"auth-guard.js","sourceRoot":"","sources":["../../../../src/auth-guard/auth-guard.ts"],"names":[],"mappings":"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","sourcesContent":["import { Inject, Injectable, NgZone, Optional } from '@angular/core';\nimport { ActivatedRouteSnapshot, CanActivate, Router, RouterStateSnapshot } from '@angular/router';\nimport { Observable, of, pipe, UnaryFunction } from 'rxjs';\nimport { map, observeOn, shareReplay, switchMap, take } from 'rxjs/operators';\nimport { User } from 'firebase/app';\nimport {\n  ɵAngularFireSchedulers,\n  FirebaseOptions,\n  FirebaseAppConfig,\n  FIREBASE_OPTIONS,\n  FIREBASE_APP_NAME,\n  ɵfirebaseAppFactory,\n  ɵkeepUnstableUntilFirstFactory\n} from '@angular/fire';\n\nexport type AuthPipeGenerator = (next: ActivatedRouteSnapshot, state: RouterStateSnapshot) => AuthPipe;\nexport type AuthPipe = UnaryFunction<Observable<User|null>, Observable<boolean|any[]>>;\n\nexport const loggedIn: AuthPipe = map(user => !!user);\n\n@Injectable({\n  providedIn: 'any'\n})\nexport class AngularFireAuthGuard implements CanActivate {\n\n  authState: Observable<User|null>;\n\n  constructor(\n    @Inject(FIREBASE_OPTIONS) options: FirebaseOptions,\n    @Optional() @Inject(FIREBASE_APP_NAME) nameOrConfig: string|FirebaseAppConfig|null|undefined,\n    zone: NgZone,\n    private router: Router\n  ) {\n\n    const schedulers = new ɵAngularFireSchedulers(zone);\n    const keepUnstableUntilFirst = ɵkeepUnstableUntilFirstFactory(schedulers);\n\n    const auth = of(undefined).pipe(\n      observeOn(new ɵAngularFireSchedulers(zone).outsideAngular),\n      switchMap(() => zone.runOutsideAngular(() => import('firebase/auth'))),\n      map(() => ɵfirebaseAppFactory(options, zone, nameOrConfig)),\n      map(app => zone.runOutsideAngular(() => app.auth())),\n      shareReplay({ bufferSize: 1, refCount: false }),\n    );\n\n    this.authState = auth.pipe(\n      switchMap(auth => new Observable<User|null>(auth.onAuthStateChanged.bind(auth))),\n      keepUnstableUntilFirst\n    );\n  }\n\n  canActivate = (next: ActivatedRouteSnapshot, state: RouterStateSnapshot) => {\n    const authPipeFactory = next.data.authGuardPipe as AuthPipeGenerator || (() => loggedIn);\n    return this.authState.pipe(\n      take(1),\n      authPipeFactory(next, state),\n      map(can => typeof can === 'boolean' ? can : this.router.createUrlTree(can as any[]))\n    );\n  }\n\n}\n\nexport const canActivate = (pipe: AuthPipeGenerator) => ({\n    canActivate: [ AngularFireAuthGuard ], data: { authGuardPipe: pipe }\n});\n\n\nexport const isNotAnonymous: AuthPipe = map(user => !!user && !user.isAnonymous);\nexport const idTokenResult = switchMap((user: User|null) => user ? user.getIdTokenResult() : of(null));\nexport const emailVerified: AuthPipe = map(user => !!user && user.emailVerified);\nexport const customClaims = pipe(idTokenResult, map(idTokenResult => idTokenResult ? idTokenResult.claims : []));\nexport const hasCustomClaim: (claim: string) => AuthPipe =\n  (claim) => pipe(customClaims, map(claims =>  claims.hasOwnProperty(claim)));\nexport const redirectUnauthorizedTo: (redirect: any[]) => AuthPipe =\n  (redirect) => pipe(loggedIn, map(loggedIn => loggedIn || redirect));\nexport const redirectLoggedInTo: (redirect: any[]) => AuthPipe =\n  (redirect) => pipe(loggedIn, map(loggedIn => loggedIn && redirect || true));\n"]}