@progalaxyelabs/ngx-stonescriptphp-client 1.0.0 → 1.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.
Files changed (83) hide show
  1. package/HLD.md +31 -0
  2. package/LICENSE +21 -0
  3. package/README.md +89 -2
  4. package/{lib → dist}/api-connection.service.d.ts +1 -3
  5. package/dist/api-connection.service.d.ts.map +1 -0
  6. package/dist/api-connection.service.js +314 -0
  7. package/dist/api-connection.service.js.map +1 -0
  8. package/{lib → dist}/api-response.model.d.ts +1 -0
  9. package/dist/api-response.model.d.ts.map +1 -0
  10. package/dist/api-response.model.js +51 -0
  11. package/dist/api-response.model.js.map +1 -0
  12. package/dist/auth.service.d.ts +4 -0
  13. package/dist/auth.service.d.ts.map +1 -0
  14. package/dist/auth.service.js +16 -0
  15. package/dist/auth.service.js.map +1 -0
  16. package/{lib → dist}/csrf.service.d.ts +1 -3
  17. package/dist/csrf.service.d.ts.map +1 -0
  18. package/dist/csrf.service.js +47 -0
  19. package/dist/csrf.service.js.map +1 -0
  20. package/dist/db.service.d.ts +4 -0
  21. package/dist/db.service.d.ts.map +1 -0
  22. package/dist/db.service.js +16 -0
  23. package/dist/db.service.js.map +1 -0
  24. package/{fesm2022/progalaxyelabs-ngx-stonescriptphp-client.mjs → dist/esm/api-connection.service.js} +28 -276
  25. package/dist/esm/api-connection.service.js.map +1 -0
  26. package/dist/esm/api-response.model.js +47 -0
  27. package/dist/esm/api-response.model.js.map +1 -0
  28. package/dist/esm/auth.service.js +13 -0
  29. package/dist/esm/auth.service.js.map +1 -0
  30. package/dist/esm/csrf.service.js +44 -0
  31. package/dist/esm/csrf.service.js.map +1 -0
  32. package/dist/esm/db.service.js +13 -0
  33. package/dist/esm/db.service.js.map +1 -0
  34. package/dist/esm/index.js +13 -0
  35. package/dist/esm/index.js.map +1 -0
  36. package/dist/esm/my-environment.model.js +29 -0
  37. package/dist/esm/my-environment.model.js.map +1 -0
  38. package/dist/esm/ngx-stonescriptphp-client.module.js +25 -0
  39. package/dist/esm/ngx-stonescriptphp-client.module.js.map +1 -0
  40. package/dist/esm/signin-status.service.js +23 -0
  41. package/dist/esm/signin-status.service.js.map +1 -0
  42. package/dist/esm/token.service.js +61 -0
  43. package/dist/esm/token.service.js.map +1 -0
  44. package/dist/index.d.ts +10 -0
  45. package/dist/index.d.ts.map +1 -0
  46. package/dist/index.js +16 -0
  47. package/dist/index.js.map +1 -0
  48. package/{lib → dist}/my-environment.model.d.ts +1 -0
  49. package/dist/my-environment.model.d.ts.map +1 -0
  50. package/dist/my-environment.model.js +33 -0
  51. package/dist/my-environment.model.js.map +1 -0
  52. package/dist/ngx-stonescriptphp-client.module.d.ts +6 -0
  53. package/dist/ngx-stonescriptphp-client.module.d.ts.map +1 -0
  54. package/dist/ngx-stonescriptphp-client.module.js +28 -0
  55. package/dist/ngx-stonescriptphp-client.module.js.map +1 -0
  56. package/{lib → dist}/signin-status.service.d.ts +1 -3
  57. package/dist/signin-status.service.d.ts.map +1 -0
  58. package/dist/signin-status.service.js +26 -0
  59. package/dist/signin-status.service.js.map +1 -0
  60. package/{lib → dist}/token.service.d.ts +1 -3
  61. package/dist/token.service.d.ts.map +1 -0
  62. package/dist/token.service.js +64 -0
  63. package/dist/token.service.js.map +1 -0
  64. package/docs/AUTH_COMPATIBILITY.md +310 -0
  65. package/docs/CHANGELOG.md +261 -0
  66. package/package.json +59 -18
  67. package/esm2022/lib/api-connection.service.mjs +0 -304
  68. package/esm2022/lib/api-response.model.mjs +0 -44
  69. package/esm2022/lib/auth.service.mjs +0 -14
  70. package/esm2022/lib/csrf.service.mjs +0 -46
  71. package/esm2022/lib/db.service.mjs +0 -14
  72. package/esm2022/lib/my-environment.model.mjs +0 -31
  73. package/esm2022/lib/ngx-stonescriptphp-client/ngx-stonescriptphp-client.module.mjs +0 -27
  74. package/esm2022/lib/signin-status.service.mjs +0 -23
  75. package/esm2022/lib/token.service.mjs +0 -63
  76. package/esm2022/progalaxyelabs-ngx-stonescriptphp-client.mjs +0 -5
  77. package/esm2022/public-api.mjs +0 -13
  78. package/fesm2022/progalaxyelabs-ngx-stonescriptphp-client.mjs.map +0 -1
  79. package/index.d.ts +0 -5
  80. package/lib/auth.service.d.ts +0 -6
  81. package/lib/db.service.d.ts +0 -6
  82. package/lib/ngx-stonescriptphp-client/ngx-stonescriptphp-client.module.d.ts +0 -10
  83. 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":"AAAA,OAAO,EAAE,UAAU,EAAE,MAAM,eAAe,CAAC;AAG3C,OAAO,EAAE,WAAW,EAAE,MAAM,sBAAsB,CAAC;;;;;;AAOnD,MAAM,OAAO,oBAAoB;IAQ7B,YACY,MAAoB,EACpB,YAAiC,EACjC,WAA+B,EAC/B,IAAiB;QAHjB,WAAM,GAAN,MAAM,CAAc;QACpB,iBAAY,GAAZ,YAAY,CAAqB;QACjC,gBAAW,GAAX,WAAW,CAAoB;QAC/B,SAAI,GAAJ,IAAI,CAAa;QAVrB,SAAI,GAAG,EAAE,CAAA,CAAC,0BAA0B;QAEpC,gBAAW,GAAG,EAAE,CAAA;QAUpB,IAAI,CAAC,IAAI,GAAG,WAAW,CAAC,SAAS,CAAC,IAAI,CAAA;QAEtC,wCAAwC;QACxC,IAAI,CAAC,UAAU,GAAG;YACd,IAAI,EAAE,WAAW,CAAC,IAAI,EAAE,IAAI,IAAI,QAAQ;YACxC,eAAe,EAAE,WAAW,CAAC,IAAI,EAAE,eAAe;YAClD,OAAO,EAAE,WAAW,CAAC,IAAI,EAAE,OAAO;YAClC,sBAAsB,EAAE,WAAW,CAAC,IAAI,EAAE,sBAAsB,IAAI,eAAe;YACnF,mBAAmB,EAAE,WAAW,CAAC,IAAI,EAAE,mBAAmB,IAAI,YAAY;YAC1E,cAAc,EAAE,WAAW,CAAC,IAAI,EAAE,cAAc,IAAI,cAAc;SACrE,CAAA;QAED,8DAA8D;QAC9D,IAAI,CAAC,IAAI,CAAC,UAAU,CAAC,eAAe,EAAE;YAClC,IAAI,CAAC,UAAU,CAAC,eAAe,GAAG,IAAI,CAAC,UAAU,CAAC,IAAI,KAAK,QAAQ;gBAC/D,CAAC,CAAC,eAAe;gBACjB,CAAC,CAAC,sBAAsB,CAAA;SAC/B;QAED,0DAA0D;QAC1D,IAAI,IAAI,CAAC,UAAU,CAAC,OAAO,KAAK,SAAS,EAAE;YACvC,IAAI,CAAC,UAAU,CAAC,OAAO,GAAG,IAAI,CAAC,UAAU,CAAC,IAAI,KAAK,QAAQ,CAAA;SAC9D;IACL,CAAC;IAGO,KAAK,CAAC,OAAO,CAAW,GAAW,EAAE,OAAY,EAAE,IAAgB;QACvE,IAAI;YAEA,IAAG,IAAI,KAAK,IAAI,EAAE;gBACd,MAAM,IAAI,GAAG,IAAI,CAAC,SAAS,CAAC,IAAI,CAAC,CAAA;gBACjC,IAAG,IAAI,EAAE;oBACL,OAAO,CAAC,IAAI,GAAG,IAAI,CAAA;iBACtB;qBAAM;oBACH,OAAO,CAAC,IAAI,GAAG,EAAE,CAAA;iBACpB;aACJ;YAED,MAAM,mBAAmB,GAAG,IAAI,CAAC,kBAAkB,CAAC,OAAO,CAAC,CAAA;YAE5D,IAAI,QAAQ,GAAa,MAAM,KAAK,CAAC,GAAG,EAAE,OAAO,CAAC,CAAA;YAElD,IAAI,CAAC,QAAQ,CAAC,MAAM,KAAK,GAAG,CAAC,IAAI,mBAAmB,EAAE;gBAClD,QAAQ,GAAG,MAAM,IAAI,CAAC,0BAA0B,CAAC,GAAG,EAAE,OAAO,EAAE,QAAQ,CAAC,CAAA;aAC3E;YAED,IAAI,QAAQ,CAAC,EAAE,EAAE;gBACb,MAAM,IAAI,GAAG,MAAM,CAAC,QAAQ,CAAC,IAAI,EAAE,CAAC,CAAA;gBACpC,OAAO,CAAC,IAAI,WAAW,CAAW,IAAI,CAAC,MAAM,EAAE,IAAI,CAAC,IAAI,EAAE,IAAI,CAAC,OAAO,CAAC,CAAC,CAAA;aAC3E;YAED,IAAI,QAAQ,CAAC,MAAM,KAAK,GAAG,EAAE;gBACzB,IAAI,CAAC,YAAY,CAAC,SAAS,EAAE,CAAA;aAChC;YAED,OAAO,IAAI,CAAC,WAAW,CAAW,QAAQ,CAAC,CAAA;SAC9C;QAAC,OAAO,KAAK,EAAE;YACZ,OAAO,IAAI,CAAC,WAAW,CAAW,KAAK,CAAC,CAAA;SAC3C;IACL,CAAC;IAEO,WAAW,CAAW,KAAU;QACpC,OAAO,CAAC,KAAK,CACT,yBAAyB,KAAK,CAAC,MAAM,IAAI;YACzC,cAAc,EAAE,KAAK,CAAC,CAAC;QAC3B,OAAO,IAAI,WAAW,CAAW,OAAO,CAAC,CAAA;IAC7C,CAAC;IAED,KAAK,CAAC,GAAG,CAAW,QAAgB,EAAE,cAAoB;QACtD,MAAM,GAAG,GAAG,IAAI,CAAC,IAAI,GAAG,QAAQ,CAAC,OAAO,CAAC,MAAM,EAAE,EAAE,CAAC,GAAG,IAAI,CAAC,gBAAgB,CAAC,cAAc,CAAC,CAAA;QAC5F,MAAM,YAAY,GAAgB;YAC9B,IAAI,EAAE,MAAM;YACZ,QAAQ,EAAE,OAAO;SACpB,CAAA;QACD,OAAO,IAAI,CAAC,OAAO,CAAC,GAAG,EAAE,YAAY,EAAE,IAAI,CAAC,CAAA;IAChD,CAAC;IAED,KAAK,CAAC,IAAI,CAAW,mBAA2B,EAAE,IAAS;QACvD,MAAM,GAAG,GAAG,IAAI,CAAC,IAAI,GAAG,mBAAmB,CAAC,OAAO,CAAC,MAAM,EAAE,EAAE,CAAC,CAAA;QAC/D,MAAM,YAAY,GAAgB;YAC9B,MAAM,EAAE,MAAM;YACd,IAAI,EAAE,MAAM;YACZ,QAAQ,EAAE,OAAO;YACjB,OAAO,EAAE;gBACL,cAAc,EAAE,kBAAkB;aACrC;YACD,IAAI,EAAE,IAAI,CAAC,SAAS,CAAC,IAAI,CAAC;SAC7B,CAAA;QACD,OAAO,IAAI,CAAC,OAAO,CAAC,GAAG,EAAE,YAAY,EAAE,IAAI,CAAC,CAAA;IAChD,CAAC;IAED,KAAK,CAAC,GAAG,CAAW,mBAA2B,EAAE,IAAS;QACtD,MAAM,GAAG,GAAG,IAAI,CAAC,IAAI,GAAG,mBAAmB,CAAC,OAAO,CAAC,MAAM,EAAE,EAAE,CAAC,CAAA;QAC/D,MAAM,YAAY,GAAgB;YAC9B,MAAM,EAAE,KAAK;YACb,IAAI,EAAE,MAAM;YACZ,QAAQ,EAAE,OAAO;YACjB,OAAO,EAAE;gBACL,cAAc,EAAE,kBAAkB;aACrC;YACD,IAAI,EAAE,IAAI,CAAC,SAAS,CAAC,IAAI,CAAC;SAC7B,CAAA;QACD,OAAO,IAAI,CAAC,OAAO,CAAC,GAAG,EAAE,YAAY,EAAE,IAAI,CAAC,CAAA;IAChD,CAAC;IAED,KAAK,CAAC,KAAK,CAAW,mBAA2B,EAAE,IAAS;QACxD,MAAM,GAAG,GAAG,IAAI,CAAC,IAAI,GAAG,mBAAmB,CAAC,OAAO,CAAC,MAAM,EAAE,EAAE,CAAC,CAAA;QAC/D,MAAM,YAAY,GAAgB;YAC9B,MAAM,EAAE,OAAO;YACf,IAAI,EAAE,MAAM;YACZ,QAAQ,EAAE,OAAO;YACjB,OAAO,EAAE;gBACL,cAAc,EAAE,kBAAkB;aACrC;YACD,IAAI,EAAE,IAAI,CAAC,SAAS,CAAC,IAAI,CAAC;SAC7B,CAAA;QACD,OAAO,IAAI,CAAC,OAAO,CAAC,GAAG,EAAE,YAAY,EAAE,IAAI,CAAC,CAAA;IAChD,CAAC;IAED,KAAK,CAAC,MAAM,CAAW,QAAgB,EAAE,cAAoB;QACzD,MAAM,GAAG,GAAG,IAAI,CAAC,IAAI,GAAG,QAAQ,CAAC,OAAO,CAAC,MAAM,EAAE,EAAE,CAAC,GAAG,IAAI,CAAC,gBAAgB,CAAC,cAAc,CAAC,CAAA;QAC5F,MAAM,YAAY,GAAgB;YAC9B,MAAM,EAAE,QAAQ;YAChB,IAAI,EAAE,MAAM;YACZ,QAAQ,EAAE,OAAO;SACpB,CAAA;QACD,OAAO,IAAI,CAAC,OAAO,CAAC,GAAG,EAAE,YAAY,EAAE,IAAI,CAAC,CAAA;IAChD,CAAC;IAED,0GAA0G;IAC1G,sEAAsE;IACtE,YAAY;IACZ,8CAA8C;IAC9C,8BAA8B;IAC9B,4BAA4B;IAC5B,iCAAiC;IACjC,6BAA6B;IAC7B,YAAY;IAEZ,4EAA4E;IAE5E,kEAAkE;IAElE,kEAAkE;IAClE,4FAA4F;IAC5F,YAAY;IAEZ,6BAA6B;IAC7B,gEAAgE;IAChE,YAAY;IAEZ,4CAA4C;IAC5C,wBAAwB;IACxB,yCAAyC;IACzC,QAAQ;IACR,IAAI;IAEI,kBAAkB,CAAC,OAAY;QACnC,IAAI,CAAC,WAAW,GAAG,IAAI,CAAC,MAAM,CAAC,cAAc,EAAE,CAAA;QAC/C,IAAI,CAAC,IAAI,CAAC,WAAW,EAAE;YACnB,OAAO,KAAK,CAAA;SACf;QAED,IAAI,CAAC,OAAO,CAAC,OAAO,EAAE;YAClB,OAAO,CAAC,OAAO,GAAG,EAAE,CAAA;SACvB;QACD,OAAO,CAAC,OAAO,CAAC,eAAe,CAAC,GAAG,SAAS,GAAG,IAAI,CAAC,WAAW,CAAA;QAC/D,OAAO,IAAI,CAAA;IACf,CAAC;IAEO,KAAK,CAAC,0BAA0B,CAAC,GAAW,EAAE,YAAiB,EAAE,QAAkB;QAEvF,MAAM,eAAe,GAAG,MAAM,IAAI,CAAC,kBAAkB,EAAE,CAAA;QACvD,IAAI,CAAC,eAAe,EAAE;YAClB,OAAO,QAAQ,CAAA;SAClB;QAED,YAAY,CAAC,OAAO,CAAC,eAAe,CAAC,GAAG,SAAS,GAAG,IAAI,CAAC,WAAW,CAAA;QACpE,QAAQ,GAAG,MAAM,KAAK,CAAC,GAAG,EAAE,YAAY,CAAC,CAAA;QACzC,OAAO,QAAQ,CAAA;IACnB,CAAC;IAED,KAAK,CAAC,kBAAkB;QACpB,IAAI,IAAI,CAAC,UAAU,CAAC,IAAI,KAAK,MAAM,EAAE;YACjC,OAAO,KAAK,CAAA;SACf;QAED,IAAI,IAAI,CAAC,UAAU,CAAC,IAAI,KAAK,QAAQ,EAAE;YACnC,OAAO,MAAM,IAAI,CAAC,4BAA4B,EAAE,CAAA;SACnD;aAAM;YACH,OAAO,MAAM,IAAI,CAAC,0BAA0B,EAAE,CAAA;SACjD;IACL,CAAC;IAED;;OAEG;IACK,KAAK,CAAC,4BAA4B;QACtC,IAAI;YACA,MAAM,eAAe,GAAG,IAAI,CAAC,IAAI,GAAG,IAAI,CAAC,UAAU,CAAC,eAAgB,CAAC,OAAO,CAAC,MAAM,EAAE,EAAE,CAAC,CAAA;YACxF,MAAM,OAAO,GAAQ;gBACjB,cAAc,EAAE,kBAAkB;aACrC,CAAA;YAED,4BAA4B;YAC5B,IAAI,IAAI,CAAC,UAAU,CAAC,OAAO,EAAE;gBACzB,MAAM,SAAS,GAAG,IAAI,CAAC,IAAI,CAAC,YAAY,CAAC,IAAI,CAAC,UAAU,CAAC,mBAAoB,CAAC,CAAA;gBAC9E,IAAI,CAAC,SAAS,EAAE;oBACZ,OAAO,CAAC,KAAK,CAAC,gCAAgC,CAAC,CAAA;oBAC/C,OAAO,KAAK,CAAA;iBACf;gBACD,OAAO,CAAC,IAAI,CAAC,UAAU,CAAC,cAAe,CAAC,GAAG,SAAS,CAAA;aACvD;YAED,IAAI,oBAAoB,GAAG,MAAM,KAAK,CAAC,eAAe,EAAE;gBACpD,MAAM,EAAE,MAAM;gBACd,IAAI,EAAE,MAAM;gBACZ,WAAW,EAAE,SAAS;gBACtB,QAAQ,EAAE,OAAO;gBACjB,OAAO,EAAE,OAAO;aACnB,CAAC,CAAA;YAEF,IAAI,CAAC,oBAAoB,CAAC,EAAE,EAAE;gBAC1B,IAAI,CAAC,WAAW,GAAG,EAAE,CAAA;gBACrB,IAAI,CAAC,MAAM,CAAC,KAAK,EAAE,CAAA;gBACnB,OAAO,KAAK,CAAA;aACf;YAED,IAAI,iBAAiB,GAAG,MAAM,oBAAoB,CAAC,IAAI,EAAE,CAAA;YACzD,IAAI,CAAC,iBAAiB,IAAI,iBAAiB,CAAC,MAAM,KAAK,IAAI,EAAE;gBACzD,OAAO,KAAK,CAAA;aACf;YAED,qCAAqC;YACrC,MAAM,cAAc,GAAG,iBAAiB,CAAC,IAAI,EAAE,YAAY,IAAI,iBAAiB,CAAC,YAAY,CAAA;YAC7F,IAAI,CAAC,cAAc,EAAE;gBACjB,OAAO,CAAC,KAAK,CAAC,qCAAqC,CAAC,CAAA;gBACpD,OAAO,KAAK,CAAA;aACf;YAED,+DAA+D;YAC/D,IAAI,CAAC,MAAM,CAAC,cAAc,CAAC,cAAc,CAAC,CAAA;YAC1C,IAAI,CAAC,WAAW,GAAG,cAAc,CAAA;YAEjC,OAAO,IAAI,CAAA;SACd;QAAC,OAAO,KAAK,EAAE;YACZ,OAAO,CAAC,KAAK,CAAC,qCAAqC,EAAE,KAAK,CAAC,CAAA;YAC3D,IAAI,CAAC,WAAW,GAAG,EAAE,CAAA;YACrB,IAAI,CAAC,MAAM,CAAC,KAAK,EAAE,CAAA;YACnB,OAAO,KAAK,CAAA;SACf;IACL,CAAC;IAED;;OAEG;IACK,KAAK,CAAC,0BAA0B;QACpC,IAAI;YACA,MAAM,YAAY,GAAG,IAAI,CAAC,MAAM,CAAC,eAAe,EAAE,CAAA;YAClD,IAAI,CAAC,YAAY,EAAE;gBACf,OAAO,KAAK,CAAA;aACf;YAED,MAAM,eAAe,GAAG,IAAI,CAAC,IAAI,GAAG,IAAI,CAAC,UAAU,CAAC,eAAgB,CAAC,OAAO,CAAC,MAAM,EAAE,EAAE,CAAC,CAAA;YACxF,IAAI,oBAAoB,GAAG,MAAM,KAAK,CAAC,eAAe,EAAE;gBACpD,MAAM,EAAE,MAAM;gBACd,IAAI,EAAE,MAAM;gBACZ,QAAQ,EAAE,OAAO;gBACjB,OAAO,EAAE;oBACL,cAAc,EAAE,kBAAkB;iBACrC;gBACD,IAAI,EAAE,IAAI,CAAC,SAAS,CAAC;oBACjB,YAAY,EAAE,IAAI,CAAC,WAAW;oBAC9B,aAAa,EAAE,YAAY;iBAC9B,CAAC;aACL,CAAC,CAAA;YAEF,IAAI,CAAC,oBAAoB,CAAC,EAAE,EAAE;gBAC1B,IAAI,CAAC,WAAW,GAAG,EAAE,CAAA;gBACrB,IAAI,CAAC,MAAM,CAAC,KAAK,EAAE,CAAA;gBACnB,OAAO,KAAK,CAAA;aACf;YAED,IAAI,iBAAiB,GAAG,MAAM,oBAAoB,CAAC,IAAI,EAAE,CAAA;YACzD,IAAI,CAAC,iBAAiB,EAAE;gBACpB,OAAO,KAAK,CAAA;aACf;YAED,MAAM,cAAc,GAAG,iBAAiB,CAAC,IAAI,EAAE,YAAY,IAAI,iBAAiB,CAAC,YAAY,CAAA;YAC7F,IAAI,CAAC,cAAc,EAAE;gBACjB,OAAO,CAAC,KAAK,CAAC,qCAAqC,CAAC,CAAA;gBACpD,OAAO,KAAK,CAAA;aACf;YAED,IAAI,CAAC,MAAM,CAAC,SAAS,CAAC,cAAc,EAAE,YAAY,CAAC,CAAA;YACnD,IAAI,CAAC,WAAW,GAAG,cAAc,CAAA;YAEjC,OAAO,IAAI,CAAA;SACd;QAAC,OAAO,KAAK,EAAE;YACZ,OAAO,CAAC,KAAK,CAAC,mCAAmC,EAAE,KAAK,CAAC,CAAA;YACzD,IAAI,CAAC,WAAW,GAAG,EAAE,CAAA;YACrB,IAAI,CAAC,MAAM,CAAC,KAAK,EAAE,CAAA;YACnB,OAAO,KAAK,CAAA;SACf;IACL,CAAC;IAED,gBAAgB,CAAC,OAAa;QAC1B,IAAI,OAAO,KAAK,SAAS,EAAE;YACvB,OAAO,EAAE,CAAA;SACZ;QAED,MAAM,KAAK,GAAG,EAAE,CAAA;QAChB,KAAK,IAAI,GAAG,IAAI,OAAO,EAAE;YACrB,IAAI,OAAO,CAAC,cAAc,CAAC,GAAG,CAAC,IAAI,CAAC,OAAO,CAAC,GAAG,CAAC,KAAK,IAAI,CAAC,IAAI,CAAC,OAAO,CAAC,GAAG,CAAC,KAAK,SAAS,CAAC,EAAE;gBACxF,KAAK,CAAC,IAAI,CAAC,kBAAkB,CAAC,GAAG,CAAC,GAAG,GAAG,GAAG,kBAAkB,CAAC,OAAO,CAAC,GAAG,CAAC,CAAC,CAAC,CAAA;aAC/E;SACJ;QACD,MAAM,GAAG,GAAG,KAAK,CAAC,IAAI,CAAC,GAAG,CAAC,CAAA;QAC3B,IAAI,GAAG,KAAK,EAAE,EAAE;YACZ,OAAO,GAAG,GAAG,GAAG,CAAA;SACnB;QAED,OAAO,EAAE,CAAA;IACb,CAAC;+GAjVQ,oBAAoB;mHAApB,oBAAoB,cAFjB,MAAM;;4FAET,oBAAoB;kBAHhC,UAAU;mBAAC;oBACR,UAAU,EAAE,MAAM;iBACrB","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