-
Notifications
You must be signed in to change notification settings - Fork 4
/
Copy pathauthentication.service.ts
128 lines (112 loc) · 3.67 KB
/
authentication.service.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
122
123
124
125
126
127
128
import { Injectable } from '@angular/core';
import { AuthConnect, AuthResult, AzureProvider, ProviderOptions, TokenType } from '@ionic-enterprise/auth';
import { Platform } from '@ionic/angular';
import { nativeIonicAuthOptions, webIonicAuthOptions } from '../../environments/environment';
import { RouteService } from './route.service';
import { VaultService } from './vault.service';
import { checkAuthResult } from './util';
@Injectable({ providedIn: 'root' })
export class AuthenticationService {
private result: AuthResult | undefined;
constructor(
private platform: Platform,
private routeService: RouteService,
private vaultService: VaultService) {
this.init();
}
/**
* Initialize: setup Auth Connect, and get token from storage if available
*/
public async init() {
await AuthConnect.setup({
platform: this.platform.is('hybrid') ? 'capacitor' : 'web',
logLevel: 'NONE',
ios: {
webView: 'private',
safariWebViewOptions: {
dismissButtonStyle: 'close',
preferredBarTintColor: '#FFFFFF',
preferredControlTintColor: '#333333' }
},
android: {
isAnimated: false,
showDefaultShareMenuItem: false },
web: {
uiMode: 'current',
authFlow: 'PKCE' }
});
try {
this.result = await this.vaultService.get();
} catch (error) {
console.error(error);
this.result = undefined;
}
}
/**
* Login
*/
public async login() {
this.result = await AuthConnect.login(this.azureB2CProvider(), this.getAuthOptions());
await this.vaultService.set(this.result);
this.routeService.goToRoot();
}
/**
* Called for the web platform. Passes Auth Connect the auto info from query parameters
* to get the auth object which we store and redirect to the home page
*/
public async handleLogin() {
const urlParams = new URLSearchParams(window.location.search);
const queryEntries = (Object as any).fromEntries(urlParams.entries());
// WN-1241 - providerOptions is optional but if you dont set it the logout method will fail
this.result = await AuthConnect.handleLoginCallback(queryEntries, this.getAuthOptions());
await this.vaultService.set(this.result);
this.routeService.goToRoot();
}
/**
* Logout
*/
public async logout() {
//await checkAuthResult(this.result);
try {
await AuthConnect.logout(this.azureB2CProvider(), this.result!);
} catch (error) {
console.error('AuthConnect.logout', error);
}
this.routeService.returnToLogin();
}
public async isAuthenticated(): Promise<boolean> {
try {
const authResult = await this.vaultService.get();
if (!authResult) {
return false;
}
const { idToken } = authResult;
if (!idToken) {
throw new Error('No ID Token');
}
const expired = await AuthConnect.isAccessTokenExpired(authResult);
if (!expired) {
return true;
}
const newAuthResult = await AuthConnect.refreshSession(this.azureB2CProvider(), authResult);
await this.vaultService.set(newAuthResult);
return true;
} catch (e) {
console.error(e);
await this.vaultService.clear();
return false;
}
}
public async getAccessToken(): Promise<string | undefined> {
return await AuthConnect.getToken(TokenType.access, this.result!);
}
public decodeToken() {
return AuthConnect.decodeToken(TokenType.id, this.result!);
}
private azureB2CProvider(): AzureProvider {
return new AzureProvider();
}
private getAuthOptions(): ProviderOptions {
return this.platform.is('hybrid') ? nativeIonicAuthOptions : webIonicAuthOptions;
}
}