taxtank-core 0.16.11 → 0.16.12
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/bundles/taxtank-core.umd.js +0 -78
- package/bundles/taxtank-core.umd.js.map +1 -1
- package/esm2015/lib/services/http/bank/basiq/basiq.service.js +5 -79
- package/fesm2015/taxtank-core.js +1 -74
- package/fesm2015/taxtank-core.js.map +1 -1
- package/lib/services/http/bank/basiq/basiq.service.d.ts +2 -29
- package/package.json +1 -1
|
@@ -1,21 +1,13 @@
|
|
|
1
|
+
// @TODO Basiq 1.0 remove if we will use basiq 2.0 or refactor if we stay with basiq 1.0
|
|
1
2
|
import { Injectable } from '@angular/core';
|
|
2
3
|
import { ReplaySubject } from 'rxjs';
|
|
3
|
-
import { map
|
|
4
|
-
import { UserEventTypeClientTypeEnum } from '../../../../db/Enums/user-event-type-client-type.enum';
|
|
5
|
-
import { RestService } from '../../rest/rest.service';
|
|
4
|
+
import { map } from 'rxjs/operators';
|
|
6
5
|
import { BankAccount } from '../../../../models/bank/bank-account';
|
|
6
|
+
import { RestService } from '../../rest/rest.service';
|
|
7
7
|
import { BasiqToken } from '../../../../models/bank/basiq-token';
|
|
8
8
|
import { AppEventTypeEnum } from '../../../../models/event/app-event-type.enum';
|
|
9
|
-
import {
|
|
9
|
+
import { UserEventTypeClientTypeEnum } from '../../../../db/Enums/user-event-type-client-type.enum';
|
|
10
10
|
import * as i0 from "@angular/core";
|
|
11
|
-
/**
|
|
12
|
-
* Basiq consent UI initial URL. Replace USER_ID and TOKEN by user data + handle action parameter
|
|
13
|
-
*/
|
|
14
|
-
const BASIQ_CONSENT_URL = 'https://consent.basiq.io/home?userId=USER_ID&token=TOKEN&action=connect';
|
|
15
|
-
/**
|
|
16
|
-
* Event message name we listen to handle basiq UI result
|
|
17
|
-
*/
|
|
18
|
-
const FINISH_BASIQ_EVENT = 'finish-basiq';
|
|
19
11
|
/**
|
|
20
12
|
* basiq is a middleman between bank and user
|
|
21
13
|
* service is responsible for fetching bank related information
|
|
@@ -33,23 +25,6 @@ export class BasiqService extends RestService {
|
|
|
33
25
|
listenEvents() {
|
|
34
26
|
this.listenToBankConnectionAdded();
|
|
35
27
|
this.listenNotifications();
|
|
36
|
-
this.listenBasiqConcentUpdated();
|
|
37
|
-
}
|
|
38
|
-
/**
|
|
39
|
-
* Update user's basiq consents data on backend
|
|
40
|
-
*/
|
|
41
|
-
confirmConsents() {
|
|
42
|
-
return this.http.put(`${this.environment.apiV2}/basiq/consents`, {}).pipe(map((isConfirmed) => {
|
|
43
|
-
this.eventDispatcherService.dispatch(new AppEvent(AppEventTypeEnum.BASIQ_CONSENT_UPDATED, isConfirmed));
|
|
44
|
-
}));
|
|
45
|
-
}
|
|
46
|
-
/**
|
|
47
|
-
* Notify backend to update connections
|
|
48
|
-
*/
|
|
49
|
-
updateConnections() {
|
|
50
|
-
return this.http.post(`${this.environment.apiV2}/basiq/connections`, {}).pipe(map((connections) => {
|
|
51
|
-
this.eventDispatcherService.dispatch(new AppEvent(AppEventTypeEnum.BASIQ_CONNECTION_UPDATED, !!connections));
|
|
52
|
-
}));
|
|
53
28
|
}
|
|
54
29
|
/**
|
|
55
30
|
* access token to use basiq connect ui iframe
|
|
@@ -62,15 +37,11 @@ export class BasiqService extends RestService {
|
|
|
62
37
|
return new BasiqToken(response['access_token'], new Date(now + response['expires_in'] * 1000));
|
|
63
38
|
}))
|
|
64
39
|
.subscribe((token) => {
|
|
65
|
-
this.token = token;
|
|
66
40
|
this.tokenSubject.next(token);
|
|
67
41
|
});
|
|
68
42
|
}
|
|
69
43
|
return this.tokenSubject.asObservable();
|
|
70
44
|
}
|
|
71
|
-
/**
|
|
72
|
-
* Get list of user's bank conections
|
|
73
|
-
*/
|
|
74
45
|
getConnections() {
|
|
75
46
|
return this.get().pipe(map((bankAccounts) => {
|
|
76
47
|
// get all connections
|
|
@@ -81,40 +52,6 @@ export class BasiqService extends RestService {
|
|
|
81
52
|
return [...new Map(connections.map((connection) => [connection.id, connection])).values()];
|
|
82
53
|
}));
|
|
83
54
|
}
|
|
84
|
-
/**
|
|
85
|
-
* Listen response from basiq UI to handle result.
|
|
86
|
-
* @param isBasiqConsentExist flag from User.ClientDetails - true if user confirmed basiq consent
|
|
87
|
-
* @param callback function we run after basiq UI work is finished
|
|
88
|
-
*/
|
|
89
|
-
listenBasiqResponse(isBasiqConsentExist, callback) {
|
|
90
|
-
window.addEventListener('message', (message) => {
|
|
91
|
-
if (message.data !== FINISH_BASIQ_EVENT) {
|
|
92
|
-
return;
|
|
93
|
-
}
|
|
94
|
-
// update user's basiq consent confirmation status for the first basiq ui run
|
|
95
|
-
if (isBasiqConsentExist) {
|
|
96
|
-
this.updateConnections().pipe(take(1)).subscribe();
|
|
97
|
-
}
|
|
98
|
-
else {
|
|
99
|
-
this.confirmConsents().pipe(take(1)).subscribe();
|
|
100
|
-
}
|
|
101
|
-
callback();
|
|
102
|
-
}, { once: true });
|
|
103
|
-
}
|
|
104
|
-
/**
|
|
105
|
-
* Get URL with filled params to run basiq UI iframe
|
|
106
|
-
*/
|
|
107
|
-
generateBasiqConsentUrl(user) {
|
|
108
|
-
return this.getToken().pipe(map((token) => {
|
|
109
|
-
let url = BASIQ_CONSENT_URL;
|
|
110
|
-
url = url.replace('USER_ID', user.basiqId);
|
|
111
|
-
url = url.replace('TOKEN', token.value);
|
|
112
|
-
if (!user.clientDetails.basiqConsentExist) {
|
|
113
|
-
url = url.split('&action')[0];
|
|
114
|
-
}
|
|
115
|
-
return url;
|
|
116
|
-
}));
|
|
117
|
-
}
|
|
118
55
|
/**
|
|
119
56
|
* Listen to EventDispatcherService event related to added Bank connection
|
|
120
57
|
*/
|
|
@@ -137,17 +74,6 @@ export class BasiqService extends RestService {
|
|
|
137
74
|
}
|
|
138
75
|
});
|
|
139
76
|
}
|
|
140
|
-
/**
|
|
141
|
-
* Update user's basiq connections when user confirmed basiq consent
|
|
142
|
-
*/
|
|
143
|
-
listenBasiqConcentUpdated() {
|
|
144
|
-
this.eventDispatcherService.on(AppEventTypeEnum.BASIQ_CONSENT_UPDATED).subscribe((isConfirmed) => {
|
|
145
|
-
if (!isConfirmed) {
|
|
146
|
-
return;
|
|
147
|
-
}
|
|
148
|
-
this.updateConnections().pipe(take(1)).subscribe();
|
|
149
|
-
});
|
|
150
|
-
}
|
|
151
77
|
}
|
|
152
78
|
BasiqService.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "12.2.15", ngImport: i0, type: BasiqService, deps: null, target: i0.ɵɵFactoryTarget.Injectable });
|
|
153
79
|
BasiqService.ɵprov = i0.ɵɵngDeclareInjectable({ minVersion: "12.0.0", version: "12.2.15", ngImport: i0, type: BasiqService, providedIn: 'root' });
|
|
@@ -157,4 +83,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "12.2.15", ngImpo
|
|
|
157
83
|
providedIn: 'root'
|
|
158
84
|
}]
|
|
159
85
|
}] });
|
|
160
|
-
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"basiq.service.js","sourceRoot":"","sources":["../../../../../../../../projects/tt-core/src/lib/services/http/bank/basiq/basiq.service.ts"],"names":[],"mappings":"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","sourcesContent":["import { Injectable } from '@angular/core';\nimport { Observable, ReplaySubject } from 'rxjs';\nimport { map, take } from 'rxjs/operators';\nimport { BankAccount as BankAccountBase } from '../../../../db/Models/bank/bank-account';\nimport { UserEventTypeClientTypeEnum } from '../../../../db/Enums/user-event-type-client-type.enum';\nimport { RestService } from '../../rest/rest.service';\nimport { BankAccount } from '../../../../models/bank/bank-account';\nimport { BasiqToken } from '../../../../models/bank/basiq-token';\nimport { AppEventTypeEnum } from '../../../../models/event/app-event-type.enum';\nimport { BankConnection } from '../../../../models/bank/bank-connection';\nimport { Notification } from '../../../../models/notification/notification';\nimport { IEventListener } from '../../../../interfaces/event-listener.interface';\nimport { AppEvent } from '../../../../models/event/app-event';\nimport { User } from '../../../../models/user/user';\nimport { BankConnection as BankConnectionBase } from '../../../../db/Models/bank/bank-connection';\n\n/**\n * Basiq consent UI initial URL. Replace USER_ID and TOKEN by user data + handle action parameter\n */\nconst BASIQ_CONSENT_URL = 'https://consent.basiq.io/home?userId=USER_ID&token=TOKEN&action=connect';\n\n/**\n * Event message name we listen to handle basiq UI result\n */\nconst FINISH_BASIQ_EVENT = 'finish-basiq';\n\n/**\n * basiq is a middleman between bank and user\n * service is responsible for fetching bank related information\n */\n@Injectable({\n  providedIn: 'root'\n})\nexport class BasiqService extends RestService<BankAccountBase, BankAccount> implements IEventListener {\n  token: BasiqToken;\n  tokenSubject: ReplaySubject<BasiqToken> = new ReplaySubject<BasiqToken>();\n  url: string = 'basiq/accounts';\n  modelClass = BankAccount;\n\n  /**\n   * Listen events from Event Dispatcher service\n   */\n  listenEvents(): void {\n    this.listenToBankConnectionAdded();\n    this.listenNotifications();\n    this.listenBasiqConcentUpdated();\n  }\n\n  /**\n   * Update user's basiq consents data on backend\n   */\n  confirmConsents(): Observable<void> {\n    return this.http.put(`${this.environment.apiV2}/basiq/consents`, {}).pipe(\n      map((isConfirmed: boolean) => {\n        this.eventDispatcherService.dispatch(new AppEvent(AppEventTypeEnum.BASIQ_CONSENT_UPDATED, isConfirmed));\n      })\n    );\n  }\n\n  /**\n   * Notify backend to update connections\n   */\n  updateConnections(): Observable<void> {\n    return this.http.post(`${this.environment.apiV2}/basiq/connections`, {}).pipe(\n      map((connections: BankConnectionBase[]) => {\n        this.eventDispatcherService.dispatch(new AppEvent(AppEventTypeEnum.BASIQ_CONNECTION_UPDATED, !!connections));\n      })\n    );\n  }\n\n  /**\n   * access token to use basiq connect ui iframe\n   */\n  getToken(): Observable<BasiqToken> {\n    if (!this.token || this.token.isExpired()) {\n      this.http.get(`${this.environment.apiV2}/basiq/tokens`)\n        .pipe(\n          map((response: object): BasiqToken => {\n\n            const now: number = new Date().getTime();\n            return new BasiqToken(response['access_token'], new Date(now + response['expires_in'] * 1000));\n          })\n        )\n        .subscribe((token: BasiqToken) => {\n          this.token = token;\n          this.tokenSubject.next(token);\n        });\n    }\n\n    return this.tokenSubject.asObservable();\n  }\n\n  /**\n   * Get list of user's bank conections\n   */\n  getConnections(): Observable<BankConnection[]> {\n    return this.get().pipe(\n      map((bankAccounts: BankAccount[]) => {\n        // get all connections\n        const connections: BankConnection[] = bankAccounts.map((bankAccount: BankAccount) => {\n          return bankAccount.bankConnection;\n        });\n\n        // return without duplicates\n        return [...new Map(connections.map((connection: BankConnection) => [connection.id, connection])).values()];\n      })\n    );\n  }\n\n  /**\n   * Listen response from basiq UI to handle result.\n   * @param isBasiqConsentExist flag from User.ClientDetails - true if user confirmed basiq consent\n   * @param callback function we run after basiq UI work is finished\n   */\n  listenBasiqResponse(isBasiqConsentExist: boolean, callback: () => any): void {\n    window.addEventListener('message', (message: MessageEvent) => {\n      if (message.data !== FINISH_BASIQ_EVENT) {\n        return;\n      }\n\n      // update user's basiq consent confirmation status for the first basiq ui run\n      if (isBasiqConsentExist) {\n        this.updateConnections().pipe(take(1)).subscribe();\n      } else {\n        this.confirmConsents().pipe(take(1)).subscribe();\n      }\n\n      callback();\n    }, {once: true});\n  }\n\n  /**\n   * Get URL with filled params to run basiq UI iframe\n   */\n  generateBasiqConsentUrl(user: User): Observable<string> {\n    return this.getToken().pipe(\n      map((token: BasiqToken): string => {\n        let url: string = BASIQ_CONSENT_URL;\n        url = url.replace('USER_ID', user.basiqId);\n        url = url.replace('TOKEN', token.value);\n\n        if (!user.clientDetails.basiqConsentExist) {\n          url = url.split('&action')[0];\n        }\n\n        return url;\n      })\n    );\n  }\n\n  /**\n   * Listen to EventDispatcherService event related to added Bank connection\n   */\n  private listenToBankConnectionAdded(): void {\n    this.eventDispatcherService.on(AppEventTypeEnum.BANK_CONNECTION_ADDED).subscribe(() => {\n      this.fetch().subscribe((bankAccounts: BankAccount[]) => {\n        this.cache = bankAccounts;\n        this.updateCache();\n      });\n    });\n  }\n\n  /**\n   * listen to notifications to update basiq accounts list\n   */\n  private listenNotifications(): void {\n    this.eventDispatcherService.on(AppEventTypeEnum.NOTIFICATION_ADDED).subscribe((notification: Notification): void => {\n      if (!notification.isRead && notification.eventType === UserEventTypeClientTypeEnum.BASIQ_NEW_ACCOUNTS) {\n        this.resetCache();\n        this.get().subscribe();\n      }\n    });\n  }\n\n  /**\n   * Update user's basiq connections when user confirmed basiq consent\n   */\n  private listenBasiqConcentUpdated(): void {\n    this.eventDispatcherService.on(AppEventTypeEnum.BASIQ_CONSENT_UPDATED).subscribe((isConfirmed: boolean) => {\n      if (!isConfirmed) {\n        return;\n      }\n\n      this.updateConnections().pipe(take(1)).subscribe();\n    });\n  }\n}\n"]}
|
|
86
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"basiq.service.js","sourceRoot":"","sources":["../../../../../../../../projects/tt-core/src/lib/services/http/bank/basiq/basiq.service.ts"],"names":[],"mappings":"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","sourcesContent":["// @TODO Basiq 1.0 remove if we will use basiq 2.0 or refactor if we stay with basiq 1.0\nimport { Injectable } from '@angular/core';\nimport { Observable, ReplaySubject } from 'rxjs';\nimport { map } from 'rxjs/operators';\nimport { BankAccount as BankAccountBase } from '../../../../db/Models/bank/bank-account';\nimport { BankAccount } from '../../../../models/bank/bank-account';\nimport { RestService } from '../../rest/rest.service';\nimport { BasiqToken } from '../../../../models/bank/basiq-token';\nimport { BankConnection } from '../../../../models/bank/bank-connection';\nimport { AppEventTypeEnum } from '../../../../models/event/app-event-type.enum';\nimport { Notification } from '../../../../models/notification/notification';\nimport { UserEventTypeClientTypeEnum } from '../../../../db/Enums/user-event-type-client-type.enum';\n\n/**\n * basiq is a middleman between bank and user\n * service is responsible for fetching bank related information\n */\n@Injectable({\n  providedIn: 'root'\n})\nexport class BasiqService extends RestService<BankAccountBase, BankAccount> {\n  token: BasiqToken;\n  tokenSubject: ReplaySubject<BasiqToken> = new ReplaySubject<BasiqToken>();\n  url: string = 'basiq/accounts';\n  modelClass = BankAccount;\n\n  /**\n   * Listen events from Event Dispatcher service\n   */\n  listenEvents(): void {\n    this.listenToBankConnectionAdded();\n    this.listenNotifications();\n  }\n\n  /**\n   * access token to use basiq connect ui iframe\n   */\n  getToken(): Observable<BasiqToken> {\n    if (!this.token || this.token.isExpired()) {\n      this.http.get(`${this.environment.apiV2}/basiq/tokens`)\n        .pipe(\n          map((response: object) => {\n            const now: number = new Date().getTime();\n\n            return new BasiqToken(response['access_token'], new Date(now + response['expires_in'] * 1000));\n          })\n        )\n        .subscribe((token: BasiqToken) => {\n          this.tokenSubject.next(token);\n        });\n    }\n\n    return this.tokenSubject.asObservable();\n  }\n\n  getConnections(): Observable<BankConnection[]> {\n    return this.get().pipe(\n      map((bankAccounts: BankAccount[]) => {\n        // get all connections\n        const connections: BankConnection[] = bankAccounts.map((bankAccount: BankAccount) => {\n          return bankAccount.bankConnection;\n        });\n\n        // return without duplicates\n        return [...new Map(connections.map((connection: BankConnection) => [connection.id, connection])).values()];\n      })\n    );\n  }\n\n  /**\n   * Listen to EventDispatcherService event related to added Bank connection\n   */\n  private listenToBankConnectionAdded(): void {\n    this.eventDispatcherService.on(AppEventTypeEnum.BANK_CONNECTION_ADDED).subscribe(() => {\n      this.fetch().subscribe((bankAccounts: BankAccount[]) => {\n        this.cache = bankAccounts;\n        this.updateCache();\n      });\n    });\n  }\n\n  /**\n   * listen to notifications to update basiq accounts list\n   */\n  private listenNotifications(): void {\n    this.eventDispatcherService.on(AppEventTypeEnum.NOTIFICATION_ADDED).subscribe((notification: Notification): void => {\n      if (!notification.isRead && notification.eventType === UserEventTypeClientTypeEnum.BASIQ_NEW_ACCOUNTS) {\n        this.resetCache();\n        this.get().subscribe();\n      }\n    });\n  }\n}\n\n\n// @TODO Basiq 3.0 functionality remove when we decide what basiq version we will use (1 or 2)\n// import { Injectable } from '@angular/core';\n// import { Observable, ReplaySubject } from 'rxjs';\n// import { map, take } from 'rxjs/operators';\n// import { BankAccount as BankAccountBase } from '../../../../db/Models/bank/bank-account';\n// import { UserEventTypeClientTypeEnum } from '../../../../db/Enums/user-event-type-client-type.enum';\n// import { RestService } from '../../rest/rest.service';\n// import { BankAccount } from '../../../../models/bank/bank-account';\n// import { BasiqToken } from '../../../../models/bank/basiq-token';\n// import { AppEventTypeEnum } from '../../../../models/event/app-event-type.enum';\n// import { BankConnection } from '../../../../models/bank/bank-connection';\n// import { Notification } from '../../../../models/notification/notification';\n// import { IEventListener } from '../../../../interfaces/event-listener.interface';\n// import { AppEvent } from '../../../../models/event/app-event';\n// import { User } from '../../../../models/user/user';\n// import { BankConnection as BankConnectionBase } from '../../../../db/Models/bank/bank-connection';\n//\n// /**\n//  * Basiq consent UI initial URL. Replace USER_ID and TOKEN by user data + handle action parameter\n//  */\n// const BASIQ_CONSENT_URL = 'https://consent.basiq.io/home?userId=USER_ID&token=TOKEN&action=connect';\n//\n// /**\n//  * Event message name we listen to handle basiq UI result\n//  */\n// const FINISH_BASIQ_EVENT = 'finish-basiq';\n//\n// /**\n//  * basiq is a middleman between bank and user\n//  * service is responsible for fetching bank related information\n//  */\n// @Injectable({\n//   providedIn: 'root'\n// })\n// export class BasiqService extends RestService<BankAccountBase, BankAccount> implements IEventListener {\n//   token: BasiqToken;\n//   tokenSubject: ReplaySubject<BasiqToken> = new ReplaySubject<BasiqToken>();\n//   url: string = 'basiq/accounts';\n//   modelClass = BankAccount;\n//\n//   /**\n//    * Listen events from Event Dispatcher service\n//    */\n//   listenEvents(): void {\n//     this.listenToBankConnectionAdded();\n//     this.listenNotifications();\n//     this.listenBasiqConcentUpdated();\n//   }\n//\n//   /**\n//    * Update user's basiq consents data on backend\n//    */\n//   confirmConsents(): Observable<void> {\n//     return this.http.put(`${this.environment.apiV2}/basiq/consents`, {}).pipe(\n//       map((isConfirmed: boolean) => {\n//         this.eventDispatcherService.dispatch(new AppEvent(AppEventTypeEnum.BASIQ_CONSENT_UPDATED, isConfirmed));\n//       })\n//     );\n//   }\n//\n//   /**\n//    * Notify backend to update connections\n//    */\n//   updateConnections(): Observable<void> {\n//     return this.http.post(`${this.environment.apiV2}/basiq/connections`, {}).pipe(\n//       map((connections: BankConnectionBase[]) => {\n//         this.eventDispatcherService.dispatch(new AppEvent(AppEventTypeEnum.BASIQ_CONNECTION_UPDATED, !!connections));\n//       })\n//     );\n//   }\n//\n//   /**\n//    * access token to use basiq connect ui iframe\n//    */\n//   getToken(): Observable<BasiqToken> {\n//     if (!this.token || this.token.isExpired()) {\n//       this.http.get(`${this.environment.apiV2}/basiq/tokens`)\n//         .pipe(\n//           map((response: object): BasiqToken => {\n//\n//             const now: number = new Date().getTime();\n//             return new BasiqToken(response['access_token'], new Date(now + response['expires_in'] * 1000));\n//           })\n//         )\n//         .subscribe((token: BasiqToken) => {\n//           this.token = token;\n//           this.tokenSubject.next(token);\n//         });\n//     }\n//\n//     return this.tokenSubject.asObservable();\n//   }\n//\n//   /**\n//    * Get list of user's bank conections\n//    */\n//   getConnections(): Observable<BankConnection[]> {\n//     return this.get().pipe(\n//       map((bankAccounts: BankAccount[]) => {\n//         // get all connections\n//         const connections: BankConnection[] = bankAccounts.map((bankAccount: BankAccount) => {\n//           return bankAccount.bankConnection;\n//         });\n//\n//         // return without duplicates\n//         return [...new Map(connections.map((connection: BankConnection) => [connection.id, connection])).values()];\n//       })\n//     );\n//   }\n//\n//   /**\n//    * Listen response from basiq UI to handle result.\n//    * @param isBasiqConsentExist flag from User.ClientDetails - true if user confirmed basiq consent\n//    * @param callback function we run after basiq UI work is finished\n//    */\n//   listenBasiqResponse(isBasiqConsentExist: boolean, callback: () => any): void {\n//     window.addEventListener('message', (message: MessageEvent) => {\n//       if (message.data !== FINISH_BASIQ_EVENT) {\n//         return;\n//       }\n//\n//       // update user's basiq consent confirmation status for the first basiq ui run\n//       if (isBasiqConsentExist) {\n//         this.updateConnections().pipe(take(1)).subscribe();\n//       } else {\n//         this.confirmConsents().pipe(take(1)).subscribe();\n//       }\n//\n//       callback();\n//     }, {once: true});\n//   }\n//\n//   /**\n//    * Get URL with filled params to run basiq UI iframe\n//    */\n//   generateBasiqConsentUrl(user: User): Observable<string> {\n//     return this.getToken().pipe(\n//       map((token: BasiqToken): string => {\n//         let url: string = BASIQ_CONSENT_URL;\n//         url = url.replace('USER_ID', user.basiqId);\n//         url = url.replace('TOKEN', token.value);\n//\n//         if (!user.clientDetails.basiqConsentExist) {\n//           url = url.split('&action')[0];\n//         }\n//\n//         return url;\n//       })\n//     );\n//   }\n//\n//   /**\n//    * Listen to EventDispatcherService event related to added Bank connection\n//    */\n//   private listenToBankConnectionAdded(): void {\n//     this.eventDispatcherService.on(AppEventTypeEnum.BANK_CONNECTION_ADDED).subscribe(() => {\n//       this.fetch().subscribe((bankAccounts: BankAccount[]) => {\n//         this.cache = bankAccounts;\n//         this.updateCache();\n//       });\n//     });\n//   }\n//\n//   /**\n//    * listen to notifications to update basiq accounts list\n//    */\n//   private listenNotifications(): void {\n//     this.eventDispatcherService.on(AppEventTypeEnum.NOTIFICATION_ADDED).subscribe((notification: Notification): void => {\n//       if (!notification.isRead && notification.eventType === UserEventTypeClientTypeEnum.BASIQ_NEW_ACCOUNTS) {\n//         this.resetCache();\n//         this.get().subscribe();\n//       }\n//     });\n//   }\n//\n//   /**\n//    * Update user's basiq connections when user confirmed basiq consent\n//    */\n//   private listenBasiqConcentUpdated(): void {\n//     this.eventDispatcherService.on(AppEventTypeEnum.BASIQ_CONSENT_UPDATED).subscribe((isConfirmed: boolean) => {\n//       if (!isConfirmed) {\n//         return;\n//       }\n//\n//       this.updateConnections().pipe(take(1)).subscribe();\n//     });\n//   }\n// }\n"]}
|
package/fesm2015/taxtank-core.js
CHANGED
|
@@ -8408,14 +8408,7 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "12.2.15", ngImpo
|
|
|
8408
8408
|
}]
|
|
8409
8409
|
}] });
|
|
8410
8410
|
|
|
8411
|
-
|
|
8412
|
-
* Basiq consent UI initial URL. Replace USER_ID and TOKEN by user data + handle action parameter
|
|
8413
|
-
*/
|
|
8414
|
-
const BASIQ_CONSENT_URL = 'https://consent.basiq.io/home?userId=USER_ID&token=TOKEN&action=connect';
|
|
8415
|
-
/**
|
|
8416
|
-
* Event message name we listen to handle basiq UI result
|
|
8417
|
-
*/
|
|
8418
|
-
const FINISH_BASIQ_EVENT = 'finish-basiq';
|
|
8411
|
+
// @TODO Basiq 1.0 remove if we will use basiq 2.0 or refactor if we stay with basiq 1.0
|
|
8419
8412
|
/**
|
|
8420
8413
|
* basiq is a middleman between bank and user
|
|
8421
8414
|
* service is responsible for fetching bank related information
|
|
@@ -8433,23 +8426,6 @@ class BasiqService extends RestService {
|
|
|
8433
8426
|
listenEvents() {
|
|
8434
8427
|
this.listenToBankConnectionAdded();
|
|
8435
8428
|
this.listenNotifications();
|
|
8436
|
-
this.listenBasiqConcentUpdated();
|
|
8437
|
-
}
|
|
8438
|
-
/**
|
|
8439
|
-
* Update user's basiq consents data on backend
|
|
8440
|
-
*/
|
|
8441
|
-
confirmConsents() {
|
|
8442
|
-
return this.http.put(`${this.environment.apiV2}/basiq/consents`, {}).pipe(map((isConfirmed) => {
|
|
8443
|
-
this.eventDispatcherService.dispatch(new AppEvent(AppEventTypeEnum.BASIQ_CONSENT_UPDATED, isConfirmed));
|
|
8444
|
-
}));
|
|
8445
|
-
}
|
|
8446
|
-
/**
|
|
8447
|
-
* Notify backend to update connections
|
|
8448
|
-
*/
|
|
8449
|
-
updateConnections() {
|
|
8450
|
-
return this.http.post(`${this.environment.apiV2}/basiq/connections`, {}).pipe(map((connections) => {
|
|
8451
|
-
this.eventDispatcherService.dispatch(new AppEvent(AppEventTypeEnum.BASIQ_CONNECTION_UPDATED, !!connections));
|
|
8452
|
-
}));
|
|
8453
8429
|
}
|
|
8454
8430
|
/**
|
|
8455
8431
|
* access token to use basiq connect ui iframe
|
|
@@ -8462,15 +8438,11 @@ class BasiqService extends RestService {
|
|
|
8462
8438
|
return new BasiqToken(response['access_token'], new Date(now + response['expires_in'] * 1000));
|
|
8463
8439
|
}))
|
|
8464
8440
|
.subscribe((token) => {
|
|
8465
|
-
this.token = token;
|
|
8466
8441
|
this.tokenSubject.next(token);
|
|
8467
8442
|
});
|
|
8468
8443
|
}
|
|
8469
8444
|
return this.tokenSubject.asObservable();
|
|
8470
8445
|
}
|
|
8471
|
-
/**
|
|
8472
|
-
* Get list of user's bank conections
|
|
8473
|
-
*/
|
|
8474
8446
|
getConnections() {
|
|
8475
8447
|
return this.get().pipe(map((bankAccounts) => {
|
|
8476
8448
|
// get all connections
|
|
@@ -8481,40 +8453,6 @@ class BasiqService extends RestService {
|
|
|
8481
8453
|
return [...new Map(connections.map((connection) => [connection.id, connection])).values()];
|
|
8482
8454
|
}));
|
|
8483
8455
|
}
|
|
8484
|
-
/**
|
|
8485
|
-
* Listen response from basiq UI to handle result.
|
|
8486
|
-
* @param isBasiqConsentExist flag from User.ClientDetails - true if user confirmed basiq consent
|
|
8487
|
-
* @param callback function we run after basiq UI work is finished
|
|
8488
|
-
*/
|
|
8489
|
-
listenBasiqResponse(isBasiqConsentExist, callback) {
|
|
8490
|
-
window.addEventListener('message', (message) => {
|
|
8491
|
-
if (message.data !== FINISH_BASIQ_EVENT) {
|
|
8492
|
-
return;
|
|
8493
|
-
}
|
|
8494
|
-
// update user's basiq consent confirmation status for the first basiq ui run
|
|
8495
|
-
if (isBasiqConsentExist) {
|
|
8496
|
-
this.updateConnections().pipe(take(1)).subscribe();
|
|
8497
|
-
}
|
|
8498
|
-
else {
|
|
8499
|
-
this.confirmConsents().pipe(take(1)).subscribe();
|
|
8500
|
-
}
|
|
8501
|
-
callback();
|
|
8502
|
-
}, { once: true });
|
|
8503
|
-
}
|
|
8504
|
-
/**
|
|
8505
|
-
* Get URL with filled params to run basiq UI iframe
|
|
8506
|
-
*/
|
|
8507
|
-
generateBasiqConsentUrl(user) {
|
|
8508
|
-
return this.getToken().pipe(map((token) => {
|
|
8509
|
-
let url = BASIQ_CONSENT_URL;
|
|
8510
|
-
url = url.replace('USER_ID', user.basiqId);
|
|
8511
|
-
url = url.replace('TOKEN', token.value);
|
|
8512
|
-
if (!user.clientDetails.basiqConsentExist) {
|
|
8513
|
-
url = url.split('&action')[0];
|
|
8514
|
-
}
|
|
8515
|
-
return url;
|
|
8516
|
-
}));
|
|
8517
|
-
}
|
|
8518
8456
|
/**
|
|
8519
8457
|
* Listen to EventDispatcherService event related to added Bank connection
|
|
8520
8458
|
*/
|
|
@@ -8537,17 +8475,6 @@ class BasiqService extends RestService {
|
|
|
8537
8475
|
}
|
|
8538
8476
|
});
|
|
8539
8477
|
}
|
|
8540
|
-
/**
|
|
8541
|
-
* Update user's basiq connections when user confirmed basiq consent
|
|
8542
|
-
*/
|
|
8543
|
-
listenBasiqConcentUpdated() {
|
|
8544
|
-
this.eventDispatcherService.on(AppEventTypeEnum.BASIQ_CONSENT_UPDATED).subscribe((isConfirmed) => {
|
|
8545
|
-
if (!isConfirmed) {
|
|
8546
|
-
return;
|
|
8547
|
-
}
|
|
8548
|
-
this.updateConnections().pipe(take(1)).subscribe();
|
|
8549
|
-
});
|
|
8550
|
-
}
|
|
8551
8478
|
}
|
|
8552
8479
|
BasiqService.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "12.2.15", ngImport: i0, type: BasiqService, deps: null, target: i0.ɵɵFactoryTarget.Injectable });
|
|
8553
8480
|
BasiqService.ɵprov = i0.ɵɵngDeclareInjectable({ minVersion: "12.0.0", version: "12.2.15", ngImport: i0, type: BasiqService, providedIn: 'root' });
|