@progalaxyelabs/ngx-stonescriptphp-client 1.0.0 → 1.0.4
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/HLD.md +31 -0
- package/LICENSE +21 -0
- package/README.md +89 -2
- package/dist/ngx-stonescriptphp-client/README.md +186 -0
- package/{fesm2022 → dist/ngx-stonescriptphp-client/fesm2022}/progalaxyelabs-ngx-stonescriptphp-client.mjs +28 -28
- package/{fesm2022 → dist/ngx-stonescriptphp-client/fesm2022}/progalaxyelabs-ngx-stonescriptphp-client.mjs.map +1 -1
- package/dist/ngx-stonescriptphp-client/index.d.ts +184 -0
- package/docs/AUTH_COMPATIBILITY.md +310 -0
- package/docs/CHANGELOG.md +261 -0
- package/package.json +75 -18
- package/esm2022/lib/api-connection.service.mjs +0 -304
- package/esm2022/lib/api-response.model.mjs +0 -44
- package/esm2022/lib/auth.service.mjs +0 -14
- package/esm2022/lib/csrf.service.mjs +0 -46
- package/esm2022/lib/db.service.mjs +0 -14
- package/esm2022/lib/my-environment.model.mjs +0 -31
- package/esm2022/lib/ngx-stonescriptphp-client/ngx-stonescriptphp-client.module.mjs +0 -27
- package/esm2022/lib/signin-status.service.mjs +0 -23
- package/esm2022/lib/token.service.mjs +0 -63
- package/esm2022/progalaxyelabs-ngx-stonescriptphp-client.mjs +0 -5
- package/esm2022/public-api.mjs +0 -13
- package/index.d.ts +0 -5
- package/lib/api-connection.service.d.ts +0 -37
- package/lib/api-response.model.d.ts +0 -15
- package/lib/auth.service.d.ts +0 -6
- package/lib/csrf.service.d.ts +0 -24
- package/lib/db.service.d.ts +0 -6
- package/lib/my-environment.model.d.ts +0 -60
- package/lib/ngx-stonescriptphp-client/ngx-stonescriptphp-client.module.d.ts +0 -10
- package/lib/signin-status.service.d.ts +0 -10
- package/lib/token.service.d.ts +0 -16
- package/public-api.d.ts +0 -9
|
@@ -1,304 +0,0 @@
|
|
|
1
|
-
import { Injectable } from '@angular/core';
|
|
2
|
-
import { ApiResponse } from './api-response.model';
|
|
3
|
-
import * as i0 from "@angular/core";
|
|
4
|
-
import * as i1 from "./token.service";
|
|
5
|
-
import * as i2 from "./signin-status.service";
|
|
6
|
-
import * as i3 from "./my-environment.model";
|
|
7
|
-
import * as i4 from "./csrf.service";
|
|
8
|
-
export class ApiConnectionService {
|
|
9
|
-
constructor(tokens, signinStatus, environment, csrf) {
|
|
10
|
-
this.tokens = tokens;
|
|
11
|
-
this.signinStatus = signinStatus;
|
|
12
|
-
this.environment = environment;
|
|
13
|
-
this.csrf = csrf;
|
|
14
|
-
this.host = ''; // contains trailing slash
|
|
15
|
-
this.accessToken = '';
|
|
16
|
-
this.host = environment.apiServer.host;
|
|
17
|
-
// Set default auth config based on mode
|
|
18
|
-
this.authConfig = {
|
|
19
|
-
mode: environment.auth?.mode || 'cookie',
|
|
20
|
-
refreshEndpoint: environment.auth?.refreshEndpoint,
|
|
21
|
-
useCsrf: environment.auth?.useCsrf,
|
|
22
|
-
refreshTokenCookieName: environment.auth?.refreshTokenCookieName || 'refresh_token',
|
|
23
|
-
csrfTokenCookieName: environment.auth?.csrfTokenCookieName || 'csrf_token',
|
|
24
|
-
csrfHeaderName: environment.auth?.csrfHeaderName || 'X-CSRF-Token'
|
|
25
|
-
};
|
|
26
|
-
// Set default refresh endpoint based on mode if not specified
|
|
27
|
-
if (!this.authConfig.refreshEndpoint) {
|
|
28
|
-
this.authConfig.refreshEndpoint = this.authConfig.mode === 'cookie'
|
|
29
|
-
? '/auth/refresh'
|
|
30
|
-
: '/user/refresh_access';
|
|
31
|
-
}
|
|
32
|
-
// Set default CSRF setting based on mode if not specified
|
|
33
|
-
if (this.authConfig.useCsrf === undefined) {
|
|
34
|
-
this.authConfig.useCsrf = this.authConfig.mode === 'cookie';
|
|
35
|
-
}
|
|
36
|
-
}
|
|
37
|
-
async request(url, options, data) {
|
|
38
|
-
try {
|
|
39
|
-
if (data !== null) {
|
|
40
|
-
const body = JSON.stringify(data);
|
|
41
|
-
if (body) {
|
|
42
|
-
options.body = body;
|
|
43
|
-
}
|
|
44
|
-
else {
|
|
45
|
-
options.body = {};
|
|
46
|
-
}
|
|
47
|
-
}
|
|
48
|
-
const accessTokenIncluded = this.includeAccessToken(options);
|
|
49
|
-
let response = await fetch(url, options);
|
|
50
|
-
if ((response.status === 401) && accessTokenIncluded) {
|
|
51
|
-
response = await this.refreshAccessTokenAndRetry(url, options, response);
|
|
52
|
-
}
|
|
53
|
-
if (response.ok) {
|
|
54
|
-
const json = await (response.json());
|
|
55
|
-
return (new ApiResponse(json.status, json.data, json.message));
|
|
56
|
-
}
|
|
57
|
-
if (response.status === 401) {
|
|
58
|
-
this.signinStatus.signedOut();
|
|
59
|
-
}
|
|
60
|
-
return this.handleError(response);
|
|
61
|
-
}
|
|
62
|
-
catch (error) {
|
|
63
|
-
return this.handleError(error);
|
|
64
|
-
}
|
|
65
|
-
}
|
|
66
|
-
handleError(error) {
|
|
67
|
-
console.error(`Backend returned code ${error.status}, ` +
|
|
68
|
-
`full error: `, error);
|
|
69
|
-
return new ApiResponse('error');
|
|
70
|
-
}
|
|
71
|
-
async get(endpoint, queryParamsObj) {
|
|
72
|
-
const url = this.host + endpoint.replace(/^\/+/, '') + this.buildQueryString(queryParamsObj);
|
|
73
|
-
const fetchOptions = {
|
|
74
|
-
mode: 'cors',
|
|
75
|
-
redirect: 'error'
|
|
76
|
-
};
|
|
77
|
-
return this.request(url, fetchOptions, null);
|
|
78
|
-
}
|
|
79
|
-
async post(pathWithQueryParams, data) {
|
|
80
|
-
const url = this.host + pathWithQueryParams.replace(/^\/+/, '');
|
|
81
|
-
const fetchOptions = {
|
|
82
|
-
method: 'POST',
|
|
83
|
-
mode: 'cors',
|
|
84
|
-
redirect: 'error',
|
|
85
|
-
headers: {
|
|
86
|
-
'Content-Type': 'application/json'
|
|
87
|
-
},
|
|
88
|
-
body: JSON.stringify(data)
|
|
89
|
-
};
|
|
90
|
-
return this.request(url, fetchOptions, data);
|
|
91
|
-
}
|
|
92
|
-
async put(pathWithQueryParams, data) {
|
|
93
|
-
const url = this.host + pathWithQueryParams.replace(/^\/+/, '');
|
|
94
|
-
const fetchOptions = {
|
|
95
|
-
method: 'PUT',
|
|
96
|
-
mode: 'cors',
|
|
97
|
-
redirect: 'error',
|
|
98
|
-
headers: {
|
|
99
|
-
'Content-Type': 'application/json'
|
|
100
|
-
},
|
|
101
|
-
body: JSON.stringify(data)
|
|
102
|
-
};
|
|
103
|
-
return this.request(url, fetchOptions, data);
|
|
104
|
-
}
|
|
105
|
-
async patch(pathWithQueryParams, data) {
|
|
106
|
-
const url = this.host + pathWithQueryParams.replace(/^\/+/, '');
|
|
107
|
-
const fetchOptions = {
|
|
108
|
-
method: 'PATCH',
|
|
109
|
-
mode: 'cors',
|
|
110
|
-
redirect: 'error',
|
|
111
|
-
headers: {
|
|
112
|
-
'Content-Type': 'application/json'
|
|
113
|
-
},
|
|
114
|
-
body: JSON.stringify(data)
|
|
115
|
-
};
|
|
116
|
-
return this.request(url, fetchOptions, data);
|
|
117
|
-
}
|
|
118
|
-
async delete(endpoint, queryParamsObj) {
|
|
119
|
-
const url = this.host + endpoint.replace(/^\/+/, '') + this.buildQueryString(queryParamsObj);
|
|
120
|
-
const fetchOptions = {
|
|
121
|
-
method: 'DELETE',
|
|
122
|
-
mode: 'cors',
|
|
123
|
-
redirect: 'error'
|
|
124
|
-
};
|
|
125
|
-
return this.request(url, fetchOptions, null);
|
|
126
|
-
}
|
|
127
|
-
// async postFormWithFiles(pathWithQueryParams: string, formData: FormData): Promise<ApiResponse | null> {
|
|
128
|
-
// const url = this.host + pathWithQueryParams.replace(/^\/+/, '')
|
|
129
|
-
// try {
|
|
130
|
-
// const fetchOptions: RequestInit = {
|
|
131
|
-
// method: 'POST',
|
|
132
|
-
// mode: 'cors',
|
|
133
|
-
// redirect: 'error',
|
|
134
|
-
// body: formData
|
|
135
|
-
// }
|
|
136
|
-
// const accessTokenIncluded = this.includeAccessToken(fetchOptions)
|
|
137
|
-
// let response: Response = await fetch(url, fetchOptions)
|
|
138
|
-
// if ((response.status === 401) && accessTokenIncluded) {
|
|
139
|
-
// response = await this.refreshAccessTokenAndRetry(url, fetchOptions, response)
|
|
140
|
-
// }
|
|
141
|
-
// if (response.ok) {
|
|
142
|
-
// return ((await (response.json()) as ApiResponse))
|
|
143
|
-
// }
|
|
144
|
-
// return this.handleError(response)
|
|
145
|
-
// } catch (error) {
|
|
146
|
-
// return this.handleError(error)
|
|
147
|
-
// }
|
|
148
|
-
// }
|
|
149
|
-
includeAccessToken(options) {
|
|
150
|
-
this.accessToken = this.tokens.getAccessToken();
|
|
151
|
-
if (!this.accessToken) {
|
|
152
|
-
return false;
|
|
153
|
-
}
|
|
154
|
-
if (!options.headers) {
|
|
155
|
-
options.headers = {};
|
|
156
|
-
}
|
|
157
|
-
options.headers['Authorization'] = 'Bearer ' + this.accessToken;
|
|
158
|
-
return true;
|
|
159
|
-
}
|
|
160
|
-
async refreshAccessTokenAndRetry(url, fetchOptions, response) {
|
|
161
|
-
const refreshStatusOk = await this.refreshAccessToken();
|
|
162
|
-
if (!refreshStatusOk) {
|
|
163
|
-
return response;
|
|
164
|
-
}
|
|
165
|
-
fetchOptions.headers['Authorization'] = 'Bearer ' + this.accessToken;
|
|
166
|
-
response = await fetch(url, fetchOptions);
|
|
167
|
-
return response;
|
|
168
|
-
}
|
|
169
|
-
async refreshAccessToken() {
|
|
170
|
-
if (this.authConfig.mode === 'none') {
|
|
171
|
-
return false;
|
|
172
|
-
}
|
|
173
|
-
if (this.authConfig.mode === 'cookie') {
|
|
174
|
-
return await this.refreshAccessTokenCookieMode();
|
|
175
|
-
}
|
|
176
|
-
else {
|
|
177
|
-
return await this.refreshAccessTokenBodyMode();
|
|
178
|
-
}
|
|
179
|
-
}
|
|
180
|
-
/**
|
|
181
|
-
* Refresh access token using cookie-based auth (StoneScriptPHP v2.1.x default)
|
|
182
|
-
*/
|
|
183
|
-
async refreshAccessTokenCookieMode() {
|
|
184
|
-
try {
|
|
185
|
-
const refreshTokenUrl = this.host + this.authConfig.refreshEndpoint.replace(/^\/+/, '');
|
|
186
|
-
const headers = {
|
|
187
|
-
'Content-Type': 'application/json'
|
|
188
|
-
};
|
|
189
|
-
// Add CSRF token if enabled
|
|
190
|
-
if (this.authConfig.useCsrf) {
|
|
191
|
-
const csrfToken = this.csrf.getCsrfToken(this.authConfig.csrfTokenCookieName);
|
|
192
|
-
if (!csrfToken) {
|
|
193
|
-
console.error('CSRF token not found in cookie');
|
|
194
|
-
return false;
|
|
195
|
-
}
|
|
196
|
-
headers[this.authConfig.csrfHeaderName] = csrfToken;
|
|
197
|
-
}
|
|
198
|
-
let refreshTokenResponse = await fetch(refreshTokenUrl, {
|
|
199
|
-
method: 'POST',
|
|
200
|
-
mode: 'cors',
|
|
201
|
-
credentials: 'include',
|
|
202
|
-
redirect: 'error',
|
|
203
|
-
headers: headers
|
|
204
|
-
});
|
|
205
|
-
if (!refreshTokenResponse.ok) {
|
|
206
|
-
this.accessToken = '';
|
|
207
|
-
this.tokens.clear();
|
|
208
|
-
return false;
|
|
209
|
-
}
|
|
210
|
-
let refreshAccessData = await refreshTokenResponse.json();
|
|
211
|
-
if (!refreshAccessData || refreshAccessData.status !== 'ok') {
|
|
212
|
-
return false;
|
|
213
|
-
}
|
|
214
|
-
// Extract access token from response
|
|
215
|
-
const newAccessToken = refreshAccessData.data?.access_token || refreshAccessData.access_token;
|
|
216
|
-
if (!newAccessToken) {
|
|
217
|
-
console.error('No access token in refresh response');
|
|
218
|
-
return false;
|
|
219
|
-
}
|
|
220
|
-
// Store new access token (refresh token is in httpOnly cookie)
|
|
221
|
-
this.tokens.setAccessToken(newAccessToken);
|
|
222
|
-
this.accessToken = newAccessToken;
|
|
223
|
-
return true;
|
|
224
|
-
}
|
|
225
|
-
catch (error) {
|
|
226
|
-
console.error('Token refresh failed (cookie mode):', error);
|
|
227
|
-
this.accessToken = '';
|
|
228
|
-
this.tokens.clear();
|
|
229
|
-
return false;
|
|
230
|
-
}
|
|
231
|
-
}
|
|
232
|
-
/**
|
|
233
|
-
* Refresh access token using body-based auth (legacy mode)
|
|
234
|
-
*/
|
|
235
|
-
async refreshAccessTokenBodyMode() {
|
|
236
|
-
try {
|
|
237
|
-
const refreshToken = this.tokens.getRefreshToken();
|
|
238
|
-
if (!refreshToken) {
|
|
239
|
-
return false;
|
|
240
|
-
}
|
|
241
|
-
const refreshTokenUrl = this.host + this.authConfig.refreshEndpoint.replace(/^\/+/, '');
|
|
242
|
-
let refreshTokenResponse = await fetch(refreshTokenUrl, {
|
|
243
|
-
method: 'POST',
|
|
244
|
-
mode: 'cors',
|
|
245
|
-
redirect: 'error',
|
|
246
|
-
headers: {
|
|
247
|
-
'Content-Type': 'application/json'
|
|
248
|
-
},
|
|
249
|
-
body: JSON.stringify({
|
|
250
|
-
access_token: this.accessToken,
|
|
251
|
-
refresh_token: refreshToken
|
|
252
|
-
})
|
|
253
|
-
});
|
|
254
|
-
if (!refreshTokenResponse.ok) {
|
|
255
|
-
this.accessToken = '';
|
|
256
|
-
this.tokens.clear();
|
|
257
|
-
return false;
|
|
258
|
-
}
|
|
259
|
-
let refreshAccessData = await refreshTokenResponse.json();
|
|
260
|
-
if (!refreshAccessData) {
|
|
261
|
-
return false;
|
|
262
|
-
}
|
|
263
|
-
const newAccessToken = refreshAccessData.data?.access_token || refreshAccessData.access_token;
|
|
264
|
-
if (!newAccessToken) {
|
|
265
|
-
console.error('No access token in refresh response');
|
|
266
|
-
return false;
|
|
267
|
-
}
|
|
268
|
-
this.tokens.setTokens(newAccessToken, refreshToken);
|
|
269
|
-
this.accessToken = newAccessToken;
|
|
270
|
-
return true;
|
|
271
|
-
}
|
|
272
|
-
catch (error) {
|
|
273
|
-
console.error('Token refresh failed (body mode):', error);
|
|
274
|
-
this.accessToken = '';
|
|
275
|
-
this.tokens.clear();
|
|
276
|
-
return false;
|
|
277
|
-
}
|
|
278
|
-
}
|
|
279
|
-
buildQueryString(options) {
|
|
280
|
-
if (options === undefined) {
|
|
281
|
-
return '';
|
|
282
|
-
}
|
|
283
|
-
const array = [];
|
|
284
|
-
for (let key in options) {
|
|
285
|
-
if (options.hasOwnProperty(key) && (options[key] !== null) && (options[key] !== undefined)) {
|
|
286
|
-
array.push(encodeURIComponent(key) + "=" + encodeURIComponent(options[key]));
|
|
287
|
-
}
|
|
288
|
-
}
|
|
289
|
-
const str = array.join('&');
|
|
290
|
-
if (str !== '') {
|
|
291
|
-
return '?' + str;
|
|
292
|
-
}
|
|
293
|
-
return '';
|
|
294
|
-
}
|
|
295
|
-
static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "16.2.12", ngImport: i0, type: ApiConnectionService, deps: [{ token: i1.TokenService }, { token: i2.SigninStatusService }, { token: i3.MyEnvironmentModel }, { token: i4.CsrfService }], target: i0.ɵɵFactoryTarget.Injectable }); }
|
|
296
|
-
static { this.ɵprov = i0.ɵɵngDeclareInjectable({ minVersion: "12.0.0", version: "16.2.12", ngImport: i0, type: ApiConnectionService, providedIn: 'root' }); }
|
|
297
|
-
}
|
|
298
|
-
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "16.2.12", ngImport: i0, type: ApiConnectionService, decorators: [{
|
|
299
|
-
type: Injectable,
|
|
300
|
-
args: [{
|
|
301
|
-
providedIn: 'root'
|
|
302
|
-
}]
|
|
303
|
-
}], ctorParameters: function () { return [{ type: i1.TokenService }, { type: i2.SigninStatusService }, { type: i3.MyEnvironmentModel }, { type: i4.CsrfService }]; } });
|
|
304
|
-
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"api-connection.service.js","sourceRoot":"","sources":["../../../../projects/ngx-stonescriptphp-client/src/lib/api-connection.service.ts"],"names":[],"mappings":"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","sourcesContent":["import { Injectable } from '@angular/core';\nimport { TokenService } from './token.service';\nimport { SigninStatusService } from './signin-status.service';\nimport { ApiResponse } from './api-response.model';\nimport { MyEnvironmentModel, AuthConfig } from './my-environment.model';\nimport { CsrfService } from './csrf.service';\n\n@Injectable({\n    providedIn: 'root'\n})\nexport class ApiConnectionService {\n\n    private host = '' // contains trailing slash\n\n    private accessToken = ''\n\n    private authConfig: AuthConfig\n\n    constructor(\n        private tokens: TokenService,\n        private signinStatus: SigninStatusService,\n        private environment: MyEnvironmentModel,\n        private csrf: CsrfService\n    ) {\n        this.host = environment.apiServer.host\n\n        // Set default auth config based on mode\n        this.authConfig = {\n            mode: environment.auth?.mode || 'cookie',\n            refreshEndpoint: environment.auth?.refreshEndpoint,\n            useCsrf: environment.auth?.useCsrf,\n            refreshTokenCookieName: environment.auth?.refreshTokenCookieName || 'refresh_token',\n            csrfTokenCookieName: environment.auth?.csrfTokenCookieName || 'csrf_token',\n            csrfHeaderName: environment.auth?.csrfHeaderName || 'X-CSRF-Token'\n        }\n\n        // Set default refresh endpoint based on mode if not specified\n        if (!this.authConfig.refreshEndpoint) {\n            this.authConfig.refreshEndpoint = this.authConfig.mode === 'cookie'\n                ? '/auth/refresh'\n                : '/user/refresh_access'\n        }\n\n        // Set default CSRF setting based on mode if not specified\n        if (this.authConfig.useCsrf === undefined) {\n            this.authConfig.useCsrf = this.authConfig.mode === 'cookie'\n        }\n    }\n\n\n    private async request<DataType>(url: string, options: any, data: any | null): Promise<ApiResponse<DataType>> {\n        try {\n            \n            if(data !== null) {\n                const body = JSON.stringify(data)\n                if(body) {\n                    options.body = body\n                } else {\n                    options.body = {}\n                }\n            }\n\n            const accessTokenIncluded = this.includeAccessToken(options)\n\n            let response: Response = await fetch(url, options)\n\n            if ((response.status === 401) && accessTokenIncluded) {\n                response = await this.refreshAccessTokenAndRetry(url, options, response)\n            }\n\n            if (response.ok) {\n                const json = await (response.json())\n                return (new ApiResponse<DataType>(json.status, json.data, json.message))\n            }\n\n            if (response.status === 401) {\n                this.signinStatus.signedOut()\n            }\n\n            return this.handleError<DataType>(response)\n        } catch (error) {\n            return this.handleError<DataType>(error)\n        }\n    }\n\n    private handleError<DataType>(error: any): ApiResponse<DataType> {\n        console.error(\n            `Backend returned code ${error.status}, ` +\n            `full error: `, error);\n        return new ApiResponse<DataType>('error')\n    }\n\n    async get<DataType>(endpoint: string, queryParamsObj?: any ): Promise<ApiResponse<DataType>> {\n        const url = this.host + endpoint.replace(/^\\/+/, '') + this.buildQueryString(queryParamsObj)\n        const fetchOptions: RequestInit = {\n            mode: 'cors',\n            redirect: 'error'\n        }\n        return this.request(url, fetchOptions, null)\n    }\n\n    async post<DataType>(pathWithQueryParams: string, data: any): Promise<ApiResponse<DataType>> {\n        const url = this.host + pathWithQueryParams.replace(/^\\/+/, '')\n        const fetchOptions: RequestInit = {\n            method: 'POST',\n            mode: 'cors',\n            redirect: 'error',\n            headers: {\n                'Content-Type': 'application/json'\n            },\n            body: JSON.stringify(data)\n        }\n        return this.request(url, fetchOptions, data)\n    }\n\n    async put<DataType>(pathWithQueryParams: string, data: any): Promise<ApiResponse<DataType>> {\n        const url = this.host + pathWithQueryParams.replace(/^\\/+/, '')\n        const fetchOptions: RequestInit = {\n            method: 'PUT',\n            mode: 'cors',\n            redirect: 'error',\n            headers: {\n                'Content-Type': 'application/json'\n            },\n            body: JSON.stringify(data)\n        }\n        return this.request(url, fetchOptions, data)\n    }\n\n    async patch<DataType>(pathWithQueryParams: string, data: any): Promise<ApiResponse<DataType>> {\n        const url = this.host + pathWithQueryParams.replace(/^\\/+/, '')\n        const fetchOptions: RequestInit = {\n            method: 'PATCH',\n            mode: 'cors',\n            redirect: 'error',\n            headers: {\n                'Content-Type': 'application/json'\n            },\n            body: JSON.stringify(data)\n        }\n        return this.request(url, fetchOptions, data)\n    }\n\n    async delete<DataType>(endpoint: string, queryParamsObj?: any): Promise<ApiResponse<DataType>> {\n        const url = this.host + endpoint.replace(/^\\/+/, '') + this.buildQueryString(queryParamsObj)\n        const fetchOptions: RequestInit = {\n            method: 'DELETE',\n            mode: 'cors',\n            redirect: 'error'\n        }\n        return this.request(url, fetchOptions, null)\n    }\n\n    // async postFormWithFiles(pathWithQueryParams: string, formData: FormData): Promise<ApiResponse | null> {\n    //     const url = this.host + pathWithQueryParams.replace(/^\\/+/, '')\n    //     try {\n    //         const fetchOptions: RequestInit = {\n    //             method: 'POST',\n    //             mode: 'cors',\n    //             redirect: 'error',\n    //             body: formData\n    //         }\n\n    //         const accessTokenIncluded = this.includeAccessToken(fetchOptions)\n\n    //         let response: Response = await fetch(url, fetchOptions)\n\n    //         if ((response.status === 401) && accessTokenIncluded) {\n    //             response = await this.refreshAccessTokenAndRetry(url, fetchOptions, response)\n    //         }\n\n    //         if (response.ok) {\n    //             return ((await (response.json()) as ApiResponse))\n    //         }\n\n    //         return this.handleError(response)\n    //     } catch (error) {\n    //         return this.handleError(error)\n    //     }\n    // }\n\n    private includeAccessToken(options: any): boolean {\n        this.accessToken = this.tokens.getAccessToken()\n        if (!this.accessToken) {\n            return false\n        }\n\n        if (!options.headers) {\n            options.headers = {}\n        }\n        options.headers['Authorization'] = 'Bearer ' + this.accessToken\n        return true\n    }\n\n    private async refreshAccessTokenAndRetry(url: string, fetchOptions: any, response: Response): Promise<Response> {\n\n        const refreshStatusOk = await this.refreshAccessToken()\n        if (!refreshStatusOk) {\n            return response\n        }\n\n        fetchOptions.headers['Authorization'] = 'Bearer ' + this.accessToken\n        response = await fetch(url, fetchOptions)\n        return response\n    }\n\n    async refreshAccessToken(): Promise<boolean> {\n        if (this.authConfig.mode === 'none') {\n            return false\n        }\n\n        if (this.authConfig.mode === 'cookie') {\n            return await this.refreshAccessTokenCookieMode()\n        } else {\n            return await this.refreshAccessTokenBodyMode()\n        }\n    }\n\n    /**\n     * Refresh access token using cookie-based auth (StoneScriptPHP v2.1.x default)\n     */\n    private async refreshAccessTokenCookieMode(): Promise<boolean> {\n        try {\n            const refreshTokenUrl = this.host + this.authConfig.refreshEndpoint!.replace(/^\\/+/, '')\n            const headers: any = {\n                'Content-Type': 'application/json'\n            }\n\n            // Add CSRF token if enabled\n            if (this.authConfig.useCsrf) {\n                const csrfToken = this.csrf.getCsrfToken(this.authConfig.csrfTokenCookieName!)\n                if (!csrfToken) {\n                    console.error('CSRF token not found in cookie')\n                    return false\n                }\n                headers[this.authConfig.csrfHeaderName!] = csrfToken\n            }\n\n            let refreshTokenResponse = await fetch(refreshTokenUrl, {\n                method: 'POST',\n                mode: 'cors',\n                credentials: 'include', // Important: send cookies\n                redirect: 'error',\n                headers: headers\n            })\n\n            if (!refreshTokenResponse.ok) {\n                this.accessToken = ''\n                this.tokens.clear()\n                return false\n            }\n\n            let refreshAccessData = await refreshTokenResponse.json()\n            if (!refreshAccessData || refreshAccessData.status !== 'ok') {\n                return false\n            }\n\n            // Extract access token from response\n            const newAccessToken = refreshAccessData.data?.access_token || refreshAccessData.access_token\n            if (!newAccessToken) {\n                console.error('No access token in refresh response')\n                return false\n            }\n\n            // Store new access token (refresh token is in httpOnly cookie)\n            this.tokens.setAccessToken(newAccessToken)\n            this.accessToken = newAccessToken\n\n            return true\n        } catch (error) {\n            console.error('Token refresh failed (cookie mode):', error)\n            this.accessToken = ''\n            this.tokens.clear()\n            return false\n        }\n    }\n\n    /**\n     * Refresh access token using body-based auth (legacy mode)\n     */\n    private async refreshAccessTokenBodyMode(): Promise<boolean> {\n        try {\n            const refreshToken = this.tokens.getRefreshToken()\n            if (!refreshToken) {\n                return false\n            }\n\n            const refreshTokenUrl = this.host + this.authConfig.refreshEndpoint!.replace(/^\\/+/, '')\n            let refreshTokenResponse = await fetch(refreshTokenUrl, {\n                method: 'POST',\n                mode: 'cors',\n                redirect: 'error',\n                headers: {\n                    'Content-Type': 'application/json'\n                },\n                body: JSON.stringify({\n                    access_token: this.accessToken,\n                    refresh_token: refreshToken\n                })\n            })\n\n            if (!refreshTokenResponse.ok) {\n                this.accessToken = ''\n                this.tokens.clear()\n                return false\n            }\n\n            let refreshAccessData = await refreshTokenResponse.json()\n            if (!refreshAccessData) {\n                return false\n            }\n\n            const newAccessToken = refreshAccessData.data?.access_token || refreshAccessData.access_token\n            if (!newAccessToken) {\n                console.error('No access token in refresh response')\n                return false\n            }\n\n            this.tokens.setTokens(newAccessToken, refreshToken)\n            this.accessToken = newAccessToken\n\n            return true\n        } catch (error) {\n            console.error('Token refresh failed (body mode):', error)\n            this.accessToken = ''\n            this.tokens.clear()\n            return false\n        }\n    }\n\n    buildQueryString(options?: any): string {\n        if (options === undefined) {\n            return ''\n        }\n\n        const array = []\n        for (let key in options) {\n            if (options.hasOwnProperty(key) && (options[key] !== null) && (options[key] !== undefined)) {\n                array.push(encodeURIComponent(key) + \"=\" + encodeURIComponent(options[key]))\n            }\n        }\n        const str = array.join('&')\n        if (str !== '') {\n            return '?' + str\n        }\n\n        return ''\n    }\n}\n"]}
|
|
@@ -1,44 +0,0 @@
|
|
|
1
|
-
export class ApiResponse {
|
|
2
|
-
constructor(status, data = {}, message = '') {
|
|
3
|
-
this.status = status;
|
|
4
|
-
this.data = data;
|
|
5
|
-
this.message = message;
|
|
6
|
-
}
|
|
7
|
-
onOk(callback) {
|
|
8
|
-
if (this.status === 'ok') {
|
|
9
|
-
callback(this.data);
|
|
10
|
-
}
|
|
11
|
-
return this;
|
|
12
|
-
}
|
|
13
|
-
onNotOk(callback) {
|
|
14
|
-
if (this.status === 'not ok') {
|
|
15
|
-
callback(this.message, this.data);
|
|
16
|
-
}
|
|
17
|
-
return this;
|
|
18
|
-
}
|
|
19
|
-
onError(callback) {
|
|
20
|
-
if (this.status === 'error') {
|
|
21
|
-
callback();
|
|
22
|
-
}
|
|
23
|
-
return this;
|
|
24
|
-
}
|
|
25
|
-
isSuccess() {
|
|
26
|
-
return this.status === 'ok';
|
|
27
|
-
}
|
|
28
|
-
isError() {
|
|
29
|
-
return this.status === 'error' || this.status === 'not ok';
|
|
30
|
-
}
|
|
31
|
-
getData() {
|
|
32
|
-
return this.data || null;
|
|
33
|
-
}
|
|
34
|
-
getError() {
|
|
35
|
-
return this.message || 'Unknown error';
|
|
36
|
-
}
|
|
37
|
-
getStatus() {
|
|
38
|
-
return this.status;
|
|
39
|
-
}
|
|
40
|
-
getMessage() {
|
|
41
|
-
return this.message;
|
|
42
|
-
}
|
|
43
|
-
}
|
|
44
|
-
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiYXBpLXJlc3BvbnNlLm1vZGVsLmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vLi4vLi4vLi4vcHJvamVjdHMvbmd4LXN0b25lc2NyaXB0cGhwLWNsaWVudC9zcmMvbGliL2FwaS1yZXNwb25zZS5tb2RlbC50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFBQSxNQUFNLE9BQU8sV0FBVztJQUtwQixZQUFZLE1BQWMsRUFBRSxPQUFZLEVBQUUsRUFBRSxVQUFrQixFQUFFO1FBQzVELElBQUksQ0FBQyxNQUFNLEdBQUcsTUFBTSxDQUFBO1FBQ3BCLElBQUksQ0FBQyxJQUFJLEdBQUcsSUFBSSxDQUFBO1FBQ2hCLElBQUksQ0FBQyxPQUFPLEdBQUcsT0FBTyxDQUFBO0lBQzFCLENBQUM7SUFFRCxJQUFJLENBQUMsUUFBa0M7UUFDbkMsSUFBSSxJQUFJLENBQUMsTUFBTSxLQUFLLElBQUksRUFBRTtZQUN0QixRQUFRLENBQUMsSUFBSSxDQUFDLElBQUksQ0FBQyxDQUFBO1NBQ3RCO1FBQ0QsT0FBTyxJQUFJLENBQUE7SUFDZixDQUFDO0lBRUQsT0FBTyxDQUFDLFFBQW1EO1FBQ3ZELElBQUksSUFBSSxDQUFDLE1BQU0sS0FBSyxRQUFRLEVBQUU7WUFDMUIsUUFBUSxDQUFDLElBQUksQ0FBQyxPQUFPLEVBQUUsSUFBSSxDQUFDLElBQUksQ0FBQyxDQUFBO1NBQ3BDO1FBQ0QsT0FBTyxJQUFJLENBQUE7SUFDZixDQUFDO0lBRUQsT0FBTyxDQUFDLFFBQW9CO1FBQ3hCLElBQUksSUFBSSxDQUFDLE1BQU0sS0FBSyxPQUFPLEVBQUU7WUFDekIsUUFBUSxFQUFFLENBQUE7U0FDYjtRQUNELE9BQU8sSUFBSSxDQUFBO0lBQ2YsQ0FBQztJQUVELFNBQVM7UUFDTCxPQUFPLElBQUksQ0FBQyxNQUFNLEtBQUssSUFBSSxDQUFBO0lBQy9CLENBQUM7SUFFRCxPQUFPO1FBQ0gsT0FBTyxJQUFJLENBQUMsTUFBTSxLQUFLLE9BQU8sSUFBSSxJQUFJLENBQUMsTUFBTSxLQUFLLFFBQVEsQ0FBQTtJQUM5RCxDQUFDO0lBRUQsT0FBTztRQUNILE9BQU8sSUFBSSxDQUFDLElBQUksSUFBSSxJQUFJLENBQUE7SUFDNUIsQ0FBQztJQUVELFFBQVE7UUFDSixPQUFPLElBQUksQ0FBQyxPQUFPLElBQUksZUFBZSxDQUFBO0lBQzFDLENBQUM7SUFFRCxTQUFTO1FBQ0wsT0FBTyxJQUFJLENBQUMsTUFBTSxDQUFBO0lBQ3RCLENBQUM7SUFFRCxVQUFVO1FBQ04sT0FBTyxJQUFJLENBQUMsT0FBTyxDQUFBO0lBQ3ZCLENBQUM7Q0FDSiIsInNvdXJjZXNDb250ZW50IjpbImV4cG9ydCBjbGFzcyBBcGlSZXNwb25zZTxEYXRhVHlwZT4ge1xuICAgIHByaXZhdGUgc3RhdHVzOiBzdHJpbmdcbiAgICBwcml2YXRlIGRhdGE6IGFueVxuICAgIHByaXZhdGUgbWVzc2FnZTogc3RyaW5nXG5cbiAgICBjb25zdHJ1Y3RvcihzdGF0dXM6IHN0cmluZywgZGF0YTogYW55ID0ge30sIG1lc3NhZ2U6IHN0cmluZyA9ICcnKSB7XG4gICAgICAgIHRoaXMuc3RhdHVzID0gc3RhdHVzXG4gICAgICAgIHRoaXMuZGF0YSA9IGRhdGFcbiAgICAgICAgdGhpcy5tZXNzYWdlID0gbWVzc2FnZVxuICAgIH1cblxuICAgIG9uT2soY2FsbGJhY2s6IChkYXRhOiBEYXRhVHlwZSkgPT4gdm9pZCk6IEFwaVJlc3BvbnNlPERhdGFUeXBlPiB7XG4gICAgICAgIGlmICh0aGlzLnN0YXR1cyA9PT0gJ29rJykge1xuICAgICAgICAgICAgY2FsbGJhY2sodGhpcy5kYXRhKVxuICAgICAgICB9XG4gICAgICAgIHJldHVybiB0aGlzXG4gICAgfVxuXG4gICAgb25Ob3RPayhjYWxsYmFjazogKG1lc3NhZ2U6IHN0cmluZywgZGF0YTogRGF0YVR5cGUpID0+IHZvaWQpOiBBcGlSZXNwb25zZTxEYXRhVHlwZT4ge1xuICAgICAgICBpZiAodGhpcy5zdGF0dXMgPT09ICdub3Qgb2snKSB7XG4gICAgICAgICAgICBjYWxsYmFjayh0aGlzLm1lc3NhZ2UsIHRoaXMuZGF0YSlcbiAgICAgICAgfVxuICAgICAgICByZXR1cm4gdGhpc1xuICAgIH1cblxuICAgIG9uRXJyb3IoY2FsbGJhY2s6ICgpID0+IHZvaWQpOiBBcGlSZXNwb25zZTxEYXRhVHlwZT4ge1xuICAgICAgICBpZiAodGhpcy5zdGF0dXMgPT09ICdlcnJvcicpIHtcbiAgICAgICAgICAgIGNhbGxiYWNrKClcbiAgICAgICAgfVxuICAgICAgICByZXR1cm4gdGhpc1xuICAgIH1cblxuICAgIGlzU3VjY2VzcygpOiBib29sZWFuIHtcbiAgICAgICAgcmV0dXJuIHRoaXMuc3RhdHVzID09PSAnb2snXG4gICAgfVxuXG4gICAgaXNFcnJvcigpOiBib29sZWFuIHtcbiAgICAgICAgcmV0dXJuIHRoaXMuc3RhdHVzID09PSAnZXJyb3InIHx8IHRoaXMuc3RhdHVzID09PSAnbm90IG9rJ1xuICAgIH1cblxuICAgIGdldERhdGEoKTogRGF0YVR5cGUgfCBudWxsIHtcbiAgICAgICAgcmV0dXJuIHRoaXMuZGF0YSB8fCBudWxsXG4gICAgfVxuXG4gICAgZ2V0RXJyb3IoKTogc3RyaW5nIHtcbiAgICAgICAgcmV0dXJuIHRoaXMubWVzc2FnZSB8fCAnVW5rbm93biBlcnJvcidcbiAgICB9XG5cbiAgICBnZXRTdGF0dXMoKTogc3RyaW5nIHtcbiAgICAgICAgcmV0dXJuIHRoaXMuc3RhdHVzXG4gICAgfVxuXG4gICAgZ2V0TWVzc2FnZSgpOiBzdHJpbmcge1xuICAgICAgICByZXR1cm4gdGhpcy5tZXNzYWdlXG4gICAgfVxufSJdfQ==
|
|
@@ -1,14 +0,0 @@
|
|
|
1
|
-
import { Injectable } from '@angular/core';
|
|
2
|
-
import * as i0 from "@angular/core";
|
|
3
|
-
export class AuthService {
|
|
4
|
-
constructor() { }
|
|
5
|
-
static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "16.2.12", ngImport: i0, type: AuthService, deps: [], target: i0.ɵɵFactoryTarget.Injectable }); }
|
|
6
|
-
static { this.ɵprov = i0.ɵɵngDeclareInjectable({ minVersion: "12.0.0", version: "16.2.12", ngImport: i0, type: AuthService, providedIn: 'root' }); }
|
|
7
|
-
}
|
|
8
|
-
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "16.2.12", ngImport: i0, type: AuthService, decorators: [{
|
|
9
|
-
type: Injectable,
|
|
10
|
-
args: [{
|
|
11
|
-
providedIn: 'root'
|
|
12
|
-
}]
|
|
13
|
-
}], ctorParameters: function () { return []; } });
|
|
14
|
-
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiYXV0aC5zZXJ2aWNlLmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vLi4vLi4vLi4vcHJvamVjdHMvbmd4LXN0b25lc2NyaXB0cGhwLWNsaWVudC9zcmMvbGliL2F1dGguc2VydmljZS50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFBQSxPQUFPLEVBQUUsVUFBVSxFQUFFLE1BQU0sZUFBZSxDQUFDOztBQUszQyxNQUFNLE9BQU8sV0FBVztJQUV0QixnQkFBZ0IsQ0FBQzsrR0FGTixXQUFXO21IQUFYLFdBQVcsY0FGVixNQUFNOzs0RkFFUCxXQUFXO2tCQUh2QixVQUFVO21CQUFDO29CQUNWLFVBQVUsRUFBRSxNQUFNO2lCQUNuQiIsInNvdXJjZXNDb250ZW50IjpbImltcG9ydCB7IEluamVjdGFibGUgfSBmcm9tICdAYW5ndWxhci9jb3JlJztcblxuQEluamVjdGFibGUoe1xuICBwcm92aWRlZEluOiAncm9vdCdcbn0pXG5leHBvcnQgY2xhc3MgQXV0aFNlcnZpY2Uge1xuXG4gIGNvbnN0cnVjdG9yKCkgeyB9XG59XG4iXX0=
|
|
@@ -1,46 +0,0 @@
|
|
|
1
|
-
import { Injectable } from '@angular/core';
|
|
2
|
-
import * as i0 from "@angular/core";
|
|
3
|
-
/**
|
|
4
|
-
* CSRF Token Service
|
|
5
|
-
*
|
|
6
|
-
* Manages CSRF tokens for cookie-based authentication.
|
|
7
|
-
* Reads CSRF token from cookies and provides it for request headers.
|
|
8
|
-
*/
|
|
9
|
-
export class CsrfService {
|
|
10
|
-
/**
|
|
11
|
-
* Get CSRF token from cookie
|
|
12
|
-
*/
|
|
13
|
-
getCsrfToken(cookieName = 'csrf_token') {
|
|
14
|
-
const cookies = document.cookie.split(';');
|
|
15
|
-
for (const cookie of cookies) {
|
|
16
|
-
const [name, value] = cookie.trim().split('=');
|
|
17
|
-
if (name === cookieName) {
|
|
18
|
-
return decodeURIComponent(value);
|
|
19
|
-
}
|
|
20
|
-
}
|
|
21
|
-
return null;
|
|
22
|
-
}
|
|
23
|
-
/**
|
|
24
|
-
* Check if CSRF token exists
|
|
25
|
-
*/
|
|
26
|
-
hasCsrfToken(cookieName = 'csrf_token') {
|
|
27
|
-
return this.getCsrfToken(cookieName) !== null;
|
|
28
|
-
}
|
|
29
|
-
/**
|
|
30
|
-
* Clear CSRF token (for logout)
|
|
31
|
-
* Note: Client-side deletion is limited for httpOnly cookies
|
|
32
|
-
*/
|
|
33
|
-
clearCsrfToken(cookieName = 'csrf_token') {
|
|
34
|
-
// Can only clear non-httpOnly cookies
|
|
35
|
-
document.cookie = `${cookieName}=; expires=Thu, 01 Jan 1970 00:00:00 UTC; path=/;`;
|
|
36
|
-
}
|
|
37
|
-
static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "16.2.12", ngImport: i0, type: CsrfService, deps: [], target: i0.ɵɵFactoryTarget.Injectable }); }
|
|
38
|
-
static { this.ɵprov = i0.ɵɵngDeclareInjectable({ minVersion: "12.0.0", version: "16.2.12", ngImport: i0, type: CsrfService, providedIn: 'root' }); }
|
|
39
|
-
}
|
|
40
|
-
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "16.2.12", ngImport: i0, type: CsrfService, decorators: [{
|
|
41
|
-
type: Injectable,
|
|
42
|
-
args: [{
|
|
43
|
-
providedIn: 'root'
|
|
44
|
-
}]
|
|
45
|
-
}] });
|
|
46
|
-
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiY3NyZi5zZXJ2aWNlLmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vLi4vLi4vLi4vcHJvamVjdHMvbmd4LXN0b25lc2NyaXB0cGhwLWNsaWVudC9zcmMvbGliL2NzcmYuc2VydmljZS50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFBQSxPQUFPLEVBQUUsVUFBVSxFQUFFLE1BQU0sZUFBZSxDQUFDOztBQUUzQzs7Ozs7R0FLRztBQUlILE1BQU0sT0FBTyxXQUFXO0lBRXBCOztPQUVHO0lBQ0gsWUFBWSxDQUFDLGFBQXFCLFlBQVk7UUFDMUMsTUFBTSxPQUFPLEdBQUcsUUFBUSxDQUFDLE1BQU0sQ0FBQyxLQUFLLENBQUMsR0FBRyxDQUFDLENBQUM7UUFDM0MsS0FBSyxNQUFNLE1BQU0sSUFBSSxPQUFPLEVBQUU7WUFDMUIsTUFBTSxDQUFDLElBQUksRUFBRSxLQUFLLENBQUMsR0FBRyxNQUFNLENBQUMsSUFBSSxFQUFFLENBQUMsS0FBSyxDQUFDLEdBQUcsQ0FBQyxDQUFDO1lBQy9DLElBQUksSUFBSSxLQUFLLFVBQVUsRUFBRTtnQkFDckIsT0FBTyxrQkFBa0IsQ0FBQyxLQUFLLENBQUMsQ0FBQzthQUNwQztTQUNKO1FBQ0QsT0FBTyxJQUFJLENBQUM7SUFDaEIsQ0FBQztJQUVEOztPQUVHO0lBQ0gsWUFBWSxDQUFDLGFBQXFCLFlBQVk7UUFDMUMsT0FBTyxJQUFJLENBQUMsWUFBWSxDQUFDLFVBQVUsQ0FBQyxLQUFLLElBQUksQ0FBQztJQUNsRCxDQUFDO0lBRUQ7OztPQUdHO0lBQ0gsY0FBYyxDQUFDLGFBQXFCLFlBQVk7UUFDNUMsc0NBQXNDO1FBQ3RDLFFBQVEsQ0FBQyxNQUFNLEdBQUcsR0FBRyxVQUFVLG1EQUFtRCxDQUFDO0lBQ3ZGLENBQUM7K0dBOUJRLFdBQVc7bUhBQVgsV0FBVyxjQUZSLE1BQU07OzRGQUVULFdBQVc7a0JBSHZCLFVBQVU7bUJBQUM7b0JBQ1IsVUFBVSxFQUFFLE1BQU07aUJBQ3JCIiwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IHsgSW5qZWN0YWJsZSB9IGZyb20gJ0Bhbmd1bGFyL2NvcmUnO1xuXG4vKipcbiAqIENTUkYgVG9rZW4gU2VydmljZVxuICpcbiAqIE1hbmFnZXMgQ1NSRiB0b2tlbnMgZm9yIGNvb2tpZS1iYXNlZCBhdXRoZW50aWNhdGlvbi5cbiAqIFJlYWRzIENTUkYgdG9rZW4gZnJvbSBjb29raWVzIGFuZCBwcm92aWRlcyBpdCBmb3IgcmVxdWVzdCBoZWFkZXJzLlxuICovXG5ASW5qZWN0YWJsZSh7XG4gICAgcHJvdmlkZWRJbjogJ3Jvb3QnXG59KVxuZXhwb3J0IGNsYXNzIENzcmZTZXJ2aWNlIHtcblxuICAgIC8qKlxuICAgICAqIEdldCBDU1JGIHRva2VuIGZyb20gY29va2llXG4gICAgICovXG4gICAgZ2V0Q3NyZlRva2VuKGNvb2tpZU5hbWU6IHN0cmluZyA9ICdjc3JmX3Rva2VuJyk6IHN0cmluZyB8IG51bGwge1xuICAgICAgICBjb25zdCBjb29raWVzID0gZG9jdW1lbnQuY29va2llLnNwbGl0KCc7Jyk7XG4gICAgICAgIGZvciAoY29uc3QgY29va2llIG9mIGNvb2tpZXMpIHtcbiAgICAgICAgICAgIGNvbnN0IFtuYW1lLCB2YWx1ZV0gPSBjb29raWUudHJpbSgpLnNwbGl0KCc9Jyk7XG4gICAgICAgICAgICBpZiAobmFtZSA9PT0gY29va2llTmFtZSkge1xuICAgICAgICAgICAgICAgIHJldHVybiBkZWNvZGVVUklDb21wb25lbnQodmFsdWUpO1xuICAgICAgICAgICAgfVxuICAgICAgICB9XG4gICAgICAgIHJldHVybiBudWxsO1xuICAgIH1cblxuICAgIC8qKlxuICAgICAqIENoZWNrIGlmIENTUkYgdG9rZW4gZXhpc3RzXG4gICAgICovXG4gICAgaGFzQ3NyZlRva2VuKGNvb2tpZU5hbWU6IHN0cmluZyA9ICdjc3JmX3Rva2VuJyk6IGJvb2xlYW4ge1xuICAgICAgICByZXR1cm4gdGhpcy5nZXRDc3JmVG9rZW4oY29va2llTmFtZSkgIT09IG51bGw7XG4gICAgfVxuXG4gICAgLyoqXG4gICAgICogQ2xlYXIgQ1NSRiB0b2tlbiAoZm9yIGxvZ291dClcbiAgICAgKiBOb3RlOiBDbGllbnQtc2lkZSBkZWxldGlvbiBpcyBsaW1pdGVkIGZvciBodHRwT25seSBjb29raWVzXG4gICAgICovXG4gICAgY2xlYXJDc3JmVG9rZW4oY29va2llTmFtZTogc3RyaW5nID0gJ2NzcmZfdG9rZW4nKTogdm9pZCB7XG4gICAgICAgIC8vIENhbiBvbmx5IGNsZWFyIG5vbi1odHRwT25seSBjb29raWVzXG4gICAgICAgIGRvY3VtZW50LmNvb2tpZSA9IGAke2Nvb2tpZU5hbWV9PTsgZXhwaXJlcz1UaHUsIDAxIEphbiAxOTcwIDAwOjAwOjAwIFVUQzsgcGF0aD0vO2A7XG4gICAgfVxufVxuIl19
|
|
@@ -1,14 +0,0 @@
|
|
|
1
|
-
import { Injectable } from '@angular/core';
|
|
2
|
-
import * as i0 from "@angular/core";
|
|
3
|
-
export class DbService {
|
|
4
|
-
constructor() { }
|
|
5
|
-
static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "16.2.12", ngImport: i0, type: DbService, deps: [], target: i0.ɵɵFactoryTarget.Injectable }); }
|
|
6
|
-
static { this.ɵprov = i0.ɵɵngDeclareInjectable({ minVersion: "12.0.0", version: "16.2.12", ngImport: i0, type: DbService, providedIn: 'root' }); }
|
|
7
|
-
}
|
|
8
|
-
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "16.2.12", ngImport: i0, type: DbService, decorators: [{
|
|
9
|
-
type: Injectable,
|
|
10
|
-
args: [{
|
|
11
|
-
providedIn: 'root'
|
|
12
|
-
}]
|
|
13
|
-
}], ctorParameters: function () { return []; } });
|
|
14
|
-
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiZGIuc2VydmljZS5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uLy4uLy4uL3Byb2plY3RzL25neC1zdG9uZXNjcmlwdHBocC1jbGllbnQvc3JjL2xpYi9kYi5zZXJ2aWNlLnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQUFBLE9BQU8sRUFBRSxVQUFVLEVBQUUsTUFBTSxlQUFlLENBQUM7O0FBSzNDLE1BQU0sT0FBTyxTQUFTO0lBRXBCLGdCQUFnQixDQUFDOytHQUZOLFNBQVM7bUhBQVQsU0FBUyxjQUZSLE1BQU07OzRGQUVQLFNBQVM7a0JBSHJCLFVBQVU7bUJBQUM7b0JBQ1YsVUFBVSxFQUFFLE1BQU07aUJBQ25CIiwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IHsgSW5qZWN0YWJsZSB9IGZyb20gJ0Bhbmd1bGFyL2NvcmUnO1xuXG5ASW5qZWN0YWJsZSh7XG4gIHByb3ZpZGVkSW46ICdyb290J1xufSlcbmV4cG9ydCBjbGFzcyBEYlNlcnZpY2Uge1xuXG4gIGNvbnN0cnVjdG9yKCkgeyB9XG59XG4iXX0=
|
|
@@ -1,31 +0,0 @@
|
|
|
1
|
-
export class MyEnvironmentModel {
|
|
2
|
-
constructor() {
|
|
3
|
-
this.production = true;
|
|
4
|
-
this.firebase = {
|
|
5
|
-
projectId: '',
|
|
6
|
-
appId: '',
|
|
7
|
-
databaseURL: '',
|
|
8
|
-
storageBucket: '',
|
|
9
|
-
locationId: '',
|
|
10
|
-
apiKey: '',
|
|
11
|
-
authDomain: '',
|
|
12
|
-
messagingSenderId: '',
|
|
13
|
-
measurementId: ''
|
|
14
|
-
};
|
|
15
|
-
this.apiServer = { host: '' };
|
|
16
|
-
this.chatServer = { host: '' };
|
|
17
|
-
/**
|
|
18
|
-
* Authentication configuration
|
|
19
|
-
* @default { mode: 'cookie', refreshEndpoint: '/auth/refresh', useCsrf: true }
|
|
20
|
-
*/
|
|
21
|
-
this.auth = {
|
|
22
|
-
mode: 'cookie',
|
|
23
|
-
refreshEndpoint: '/auth/refresh',
|
|
24
|
-
useCsrf: true,
|
|
25
|
-
refreshTokenCookieName: 'refresh_token',
|
|
26
|
-
csrfTokenCookieName: 'csrf_token',
|
|
27
|
-
csrfHeaderName: 'X-CSRF-Token'
|
|
28
|
-
};
|
|
29
|
-
}
|
|
30
|
-
}
|
|
31
|
-
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoibXktZW52aXJvbm1lbnQubW9kZWwuanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi8uLi9wcm9qZWN0cy9uZ3gtc3RvbmVzY3JpcHRwaHAtY2xpZW50L3NyYy9saWIvbXktZW52aXJvbm1lbnQubW9kZWwudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBMENBLE1BQU0sT0FBTyxrQkFBa0I7SUFBL0I7UUFDSSxlQUFVLEdBQVksSUFBSSxDQUFBO1FBQzFCLGFBQVEsR0FVSjtZQUNJLFNBQVMsRUFBRSxFQUFFO1lBQ2IsS0FBSyxFQUFFLEVBQUU7WUFDVCxXQUFXLEVBQUUsRUFBRTtZQUNmLGFBQWEsRUFBRSxFQUFFO1lBQ2pCLFVBQVUsRUFBRSxFQUFFO1lBQ2QsTUFBTSxFQUFFLEVBQUU7WUFDVixVQUFVLEVBQUUsRUFBRTtZQUNkLGlCQUFpQixFQUFFLEVBQUU7WUFDckIsYUFBYSxFQUFFLEVBQUU7U0FDcEIsQ0FBQTtRQUNMLGNBQVMsR0FFTCxFQUFFLElBQUksRUFBRSxFQUFFLEVBQUUsQ0FBQTtRQUNoQixlQUFVLEdBRU4sRUFBRSxJQUFJLEVBQUUsRUFBRSxFQUFFLENBQUE7UUFFaEI7OztXQUdHO1FBQ0gsU0FBSSxHQUFnQjtZQUNoQixJQUFJLEVBQUUsUUFBUTtZQUNkLGVBQWUsRUFBRSxlQUFlO1lBQ2hDLE9BQU8sRUFBRSxJQUFJO1lBQ2Isc0JBQXNCLEVBQUUsZUFBZTtZQUN2QyxtQkFBbUIsRUFBRSxZQUFZO1lBQ2pDLGNBQWMsRUFBRSxjQUFjO1NBQ2pDLENBQUM7SUFDTixDQUFDO0NBQUEiLCJzb3VyY2VzQ29udGVudCI6WyJleHBvcnQgdHlwZSBBdXRoTW9kZSA9ICdjb29raWUnIHwgJ2JvZHknIHwgJ25vbmUnO1xuXG5leHBvcnQgaW50ZXJmYWNlIEF1dGhDb25maWcge1xuICAgIC8qKlxuICAgICAqIEF1dGhlbnRpY2F0aW9uIG1vZGU6XG4gICAgICogLSAnY29va2llJzogVXNlIGh0dHBPbmx5IGNvb2tpZXMgKyBDU1JGIHRva2VucyAocmVjb21tZW5kZWQsIG1hdGNoZXMgU3RvbmVTY3JpcHRQSFAgdjIuMS54KVxuICAgICAqIC0gJ2JvZHknOiBTZW5kIHRva2VucyBpbiByZXF1ZXN0IGJvZHkgKGxlZ2FjeSBtb2RlKVxuICAgICAqIC0gJ25vbmUnOiBObyBhdXRvbWF0aWMgdG9rZW4gcmVmcmVzaFxuICAgICAqL1xuICAgIG1vZGU6IEF1dGhNb2RlO1xuXG4gICAgLyoqXG4gICAgICogVG9rZW4gcmVmcmVzaCBlbmRwb2ludCBwYXRoXG4gICAgICogQGRlZmF1bHQgJy9hdXRoL3JlZnJlc2gnIGZvciBjb29raWUgbW9kZSwgJy91c2VyL3JlZnJlc2hfYWNjZXNzJyBmb3IgYm9keSBtb2RlXG4gICAgICovXG4gICAgcmVmcmVzaEVuZHBvaW50Pzogc3RyaW5nO1xuXG4gICAgLyoqXG4gICAgICogRW5hYmxlIENTUkYgdG9rZW4gc3VwcG9ydCAocmVxdWlyZWQgZm9yIGNvb2tpZSBtb2RlKVxuICAgICAqIEBkZWZhdWx0IHRydWUgZm9yIGNvb2tpZSBtb2RlLCBmYWxzZSBmb3IgYm9keSBtb2RlXG4gICAgICovXG4gICAgdXNlQ3NyZj86IGJvb2xlYW47XG5cbiAgICAvKipcbiAgICAgKiBDb29raWUgbmFtZSBmb3IgcmVmcmVzaCB0b2tlblxuICAgICAqIEBkZWZhdWx0ICdyZWZyZXNoX3Rva2VuJ1xuICAgICAqL1xuICAgIHJlZnJlc2hUb2tlbkNvb2tpZU5hbWU/OiBzdHJpbmc7XG5cbiAgICAvKipcbiAgICAgKiBDb29raWUgbmFtZSBmb3IgQ1NSRiB0b2tlblxuICAgICAqIEBkZWZhdWx0ICdjc3JmX3Rva2VuJ1xuICAgICAqL1xuICAgIGNzcmZUb2tlbkNvb2tpZU5hbWU/OiBzdHJpbmc7XG5cbiAgICAvKipcbiAgICAgKiBDU1JGIGhlYWRlciBuYW1lXG4gICAgICogQGRlZmF1bHQgJ1gtQ1NSRi1Ub2tlbidcbiAgICAgKi9cbiAgICBjc3JmSGVhZGVyTmFtZT86IHN0cmluZztcbn1cblxuZXhwb3J0IGNsYXNzIE15RW52aXJvbm1lbnRNb2RlbCB7XG4gICAgcHJvZHVjdGlvbjogYm9vbGVhbiA9IHRydWVcbiAgICBmaXJlYmFzZToge1xuICAgICAgICBwcm9qZWN0SWQ6IHN0cmluZ1xuICAgICAgICBhcHBJZDogc3RyaW5nXG4gICAgICAgIGRhdGFiYXNlVVJMOiBzdHJpbmdcbiAgICAgICAgc3RvcmFnZUJ1Y2tldDogc3RyaW5nXG4gICAgICAgIGxvY2F0aW9uSWQ6IHN0cmluZ1xuICAgICAgICBhcGlLZXk6IHN0cmluZ1xuICAgICAgICBhdXRoRG9tYWluOiBzdHJpbmdcbiAgICAgICAgbWVzc2FnaW5nU2VuZGVySWQ6IHN0cmluZ1xuICAgICAgICBtZWFzdXJlbWVudElkOiBzdHJpbmdcbiAgICB9ID0ge1xuICAgICAgICAgICAgcHJvamVjdElkOiAnJyxcbiAgICAgICAgICAgIGFwcElkOiAnJyxcbiAgICAgICAgICAgIGRhdGFiYXNlVVJMOiAnJyxcbiAgICAgICAgICAgIHN0b3JhZ2VCdWNrZXQ6ICcnLFxuICAgICAgICAgICAgbG9jYXRpb25JZDogJycsXG4gICAgICAgICAgICBhcGlLZXk6ICcnLFxuICAgICAgICAgICAgYXV0aERvbWFpbjogJycsXG4gICAgICAgICAgICBtZXNzYWdpbmdTZW5kZXJJZDogJycsXG4gICAgICAgICAgICBtZWFzdXJlbWVudElkOiAnJ1xuICAgICAgICB9XG4gICAgYXBpU2VydmVyOiB7XG4gICAgICAgIGhvc3Q6IHN0cmluZ1xuICAgIH0gPSB7IGhvc3Q6ICcnIH1cbiAgICBjaGF0U2VydmVyOiB7XG4gICAgICAgIGhvc3Q6IHN0cmluZ1xuICAgIH0gPSB7IGhvc3Q6ICcnIH1cblxuICAgIC8qKlxuICAgICAqIEF1dGhlbnRpY2F0aW9uIGNvbmZpZ3VyYXRpb25cbiAgICAgKiBAZGVmYXVsdCB7IG1vZGU6ICdjb29raWUnLCByZWZyZXNoRW5kcG9pbnQ6ICcvYXV0aC9yZWZyZXNoJywgdXNlQ3NyZjogdHJ1ZSB9XG4gICAgICovXG4gICAgYXV0aD86IEF1dGhDb25maWcgPSB7XG4gICAgICAgIG1vZGU6ICdjb29raWUnLFxuICAgICAgICByZWZyZXNoRW5kcG9pbnQ6ICcvYXV0aC9yZWZyZXNoJyxcbiAgICAgICAgdXNlQ3NyZjogdHJ1ZSxcbiAgICAgICAgcmVmcmVzaFRva2VuQ29va2llTmFtZTogJ3JlZnJlc2hfdG9rZW4nLFxuICAgICAgICBjc3JmVG9rZW5Db29raWVOYW1lOiAnY3NyZl90b2tlbicsXG4gICAgICAgIGNzcmZIZWFkZXJOYW1lOiAnWC1DU1JGLVRva2VuJ1xuICAgIH07XG59Il19
|
|
@@ -1,27 +0,0 @@
|
|
|
1
|
-
import { NgModule } from '@angular/core';
|
|
2
|
-
import { CommonModule } from '@angular/common';
|
|
3
|
-
import { MyEnvironmentModel } from '../my-environment.model';
|
|
4
|
-
import * as i0 from "@angular/core";
|
|
5
|
-
export class NgxStoneScriptPhpClientModule {
|
|
6
|
-
static forRoot(environment) {
|
|
7
|
-
return {
|
|
8
|
-
ngModule: NgxStoneScriptPhpClientModule,
|
|
9
|
-
providers: [
|
|
10
|
-
{ provide: MyEnvironmentModel, useValue: environment }
|
|
11
|
-
]
|
|
12
|
-
};
|
|
13
|
-
}
|
|
14
|
-
static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "16.2.12", ngImport: i0, type: NgxStoneScriptPhpClientModule, deps: [], target: i0.ɵɵFactoryTarget.NgModule }); }
|
|
15
|
-
static { this.ɵmod = i0.ɵɵngDeclareNgModule({ minVersion: "14.0.0", version: "16.2.12", ngImport: i0, type: NgxStoneScriptPhpClientModule, imports: [CommonModule] }); }
|
|
16
|
-
static { this.ɵinj = i0.ɵɵngDeclareInjector({ minVersion: "12.0.0", version: "16.2.12", ngImport: i0, type: NgxStoneScriptPhpClientModule, imports: [CommonModule] }); }
|
|
17
|
-
}
|
|
18
|
-
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "16.2.12", ngImport: i0, type: NgxStoneScriptPhpClientModule, decorators: [{
|
|
19
|
-
type: NgModule,
|
|
20
|
-
args: [{
|
|
21
|
-
declarations: [],
|
|
22
|
-
imports: [
|
|
23
|
-
CommonModule
|
|
24
|
-
]
|
|
25
|
-
}]
|
|
26
|
-
}] });
|
|
27
|
-
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoibmd4LXN0b25lc2NyaXB0cGhwLWNsaWVudC5tb2R1bGUuanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi8uLi8uLi9wcm9qZWN0cy9uZ3gtc3RvbmVzY3JpcHRwaHAtY2xpZW50L3NyYy9saWIvbmd4LXN0b25lc2NyaXB0cGhwLWNsaWVudC9uZ3gtc3RvbmVzY3JpcHRwaHAtY2xpZW50Lm1vZHVsZS50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFBQSxPQUFPLEVBQXVCLFFBQVEsRUFBRSxNQUFNLGVBQWUsQ0FBQztBQUM5RCxPQUFPLEVBQUUsWUFBWSxFQUFFLE1BQU0saUJBQWlCLENBQUM7QUFDL0MsT0FBTyxFQUFFLGtCQUFrQixFQUFFLE1BQU0seUJBQXlCLENBQUM7O0FBVTdELE1BQU0sT0FBTyw2QkFBNkI7SUFDL0IsTUFBTSxDQUFDLE9BQU8sQ0FBQyxXQUErQjtRQUNqRCxPQUFPO1lBQ0gsUUFBUSxFQUFFLDZCQUE2QjtZQUN2QyxTQUFTLEVBQUU7Z0JBQ1AsRUFBRSxPQUFPLEVBQUUsa0JBQWtCLEVBQUUsUUFBUSxFQUFFLFdBQVcsRUFBRTthQUN6RDtTQUNKLENBQUE7SUFDTCxDQUFDOytHQVJRLDZCQUE2QjtnSEFBN0IsNkJBQTZCLFlBSGxDLFlBQVk7Z0hBR1AsNkJBQTZCLFlBSGxDLFlBQVk7OzRGQUdQLDZCQUE2QjtrQkFOekMsUUFBUTttQkFBQztvQkFDTixZQUFZLEVBQUUsRUFBRTtvQkFDaEIsT0FBTyxFQUFFO3dCQUNMLFlBQVk7cUJBQ2Y7aUJBQ0oiLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQgeyBNb2R1bGVXaXRoUHJvdmlkZXJzLCBOZ01vZHVsZSB9IGZyb20gJ0Bhbmd1bGFyL2NvcmUnO1xuaW1wb3J0IHsgQ29tbW9uTW9kdWxlIH0gZnJvbSAnQGFuZ3VsYXIvY29tbW9uJztcbmltcG9ydCB7IE15RW52aXJvbm1lbnRNb2RlbCB9IGZyb20gJy4uL215LWVudmlyb25tZW50Lm1vZGVsJztcblxuXG5cbkBOZ01vZHVsZSh7XG4gICAgZGVjbGFyYXRpb25zOiBbXSxcbiAgICBpbXBvcnRzOiBbXG4gICAgICAgIENvbW1vbk1vZHVsZVxuICAgIF1cbn0pXG5leHBvcnQgY2xhc3MgTmd4U3RvbmVTY3JpcHRQaHBDbGllbnRNb2R1bGUge1xuICAgIHB1YmxpYyBzdGF0aWMgZm9yUm9vdChlbnZpcm9ubWVudDogTXlFbnZpcm9ubWVudE1vZGVsKTogTW9kdWxlV2l0aFByb3ZpZGVyczxOZ3hTdG9uZVNjcmlwdFBocENsaWVudE1vZHVsZT4ge1xuICAgICAgICByZXR1cm4ge1xuICAgICAgICAgICAgbmdNb2R1bGU6IE5neFN0b25lU2NyaXB0UGhwQ2xpZW50TW9kdWxlLFxuICAgICAgICAgICAgcHJvdmlkZXJzOiBbXG4gICAgICAgICAgICAgICAgeyBwcm92aWRlOiBNeUVudmlyb25tZW50TW9kZWwsIHVzZVZhbHVlOiBlbnZpcm9ubWVudCB9XG4gICAgICAgICAgICBdXG4gICAgICAgIH1cbiAgICB9XG59XG4iXX0=
|
|
@@ -1,23 +0,0 @@
|
|
|
1
|
-
import { Injectable } from '@angular/core';
|
|
2
|
-
import { BehaviorSubject } from 'rxjs';
|
|
3
|
-
import * as i0 from "@angular/core";
|
|
4
|
-
export class SigninStatusService {
|
|
5
|
-
constructor() {
|
|
6
|
-
this.status = new BehaviorSubject(false);
|
|
7
|
-
}
|
|
8
|
-
signedOut() {
|
|
9
|
-
this.status.next(false);
|
|
10
|
-
}
|
|
11
|
-
signedIn() {
|
|
12
|
-
this.status.next(true);
|
|
13
|
-
}
|
|
14
|
-
static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "16.2.12", ngImport: i0, type: SigninStatusService, deps: [], target: i0.ɵɵFactoryTarget.Injectable }); }
|
|
15
|
-
static { this.ɵprov = i0.ɵɵngDeclareInjectable({ minVersion: "12.0.0", version: "16.2.12", ngImport: i0, type: SigninStatusService, providedIn: 'root' }); }
|
|
16
|
-
}
|
|
17
|
-
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "16.2.12", ngImport: i0, type: SigninStatusService, decorators: [{
|
|
18
|
-
type: Injectable,
|
|
19
|
-
args: [{
|
|
20
|
-
providedIn: 'root'
|
|
21
|
-
}]
|
|
22
|
-
}], ctorParameters: function () { return []; } });
|
|
23
|
-
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoic2lnbmluLXN0YXR1cy5zZXJ2aWNlLmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vLi4vLi4vLi4vcHJvamVjdHMvbmd4LXN0b25lc2NyaXB0cGhwLWNsaWVudC9zcmMvbGliL3NpZ25pbi1zdGF0dXMuc2VydmljZS50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFBQSxPQUFPLEVBQUUsVUFBVSxFQUFFLE1BQU0sZUFBZSxDQUFDO0FBQzNDLE9BQU8sRUFBRSxlQUFlLEVBQUUsTUFBTSxNQUFNLENBQUM7O0FBS3ZDLE1BQU0sT0FBTyxtQkFBbUI7SUFHNUI7UUFDSSxJQUFJLENBQUMsTUFBTSxHQUFHLElBQUksZUFBZSxDQUFVLEtBQUssQ0FBQyxDQUFBO0lBQ3JELENBQUM7SUFFRCxTQUFTO1FBQ0wsSUFBSSxDQUFDLE1BQU0sQ0FBQyxJQUFJLENBQUMsS0FBSyxDQUFDLENBQUE7SUFDM0IsQ0FBQztJQUVELFFBQVE7UUFDSixJQUFJLENBQUMsTUFBTSxDQUFDLElBQUksQ0FBQyxJQUFJLENBQUMsQ0FBQTtJQUMxQixDQUFDOytHQWJRLG1CQUFtQjttSEFBbkIsbUJBQW1CLGNBRmhCLE1BQU07OzRGQUVULG1CQUFtQjtrQkFIL0IsVUFBVTttQkFBQztvQkFDUixVQUFVLEVBQUUsTUFBTTtpQkFDckIiLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQgeyBJbmplY3RhYmxlIH0gZnJvbSAnQGFuZ3VsYXIvY29yZSc7XG5pbXBvcnQgeyBCZWhhdmlvclN1YmplY3QgfSBmcm9tICdyeGpzJztcblxuQEluamVjdGFibGUoe1xuICAgIHByb3ZpZGVkSW46ICdyb290J1xufSlcbmV4cG9ydCBjbGFzcyBTaWduaW5TdGF0dXNTZXJ2aWNlIHtcbiAgICBwdWJsaWMgc3RhdHVzOiBCZWhhdmlvclN1YmplY3Q8Ym9vbGVhbj5cblxuICAgIGNvbnN0cnVjdG9yKCkge1xuICAgICAgICB0aGlzLnN0YXR1cyA9IG5ldyBCZWhhdmlvclN1YmplY3Q8Ym9vbGVhbj4oZmFsc2UpXG4gICAgfVxuXG4gICAgc2lnbmVkT3V0KCk6IHZvaWQge1xuICAgICAgICB0aGlzLnN0YXR1cy5uZXh0KGZhbHNlKVxuICAgIH1cblxuICAgIHNpZ25lZEluKCk6IHZvaWQge1xuICAgICAgICB0aGlzLnN0YXR1cy5uZXh0KHRydWUpXG4gICAgfVxufVxuIl19
|