UNPKG

@angular/fire

Version:

The official library for Firebase and Angular

166 lines 13.7 kB
/** * @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"]}