-
Notifications
You must be signed in to change notification settings - Fork 0
/
Copy pathpolicy-mananger.ts
76 lines (67 loc) · 2.62 KB
/
policy-mananger.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
import { PolicyManagerSettings } from './policy-manager.settings';
import { PolicyStore } from './policy-store';
import { Permission, Dicovery } from './models';
import { HttpClient } from './http-client';
import { StateStore } from './state-store';
export class PolicyManager {
private readonly _http: HttpClient = new HttpClient();
public readonly settings: PolicyManagerSettings;
private readonly _defaultSettings: PolicyManagerSettings = <PolicyManagerSettings>{
authority: undefined,
requireHttpsMetadata: true,
endpoints: {
discovery: '.well-known/policy-configuration',
permission: undefined,
policy: undefined
},
policyStore: new PolicyStore(this._http),
stateStore: new StateStore()
};
private _loaded: boolean = false;
private _token: string;
constructor(settings?: PolicyManagerSettings) {
this.settings = Object.assign(this._defaultSettings, settings);
}
public setToken(token: string) {
this._token = token;
}
public removeToken() {
this._token = null;
}
public getPolicy(): Promise<Permission> {
const key = `permision:${this.settings.authority}:${this.settings.clientId}`;
return this.getPermssionEndpoint().then(url => {
return this.settings.stateStore.get(key).then(strPermission => {
const currentPermission = strPermission != null ? (JSON.parse(strPermission) as Permission) : null;
const hasCacheData =
currentPermission != null &&
new Date().getTime() <= currentPermission.created + currentPermission.expireIn * 1000;
if (hasCacheData) {
return new Promise<Permission>(r => {
r(currentPermission);
});
} else {
return this.settings.policyStore.getPolicy(url, this.settings.clientId, this._token).then(newPermssion => {
newPermssion.created = new Date().getTime();
this.settings.stateStore.set(key, JSON.stringify(newPermssion));
return newPermssion;
});
}
});
});
}
public removePolicy() {
const key = `permision:${this.settings.authority}:${this.settings.clientId}`;
this.settings.stateStore.remove(key);
}
public getPermssionEndpoint(): Promise<string> {
if (this.settings.endpoints.permission != null) {
return new Promise<string>(r => r(this.settings.endpoints.permission));
}
return this._http.get<Dicovery>(`${this.settings.authority}/${this.settings.endpoints.discovery}`).then(p => {
this.settings.endpoints.permission = p.permissionEndpoint;
this.settings.endpoints.policy = p.policyEndpoint;
return p.permissionEndpoint;
});
}
}