@colijnit/ioneconnector 2.1.15 → 3.1.0
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/build/connector.d.ts +3 -5
- package/build/connector.js +8 -12
- package/build/connector.js.map +1 -1
- package/build/connector.unit.test.js +1 -1
- package/build/connector.unit.test.js.map +1 -1
- package/build/enum/backend-service-name.enum.d.ts +2 -1
- package/build/enum/backend-service-name.enum.js +1 -0
- package/build/enum/backend-service-name.enum.js.map +1 -1
- package/build/enum/health-service-method.enum.d.ts +3 -0
- package/build/enum/health-service-method.enum.js +8 -0
- package/build/enum/health-service-method.enum.js.map +1 -0
- package/build/enum/login-service-method.enum.d.ts +2 -0
- package/build/enum/login-service-method.enum.js +2 -0
- package/build/enum/login-service-method.enum.js.map +1 -1
- package/build/interface/login-storage-data.interface.d.ts +9 -0
- package/build/interface/login-storage-data.interface.js +3 -0
- package/build/interface/login-storage-data.interface.js.map +1 -0
- package/build/model/data-service-response-data.d.ts +1 -0
- package/build/model/data-service-response-data.js +3 -0
- package/build/model/data-service-response-data.js.map +1 -1
- package/build/model/local-storage-root-object.d.ts +6 -0
- package/build/model/local-storage-root-object.js +7 -0
- package/build/model/local-storage-root-object.js.map +1 -0
- package/build/model/login-request.d.ts +2 -0
- package/build/model/login-request.js.map +1 -1
- package/build/model/login-response.d.ts +2 -0
- package/build/model/login-response.js.map +1 -1
- package/build/model/login-service-request-data.d.ts +2 -0
- package/build/model/options.d.ts +4 -5
- package/build/model/options.js +1 -2
- package/build/model/options.js.map +1 -1
- package/build/model/session-storage-root-object.d.ts +4 -0
- package/build/model/session-storage-root-object.js +10 -0
- package/build/model/session-storage-root-object.js.map +1 -0
- package/build/model/session.d.ts +0 -9
- package/build/model/session.js +0 -15
- package/build/model/session.js.map +1 -1
- package/build/model/token-response.bo.d.ts +5 -0
- package/build/model/token-response.bo.js +8 -0
- package/build/model/token-response.bo.js.map +1 -0
- package/build/provider/ajax.service.d.ts +4 -4
- package/build/provider/ajax.service.js +72 -51
- package/build/provider/ajax.service.js.map +1 -1
- package/build/provider/base-backend-connection.service.d.ts +19 -9
- package/build/provider/base-backend-connection.service.js +58 -25
- package/build/provider/base-backend-connection.service.js.map +1 -1
- package/build/service/health.service.d.ts +10 -0
- package/build/service/health.service.js +35 -0
- package/build/service/health.service.js.map +1 -0
- package/build/service/jwt-token.service.d.ts +14 -0
- package/build/service/jwt-token.service.js +42 -0
- package/build/service/jwt-token.service.js.map +1 -0
- package/build/service/local-storage.service.d.ts +17 -0
- package/build/service/local-storage.service.js +51 -0
- package/build/service/local-storage.service.js.map +1 -0
- package/build/service/login.service.d.ts +8 -6
- package/build/service/login.service.js +89 -45
- package/build/service/login.service.js.map +1 -1
- package/build/service/session-storage.service.d.ts +12 -0
- package/build/service/session-storage.service.js +31 -0
- package/build/service/session-storage.service.js.map +1 -0
- package/build/tests/int/connector.int.test.js +0 -1
- package/build/tests/int/connector.int.test.js.map +1 -1
- package/package.json +2 -1
|
@@ -11,33 +11,41 @@ class AjaxService extends base_backend_connection_service_1.BaseBackendConnectio
|
|
|
11
11
|
constructor(options) {
|
|
12
12
|
super(options);
|
|
13
13
|
this._showLoaderRequests = 0;
|
|
14
|
-
this._usePublicToken = true;
|
|
15
14
|
this._timeout = 180000;
|
|
16
|
-
this.schema = options.schema;
|
|
17
15
|
if (options && options.timeoutInMs) {
|
|
18
16
|
this._timeout = options.timeoutInMs;
|
|
19
17
|
}
|
|
20
|
-
if (options && ((options.username && options.password) || !options.withCredentials)) {
|
|
21
|
-
this._usePublicToken = false;
|
|
22
|
-
}
|
|
23
18
|
}
|
|
24
|
-
async
|
|
25
|
-
if (this.
|
|
26
|
-
|
|
19
|
+
async connect() {
|
|
20
|
+
if (this.usePublicToken) {
|
|
21
|
+
if (this.localStorageService.publicToken) {
|
|
22
|
+
return true;
|
|
23
|
+
}
|
|
24
|
+
return this._createPublicSession();
|
|
27
25
|
}
|
|
28
|
-
|
|
26
|
+
else {
|
|
27
|
+
if (this.localStorageService.sessionId) {
|
|
28
|
+
return true;
|
|
29
|
+
}
|
|
30
|
+
return this.loginService.loginAndCreateDataSession();
|
|
31
|
+
}
|
|
32
|
+
}
|
|
33
|
+
async call(method, data = {}, showLoader = true, service = backend_service_name_enum_1.BackendServiceName.LoginService, endPoint = end_point_enum_1.EndPoint.AjaxService, ownMessage) {
|
|
34
|
+
if (this.usePublicToken || (service === backend_service_name_enum_1.BackendServiceName.PublicService ||
|
|
29
35
|
service === backend_service_name_enum_1.BackendServiceName.LoginService ||
|
|
30
36
|
service === backend_service_name_enum_1.BackendServiceName.DatasessionService)) {
|
|
31
|
-
return this._doCall(method, data, showLoader, service, endPoint);
|
|
37
|
+
return this._doCall(method, data, showLoader, service, endPoint, ownMessage);
|
|
32
38
|
}
|
|
33
39
|
else {
|
|
34
|
-
|
|
35
|
-
return this._doCall(method, data, showLoader, service, endPoint);
|
|
40
|
+
return this._doCall(method, data, showLoader, service, endPoint, ownMessage);
|
|
36
41
|
}
|
|
37
42
|
}
|
|
38
43
|
async login(request, encrypt) {
|
|
39
44
|
return this.loginService.login(request, encrypt);
|
|
40
45
|
}
|
|
46
|
+
async logInByKeycloakCode(code, uri) {
|
|
47
|
+
return this.loginService.loginByKeycloakCode(code, uri);
|
|
48
|
+
}
|
|
41
49
|
async confirmCode(upId, userName, confirmationCode, clientDeviceFingerprint, clientDeviceDescription, rememberClientDeviceForMFA) {
|
|
42
50
|
return this.loginService.confirmCode(upId, userName, confirmationCode, clientDeviceFingerprint, clientDeviceDescription, rememberClientDeviceForMFA);
|
|
43
51
|
}
|
|
@@ -60,68 +68,71 @@ class AjaxService extends base_backend_connection_service_1.BaseBackendConnectio
|
|
|
60
68
|
return this.loginService.getPublicKey();
|
|
61
69
|
}
|
|
62
70
|
close() {
|
|
63
|
-
if (this.
|
|
71
|
+
if (this.usePublicToken) {
|
|
64
72
|
return this._doCall(datasession_service_method_enum_1.DatasessionServiceMethod.ClosePublicSession, {});
|
|
65
73
|
}
|
|
66
74
|
else {
|
|
67
75
|
return this.closeDataSession();
|
|
68
76
|
}
|
|
69
77
|
}
|
|
70
|
-
async waitForPublicToken() {
|
|
71
|
-
if (this.session && this.session.publicToken) {
|
|
72
|
-
return true;
|
|
73
|
-
}
|
|
74
|
-
if (this.session.gettingPublicToken) {
|
|
75
|
-
return await this._waitForPublicTokenToFinish();
|
|
76
|
-
}
|
|
77
|
-
this.session.gettingPublicToken = true;
|
|
78
|
-
await this._createPublicSession();
|
|
79
|
-
this.session.gettingPublicToken = false;
|
|
80
|
-
}
|
|
81
78
|
async _createPublicSession() {
|
|
82
79
|
const data = {
|
|
83
80
|
upId: this.schema
|
|
84
81
|
};
|
|
85
|
-
|
|
86
|
-
|
|
87
|
-
|
|
88
|
-
|
|
89
|
-
|
|
90
|
-
|
|
91
|
-
|
|
92
|
-
});
|
|
93
|
-
});
|
|
82
|
+
const token = await this._doCall(datasession_service_method_enum_1.DatasessionServiceMethod.CreatePublicSession, data, false, backend_service_name_enum_1.BackendServiceName.PublicService, end_point_enum_1.EndPoint.PublicService);
|
|
83
|
+
if (token) {
|
|
84
|
+
this.localStorageService.setPublicToken(token);
|
|
85
|
+
this.createNewSession();
|
|
86
|
+
return true;
|
|
87
|
+
}
|
|
88
|
+
return false;
|
|
94
89
|
}
|
|
95
|
-
_doCall(method, data = {}, showLoader = true, service = backend_service_name_enum_1.BackendServiceName.LoginService, endPoint = end_point_enum_1.EndPoint.AjaxService) {
|
|
90
|
+
_doCall(method, data = {}, showLoader = true, service = backend_service_name_enum_1.BackendServiceName.LoginService, endPoint = end_point_enum_1.EndPoint.AjaxService, ownMessage) {
|
|
96
91
|
if (showLoader) {
|
|
97
92
|
this.setShowLoaderRequests(this._showLoaderRequests + 1);
|
|
98
93
|
}
|
|
99
|
-
return new Promise((resolve, reject) => {
|
|
94
|
+
return new Promise(async (resolve, reject) => {
|
|
100
95
|
const url = url_utils_1.UrlUtils.createReadableUrl(method, data, this.url, endPoint);
|
|
101
96
|
let message;
|
|
102
|
-
if (
|
|
103
|
-
message = JSON.stringify(
|
|
104
|
-
method: method,
|
|
105
|
-
data: data,
|
|
106
|
-
token: this.session.publicToken
|
|
107
|
-
});
|
|
97
|
+
if (ownMessage) {
|
|
98
|
+
message = JSON.stringify(ownMessage);
|
|
108
99
|
}
|
|
109
100
|
else {
|
|
110
|
-
|
|
111
|
-
|
|
112
|
-
|
|
113
|
-
|
|
114
|
-
|
|
115
|
-
|
|
116
|
-
|
|
117
|
-
|
|
118
|
-
|
|
101
|
+
if (this.usePublicToken) {
|
|
102
|
+
message = JSON.stringify({
|
|
103
|
+
method: method,
|
|
104
|
+
data: data,
|
|
105
|
+
token: this.session.publicToken
|
|
106
|
+
});
|
|
107
|
+
}
|
|
108
|
+
else {
|
|
109
|
+
if (this.options.jwtEnabled) {
|
|
110
|
+
await this._waitForAccessToken(data && service && service === backend_service_name_enum_1.BackendServiceName.LoginService);
|
|
111
|
+
}
|
|
112
|
+
message = JSON.stringify({
|
|
113
|
+
service: service,
|
|
114
|
+
method: method,
|
|
115
|
+
id: this.callId,
|
|
116
|
+
data: data,
|
|
117
|
+
dataSessionId: this.session ? this.session.dataSessionId : "",
|
|
118
|
+
windowSessionId: this.session ? this.session.windowsId : "1",
|
|
119
|
+
sessionId: this.session ? this.session.id : ""
|
|
120
|
+
});
|
|
121
|
+
}
|
|
122
|
+
}
|
|
123
|
+
const headers = {
|
|
124
|
+
"Content-Type": "application/json; charset=utf-8"
|
|
125
|
+
};
|
|
126
|
+
if (this.options.jwtEnabled) {
|
|
127
|
+
headers["Authorization"] = `Bearer ${this.jwtService.jwt}`;
|
|
119
128
|
}
|
|
120
129
|
(0, axios_1.default)({
|
|
121
130
|
method: 'post',
|
|
122
131
|
url: url,
|
|
123
132
|
data: message,
|
|
124
|
-
|
|
133
|
+
withCredentials: this.options.jwtEnabled,
|
|
134
|
+
timeout: this._timeout,
|
|
135
|
+
headers: headers
|
|
125
136
|
}).then(response => {
|
|
126
137
|
if (response.data) {
|
|
127
138
|
if (response.data.exception) {
|
|
@@ -147,6 +158,16 @@ class AjaxService extends base_backend_connection_service_1.BaseBackendConnectio
|
|
|
147
158
|
return new Promise((resolve) => { return resolve(response); });
|
|
148
159
|
});
|
|
149
160
|
}
|
|
161
|
+
async _waitForAccessToken(isLogin) {
|
|
162
|
+
if (!isLogin && this.jwtService.retrievingToken) {
|
|
163
|
+
return new Promise((resolve) => {
|
|
164
|
+
this.jwtService.tokenRetrieved.subscribe(() => {
|
|
165
|
+
resolve(true);
|
|
166
|
+
});
|
|
167
|
+
});
|
|
168
|
+
}
|
|
169
|
+
await this.jwtService.getAccessToken(!isLogin);
|
|
170
|
+
}
|
|
150
171
|
setShowLoaderRequests(amount) {
|
|
151
172
|
this._showLoaderRequests = amount;
|
|
152
173
|
if (this._showLoaderRequests > 0) {
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"ajax.service.js","sourceRoot":"","sources":["../../src/provider/ajax.service.ts"],"names":[],"mappings":";;;AAAA,iFAAqE;AAGrE,uFAA+E;AAC/E,iCAA0B;AAC1B,kDAA4C;AAC5C,6FAAiF;AAEjF,2DAAgD;AAOhD,MAAa,WAAY,SAAQ,8DAA4B;
|
|
1
|
+
{"version":3,"file":"ajax.service.js","sourceRoot":"","sources":["../../src/provider/ajax.service.ts"],"names":[],"mappings":";;;AAAA,iFAAqE;AAGrE,uFAA+E;AAC/E,iCAA0B;AAC1B,kDAA4C;AAC5C,6FAAiF;AAEjF,2DAAgD;AAOhD,MAAa,WAAY,SAAQ,8DAA4B;IAIzD,YAAY,OAAgB;QACxB,KAAK,CAAC,OAAO,CAAC,CAAC;QAJX,wBAAmB,GAAW,CAAC,CAAC;QAChC,aAAQ,GAAW,MAAM,CAAC;QAI9B,IAAI,OAAO,IAAI,OAAO,CAAC,WAAW,EAAE;YAChC,IAAI,CAAC,QAAQ,GAAG,OAAO,CAAC,WAAW,CAAC;SACvC;IACL,CAAC;IAMM,KAAK,CAAC,OAAO;QAChB,IAAI,IAAI,CAAC,cAAc,EAAE;YACrB,IAAI,IAAI,CAAC,mBAAmB,CAAC,WAAW,EAAE;gBACtC,OAAO,IAAI,CAAC;aACf;YACD,OAAO,IAAI,CAAC,oBAAoB,EAAE,CAAC;SACtC;aAAM;YACH,IAAI,IAAI,CAAC,mBAAmB,CAAC,SAAS,EAAE;gBACpC,OAAO,IAAI,CAAC;aACf;YACD,OAAO,IAAI,CAAC,YAAY,CAAC,yBAAyB,EAAE,CAAC;SACxD;IACL,CAAC;IAEM,KAAK,CAAC,IAAI,CAAC,MAAc,EAAE,OAAmD,EAAE,EAAE,aAAsB,IAAI,EAC/G,UAAkB,8CAAkB,CAAC,YAAY,EAAE,WAAmB,yBAAQ,CAAC,WAAW,EAAE,UAAe;QAC3G,IAAI,IAAI,CAAC,cAAc,IAAI,CACvB,OAAO,KAAK,8CAAkB,CAAC,aAAa;YAC5C,OAAO,KAAK,8CAAkB,CAAC,YAAY;YAC3C,OAAO,KAAK,8CAAkB,CAAC,kBAAkB,CAAC,EAAE;YACpD,OAAO,IAAI,CAAC,OAAO,CAAC,MAAM,EAAE,IAAI,EAAE,UAAU,EAAE,OAAO,EAAE,QAAQ,EAAE,UAAU,CAAC,CAAC;SAChF;aAAM;YACH,OAAO,IAAI,CAAC,OAAO,CAAC,MAAM,EAAE,IAAI,EAAE,UAAU,EAAE,OAAO,EAAE,QAAQ,EAAE,UAAU,CAAC,CAAC;SAChF;IACL,CAAC;IAEM,KAAK,CAAC,KAAK,CAAC,OAAqB,EAAE,OAAgB;QACtD,OAAO,IAAI,CAAC,YAAY,CAAC,KAAK,CAAC,OAAO,EAAE,OAAO,CAAC,CAAC;IACrD,CAAC;IAEM,KAAK,CAAC,mBAAmB,CAAC,IAAY,EAAE,GAAW;QACtD,OAAO,IAAI,CAAC,YAAY,CAAC,mBAAmB,CAAC,IAAI,EAAE,GAAG,CAAC,CAAC;IAC5D,CAAC;IAEM,KAAK,CAAC,WAAW,CACpB,IAAY,EACZ,QAAgB,EAChB,gBAAwB,EACxB,uBAA+B,EAC/B,uBAA+B,EAC/B,0BAAmC;QAEnC,OAAO,IAAI,CAAC,YAAY,CAAC,WAAW,CAAC,IAAI,EAAE,QAAQ,EAAE,gBAAgB,EAAE,uBAAuB,EAAE,uBAAuB,EAAE,0BAA0B,CAAC,CAAC;IACzJ,CAAC;IAEM,KAAK,CAAC,eAAe,CAAC,IAAY,EAAE,QAAgB;QACvD,OAAO,IAAI,CAAC,YAAY,CAAC,eAAe,CAAC,IAAI,EAAE,QAAQ,CAAC,CAAC;IAC7D,CAAC;IAEM,KAAK,CAAC,cAAc,CAAC,QAAgB,EAAE,YAAoB,EAAE,IAAY;QAC5E,OAAO,IAAI,CAAC,YAAY,CAAC,cAAc,CAAC,QAAQ,EAAE,YAAY,EAAE,IAAI,CAAC,CAAC;IAC1E,CAAC;IAEM,KAAK,CAAC,6BAA6B,CAAC,QAAgB,EAAE,YAAoB,EAAE,IAAY,EAAE,iBAA0B;QACvH,OAAO,IAAI,CAAC,YAAY,CAAC,6BAA6B,CAAC,QAAQ,EAAE,YAAY,EAAE,IAAI,EAAE,iBAAiB,CAAC,CAAC;IAC5G,CAAC;IAEM,KAAK,CAAC,gCAAgC,CAAC,IAAY,EAAE,QAAgB,EAAE,iBAAyB;QACnG,OAAO,IAAI,CAAC,YAAY,CAAC,gCAAgC,CAAC,IAAI,EAAE,QAAQ,EAAE,iBAAiB,CAAC,CAAC;IACjG,CAAC;IAEM,KAAK,CAAC,yBAAyB,CAAC,YAAoB,EAAE,IAAY;QACrE,OAAO,IAAI,CAAC,YAAY,CAAC,yBAAyB,CAAC,YAAY,EAAE,IAAI,CAAC,CAAC;IAC3E,CAAC;IAEM,KAAK,CAAC,YAAY;QACrB,OAAO,IAAI,CAAC,YAAY,CAAC,YAAY,EAAE,CAAC;IAC5C,CAAC;IAEM,KAAK;QACR,IAAI,IAAI,CAAC,cAAc,EAAE;YACrB,OAAO,IAAI,CAAC,OAAO,CAAC,0DAAwB,CAAC,kBAAkB,EAAE,EAAE,CAAC,CAAC;SACxE;aAAM;YACH,OAAO,IAAI,CAAC,gBAAgB,EAAE,CAAC;SAClC;IACL,CAAC;IAEO,KAAK,CAAC,oBAAoB;QAC9B,MAAM,IAAI,GAAoB;YAC1B,IAAI,EAAE,IAAI,CAAC,MAAM;SACpB,CAAC;QACF,MAAM,KAAK,GAA6B,MAAM,IAAI,CAAC,OAAO,CAAC,0DAAwB,CAAC,mBAAmB,EAAE,IAAI,EAAE,KAAK,EAAE,8CAAkB,CAAC,aAAa,EAAE,yBAAQ,CAAC,aAAa,CAAC,CAAC;QAChL,IAAI,KAAK,EAAE;YACP,IAAI,CAAC,mBAAmB,CAAC,cAAc,CAAC,KAAK,CAAC,CAAC;YAC/C,IAAI,CAAC,gBAAgB,EAAE,CAAC;YACxB,OAAO,IAAI,CAAC;SACf;QACD,OAAO,KAAK,CAAC;IACjB,CAAC;IAEO,OAAO,CAAC,MAAc,EAAE,OAAmD,EAAE,EAAE,aAAsB,IAAI,EAC7G,UAAkB,8CAAkB,CAAC,YAAY,EAAE,WAAmB,yBAAQ,CAAC,WAAW,EAAE,UAAe;QAC3G,IAAI,UAAU,EAAE;YACZ,IAAI,CAAC,qBAAqB,CAAC,IAAI,CAAC,mBAAmB,GAAG,CAAC,CAAC,CAAC;SAC5D;QACD,OAAO,IAAI,OAAO,CAAC,KAAK,EAAE,OAAiB,EAAE,MAAgB,EAAE,EAAE;YAC7D,MAAM,GAAG,GAAW,oBAAQ,CAAC,iBAAiB,CAAC,MAAM,EAAE,IAAI,EAAE,IAAI,CAAC,GAAG,EAAE,QAAQ,CAAC,CAAC;YACjF,IAAI,OAAe,CAAC;YACpB,IAAI,UAAU,EAAE;gBACZ,OAAO,GAAG,IAAI,CAAC,SAAS,CAAC,UAAU,CAAC,CAAC;aACxC;iBAAM;gBACH,IAAI,IAAI,CAAC,cAAc,EAAE;oBACrB,OAAO,GAAG,IAAI,CAAC,SAAS,CAAC;wBACrB,MAAM,EAAE,MAAM;wBACd,IAAI,EAAE,IAAI;wBACV,KAAK,EAAE,IAAI,CAAC,OAAO,CAAC,WAAW;qBAClC,CAAC,CAAC;iBACN;qBAAM;oBACH,IAAI,IAAI,CAAC,OAAO,CAAC,UAAU,EAAE;wBACzB,MAAM,IAAI,CAAC,mBAAmB,CAAC,IAAI,IAAI,OAAO,IAAI,OAAO,KAAK,8CAAkB,CAAC,YAAY,CAAC,CAAC;qBAClG;oBACD,OAAO,GAAG,IAAI,CAAC,SAAS,CAAC;wBACrB,OAAO,EAAE,OAAO;wBAChB,MAAM,EAAE,MAAM;wBACd,EAAE,EAAE,IAAI,CAAC,MAAM;wBACf,IAAI,EAAE,IAAI;wBACV,aAAa,EAAE,IAAI,CAAC,OAAO,CAAC,CAAC,CAAC,IAAI,CAAC,OAAO,CAAC,aAAa,CAAC,CAAC,CAAC,EAAE;wBAC7D,eAAe,EAAE,IAAI,CAAC,OAAO,CAAC,CAAC,CAAC,IAAI,CAAC,OAAO,CAAC,SAAS,CAAC,CAAC,CAAC,GAAG;wBAC5D,SAAS,EAAE,IAAI,CAAC,OAAO,CAAC,CAAC,CAAC,IAAI,CAAC,OAAO,CAAC,EAAE,CAAC,CAAC,CAAC,EAAE;qBACjD,CAAC,CAAC;iBACN;aACJ;YACD,MAAM,OAAO,GAAG;gBACZ,cAAc,EAAE,iCAAiC;aACpD,CAAC;YACF,IAAI,IAAI,CAAC,OAAO,CAAC,UAAU,EAAE;gBACzB,OAAO,CAAC,eAAe,CAAC,GAAG,UAAU,IAAI,CAAC,UAAU,CAAC,GAAG,EAAE,CAAC;aAC9D;YACD,IAAA,eAAK,EAAC;gBACF,MAAM,EAAE,MAAM;gBACd,GAAG,EAAE,GAAG;gBACR,IAAI,EAAE,OAAO;gBACb,eAAe,EAAE,IAAI,CAAC,OAAO,CAAC,UAAU;gBACxC,OAAO,EAAE,IAAI,CAAC,QAAQ;gBACtB,OAAO,EAAE,OAAO;aACnB,CAAC,CAAC,IAAI,CAAC,QAAQ,CAAC,EAAE;gBACf,IAAI,QAAQ,CAAC,IAAI,EAAE;oBACf,IAAK,QAAQ,CAAC,IAAY,CAAC,SAAS,EAAE;wBAClC,OAAO,CAAE,QAAQ,CAAC,IAAY,CAAC,SAAS,CAAC,CAAC;qBAC7C;yBAAM;wBACH,OAAO,CAAC,QAAQ,CAAC,IAAI,CAAC,IAAI,CAAC,CAAC;qBAC/B;iBACJ;YACL,CAAC,CAAC,CAAC,KAAK,CAAC,KAAK,CAAC,EAAE;gBACb,IAAI,UAAU,EAAE;oBACZ,IAAI,CAAC,qBAAqB,CAAC,CAAC,CAAC,CAAC;iBACjC;gBACD,IAAI,KAAK,CAAC,IAAI,KAAK,cAAc,EAAE;oBAC/B,IAAI,CAAC,iBAAiB,CAAC,IAAI,EAAE,CAAC;iBACjC;gBAID,MAAM,CAAC,KAAK,CAAC,CAAC;YAClB,CAAC,CAAC,CAAC;QACP,CAAC,CAAC,CAAC,IAAI,CAAC,QAAQ,CAAC,EAAE;YACf,IAAI,UAAU,EAAE;gBACZ,IAAI,CAAC,qBAAqB,CAAC,IAAI,CAAC,mBAAmB,GAAG,CAAC,CAAC,CAAC;aAC5D;YACD,OAAO,IAAI,OAAO,CAAC,CAAC,OAAiB,EAAE,EAAE,GAAG,OAAO,OAAO,CAAC,QAAQ,CAAC,CAAC,CAAC,CAAC,CAAE,CAAC;QAC9E,CAAC,CAAC,CAAC;IACP,CAAC;IAEO,KAAK,CAAC,mBAAmB,CAAC,OAAgB;QAC9C,IAAI,CAAC,OAAO,IAAI,IAAI,CAAC,UAAU,CAAC,eAAe,EAAE;YAC7C,OAAO,IAAI,OAAO,CAAC,CAAC,OAAiB,EAAE,EAAE;gBACrC,IAAI,CAAC,UAAU,CAAC,cAAc,CAAC,SAAS,CAAC,GAAG,EAAE;oBAC1C,OAAO,CAAC,IAAI,CAAC,CAAC;gBAClB,CAAC,CAAC,CAAC;YACP,CAAC,CAAC,CAAC;SACN;QACD,MAAM,IAAI,CAAC,UAAU,CAAC,cAAc,CAAC,CAAC,OAAO,CAAC,CAAC;IACnD,CAAC;IAEO,qBAAqB,CAAC,MAAc;QACxC,IAAI,CAAC,mBAAmB,GAAG,MAAM,CAAC;QAClC,IAAI,IAAI,CAAC,mBAAmB,GAAG,CAAC,EAAE;YAC9B,IAAI,CAAC,UAAU,CAAC,IAAI,CAAC,IAAI,CAAC,CAAC;SAC9B;aAAM;YACH,IAAI,CAAC,UAAU,CAAC,IAAI,CAAC,KAAK,CAAC,CAAC;SAC/B;IACL,CAAC;CACJ;AArMD,kCAqMC"}
|
|
@@ -1,26 +1,36 @@
|
|
|
1
|
-
import { BackendServiceName } from
|
|
2
|
-
import { Session } from
|
|
3
|
-
import { LoginService } from
|
|
1
|
+
import { BackendServiceName } from '../enum/backend-service-name.enum';
|
|
2
|
+
import { Session } from '../model/session';
|
|
3
|
+
import { LoginService } from '../service/login.service';
|
|
4
4
|
import { Subject } from 'rxjs';
|
|
5
|
-
import { Options } from
|
|
5
|
+
import { Options } from '../model/options';
|
|
6
6
|
import { ServerResponseData } from '../model/server-response-data';
|
|
7
|
+
import { LocalStorageService } from '../service/local-storage.service';
|
|
8
|
+
import { JwtTokenService } from '../service/jwt-token.service';
|
|
9
|
+
import { SessionStorageService } from '../service/session-storage.service';
|
|
7
10
|
export declare abstract class BaseBackendConnectionService {
|
|
8
11
|
readonly showLoader: Subject<boolean>;
|
|
9
12
|
readonly connectionAborted: Subject<void>;
|
|
10
13
|
readonly connectionResetInactivity: Subject<void>;
|
|
11
14
|
session: Session;
|
|
15
|
+
dataSessionId: string;
|
|
16
|
+
sessionId: string;
|
|
17
|
+
module: string;
|
|
12
18
|
options: Options;
|
|
19
|
+
localStorageService: LocalStorageService;
|
|
20
|
+
sessionStorageService: SessionStorageService;
|
|
21
|
+
jwtService: JwtTokenService;
|
|
22
|
+
version: number;
|
|
13
23
|
protected callId: string;
|
|
14
24
|
protected url: string;
|
|
15
25
|
protected schema: string;
|
|
16
26
|
protected loginService: LoginService;
|
|
27
|
+
protected usePublicToken: boolean;
|
|
17
28
|
private _datasessionService;
|
|
18
29
|
constructor(options: Options);
|
|
19
|
-
abstract call(method: string, data: any, showLoader: boolean, service: BackendServiceName): Promise<any>;
|
|
30
|
+
abstract call(method: string, data: any, showLoader: boolean, service: BackendServiceName, ownMessage?: {}): Promise<any>;
|
|
20
31
|
commit(): Promise<boolean>;
|
|
21
32
|
closeDataSession(): Promise<ServerResponseData>;
|
|
22
|
-
|
|
23
|
-
|
|
24
|
-
private
|
|
25
|
-
private _generateUniqueId;
|
|
33
|
+
createNewSession(): void;
|
|
34
|
+
generateUniqueId(): string;
|
|
35
|
+
private _checkSession;
|
|
26
36
|
}
|
|
@@ -5,23 +5,48 @@ const session_1 = require("../model/session");
|
|
|
5
5
|
const login_service_1 = require("../service/login.service");
|
|
6
6
|
const rxjs_1 = require("rxjs");
|
|
7
7
|
const datasession_service_1 = require("../service/datasession.service");
|
|
8
|
+
const local_storage_service_1 = require("../service/local-storage.service");
|
|
9
|
+
const jwt_token_service_1 = require("../service/jwt-token.service");
|
|
10
|
+
const session_storage_service_1 = require("../service/session-storage.service");
|
|
8
11
|
class BaseBackendConnectionService {
|
|
9
12
|
constructor(options) {
|
|
10
13
|
this.showLoader = new rxjs_1.Subject();
|
|
11
14
|
this.connectionAborted = new rxjs_1.Subject();
|
|
12
15
|
this.connectionResetInactivity = new rxjs_1.Subject();
|
|
13
16
|
this.session = new session_1.Session();
|
|
17
|
+
this.module = 'webselector';
|
|
14
18
|
this.callId = "1";
|
|
19
|
+
this.usePublicToken = true;
|
|
15
20
|
this.options = options;
|
|
16
|
-
this.
|
|
17
|
-
|
|
18
|
-
|
|
21
|
+
if (this.options.schema === "") {
|
|
22
|
+
console.error("Schema is not provided");
|
|
23
|
+
}
|
|
24
|
+
if (this.options.version === "") {
|
|
25
|
+
console.error("Version is not provided");
|
|
19
26
|
}
|
|
20
27
|
else {
|
|
21
|
-
this.
|
|
28
|
+
this.version = parseInt(this.options.version);
|
|
29
|
+
}
|
|
30
|
+
if (options && ((options.username && options.password) || !options.jwtEnabled)) {
|
|
31
|
+
this.usePublicToken = false;
|
|
32
|
+
}
|
|
33
|
+
this.schema = options.schema;
|
|
34
|
+
this.url = options.url;
|
|
35
|
+
if (options.sessionId) {
|
|
36
|
+
this.sessionId = options.sessionId;
|
|
37
|
+
}
|
|
38
|
+
if (options.dataSessionId) {
|
|
39
|
+
this.dataSessionId = options.dataSessionId;
|
|
22
40
|
}
|
|
41
|
+
if (options.module) {
|
|
42
|
+
this.module = options.module;
|
|
43
|
+
}
|
|
44
|
+
this.localStorageService = new local_storage_service_1.LocalStorageService();
|
|
45
|
+
this.sessionStorageService = new session_storage_service_1.SessionStorageService();
|
|
23
46
|
this.loginService = new login_service_1.LoginService(this);
|
|
47
|
+
this.jwtService = new jwt_token_service_1.JwtTokenService(this.sessionStorageService, this.loginService);
|
|
24
48
|
this._datasessionService = new datasession_service_1.DatasessionService(this);
|
|
49
|
+
this._checkSession();
|
|
25
50
|
}
|
|
26
51
|
async commit() {
|
|
27
52
|
return this._datasessionService.commit();
|
|
@@ -29,30 +54,23 @@ class BaseBackendConnectionService {
|
|
|
29
54
|
closeDataSession() {
|
|
30
55
|
return this.loginService.logout();
|
|
31
56
|
}
|
|
32
|
-
|
|
33
|
-
|
|
34
|
-
|
|
35
|
-
|
|
36
|
-
}
|
|
37
|
-
async waitForLogin() {
|
|
38
|
-
if (this.session && this.session.created) {
|
|
39
|
-
return true;
|
|
57
|
+
createNewSession() {
|
|
58
|
+
this.session = new session_1.Session();
|
|
59
|
+
if (this.usePublicToken) {
|
|
60
|
+
this.session.publicToken = this.localStorageService.publicToken;
|
|
40
61
|
}
|
|
41
|
-
|
|
42
|
-
|
|
62
|
+
else {
|
|
63
|
+
if (!this.dataSessionId) {
|
|
64
|
+
this.dataSessionId = `${this.module}_${this.generateUniqueId()}`;
|
|
65
|
+
}
|
|
66
|
+
this.session.dataSessionId = this.dataSessionId;
|
|
67
|
+
this.session.id = this.sessionId ? this.sessionId : this.generateUniqueId();
|
|
68
|
+
this.session.windowsId = "1";
|
|
69
|
+
this.localStorageService.setDataSessionId(this.session.dataSessionId);
|
|
70
|
+
this.localStorageService.setSessionId(this.session.id);
|
|
43
71
|
}
|
|
44
|
-
this.session.loggingIn = true;
|
|
45
|
-
await this.loginService.loginAndCreateDataSession();
|
|
46
|
-
this.session.loggingIn = false;
|
|
47
|
-
}
|
|
48
|
-
_createNewSession() {
|
|
49
|
-
const session = new session_1.Session();
|
|
50
|
-
session.dataSessionId = 'webselector_' + this._generateUniqueId();
|
|
51
|
-
session.id = this._generateUniqueId();
|
|
52
|
-
session.windowsId = "1";
|
|
53
|
-
return session;
|
|
54
72
|
}
|
|
55
|
-
|
|
73
|
+
generateUniqueId() {
|
|
56
74
|
function s4() {
|
|
57
75
|
return Math.floor((1 + Math.random()) * 0x10000)
|
|
58
76
|
.toString(16)
|
|
@@ -60,6 +78,21 @@ class BaseBackendConnectionService {
|
|
|
60
78
|
}
|
|
61
79
|
return s4() + s4() + s4();
|
|
62
80
|
}
|
|
81
|
+
_checkSession() {
|
|
82
|
+
if (this.usePublicToken && this.localStorageService.publicToken) {
|
|
83
|
+
this.createNewSession();
|
|
84
|
+
}
|
|
85
|
+
else {
|
|
86
|
+
if (this.sessionId && this.dataSessionId) {
|
|
87
|
+
this.createNewSession();
|
|
88
|
+
}
|
|
89
|
+
else if (this.localStorageService.sessionId && this.localStorageService.dataSessionId) {
|
|
90
|
+
this.sessionId = this.localStorageService.sessionId;
|
|
91
|
+
this.dataSessionId = this.localStorageService.dataSessionId;
|
|
92
|
+
this.createNewSession();
|
|
93
|
+
}
|
|
94
|
+
}
|
|
95
|
+
}
|
|
63
96
|
}
|
|
64
97
|
exports.BaseBackendConnectionService = BaseBackendConnectionService;
|
|
65
98
|
//# sourceMappingURL=base-backend-connection.service.js.map
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"base-backend-connection.service.js","sourceRoot":"","sources":["../../src/provider/base-backend-connection.service.ts"],"names":[],"mappings":";;;AACA,8CAAyC;AACzC,4DAAsD;AACtD,+
|
|
1
|
+
{"version":3,"file":"base-backend-connection.service.js","sourceRoot":"","sources":["../../src/provider/base-backend-connection.service.ts"],"names":[],"mappings":"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"}
|
|
@@ -0,0 +1,10 @@
|
|
|
1
|
+
import { BaseBackendConnectionService } from '../provider/base-backend-connection.service';
|
|
2
|
+
export declare class HealthService {
|
|
3
|
+
private static HEARTBEAT_INTERVAL_MS;
|
|
4
|
+
protected heartbeatTimer: any;
|
|
5
|
+
protected backendConnection: BaseBackendConnectionService;
|
|
6
|
+
constructor(backendConnection: BaseBackendConnectionService);
|
|
7
|
+
startHeartBeat(): void;
|
|
8
|
+
stopHeartBeat(): void;
|
|
9
|
+
private _call;
|
|
10
|
+
}
|
|
@@ -0,0 +1,35 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
Object.defineProperty(exports, "__esModule", { value: true });
|
|
3
|
+
exports.HealthService = void 0;
|
|
4
|
+
const backend_service_name_enum_1 = require("../enum/backend-service-name.enum");
|
|
5
|
+
const health_service_method_enum_1 = require("../enum/health-service-method.enum");
|
|
6
|
+
class HealthService {
|
|
7
|
+
constructor(backendConnection) {
|
|
8
|
+
this.backendConnection = backendConnection;
|
|
9
|
+
}
|
|
10
|
+
startHeartBeat() {
|
|
11
|
+
if (!this.heartbeatTimer) {
|
|
12
|
+
this.heartbeatTimer = setInterval(() => {
|
|
13
|
+
this._call(health_service_method_enum_1.HealthServiceMethod.GetHeartBeat, {}, false);
|
|
14
|
+
}, HealthService.HEARTBEAT_INTERVAL_MS);
|
|
15
|
+
}
|
|
16
|
+
}
|
|
17
|
+
stopHeartBeat() {
|
|
18
|
+
if (this.heartbeatTimer) {
|
|
19
|
+
clearInterval(this.heartbeatTimer);
|
|
20
|
+
this.heartbeatTimer = null;
|
|
21
|
+
}
|
|
22
|
+
}
|
|
23
|
+
_call(method, data, showLoader) {
|
|
24
|
+
if (data === undefined) {
|
|
25
|
+
data = {};
|
|
26
|
+
}
|
|
27
|
+
if (showLoader === undefined) {
|
|
28
|
+
showLoader = true;
|
|
29
|
+
}
|
|
30
|
+
return this.backendConnection.call(method, data, showLoader, backend_service_name_enum_1.BackendServiceName.HealthService);
|
|
31
|
+
}
|
|
32
|
+
}
|
|
33
|
+
exports.HealthService = HealthService;
|
|
34
|
+
HealthService.HEARTBEAT_INTERVAL_MS = 59000;
|
|
35
|
+
//# sourceMappingURL=health.service.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"health.service.js","sourceRoot":"","sources":["../../src/service/health.service.ts"],"names":[],"mappings":";;;AAAA,iFAAqE;AAGrE,mFAAuE;AAEvE,MAAa,aAAa;IAMtB,YAAY,iBAA+C;QACvD,IAAI,CAAC,iBAAiB,GAAG,iBAAiB,CAAC;IAC/C,CAAC;IAEM,cAAc;QACjB,IAAI,CAAC,IAAI,CAAC,cAAc,EAAE;YACtB,IAAI,CAAC,cAAc,GAAG,WAAW,CAAC,GAAG,EAAE;gBACnC,IAAI,CAAC,KAAK,CAAC,gDAAmB,CAAC,YAAY,EAAE,EAAE,EAAE,KAAK,CAAC,CAAC;YAC5D,CAAC,EAAE,aAAa,CAAC,qBAAqB,CAAC,CAAC;SAC3C;IACL,CAAC;IAEM,aAAa;QAChB,IAAI,IAAI,CAAC,cAAc,EAAE;YACrB,aAAa,CAAC,IAAI,CAAC,cAAc,CAAC,CAAC;YACnC,IAAI,CAAC,cAAc,GAAG,IAAI,CAAC;SAC9B;IACL,CAAC;IAEO,KAAK,CAAC,MAA2B,EAAE,IAAS,EAAE,UAAmB;QACrE,IAAI,IAAI,KAAK,SAAS,EAAE;YACpB,IAAI,GAAG,EAAE,CAAC;SACb;QACD,IAAI,UAAU,KAAK,SAAS,EAAE;YAC1B,UAAU,GAAG,IAAI,CAAC;SACrB;QACD,OAAO,IAAI,CAAC,iBAAiB,CAAC,IAAI,CAAC,MAAM,EAAE,IAAI,EAAE,UAAU,EAAE,8CAAkB,CAAC,aAAa,CAAC,CAAC;IACnG,CAAC;;AAjCL,sCAkCC;AAjCkB,mCAAqB,GAAW,KAAK,CAAC"}
|
|
@@ -0,0 +1,14 @@
|
|
|
1
|
+
import { Subject } from 'rxjs';
|
|
2
|
+
export declare class JwtTokenService {
|
|
3
|
+
jwt: string;
|
|
4
|
+
retrievingToken: boolean;
|
|
5
|
+
tokenRetrieved: Subject<boolean>;
|
|
6
|
+
private _tokenExpiredTime;
|
|
7
|
+
private _sessionStorageService;
|
|
8
|
+
private _loginService;
|
|
9
|
+
constructor(sessionStorageService: any, loginService: any);
|
|
10
|
+
getAccessToken(refresh?: boolean): Promise<void>;
|
|
11
|
+
setExpirationTime(jwt: string): void;
|
|
12
|
+
private _tokenExpired;
|
|
13
|
+
private _refreshToken;
|
|
14
|
+
}
|
|
@@ -0,0 +1,42 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
Object.defineProperty(exports, "__esModule", { value: true });
|
|
3
|
+
exports.JwtTokenService = void 0;
|
|
4
|
+
const rxjs_1 = require("rxjs");
|
|
5
|
+
const jwt_decode_1 = require("jwt-decode");
|
|
6
|
+
class JwtTokenService {
|
|
7
|
+
constructor(sessionStorageService, loginService) {
|
|
8
|
+
this.retrievingToken = false;
|
|
9
|
+
this.tokenRetrieved = new rxjs_1.Subject();
|
|
10
|
+
this._sessionStorageService = sessionStorageService;
|
|
11
|
+
this._loginService = loginService;
|
|
12
|
+
}
|
|
13
|
+
async getAccessToken(refresh = true) {
|
|
14
|
+
if (refresh && this._tokenExpired()) {
|
|
15
|
+
await this._refreshToken();
|
|
16
|
+
}
|
|
17
|
+
this.jwt = this._sessionStorageService.getLoginData().accessToken;
|
|
18
|
+
}
|
|
19
|
+
setExpirationTime(jwt) {
|
|
20
|
+
const decoded = (0, jwt_decode_1.default)(jwt);
|
|
21
|
+
this._tokenExpiredTime = decoded.exp;
|
|
22
|
+
}
|
|
23
|
+
_tokenExpired() {
|
|
24
|
+
if (this._sessionStorageService.getLoginData().accessToken && this._tokenExpiredTime) {
|
|
25
|
+
return ((1000 * this._tokenExpiredTime) - (new Date()).getTime()) < 120000;
|
|
26
|
+
}
|
|
27
|
+
return false;
|
|
28
|
+
}
|
|
29
|
+
async _refreshToken() {
|
|
30
|
+
this.retrievingToken = true;
|
|
31
|
+
const tokenResponse = await this._loginService.refreshAccessToken(this._sessionStorageService.getLoginData().refreshToken);
|
|
32
|
+
const loginData = this._sessionStorageService.getLoginData();
|
|
33
|
+
loginData.accessToken = tokenResponse.accessToken;
|
|
34
|
+
loginData.refreshToken = tokenResponse.refreshToken;
|
|
35
|
+
this.setExpirationTime(tokenResponse.accessToken);
|
|
36
|
+
this._sessionStorageService.setLoginData(loginData);
|
|
37
|
+
this.retrievingToken = false;
|
|
38
|
+
this.tokenRetrieved.next(true);
|
|
39
|
+
}
|
|
40
|
+
}
|
|
41
|
+
exports.JwtTokenService = JwtTokenService;
|
|
42
|
+
//# sourceMappingURL=jwt-token.service.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"jwt-token.service.js","sourceRoot":"","sources":["../../src/service/jwt-token.service.ts"],"names":[],"mappings":";;;AAAA,+BAA6B;AAI7B,2CAAoC;AAGpC,MAAa,eAAe;IASxB,YAAY,qBAAqB,EAAE,YAAY;QAPxC,oBAAe,GAAY,KAAK,CAAC;QACjC,mBAAc,GAAqB,IAAI,cAAO,EAAW,CAAC;QAO7D,IAAI,CAAC,sBAAsB,GAAG,qBAAqB,CAAC;QACpD,IAAI,CAAC,aAAa,GAAG,YAAY,CAAC;IACtC,CAAC;IAEM,KAAK,CAAC,cAAc,CAAC,UAAmB,IAAI;QAC/C,IAAI,OAAO,IAAI,IAAI,CAAC,aAAa,EAAE,EAAE;YACjC,MAAM,IAAI,CAAC,aAAa,EAAE,CAAC;SAC9B;QACD,IAAI,CAAC,GAAG,GAAG,IAAI,CAAC,sBAAsB,CAAC,YAAY,EAAE,CAAC,WAAW,CAAC;IACtE,CAAC;IAEM,iBAAiB,CAAC,GAAW;QAChC,MAAM,OAAO,GAAQ,IAAA,oBAAU,EAAC,GAAG,CAAC,CAAC;QACrC,IAAI,CAAC,iBAAiB,GAAG,OAAO,CAAC,GAAG,CAAC;IACzC,CAAC;IAEO,aAAa;QACjB,IAAI,IAAI,CAAC,sBAAsB,CAAC,YAAY,EAAE,CAAC,WAAW,IAAI,IAAI,CAAC,iBAAiB,EAAE;YAClF,OAAO,CAAC,CAAC,IAAI,GAAG,IAAI,CAAC,iBAAiB,CAAC,GAAG,CAAC,IAAI,IAAI,EAAE,CAAC,CAAC,OAAO,EAAE,CAAC,GAAG,MAAM,CAAC;SAC9E;QACD,OAAO,KAAK,CAAC;IACjB,CAAC;IAEO,KAAK,CAAC,aAAa;QACvB,IAAI,CAAC,eAAe,GAAG,IAAI,CAAC;QAC5B,MAAM,aAAa,GAAkB,MAAM,IAAI,CAAC,aAAa,CAAC,kBAAkB,CAAC,IAAI,CAAC,sBAAsB,CAAC,YAAY,EAAE,CAAC,YAAY,CAAC,CAAC;QAC1I,MAAM,SAAS,GAAqB,IAAI,CAAC,sBAAsB,CAAC,YAAY,EAAE,CAAC;QAC/E,SAAS,CAAC,WAAW,GAAG,aAAa,CAAC,WAAW,CAAC;QAClD,SAAS,CAAC,YAAY,GAAG,aAAa,CAAC,YAAY,CAAC;QACpD,IAAI,CAAC,iBAAiB,CAAC,aAAa,CAAC,WAAW,CAAC,CAAC;QAClD,IAAI,CAAC,sBAAsB,CAAC,YAAY,CAAC,SAAS,CAAC,CAAC;QACpD,IAAI,CAAC,eAAe,GAAG,KAAK,CAAC;QAC7B,IAAI,CAAC,cAAc,CAAC,IAAI,CAAC,IAAI,CAAC,CAAC;IACnC,CAAC;CACJ;AA5CD,0CA4CC"}
|
|
@@ -0,0 +1,17 @@
|
|
|
1
|
+
import { LocalStorageRootObject } from '../model/local-storage-root-object';
|
|
2
|
+
export declare class LocalStorageService {
|
|
3
|
+
readonly storage: Storage;
|
|
4
|
+
setSessionId(id: string): void;
|
|
5
|
+
get sessionId(): string;
|
|
6
|
+
setDataSessionId(id: string): void;
|
|
7
|
+
get dataSessionId(): string;
|
|
8
|
+
setPublicToken(token: string): void;
|
|
9
|
+
get publicToken(): string;
|
|
10
|
+
setKeycloakState(keycloakState: string): void;
|
|
11
|
+
get keycloakState(): string;
|
|
12
|
+
protected storageObj: LocalStorageRootObject;
|
|
13
|
+
protected appRoot: string;
|
|
14
|
+
constructor();
|
|
15
|
+
save(): void;
|
|
16
|
+
protected _initLocalStorageObj(): void;
|
|
17
|
+
}
|
|
@@ -0,0 +1,51 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
Object.defineProperty(exports, "__esModule", { value: true });
|
|
3
|
+
exports.LocalStorageService = void 0;
|
|
4
|
+
const CircularJSON = require("circular-json");
|
|
5
|
+
const local_storage_root_object_1 = require("../model/local-storage-root-object");
|
|
6
|
+
class LocalStorageService {
|
|
7
|
+
setSessionId(id) {
|
|
8
|
+
this.storageObj.sessionId = id;
|
|
9
|
+
this.save();
|
|
10
|
+
}
|
|
11
|
+
get sessionId() {
|
|
12
|
+
return this.storageObj.sessionId;
|
|
13
|
+
}
|
|
14
|
+
setDataSessionId(id) {
|
|
15
|
+
this.storageObj.dataSessionId = id;
|
|
16
|
+
this.save();
|
|
17
|
+
}
|
|
18
|
+
get dataSessionId() {
|
|
19
|
+
return this.storageObj.dataSessionId;
|
|
20
|
+
}
|
|
21
|
+
setPublicToken(token) {
|
|
22
|
+
this.storageObj.token = token;
|
|
23
|
+
this.save();
|
|
24
|
+
}
|
|
25
|
+
get publicToken() {
|
|
26
|
+
return this.storageObj.token;
|
|
27
|
+
}
|
|
28
|
+
setKeycloakState(keycloakState) {
|
|
29
|
+
this.storageObj.keycloakState = keycloakState;
|
|
30
|
+
this.save();
|
|
31
|
+
}
|
|
32
|
+
get keycloakState() {
|
|
33
|
+
return this.storageObj.keycloakState;
|
|
34
|
+
}
|
|
35
|
+
constructor() {
|
|
36
|
+
this.storage = localStorage;
|
|
37
|
+
this.storageObj = new local_storage_root_object_1.LocalStorageRootObject();
|
|
38
|
+
this.appRoot = "/";
|
|
39
|
+
this._initLocalStorageObj();
|
|
40
|
+
}
|
|
41
|
+
save() {
|
|
42
|
+
this.storage.setItem(this.appRoot, CircularJSON.stringify(this.storageObj));
|
|
43
|
+
}
|
|
44
|
+
_initLocalStorageObj() {
|
|
45
|
+
this.appRoot = window.location.pathname;
|
|
46
|
+
this.storageObj = CircularJSON.parse(this.storage.getItem(this.appRoot)) || this.storageObj;
|
|
47
|
+
this.save();
|
|
48
|
+
}
|
|
49
|
+
}
|
|
50
|
+
exports.LocalStorageService = LocalStorageService;
|
|
51
|
+
//# sourceMappingURL=local-storage.service.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"local-storage.service.js","sourceRoot":"","sources":["../../src/service/local-storage.service.ts"],"names":[],"mappings":";;;AAAA,8CAA8C;AAC9C,kFAA0E;AAE1E,MAAa,mBAAmB;IAIrB,YAAY,CAAC,EAAU;QAC1B,IAAI,CAAC,UAAU,CAAC,SAAS,GAAG,EAAE,CAAC;QAC/B,IAAI,CAAC,IAAI,EAAE,CAAC;IAChB,CAAC;IAED,IAAW,SAAS;QAChB,OAAO,IAAI,CAAC,UAAU,CAAC,SAAS,CAAC;IACrC,CAAC;IAEM,gBAAgB,CAAC,EAAU;QAC9B,IAAI,CAAC,UAAU,CAAC,aAAa,GAAG,EAAE,CAAC;QACnC,IAAI,CAAC,IAAI,EAAE,CAAC;IAChB,CAAC;IAED,IAAW,aAAa;QACpB,OAAO,IAAI,CAAC,UAAU,CAAC,aAAa,CAAC;IACzC,CAAC;IAEM,cAAc,CAAC,KAAa;QAC/B,IAAI,CAAC,UAAU,CAAC,KAAK,GAAG,KAAK,CAAC;QAC9B,IAAI,CAAC,IAAI,EAAE,CAAC;IAChB,CAAC;IAED,IAAW,WAAW;QAClB,OAAO,IAAI,CAAC,UAAU,CAAC,KAAK,CAAC;IACjC,CAAC;IAEM,gBAAgB,CAAC,aAAqB;QACzC,IAAI,CAAC,UAAU,CAAC,aAAa,GAAG,aAAa,CAAC;QAC9C,IAAI,CAAC,IAAI,EAAE,CAAC;IAChB,CAAC;IAED,IAAW,aAAa;QACpB,OAAO,IAAI,CAAC,UAAU,CAAC,aAAa,CAAC;IACzC,CAAC;IAKD;QAzCgB,YAAO,GAAY,YAAY,CAAC;QAsCtC,eAAU,GAA2B,IAAI,kDAAsB,EAAE,CAAC;QAClE,YAAO,GAAW,GAAG,CAAC;QAG5B,IAAI,CAAC,oBAAoB,EAAE,CAAC;IAChC,CAAC;IAEM,IAAI;QACP,IAAI,CAAC,OAAO,CAAC,OAAO,CAAC,IAAI,CAAC,OAAO,EAAE,YAAY,CAAC,SAAS,CAAC,IAAI,CAAC,UAAU,CAAC,CAAC,CAAC;IAChF,CAAC;IAES,oBAAoB;QAC1B,IAAI,CAAC,OAAO,GAAG,MAAM,CAAC,QAAQ,CAAC,QAAQ,CAAC;QACxC,IAAI,CAAC,UAAU,GAAG,YAAY,CAAC,KAAK,CAAC,IAAI,CAAC,OAAO,CAAC,OAAO,CAAC,IAAI,CAAC,OAAO,CAAC,CAAC,IAAI,IAAI,CAAC,UAAU,CAAC;QAC5F,IAAI,CAAC,IAAI,EAAE,CAAC;IAChB,CAAC;CAEJ;AAzDD,kDAyDC"}
|
|
@@ -1,7 +1,8 @@
|
|
|
1
|
-
import { BaseBackendConnectionService } from
|
|
2
|
-
import { ServerResponseData } from
|
|
3
|
-
import { LoginResponse } from
|
|
1
|
+
import { BaseBackendConnectionService } from '../provider/base-backend-connection.service';
|
|
2
|
+
import { ServerResponseData } from '../model/server-response-data';
|
|
3
|
+
import { LoginResponse } from '../model/login-response';
|
|
4
4
|
import { LoginRequest } from '../model/login-request';
|
|
5
|
+
import { TokenResponse } from '../model/token-response.bo';
|
|
5
6
|
export declare class LoginService {
|
|
6
7
|
private static HEARTBEAT_INTERVAL_MS;
|
|
7
8
|
protected heartbeatTimer: any;
|
|
@@ -9,18 +10,18 @@ export declare class LoginService {
|
|
|
9
10
|
protected windowsSessionId: number;
|
|
10
11
|
protected loginRequest: LoginRequest;
|
|
11
12
|
private _encryptionService;
|
|
13
|
+
private _healthService;
|
|
12
14
|
private _useEncryption;
|
|
13
15
|
private _publicService;
|
|
14
16
|
private _datasessionService;
|
|
15
17
|
private _boFactory;
|
|
16
|
-
private _creatingDataSession;
|
|
17
|
-
private _dataSessionCreated;
|
|
18
18
|
constructor(backendConnection: BaseBackendConnectionService);
|
|
19
19
|
getPublicKey(): Promise<string>;
|
|
20
20
|
loginAndCreateDataSession(): Promise<boolean>;
|
|
21
|
-
waitForLoginToFinish(): Promise<boolean>;
|
|
22
21
|
logout(): Promise<ServerResponseData>;
|
|
23
22
|
login(request?: LoginRequest, encrypt?: boolean): Promise<LoginResponse>;
|
|
23
|
+
loginByKeycloakCode(code: string, uri: string): Promise<LoginResponse>;
|
|
24
|
+
refreshAccessToken(refreshToken: string): Promise<TokenResponse>;
|
|
24
25
|
confirmCode(upId: number, userName: string, confirmationCode: string, clientDeviceFingerprint: string, clientDeviceDescription: string, rememberClientDeviceForMFA: boolean): Promise<ServerResponseData>;
|
|
25
26
|
resetGoogleAuth(upId: number, userName: string): Promise<ServerResponseData>;
|
|
26
27
|
changePassword(password: string, securityCode: string, upId: number): Promise<ServerResponseData>;
|
|
@@ -31,5 +32,6 @@ export declare class LoginService {
|
|
|
31
32
|
private _stopHeartBeat;
|
|
32
33
|
private _checkEncryption;
|
|
33
34
|
private _callLogin;
|
|
35
|
+
private _loginUserByLoginCode;
|
|
34
36
|
private _call;
|
|
35
37
|
}
|