-
Notifications
You must be signed in to change notification settings - Fork 2.2k
/
Copy pathfirebase_sdk_auth_backend.ts
121 lines (106 loc) · 4.21 KB
/
firebase_sdk_auth_backend.ts
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
import { Injectable, Inject } from '@angular/core';
import { Observable } from 'rxjs/Observable';
import { Observer } from 'rxjs/Observer';
import { FirebaseApp } from '../tokens';
import { isPresent, ZoneScheduler } from '../utils';
import { auth } from 'firebase';
import {
authDataToAuthState,
AuthBackend,
AuthProviders,
AuthMethods,
FirebaseAuthState,
EmailPasswordCredentials
} from './auth_backend';
const {
FacebookAuthProvider,
GithubAuthProvider,
GoogleAuthProvider,
TwitterAuthProvider
} = auth;
import 'rxjs/add/operator/map';
import 'rxjs/add/observable/fromPromise';
import 'rxjs/add/operator/observeOn';
@Injectable()
export class FirebaseSdkAuthBackend extends AuthBackend {
_fbAuth: firebase.auth.Auth;
constructor( @Inject(FirebaseApp) _fbApp: firebase.app.App,
private _webWorkerMode = false) {
super();
this._fbAuth = _fbApp.auth();
}
createUser(creds: EmailPasswordCredentials): Promise<FirebaseAuthState> {
return Promise.resolve(this._fbAuth.createUserWithEmailAndPassword(creds.email, creds.password))
.then((user: firebase.User) => authDataToAuthState(user));
}
getAuth(): FirebaseAuthState {
return authDataToAuthState(this._fbAuth.currentUser);
}
onAuth(): Observable<FirebaseAuthState> {
return Observable.create((observer: Observer<FirebaseAuthState>) => {
return this._fbAuth.onAuthStateChanged(observer);
})
.map((user: firebase.User) => {
if (!user) return null;
return authDataToAuthState(user, user.providerData[0]);
})
/**
* TODO: since the auth service automatically subscribes to this before
* any user, it will run in the Angular zone, instead of the subscription
* zone. The auth service should be refactored to capture the subscription
* zone and not use a ReplaySubject.
**/
.observeOn(new ZoneScheduler(Zone.current));
}
unauth(): void {
Promise.resolve(this._fbAuth.signOut());
}
authWithCustomToken(token: string): Promise<FirebaseAuthState> {
return Promise.resolve(this._fbAuth.signInWithCustomToken(token))
.then((user: firebase.User) => authDataToAuthState(user));
}
authAnonymously(): Promise<FirebaseAuthState> {
return Promise.resolve(this._fbAuth.signInAnonymously())
.then((user: firebase.User) => authDataToAuthState(user));
}
authWithPassword(creds: EmailPasswordCredentials): Promise<FirebaseAuthState> {
return Promise.resolve(this._fbAuth.signInWithEmailAndPassword(creds.email, creds.password))
.then((user: firebase.User) => authDataToAuthState(user));
}
authWithOAuthPopup(provider: AuthProviders, options?: any): Promise<firebase.auth.UserCredential> {
var providerFromFirebase:any = this._enumToAuthProvider(provider);
if (options.scope) {
options.scope.forEach(scope => providerFromFirebase.addScope(scope));
}
return Promise.resolve(this._fbAuth.signInWithPopup(providerFromFirebase));
}
/**
* Authenticates a Firebase client using a redirect-based OAuth flow
* NOTE: This promise will not be resolved if authentication is successful since the browser redirected.
* You should subscribe to the FirebaseAuth object to listen succesful login
*/
authWithOAuthRedirect(provider: AuthProviders, options?: any): Promise<void> {
return Promise.resolve(this._fbAuth.signInWithRedirect(this._enumToAuthProvider(provider)));
}
authWithOAuthToken(credential: firebase.auth.AuthCredential): Promise<FirebaseAuthState> {
return Promise.resolve(this._fbAuth.signInWithCredential(credential))
.then((user: firebase.User) => authDataToAuthState(user));
}
getRedirectResult(): Observable<firebase.auth.UserCredential> {
return Observable.fromPromise(Promise.resolve(this._fbAuth.getRedirectResult()));
}
private _enumToAuthProvider(providerId: AuthProviders): any {
switch (providerId) {
case AuthProviders.Github:
return new GithubAuthProvider();
case AuthProviders.Twitter:
return new TwitterAuthProvider();
case AuthProviders.Facebook:
return new FacebookAuthProvider();
case AuthProviders.Google:
return new GoogleAuthProvider();
default:
throw new Error(`Unsupported firebase auth provider ${providerId}`);
}
}
}