@experteam-mx/ngx-services 15.0.0 → 16.0.0
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/README.md +7 -7
- package/{esm2020 → esm2022}/experteam-mx-ngx-services.mjs +4 -4
- package/{esm2020 → esm2022}/lib/apis/api-catalog.models.mjs +1 -1
- package/{esm2020 → esm2022}/lib/apis/api-companies.service.mjs +255 -255
- package/{esm2020 → esm2022}/lib/apis/api-security.service.mjs +128 -128
- package/{esm2020 → esm2022}/lib/apis/models/api-companies.interfaces.mjs +1 -1
- package/{esm2020 → esm2022}/lib/apis/models/api-companies.types.mjs +1 -1
- package/{esm2020 → esm2022}/lib/apis/models/api-security.interfaces.mjs +1 -1
- package/{esm2020 → esm2022}/lib/apis/models/api-security.types.mjs +1 -1
- package/{esm2020 → esm2022}/lib/apis/models/api.models.mjs +1 -1
- package/{esm2020 → esm2022}/lib/helpers/http.mjs +65 -65
- package/{esm2020 → esm2022}/lib/interceptors/api-headers.interceptor.mjs +34 -34
- package/{esm2020 → esm2022}/lib/interceptors/api-token.interceptor.mjs +35 -35
- package/{esm2020 → esm2022}/lib/interceptors/http-caching.interceptor.mjs +38 -38
- package/{esm2020 → esm2022}/lib/ngx-services.models.mjs +1 -1
- package/{esm2020 → esm2022}/lib/ngx-services.module.mjs +37 -37
- package/{esm2020 → esm2022}/public-api.mjs +19 -19
- package/{fesm2020 → fesm2022}/experteam-mx-ngx-services.mjs +557 -557
- package/{fesm2020 → fesm2022}/experteam-mx-ngx-services.mjs.map +1 -1
- package/index.d.ts +5 -5
- package/lib/apis/api-catalog.models.d.ts +71 -71
- package/lib/apis/api-companies.service.d.ts +163 -163
- package/lib/apis/api-security.service.d.ts +79 -79
- package/lib/apis/models/api-companies.interfaces.d.ts +380 -380
- package/lib/apis/models/api-companies.types.d.ts +75 -75
- package/lib/apis/models/api-security.interfaces.d.ts +55 -55
- package/lib/apis/models/api-security.types.d.ts +30 -30
- package/lib/apis/models/api.models.d.ts +23 -23
- package/lib/helpers/http.d.ts +38 -38
- package/lib/interceptors/api-headers.interceptor.d.ts +16 -16
- package/lib/interceptors/api-token.interceptor.d.ts +19 -19
- package/lib/interceptors/http-caching.interceptor.d.ts +12 -12
- package/lib/ngx-services.models.d.ts +22 -22
- package/lib/ngx-services.module.d.ts +17 -17
- package/package.json +10 -16
- package/public-api.d.ts +12 -12
- package/fesm2015/experteam-mx-ngx-services.mjs +0 -593
- package/fesm2015/experteam-mx-ngx-services.mjs.map +0 -1
|
@@ -1,128 +1,128 @@
|
|
|
1
|
-
import { Inject, Injectable } from '@angular/core';
|
|
2
|
-
import { HttpHeaders } from '@angular/common/http';
|
|
3
|
-
import { map, tap } from 'rxjs';
|
|
4
|
-
import * as i0 from "@angular/core";
|
|
5
|
-
import * as i1 from "@angular/common/http";
|
|
6
|
-
import * as i2 from "ngx-cookie-service";
|
|
7
|
-
export class ApiSecurityService {
|
|
8
|
-
constructor(environments, http, cookie) {
|
|
9
|
-
this.environments = environments;
|
|
10
|
-
this.http = http;
|
|
11
|
-
this.cookie = cookie;
|
|
12
|
-
}
|
|
13
|
-
/**
|
|
14
|
-
* Retrieves the API security URL from the environments configuration.
|
|
15
|
-
*
|
|
16
|
-
* @return {string} The API security URL.
|
|
17
|
-
*/
|
|
18
|
-
get url() {
|
|
19
|
-
return this.environments.apiSecurityUrl;
|
|
20
|
-
}
|
|
21
|
-
/**
|
|
22
|
-
* Authenticates a user with the provided credentials and role.
|
|
23
|
-
*
|
|
24
|
-
* @param {Object} param0 - The login input object.
|
|
25
|
-
* @param {string} param0.username - The username of the user.
|
|
26
|
-
* @param {string} param0.password - The password of the user.
|
|
27
|
-
* @param {string} param0.role - The role of the user.
|
|
28
|
-
* @return {Observable<LoginOut>} An observable emitting the login output object.
|
|
29
|
-
*/
|
|
30
|
-
login({ username, password, role, }) {
|
|
31
|
-
return this.http.post(`${this.url}/auth/login`, {
|
|
32
|
-
system_name: 'CRA',
|
|
33
|
-
username,
|
|
34
|
-
password,
|
|
35
|
-
role,
|
|
36
|
-
}).pipe(map(({ data }) => data), tap(({ access_token }) => this.cookie.set('tokenCRA', access_token, { path: '/' })));
|
|
37
|
-
}
|
|
38
|
-
/**
|
|
39
|
-
* Logs out the current user by making a POST request to the logout endpoint.
|
|
40
|
-
*
|
|
41
|
-
* This method deletes all cookies after a successful logout.
|
|
42
|
-
*
|
|
43
|
-
* @return {Observable<{}>} An observable that emits the server's response to the logout request.
|
|
44
|
-
*/
|
|
45
|
-
logout() {
|
|
46
|
-
return this.http.post(`${this.url}/auth/logout`, null)
|
|
47
|
-
.pipe(map(({ data }) => data), tap(() => this.cookie.deleteAll('/')));
|
|
48
|
-
}
|
|
49
|
-
/**
|
|
50
|
-
* Creates a new session for a specified model.
|
|
51
|
-
*
|
|
52
|
-
* @param {Object} params - The parameters for creating the session.
|
|
53
|
-
* @param {string} params.modelType - The type of the model.
|
|
54
|
-
* @param {string} params.modelId - The ID of the model.
|
|
55
|
-
* @param {string} [params.token] - Optional authorization token.
|
|
56
|
-
*
|
|
57
|
-
* @return {Observable<CreateSessionOut>} An observable containing the created session details.
|
|
58
|
-
*/
|
|
59
|
-
createSession({ modelType, modelId, token, }) {
|
|
60
|
-
let headers = new HttpHeaders({});
|
|
61
|
-
if (token)
|
|
62
|
-
headers = headers.set('Authorization', `Bearer ${token}`);
|
|
63
|
-
return this.http.post(`${this.url}/sessions`, {
|
|
64
|
-
model_type: modelType,
|
|
65
|
-
model_id: modelId,
|
|
66
|
-
}, {
|
|
67
|
-
headers
|
|
68
|
-
}).pipe(map(({ data }) => data));
|
|
69
|
-
}
|
|
70
|
-
/**
|
|
71
|
-
* Fetches the authenticated user's information.
|
|
72
|
-
* Sends a GET request to the endpoint '/auth/me' to retrieve information
|
|
73
|
-
* about the currently authenticated user.
|
|
74
|
-
*
|
|
75
|
-
* @return {Observable<MeOut>} An observable that emits the authenticated user's data.
|
|
76
|
-
*/
|
|
77
|
-
me() {
|
|
78
|
-
return this.http.get(`${this.url}/auth/me`)
|
|
79
|
-
.pipe(map(({ data }) => data));
|
|
80
|
-
}
|
|
81
|
-
/**
|
|
82
|
-
* Fetches the authenticated user's details from the server.
|
|
83
|
-
*
|
|
84
|
-
* @param token The JWT token used for authorization.
|
|
85
|
-
* @return An Observable that emits the user's details encapsulated in a MeOut object.
|
|
86
|
-
*/
|
|
87
|
-
otherMe(token) {
|
|
88
|
-
return this.http.get(`${this.url}/auth/me`, {
|
|
89
|
-
headers: {
|
|
90
|
-
Authorization: `Bearer ${token}`
|
|
91
|
-
}
|
|
92
|
-
}).pipe(map(({ data }) => data));
|
|
93
|
-
}
|
|
94
|
-
/**
|
|
95
|
-
* Fetches a user by their unique ID.
|
|
96
|
-
*
|
|
97
|
-
* @param {number} id - The unique identifier of the user to be fetched.
|
|
98
|
-
* @return {Observable<GetUserOut>} An observable containing the user information.
|
|
99
|
-
*/
|
|
100
|
-
user(id) {
|
|
101
|
-
return this.http.get(`${this.url}/users/${id}`)
|
|
102
|
-
.pipe(map(({ data }) => data));
|
|
103
|
-
}
|
|
104
|
-
/**
|
|
105
|
-
* Changes the language for the authenticated user.
|
|
106
|
-
*
|
|
107
|
-
* @param {Object} params - The input parameters for changing the language.
|
|
108
|
-
* @param {string} params.languageId - The ID of the new language to be set.
|
|
109
|
-
* @return {Observable<ApiSuccess<MeOut>>} An observable that emits the result of the language change request.
|
|
110
|
-
*/
|
|
111
|
-
changeLanguage({ languageId }) {
|
|
112
|
-
return this.http.put(`${this.url}/auth/me`, {
|
|
113
|
-
language_id: languageId
|
|
114
|
-
}).pipe(map(({ data }) => data));
|
|
115
|
-
}
|
|
116
|
-
}
|
|
117
|
-
|
|
118
|
-
|
|
119
|
-
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "
|
|
120
|
-
type: Injectable,
|
|
121
|
-
args: [{
|
|
122
|
-
providedIn: 'root'
|
|
123
|
-
}]
|
|
124
|
-
}], ctorParameters: function () { return [{ type: undefined, decorators: [{
|
|
125
|
-
type: Inject,
|
|
126
|
-
args: ['env']
|
|
127
|
-
}] }, { type: i1.HttpClient }, { type: i2.CookieService }]; } });
|
|
128
|
-
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"api-security.service.js","sourceRoot":"","sources":["../../../../../../projects/experteam/ngx-services/src/lib/apis/api-security.service.ts"],"names":[],"mappings":"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","sourcesContent":["import { Inject, Injectable } from '@angular/core'\r\nimport { ApiSuccess } from './models/api.models'\r\nimport {\r\n  ChangeLanguageIn,\r\n  CreateSessionIn,\r\n  CreateSessionOut,\r\n  GetUserInfoIn,\r\n  GetUserOut,\r\n  LoginIn,\r\n  LoginOut,\r\n  MeOut\r\n} from './models/api-security.types'\r\nimport { HttpClient, HttpHeaders } from '@angular/common/http'\r\nimport { Environment } from '../ngx-services.models'\r\nimport { map, Observable, tap } from 'rxjs'\r\nimport { CookieService } from 'ngx-cookie-service'\r\n\r\n@Injectable({\r\n  providedIn: 'root'\r\n})\r\nexport class ApiSecurityService {\r\n  constructor (\r\n    @Inject('env') private environments: Environment,\r\n    private http: HttpClient,\r\n    private cookie: CookieService,\r\n  ) {}\r\n\r\n  /**\r\n   * Retrieves the API security URL from the environments configuration.\r\n   *\r\n   * @return {string} The API security URL.\r\n   */\r\n  get url (): string {\r\n    return this.environments.apiSecurityUrl\r\n  }\r\n\r\n  /**\r\n   * Authenticates a user with the provided credentials and role.\r\n   *\r\n   * @param {Object} param0 - The login input object.\r\n   * @param {string} param0.username - The username of the user.\r\n   * @param {string} param0.password - The password of the user.\r\n   * @param {string} param0.role - The role of the user.\r\n   * @return {Observable<LoginOut>} An observable emitting the login output object.\r\n   */\r\n  login ({\r\n    username,\r\n    password,\r\n    role,\r\n  }: LoginIn): Observable<LoginOut> {\r\n    return this.http.post<ApiSuccess<LoginOut>>(`${this.url}/auth/login`, {\r\n      system_name: 'CRA',\r\n      username,\r\n      password,\r\n      role,\r\n    }).pipe(\r\n      map(({ data }) => data),\r\n      tap(({ access_token }) => this.cookie.set('tokenCRA', access_token, { path: '/' }))\r\n    )\r\n  }\r\n\r\n  /**\r\n   * Logs out the current user by making a POST request to the logout endpoint.\r\n   *\r\n   * This method deletes all cookies after a successful logout.\r\n   *\r\n   * @return {Observable<{}>} An observable that emits the server's response to the logout request.\r\n   */\r\n  logout (): Observable<{}> {\r\n    return this.http.post<ApiSuccess<{}>>(`${this.url}/auth/logout`, null)\r\n      .pipe(\r\n        map(({ data }) => data),\r\n        tap(() => this.cookie.deleteAll('/'))\r\n      )\r\n  }\r\n\r\n  /**\r\n   * Creates a new session for a specified model.\r\n   *\r\n   * @param {Object} params - The parameters for creating the session.\r\n   * @param {string} params.modelType - The type of the model.\r\n   * @param {string} params.modelId - The ID of the model.\r\n   * @param {string} [params.token] - Optional authorization token.\r\n   *\r\n   * @return {Observable<CreateSessionOut>} An observable containing the created session details.\r\n   */\r\n  createSession ({\r\n    modelType,\r\n    modelId,\r\n    token,\r\n  }: CreateSessionIn): Observable<CreateSessionOut> {\r\n    let headers = new HttpHeaders({})\r\n\r\n    if (token)\r\n      headers = headers.set('Authorization', `Bearer ${token}`)\r\n\r\n    return this.http.post<ApiSuccess<CreateSessionOut>>(\r\n      `${this.url}/sessions`, {\r\n        model_type: modelType,\r\n        model_id: modelId,\r\n      }, {\r\n        headers\r\n      }).pipe(map(({ data }) => data))\r\n  }\r\n\r\n  /**\r\n   * Fetches the authenticated user's information.\r\n   * Sends a GET request to the endpoint '/auth/me' to retrieve information\r\n   * about the currently authenticated user.\r\n   *\r\n   * @return {Observable<MeOut>} An observable that emits the authenticated user's data.\r\n   */\r\n  me (): Observable<MeOut> {\r\n    return this.http.get<ApiSuccess<MeOut>>(`${this.url}/auth/me`)\r\n      .pipe(map(({ data }) => data))\r\n  }\r\n\r\n  /**\r\n   * Fetches the authenticated user's details from the server.\r\n   *\r\n   * @param token The JWT token used for authorization.\r\n   * @return An Observable that emits the user's details encapsulated in a MeOut object.\r\n   */\r\n  otherMe (token: string): Observable<MeOut> {\r\n    return this.http.get<ApiSuccess<MeOut>>(`${this.url}/auth/me`, {\r\n      headers: {\r\n        Authorization: `Bearer ${token}`\r\n      }\r\n    }).pipe(map(({ data }) => data))\r\n  }\r\n\r\n  /**\r\n   * Fetches a user by their unique ID.\r\n   *\r\n   * @param {number} id - The unique identifier of the user to be fetched.\r\n   * @return {Observable<GetUserOut>} An observable containing the user information.\r\n   */\r\n  user (id: number): Observable<GetUserOut> {\r\n    return this.http.get<ApiSuccess<GetUserOut>>(`${this.url}/users/${id}`)\r\n      .pipe(map(({ data }) => data))\r\n  }\r\n\r\n  /**\r\n   * Changes the language for the authenticated user.\r\n   *\r\n   * @param {Object} params - The input parameters for changing the language.\r\n   * @param {string} params.languageId - The ID of the new language to be set.\r\n   * @return {Observable<ApiSuccess<MeOut>>} An observable that emits the result of the language change request.\r\n   */\r\n  changeLanguage ({\r\n    languageId\r\n  }: ChangeLanguageIn): Observable<MeOut> {\r\n    return this.http.put<ApiSuccess<MeOut>>(`${this.url}/auth/me`, {\r\n      language_id: languageId\r\n    }).pipe(map(({ data }) => data))\r\n  }\r\n}\r\n"]}
|
|
1
|
+
import { Inject, Injectable } from '@angular/core';
|
|
2
|
+
import { HttpHeaders } from '@angular/common/http';
|
|
3
|
+
import { map, tap } from 'rxjs';
|
|
4
|
+
import * as i0 from "@angular/core";
|
|
5
|
+
import * as i1 from "@angular/common/http";
|
|
6
|
+
import * as i2 from "ngx-cookie-service";
|
|
7
|
+
export class ApiSecurityService {
|
|
8
|
+
constructor(environments, http, cookie) {
|
|
9
|
+
this.environments = environments;
|
|
10
|
+
this.http = http;
|
|
11
|
+
this.cookie = cookie;
|
|
12
|
+
}
|
|
13
|
+
/**
|
|
14
|
+
* Retrieves the API security URL from the environments configuration.
|
|
15
|
+
*
|
|
16
|
+
* @return {string} The API security URL.
|
|
17
|
+
*/
|
|
18
|
+
get url() {
|
|
19
|
+
return this.environments.apiSecurityUrl;
|
|
20
|
+
}
|
|
21
|
+
/**
|
|
22
|
+
* Authenticates a user with the provided credentials and role.
|
|
23
|
+
*
|
|
24
|
+
* @param {Object} param0 - The login input object.
|
|
25
|
+
* @param {string} param0.username - The username of the user.
|
|
26
|
+
* @param {string} param0.password - The password of the user.
|
|
27
|
+
* @param {string} param0.role - The role of the user.
|
|
28
|
+
* @return {Observable<LoginOut>} An observable emitting the login output object.
|
|
29
|
+
*/
|
|
30
|
+
login({ username, password, role, }) {
|
|
31
|
+
return this.http.post(`${this.url}/auth/login`, {
|
|
32
|
+
system_name: 'CRA',
|
|
33
|
+
username,
|
|
34
|
+
password,
|
|
35
|
+
role,
|
|
36
|
+
}).pipe(map(({ data }) => data), tap(({ access_token }) => this.cookie.set('tokenCRA', access_token, { path: '/' })));
|
|
37
|
+
}
|
|
38
|
+
/**
|
|
39
|
+
* Logs out the current user by making a POST request to the logout endpoint.
|
|
40
|
+
*
|
|
41
|
+
* This method deletes all cookies after a successful logout.
|
|
42
|
+
*
|
|
43
|
+
* @return {Observable<{}>} An observable that emits the server's response to the logout request.
|
|
44
|
+
*/
|
|
45
|
+
logout() {
|
|
46
|
+
return this.http.post(`${this.url}/auth/logout`, null)
|
|
47
|
+
.pipe(map(({ data }) => data), tap(() => this.cookie.deleteAll('/')));
|
|
48
|
+
}
|
|
49
|
+
/**
|
|
50
|
+
* Creates a new session for a specified model.
|
|
51
|
+
*
|
|
52
|
+
* @param {Object} params - The parameters for creating the session.
|
|
53
|
+
* @param {string} params.modelType - The type of the model.
|
|
54
|
+
* @param {string} params.modelId - The ID of the model.
|
|
55
|
+
* @param {string} [params.token] - Optional authorization token.
|
|
56
|
+
*
|
|
57
|
+
* @return {Observable<CreateSessionOut>} An observable containing the created session details.
|
|
58
|
+
*/
|
|
59
|
+
createSession({ modelType, modelId, token, }) {
|
|
60
|
+
let headers = new HttpHeaders({});
|
|
61
|
+
if (token)
|
|
62
|
+
headers = headers.set('Authorization', `Bearer ${token}`);
|
|
63
|
+
return this.http.post(`${this.url}/sessions`, {
|
|
64
|
+
model_type: modelType,
|
|
65
|
+
model_id: modelId,
|
|
66
|
+
}, {
|
|
67
|
+
headers
|
|
68
|
+
}).pipe(map(({ data }) => data));
|
|
69
|
+
}
|
|
70
|
+
/**
|
|
71
|
+
* Fetches the authenticated user's information.
|
|
72
|
+
* Sends a GET request to the endpoint '/auth/me' to retrieve information
|
|
73
|
+
* about the currently authenticated user.
|
|
74
|
+
*
|
|
75
|
+
* @return {Observable<MeOut>} An observable that emits the authenticated user's data.
|
|
76
|
+
*/
|
|
77
|
+
me() {
|
|
78
|
+
return this.http.get(`${this.url}/auth/me`)
|
|
79
|
+
.pipe(map(({ data }) => data));
|
|
80
|
+
}
|
|
81
|
+
/**
|
|
82
|
+
* Fetches the authenticated user's details from the server.
|
|
83
|
+
*
|
|
84
|
+
* @param token The JWT token used for authorization.
|
|
85
|
+
* @return An Observable that emits the user's details encapsulated in a MeOut object.
|
|
86
|
+
*/
|
|
87
|
+
otherMe(token) {
|
|
88
|
+
return this.http.get(`${this.url}/auth/me`, {
|
|
89
|
+
headers: {
|
|
90
|
+
Authorization: `Bearer ${token}`
|
|
91
|
+
}
|
|
92
|
+
}).pipe(map(({ data }) => data));
|
|
93
|
+
}
|
|
94
|
+
/**
|
|
95
|
+
* Fetches a user by their unique ID.
|
|
96
|
+
*
|
|
97
|
+
* @param {number} id - The unique identifier of the user to be fetched.
|
|
98
|
+
* @return {Observable<GetUserOut>} An observable containing the user information.
|
|
99
|
+
*/
|
|
100
|
+
user(id) {
|
|
101
|
+
return this.http.get(`${this.url}/users/${id}`)
|
|
102
|
+
.pipe(map(({ data }) => data));
|
|
103
|
+
}
|
|
104
|
+
/**
|
|
105
|
+
* Changes the language for the authenticated user.
|
|
106
|
+
*
|
|
107
|
+
* @param {Object} params - The input parameters for changing the language.
|
|
108
|
+
* @param {string} params.languageId - The ID of the new language to be set.
|
|
109
|
+
* @return {Observable<ApiSuccess<MeOut>>} An observable that emits the result of the language change request.
|
|
110
|
+
*/
|
|
111
|
+
changeLanguage({ languageId }) {
|
|
112
|
+
return this.http.put(`${this.url}/auth/me`, {
|
|
113
|
+
language_id: languageId
|
|
114
|
+
}).pipe(map(({ data }) => data));
|
|
115
|
+
}
|
|
116
|
+
static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "16.2.12", ngImport: i0, type: ApiSecurityService, deps: [{ token: 'env' }, { token: i1.HttpClient }, { token: i2.CookieService }], target: i0.ɵɵFactoryTarget.Injectable }); }
|
|
117
|
+
static { this.ɵprov = i0.ɵɵngDeclareInjectable({ minVersion: "12.0.0", version: "16.2.12", ngImport: i0, type: ApiSecurityService, providedIn: 'root' }); }
|
|
118
|
+
}
|
|
119
|
+
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "16.2.12", ngImport: i0, type: ApiSecurityService, decorators: [{
|
|
120
|
+
type: Injectable,
|
|
121
|
+
args: [{
|
|
122
|
+
providedIn: 'root'
|
|
123
|
+
}]
|
|
124
|
+
}], ctorParameters: function () { return [{ type: undefined, decorators: [{
|
|
125
|
+
type: Inject,
|
|
126
|
+
args: ['env']
|
|
127
|
+
}] }, { type: i1.HttpClient }, { type: i2.CookieService }]; } });
|
|
128
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"api-security.service.js","sourceRoot":"","sources":["../../../../../../projects/experteam/ngx-services/src/lib/apis/api-security.service.ts"],"names":[],"mappings":"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","sourcesContent":["import { Inject, Injectable } from '@angular/core'\r\nimport { ApiSuccess } from './models/api.models'\r\nimport {\r\n  ChangeLanguageIn,\r\n  CreateSessionIn,\r\n  CreateSessionOut,\r\n  GetUserInfoIn,\r\n  GetUserOut,\r\n  LoginIn,\r\n  LoginOut,\r\n  MeOut\r\n} from './models/api-security.types'\r\nimport { HttpClient, HttpHeaders } from '@angular/common/http'\r\nimport { Environment } from '../ngx-services.models'\r\nimport { map, Observable, tap } from 'rxjs'\r\nimport { CookieService } from 'ngx-cookie-service'\r\n\r\n@Injectable({\r\n  providedIn: 'root'\r\n})\r\nexport class ApiSecurityService {\r\n  constructor (\r\n    @Inject('env') private environments: Environment,\r\n    private http: HttpClient,\r\n    private cookie: CookieService,\r\n  ) {}\r\n\r\n  /**\r\n   * Retrieves the API security URL from the environments configuration.\r\n   *\r\n   * @return {string} The API security URL.\r\n   */\r\n  get url (): string {\r\n    return this.environments.apiSecurityUrl\r\n  }\r\n\r\n  /**\r\n   * Authenticates a user with the provided credentials and role.\r\n   *\r\n   * @param {Object} param0 - The login input object.\r\n   * @param {string} param0.username - The username of the user.\r\n   * @param {string} param0.password - The password of the user.\r\n   * @param {string} param0.role - The role of the user.\r\n   * @return {Observable<LoginOut>} An observable emitting the login output object.\r\n   */\r\n  login ({\r\n    username,\r\n    password,\r\n    role,\r\n  }: LoginIn): Observable<LoginOut> {\r\n    return this.http.post<ApiSuccess<LoginOut>>(`${this.url}/auth/login`, {\r\n      system_name: 'CRA',\r\n      username,\r\n      password,\r\n      role,\r\n    }).pipe(\r\n      map(({ data }) => data),\r\n      tap(({ access_token }) => this.cookie.set('tokenCRA', access_token, { path: '/' }))\r\n    )\r\n  }\r\n\r\n  /**\r\n   * Logs out the current user by making a POST request to the logout endpoint.\r\n   *\r\n   * This method deletes all cookies after a successful logout.\r\n   *\r\n   * @return {Observable<{}>} An observable that emits the server's response to the logout request.\r\n   */\r\n  logout (): Observable<{}> {\r\n    return this.http.post<ApiSuccess<{}>>(`${this.url}/auth/logout`, null)\r\n      .pipe(\r\n        map(({ data }) => data),\r\n        tap(() => this.cookie.deleteAll('/'))\r\n      )\r\n  }\r\n\r\n  /**\r\n   * Creates a new session for a specified model.\r\n   *\r\n   * @param {Object} params - The parameters for creating the session.\r\n   * @param {string} params.modelType - The type of the model.\r\n   * @param {string} params.modelId - The ID of the model.\r\n   * @param {string} [params.token] - Optional authorization token.\r\n   *\r\n   * @return {Observable<CreateSessionOut>} An observable containing the created session details.\r\n   */\r\n  createSession ({\r\n    modelType,\r\n    modelId,\r\n    token,\r\n  }: CreateSessionIn): Observable<CreateSessionOut> {\r\n    let headers = new HttpHeaders({})\r\n\r\n    if (token)\r\n      headers = headers.set('Authorization', `Bearer ${token}`)\r\n\r\n    return this.http.post<ApiSuccess<CreateSessionOut>>(\r\n      `${this.url}/sessions`, {\r\n        model_type: modelType,\r\n        model_id: modelId,\r\n      }, {\r\n        headers\r\n      }).pipe(map(({ data }) => data))\r\n  }\r\n\r\n  /**\r\n   * Fetches the authenticated user's information.\r\n   * Sends a GET request to the endpoint '/auth/me' to retrieve information\r\n   * about the currently authenticated user.\r\n   *\r\n   * @return {Observable<MeOut>} An observable that emits the authenticated user's data.\r\n   */\r\n  me (): Observable<MeOut> {\r\n    return this.http.get<ApiSuccess<MeOut>>(`${this.url}/auth/me`)\r\n      .pipe(map(({ data }) => data))\r\n  }\r\n\r\n  /**\r\n   * Fetches the authenticated user's details from the server.\r\n   *\r\n   * @param token The JWT token used for authorization.\r\n   * @return An Observable that emits the user's details encapsulated in a MeOut object.\r\n   */\r\n  otherMe (token: string): Observable<MeOut> {\r\n    return this.http.get<ApiSuccess<MeOut>>(`${this.url}/auth/me`, {\r\n      headers: {\r\n        Authorization: `Bearer ${token}`\r\n      }\r\n    }).pipe(map(({ data }) => data))\r\n  }\r\n\r\n  /**\r\n   * Fetches a user by their unique ID.\r\n   *\r\n   * @param {number} id - The unique identifier of the user to be fetched.\r\n   * @return {Observable<GetUserOut>} An observable containing the user information.\r\n   */\r\n  user (id: number): Observable<GetUserOut> {\r\n    return this.http.get<ApiSuccess<GetUserOut>>(`${this.url}/users/${id}`)\r\n      .pipe(map(({ data }) => data))\r\n  }\r\n\r\n  /**\r\n   * Changes the language for the authenticated user.\r\n   *\r\n   * @param {Object} params - The input parameters for changing the language.\r\n   * @param {string} params.languageId - The ID of the new language to be set.\r\n   * @return {Observable<ApiSuccess<MeOut>>} An observable that emits the result of the language change request.\r\n   */\r\n  changeLanguage ({\r\n    languageId\r\n  }: ChangeLanguageIn): Observable<MeOut> {\r\n    return this.http.put<ApiSuccess<MeOut>>(`${this.url}/auth/me`, {\r\n      language_id: languageId\r\n    }).pipe(map(({ data }) => data))\r\n  }\r\n}\r\n"]}
|
|
@@ -1,2 +1,2 @@
|
|
|
1
|
-
export {};
|
|
1
|
+
export {};
|
|
2
2
|
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"api-companies.interfaces.js","sourceRoot":"","sources":["../../../../../../../projects/experteam/ngx-services/src/lib/apis/models/api-companies.interfaces.ts"],"names":[],"mappings":"","sourcesContent":["import { LaravelModel } from './api.models'\r\nimport { Currency, State } from '../api-catalog.models'\r\n\r\nexport interface Account extends LaravelModel {\r\n  number: string\r\n  description: string\r\n  account_type_id: number\r\n  country_id: number\r\n  is_default: boolean\r\n}\r\n\r\nexport interface Company extends LaravelModel {\r\n  id: number\r\n  created_at: string\r\n  updated_at: string\r\n  name: string\r\n  contact_name: string\r\n  contact_email: string\r\n  contact_phone: string\r\n  state: string\r\n  city: string\r\n  county_name: string\r\n  zip_code: string\r\n  address1: string\r\n  address2: string\r\n  address3: string\r\n  is_active: boolean\r\n}\r\n\r\nexport interface CompanyCountry extends LaravelModel {\r\n  company_id: number\r\n  country_id: number\r\n  headquarters_city_code: string\r\n  lp_code: string\r\n  company: Company\r\n  contact_name: string\r\n  contact_email: string\r\n  contact_phone_code: string\r\n  contact_phone_number: string\r\n  state: string\r\n  city: string\r\n  zip_code: string\r\n  county_name: string\r\n  address1: string\r\n  address2: string\r\n  address3: string\r\n}\r\n\r\nexport interface CompanyCountryTax extends LaravelModel {\r\n  code: string\r\n  name: string\r\n  percentage: number\r\n  company_country_id: number\r\n  shipment_scopes: number[]\r\n  base_percentage: number\r\n  tax_type: string\r\n}\r\n\r\nexport interface CountryCurrencyRate extends CountryReferenceCurrency {\r\n  rate: number\r\n}\r\n\r\nexport interface CountryReference extends LaravelModel {\r\n  language_id: number\r\n  decimal_point: number\r\n  decimal_separator: string\r\n  thousands_separator: string\r\n  use_billing: boolean\r\n  use_payments: boolean\r\n  restricted_import_countries: number[]\r\n  currency_id: number\r\n  max_quantity_document_piece: number\r\n  max_quantity_package_piece: number\r\n  weight_restriction_piece: number\r\n  restriction_shipment: number\r\n  restriction_dimension: number\r\n  max_declared_value: number\r\n  territories: number[]\r\n  some_openings: boolean\r\n  locale: string\r\n  country_id: number\r\n  label_printer_name: string\r\n  receipt_printer_name: string\r\n  others_printer_name: string\r\n}\r\n\r\nexport interface CountryReferenceCurrency extends LaravelModel {\r\n  country_id: number\r\n  currency_id: number\r\n  is_local: boolean\r\n  can_transact: boolean\r\n  code: string\r\n  name: string\r\n  is_default: boolean\r\n  is_declared_insured: boolean\r\n  currency: Currency\r\n}\r\n\r\nexport interface Employee extends LaravelModel {\r\n  name: string\r\n  last_name: string\r\n  number: string\r\n  company_id: number\r\n  country_id: number\r\n  external: boolean\r\n  phone_code: string\r\n  phone_number: string\r\n  is_active: boolean\r\n  password: string\r\n  roles: string[]\r\n  locations: Location[]\r\n}\r\n\r\nexport interface Exchange extends LaravelModel {\r\n  company_country_currency_id: number\r\n  valid_since: string\r\n  valid_until: string | null\r\n  value: number\r\n  type: string\r\n}\r\n\r\nexport interface Installation extends LaravelModel {\r\n  system_id: number\r\n  mac_address: string\r\n  ip_address: string\r\n  location_id: number\r\n}\r\n\r\nexport interface Location extends LaravelModel {\r\n  name: string\r\n  contact_name: string\r\n  email: string\r\n  facility_code: string\r\n  location_code: string\r\n  type: string\r\n  state_name: string\r\n  state_id: number\r\n  state_code: string\r\n  city_name: string\r\n  zip_code: string\r\n  county_name: string\r\n  address1: string\r\n  address2: string\r\n  address3: string\r\n  service_area_code: string\r\n  iata_code: string\r\n  phone_code: string\r\n  phone_number: string\r\n  gmt_offset: string\r\n  company_country_id: number\r\n  country_zone_id: number\r\n  country_region_id: number\r\n  management_area_id: number\r\n  google_maps_id: string\r\n  route_number: string\r\n  locker_enabled: boolean\r\n  queue_manager_enabled: boolean\r\n  commission_account: string\r\n  service_point_id: string\r\n  is_occurs: boolean\r\n  accounts: Account[]\r\n  company_country: CompanyCountry\r\n  state: State\r\n}\r\n\r\nexport interface LocationEmployee extends LaravelModel {\r\n  location_id: number\r\n  employee_id: number\r\n  is_active: boolean\r\n  is_supervisor: boolean\r\n  employee: Employee\r\n  location: Location\r\n}\r\n\r\nexport interface Parameter {\r\n  name: string\r\n  value: any\r\n  status?: string\r\n}\r\n\r\nexport interface SupplyEntity extends LaravelModel {\r\n  name: string\r\n  description: string\r\n  country_id: number\r\n  enabled_for_dropoff: boolean\r\n  supply_type: SupplyType\r\n  supply_packing: SupplyPacking\r\n}\r\n\r\nexport interface SupplyPacking extends LaravelModel {\r\n  value: number\r\n  weight: number\r\n  height: number\r\n  depth: number\r\n  width: number\r\n  emobile_code: string | null\r\n}\r\n\r\nexport interface SupplyType extends LaravelModel {\r\n  name: string\r\n}\r\n\r\nexport interface Workflow {\r\n  page: string\r\n  enabled: boolean\r\n}\r\nexport interface LocationEmployee extends LaravelModel {\r\n  location_id: number\r\n  employee_id: number\r\n  is_active: boolean\r\n  is_supervisor: boolean\r\n  employee: Employee\r\n  location: Location\r\n}\r\n\r\nexport interface Employee extends LaravelModel {\r\n  name: string\r\n  last_name: string\r\n  number: string\r\n  company_id: number\r\n  country_id: number\r\n  external: boolean\r\n  phone_code: string\r\n  phone_number: string\r\n  is_active: boolean\r\n  password: string\r\n  roles: string[]\r\n  locations: Location[]\r\n}\r\n\r\nexport interface Location extends LaravelModel {\r\n  name: string\r\n  contact_name: string\r\n  email: string\r\n  facility_code: string\r\n  location_code: string\r\n  type: string\r\n  state_name: string\r\n  state_id: number\r\n  state_code: string\r\n  city_name: string\r\n  zip_code: string\r\n  county_name: string\r\n  address1: string\r\n  address2: string\r\n  address3: string\r\n  service_area_code: string\r\n  iata_code: string\r\n  phone_code: string\r\n  phone_number: string\r\n  gmt_offset: string\r\n  company_country_id: number\r\n  country_zone_id: number\r\n  country_region_id: number\r\n  management_area_id: number\r\n  google_maps_id: string\r\n  route_number: string\r\n  locker_enabled: boolean\r\n  queue_manager_enabled: boolean\r\n  commission_account: string\r\n  service_point_id: string\r\n  is_occurs: boolean\r\n  accounts: Account[]\r\n  company_country: CompanyCountry\r\n  state: State\r\n}\r\n\r\nexport interface Company extends LaravelModel {\r\n  id: number\r\n  created_at: string\r\n  updated_at: string\r\n  name: string\r\n  contact_name: string\r\n  contact_email: string\r\n  contact_phone: string\r\n  state: string\r\n  city: string\r\n  county_name: string\r\n  zip_code: string\r\n  address1: string\r\n  address2: string\r\n  address3: string\r\n  is_active: boolean\r\n}\r\n\r\nexport interface CompanyCountry extends LaravelModel {\r\n  company_id: number\r\n  country_id: number\r\n  headquarters_city_code: string\r\n  lp_code: string\r\n  company: Company\r\n  contact_name: string\r\n  contact_email: string\r\n  contact_phone_code: string\r\n  contact_phone_number: string\r\n  state: string\r\n  city: string\r\n  zip_code: string\r\n  county_name: string\r\n  address1: string\r\n  address2: string\r\n  address3: string\r\n}\r\n\r\nexport interface Installation extends LaravelModel {\r\n  system_id: number\r\n  mac_address: string\r\n  ip_address: string\r\n  location_id: number\r\n}\r\n\r\nexport interface SupplyEntity extends LaravelModel {\r\n  name: string\r\n  description: string\r\n  country_id: number\r\n  enabled_for_dropoff: boolean\r\n  supply_type: SupplyType\r\n  supply_packing: SupplyPacking\r\n}\r\n\r\nexport interface SupplyType extends LaravelModel {\r\n  name: string\r\n}\r\n\r\nexport interface SupplyPacking extends LaravelModel {\r\n  value: number\r\n  weight: number\r\n  height: number\r\n  depth: number\r\n  width: number\r\n  emobile_code: string | null\r\n}\r\n\r\nexport interface Employee extends LaravelModel {\r\n  name: string\r\n  last_name: string\r\n  number: string\r\n  company_id: number\r\n  country_id: number\r\n  external: boolean\r\n  phone_code: string\r\n  phone_number: string\r\n  is_active: boolean\r\n  password: string\r\n  roles: string[]\r\n  locations: Location[]\r\n}\r\n\r\nexport interface CountryReferenceCurrency extends LaravelModel {\r\n  country_id: number\r\n  currency_id: number\r\n  is_local: boolean\r\n  can_transact: boolean\r\n  code: string\r\n  name: string\r\n  is_default: boolean\r\n  is_declared_insured: boolean\r\n  currency: Currency\r\n}\r\n\r\nexport interface CompanyCountryTax extends LaravelModel {\r\n  code: string\r\n  name: string\r\n  percentage: number\r\n  company_country_id: number\r\n  shipment_scopes: number[]\r\n  base_percentage: number\r\n  tax_type: string\r\n}\r\n\r\nexport interface Exchange extends LaravelModel {\r\n  company_country_currency_id: number\r\n  valid_since: string\r\n  valid_until: string | null\r\n  value: number\r\n  type: string\r\n}\r\n\r\nexport interface Parameter {\r\n  name: string\r\n  value: any\r\n  status?: string\r\n}\r\n\r\nexport interface CountryReference extends LaravelModel {\r\n  language_id: number\r\n  decimal_point: number\r\n  decimal_separator: string\r\n  thousands_separator: string\r\n  use_billing: boolean\r\n  use_payments: boolean\r\n  restricted_import_countries: number[]\r\n  currency_id: number\r\n  max_quantity_document_piece: number\r\n  max_quantity_package_piece: number\r\n  weight_restriction_piece: number\r\n  restriction_shipment: number\r\n  restriction_dimension: number\r\n  max_declared_value: number\r\n  territories: number[]\r\n  some_openings: boolean\r\n  locale: string\r\n  country_id: number\r\n  label_printer_name: string\r\n  receipt_printer_name: string\r\n  others_printer_name: string\r\n}\r\n\r\nexport interface Workflow {\r\n  page: string\r\n  enabled: boolean\r\n}\r\n"]}
|
|
@@ -1,2 +1,2 @@
|
|
|
1
|
-
export {};
|
|
1
|
+
export {};
|
|
2
2
|
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiYXBpLWNvbXBhbmllcy50eXBlcy5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uLy4uLy4uLy4uLy4uLy4uL3Byb2plY3RzL2V4cGVydGVhbS9uZ3gtc2VydmljZXMvc3JjL2xpYi9hcGlzL21vZGVscy9hcGktY29tcGFuaWVzLnR5cGVzLnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiIiLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQge1xyXG4gIEFjY291bnQsXHJcbiAgQ29tcGFueUNvdW50cnksXHJcbiAgQ29tcGFueUNvdW50cnlUYXgsXHJcbiAgQ291bnRyeVJlZmVyZW5jZSxcclxuICBDb3VudHJ5UmVmZXJlbmNlQ3VycmVuY3ksXHJcbiAgRW1wbG95ZWUsXHJcbiAgRXhjaGFuZ2UsXHJcbiAgSW5zdGFsbGF0aW9uLFxyXG4gIExvY2F0aW9uLFxyXG4gIExvY2F0aW9uRW1wbG95ZWUsXHJcbiAgUGFyYW1ldGVyLFxyXG4gIFN1cHBseUVudGl0eSxcclxuICBXb3JrZmxvd1xyXG59IGZyb20gJy4vYXBpLWNvbXBhbmllcy5pbnRlcmZhY2VzJ1xyXG5cclxuZXhwb3J0IHR5cGUgTG9jYXRpb25FbXBsb3llZXNEYXRhID0ge1xyXG4gIGxvY2F0aW9uX2VtcGxveWVlczogTG9jYXRpb25FbXBsb3llZVtdXHJcbiAgdG90YWw6IG51bWJlclxyXG59XHJcblxyXG5leHBvcnQgdHlwZSBJbnN0YWxsYXRpb25zRGF0YSA9IHtcclxuICBpbnN0YWxsYXRpb25zOiBJbnN0YWxsYXRpb25bXVxyXG4gIHRvdGFsOiBudW1iZXJcclxufVxyXG5cclxuZXhwb3J0IHR5cGUgSW5zdGFsbGF0aW9uRGF0YSA9IHtcclxuICBpbnN0YWxsYXRpb246IEluc3RhbGxhdGlvblxyXG59XHJcblxyXG5leHBvcnQgdHlwZSBMb2NhdGlvbnNEYXRhID0ge1xyXG4gIGxvY2F0aW9uczogTG9jYXRpb25bXVxyXG4gIHRvdGFsOiBudW1iZXJcclxufVxyXG5cclxuZXhwb3J0IHR5cGUgTG9jYXRpb25EYXRhID0ge1xyXG4gIGxvY2F0aW9uOiBMb2NhdGlvblxyXG59XHJcblxyXG5leHBvcnQgdHlwZSBTdXBwbHlFbnRpdGllc0RhdGEgPSB7XHJcbiAgc3VwcGx5X2VudGl0aWVzOiBTdXBwbHlFbnRpdHlbXVxyXG4gIHRvdGFsOiBudW1iZXJcclxufVxyXG5cclxuZXhwb3J0IHR5cGUgRW1wbG95ZWVzRGF0YSA9IHtcclxuICBlbXBsb3llZXM6IEVtcGxveWVlW11cclxuICB0b3RhbDogbnVtYmVyXHJcbn1cclxuXHJcbmV4cG9ydCB0eXBlIEVtcGxveWVlRGF0YSA9IHtcclxuICBlbXBsb3llZTogRW1wbG95ZWVcclxufVxyXG5cclxuZXhwb3J0IHR5cGUgQ29tcGFueUNvdW50cmllc0RhdGEgPSB7XHJcbiAgY29tcGFueV9jb3VudHJpZXM6IENvbXBhbnlDb3VudHJ5W11cclxuICB0b3RhbDogbnVtYmVyXHJcbn1cclxuXHJcbmV4cG9ydCB0eXBlIENvbXBhbnlDb3VudHJ5RGF0YSA9IHtcclxuICBjb21wYW55X2NvdW50cnk6IENvbXBhbnlDb3VudHJ5XHJcbn1cclxuXHJcbmV4cG9ydCB0eXBlIENvdW50cnlSZWZlcmVuY2VDdXJyZW5jaWVzRGF0YSA9IHtcclxuICBjb3VudHJ5X3JlZmVyZW5jZV9jdXJyZW5jaWVzOiBDb3VudHJ5UmVmZXJlbmNlQ3VycmVuY3lbXVxyXG4gIHRvdGFsOiBudW1iZXJcclxufVxyXG5cclxuZXhwb3J0IHR5cGUgQ29tcGFueUNvdW50cnlUYXhlc0RhdGEgPSB7XHJcbiAgY29tcGFueV9jb3VudHJ5X3RheGVzOiBDb21wYW55Q291bnRyeVRheFtdXHJcbiAgdG90YWw6IG51bWJlclxyXG59XHJcblxyXG5leHBvcnQgdHlwZSBFeGNoYW5nZXNEYXRhID0ge1xyXG4gIGV4Y2hhbmdlczogRXhjaGFuZ2VbXVxyXG4gIHRvdGFsOiBudW1iZXJcclxufVxyXG5cclxuZXhwb3J0IHR5cGUgQWNjb3VudEVudGl0aWVzRGF0YSA9IHtcclxuICBhY2NvdW50X2VudGl0aWVzOiBBY2NvdW50W11cclxuICB0b3RhbDogbnVtYmVyXHJcbn1cclxuXHJcbmV4cG9ydCB0eXBlIFBhcmFtZXRlcnNQcm9wcyA9IHtcclxuICBwYXJhbU5hbWVzOiBzdHJpbmdbXVxyXG59XHJcbmV4cG9ydCB0eXBlIFBhcmFtZXRlcnNEYXRhID0ge1xyXG4gIHBhcmFtZXRlcnM6IFBhcmFtZXRlcltdXHJcbiAgdG90YWw6IG51bWJlclxyXG59XHJcblxyXG5leHBvcnQgdHlwZSBQYXJhbWV0ZXJWYWx1ZVByb3BzID0ge1xyXG4gIHBhcmFtTmFtZTogc3RyaW5nXHJcbn1cclxuZXhwb3J0IHR5cGUgUGFyYW1ldGVyVmFsdWVEYXRhID0ge1xyXG4gIHZhbHVlOiBhbnlcclxufVxyXG5cclxuZXhwb3J0IHR5cGUgQ291bnRyeVJlZmVyZW5jZXNEYXRhID0ge1xyXG4gIGNvdW50cnlfcmVmZXJlbmNlczogQ291bnRyeVJlZmVyZW5jZVtdXHJcbn1cclxuXHJcbmV4cG9ydCB0eXBlIENvdW50cnlSZWZlcmVuY2VEYXRhID0ge1xyXG4gIGNvdW50cnlfcmVmZXJlbmNlOiBDb3VudHJ5UmVmZXJlbmNlXHJcbn1cclxuXHJcbmV4cG9ydCB0eXBlIFdvcmtmbG93c0RhdGEgPSB7XHJcbiAgd29ya2Zsb3c6IFdvcmtmbG93W11cclxufVxyXG4iXX0=
|
|
@@ -1,2 +1,2 @@
|
|
|
1
|
-
export {};
|
|
1
|
+
export {};
|
|
2
2
|
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiYXBpLXNlY3VyaXR5LmludGVyZmFjZXMuanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi8uLi8uLi8uLi8uLi9wcm9qZWN0cy9leHBlcnRlYW0vbmd4LXNlcnZpY2VzL3NyYy9saWIvYXBpcy9tb2RlbHMvYXBpLXNlY3VyaXR5LmludGVyZmFjZXMudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IiIsInNvdXJjZXNDb250ZW50IjpbImltcG9ydCB7IExhcmF2ZWxNb2RlbCB9IGZyb20gJy4vYXBpLm1vZGVscydcclxuaW1wb3J0IHsgTGFuZ3VhZ2UgfSBmcm9tICcuLi9hcGktY2F0YWxvZy5tb2RlbHMnXHJcblxyXG5leHBvcnQgaW50ZXJmYWNlIFNlc3Npb24gZXh0ZW5kcyBMYXJhdmVsTW9kZWwge1xyXG4gIG5hbWU6IHN0cmluZ1xyXG4gIHVzZXJuYW1lOiBzdHJpbmdcclxuICBlbWFpbDogc3RyaW5nXHJcbiAgbW9kZWxfdHlwZTogc3RyaW5nXHJcbiAgbW9kZWxfaWQ6IG51bWJlclxyXG4gIGF1dGhfdHlwZTogc3RyaW5nXHJcbiAgbGFuZ3VhZ2VfaWQ6IG51bWJlclxyXG4gIGNvdW50cnlfaWQ6IG51bWJlclxyXG4gIGxvY2F0aW9uX2lkOiBudW1iZXJcclxuICBpbnN0YWxsYXRpb25faWQ6IG51bWJlclxyXG4gIGNvbXBhbnlfY291bnRyeV9pZDogbnVtYmVyXHJcbiAgY291bnRyeV9yZWZlcmVuY2VfY3VycmVuY3lfaWQ6IG51bWJlclxyXG4gIG9wZW5pbmdfaWQ6IG51bWJlclxyXG4gIGxvY2FsZTogc3RyaW5nXHJcbiAgcGVybWlzc2lvbnM6IHN0cmluZ1tdXHJcbiAgcm9sZXM6IFJvbGVbXVxyXG4gIHNlc3Npb246IFNlc3Npb25cclxufVxyXG5cclxuZXhwb3J0IGludGVyZmFjZSBSb2xlIGV4dGVuZHMgTGFyYXZlbE1vZGVsIHtcclxuICBjb2RlOiBzdHJpbmdcclxuICBuYW1lOiBzdHJpbmdcclxuICBndWFyZF9uYW1lOiBzdHJpbmdcclxuICBwZXJtaXNzaW9uczogUGVybWlzc2lvbltdXHJcbiAgcm9sZV90eXBlX2lkOiBudW1iZXJcclxuICByb2xlX3R5cGU6IFJvbGVUeXBlXHJcbiAgY29tcGFueV9jb3VudHJ5X2lkOiBudW1iZXJcclxufVxyXG5cclxuZXhwb3J0IGludGVyZmFjZSBSb2xlVHlwZSBleHRlbmRzIExhcmF2ZWxNb2RlbCB7XHJcbiAgbmFtZTogc3RyaW5nXHJcbiAgbGV2ZWw6IG51bWJlclxyXG59XHJcblxyXG5leHBvcnQgaW50ZXJmYWNlIFBlcm1pc3Npb24gZXh0ZW5kcyBMYXJhdmVsTW9kZWwge1xyXG4gIG5hbWU6IHN0cmluZ1xyXG4gIGd1YXJkX25hbWU6IHN0cmluZ1xyXG4gIHBpdm90OiB7XHJcbiAgICByb2xlX2lkOiBudW1iZXJcclxuICAgIHBlcm1pc3Npb25faWQ6IG51bWJlclxyXG4gIH1cclxufVxyXG5cclxuZXhwb3J0IGludGVyZmFjZSBVc2VyIGV4dGVuZHMgTGFyYXZlbE1vZGVsIHtcclxuICBuYW1lOiBzdHJpbmdcclxuICB1c2VybmFtZTogc3RyaW5nXHJcbiAgZW1haWw6IHN0cmluZ1xyXG4gIG1vZGVsX3R5cGU6IHN0cmluZ1xyXG4gIG1vZGVsX2lkOiBudW1iZXJcclxuICBhdXRoX3R5cGU6IHN0cmluZ1xyXG4gIGxhbmd1YWdlX2lkOiBudW1iZXJcclxuICBwZXJtaXNzaW9uczogc3RyaW5nW11cclxuICByb2xlOiBSb2xlXHJcbiAgc2Vzc2lvbjogU2Vzc2lvblxyXG4gIGxhbmd1YWdlOiBMYW5ndWFnZVxyXG59XHJcbiJdfQ==
|
|
@@ -1,2 +1,2 @@
|
|
|
1
|
-
export {};
|
|
1
|
+
export {};
|
|
2
2
|
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiYXBpLXNlY3VyaXR5LnR5cGVzLmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vLi4vLi4vLi4vLi4vLi4vLi4vcHJvamVjdHMvZXhwZXJ0ZWFtL25neC1zZXJ2aWNlcy9zcmMvbGliL2FwaXMvbW9kZWxzL2FwaS1zZWN1cml0eS50eXBlcy50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiIiwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IHsgU2Vzc2lvbiwgVXNlciB9IGZyb20gJy4vYXBpLXNlY3VyaXR5LmludGVyZmFjZXMnXHJcblxyXG5leHBvcnQgdHlwZSBMb2dpbkluID0ge1xyXG4gIHVzZXJuYW1lOiBzdHJpbmdcclxuICBwYXNzd29yZDogc3RyaW5nXHJcbiAgcm9sZT86IHN0cmluZ1xyXG59XHJcbmV4cG9ydCB0eXBlIExvZ2luT3V0ID0ge1xyXG4gIGFjY2Vzc190b2tlbjogc3RyaW5nXHJcbiAgdG9rZW5fdHlwZTogc3RyaW5nXHJcbiAgZXhwaXJlc19pbjogbnVtYmVyXHJcbn1cclxuXHJcbmV4cG9ydCB0eXBlIENyZWF0ZVNlc3Npb25JbiA9IHtcclxuICBtb2RlbFR5cGU6IHN0cmluZ1xyXG4gIG1vZGVsSWQ6IG51bWJlclxyXG4gIHRva2VuPzogc3RyaW5nXHJcbn1cclxuZXhwb3J0IHR5cGUgQ3JlYXRlU2Vzc2lvbk91dCA9IHtcclxuICBzZXNzaW9uOiBTZXNzaW9uXHJcbn1cclxuXHJcbmV4cG9ydCB0eXBlIEdldFVzZXJPdXQgPSB7XHJcbiAgdXNlcjogVXNlclxyXG59XHJcblxyXG5leHBvcnQgaW50ZXJmYWNlIE1lT3V0IGV4dGVuZHMgR2V0VXNlck91dCB7XHJcbn1cclxuXHJcbmV4cG9ydCB0eXBlIEdldFVzZXJJbmZvSW4gPSB7XHJcbiAgdG9rZW46IHN0cmluZ1xyXG59XHJcblxyXG5leHBvcnQgdHlwZSBDaGFuZ2VMYW5ndWFnZUluID0ge1xyXG4gIGxhbmd1YWdlSWQ6IG51bWJlclxyXG59XHJcbiJdfQ==
|
|
@@ -1,2 +1,2 @@
|
|
|
1
|
-
export {};
|
|
1
|
+
export {};
|
|
2
2
|
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiYXBpLm1vZGVscy5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uLy4uLy4uLy4uLy4uLy4uL3Byb2plY3RzL2V4cGVydGVhbS9uZ3gtc2VydmljZXMvc3JjL2xpYi9hcGlzL21vZGVscy9hcGkubW9kZWxzLnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiIiLCJzb3VyY2VzQ29udGVudCI6WyJleHBvcnQgaW50ZXJmYWNlIEFwaVJlc3BvbnNlIHtcclxuICBzdGF0dXM6ICdzdWNjZXNzJyB8ICdmYWlsJyB8ICdlcnJvcidcclxufVxyXG5cclxuZXhwb3J0IGludGVyZmFjZSBBcGlTdWNjZXNzPFQ+IGV4dGVuZHMgQXBpUmVzcG9uc2Uge1xyXG4gIHN0YXR1czogJ3N1Y2Nlc3MnXHJcbiAgZGF0YTogVFxyXG59XHJcblxyXG5leHBvcnQgaW50ZXJmYWNlIEFwaU1vZGVsIHtcclxuICBpZDogbnVtYmVyXHJcbn1cclxuXHJcbmV4cG9ydCBpbnRlcmZhY2UgTGFyYXZlbE1vZGVsIGV4dGVuZHMgQXBpTW9kZWwge1xyXG4gIGlzX2FjdGl2ZTogYm9vbGVhblxyXG4gIGNyZWF0ZWRfYXQ6IERhdGUgfCBzdHJpbmdcclxuICB1cGRhdGVkX2F0OiBEYXRlIHwgc3RyaW5nXHJcbn1cclxuXHJcbmV4cG9ydCBpbnRlcmZhY2UgU3ltZm9ueU1vZGVsIGV4dGVuZHMgQXBpTW9kZWwge1xyXG4gIGlzQWN0aXZlOiBib29sZWFuXHJcbiAgY3JlYXRlZEF0OiBEYXRlIHwgc3RyaW5nXHJcbiAgdXBkYXRlZEF0OiBEYXRlIHwgc3RyaW5nXHJcbn1cclxuXHJcbmV4cG9ydCBpbnRlcmZhY2UgUXVlcnlQYXJhbXMge1xyXG4gIFtwYXJhbTogc3RyaW5nXTogc3RyaW5nIHwgbnVtYmVyIHwgYm9vbGVhbiB8IFJlYWRvbmx5QXJyYXk8c3RyaW5nIHwgbnVtYmVyIHwgYm9vbGVhbj5cclxufVxyXG4iXX0=
|
|
@@ -1,66 +1,66 @@
|
|
|
1
|
-
import { HttpHeaders, HttpParams } from '@angular/common/http';
|
|
2
|
-
/**
|
|
3
|
-
* Convert an object of key-value pairs into a URL query string.
|
|
4
|
-
*
|
|
5
|
-
* @param {Object} params - The key-value pairs to converted into a query string.
|
|
6
|
-
*
|
|
7
|
-
* @return {string} - The generated query string.
|
|
8
|
-
*/
|
|
9
|
-
export const queryString = (params) => {
|
|
10
|
-
let queryElements = [];
|
|
11
|
-
Object.entries(params).forEach(([key, value]) => {
|
|
12
|
-
if (Array.isArray(value)) {
|
|
13
|
-
const arrayQuery = value
|
|
14
|
-
.map((item) => `${encodeURIComponent(key)}=${encodeURIComponent(item)}`)
|
|
15
|
-
.join('&');
|
|
16
|
-
queryElements.push(arrayQuery);
|
|
17
|
-
}
|
|
18
|
-
else {
|
|
19
|
-
const encodedQuery = `${encodeURIComponent(key)}=${encodeURIComponent(value)}`;
|
|
20
|
-
queryElements.push(encodedQuery);
|
|
21
|
-
}
|
|
22
|
-
});
|
|
23
|
-
const queryString = queryElements.join('&');
|
|
24
|
-
return queryString.length ? `?${queryString}` : '';
|
|
25
|
-
};
|
|
26
|
-
/**
|
|
27
|
-
* Creates an instance of HttpParams using the provided params object.
|
|
28
|
-
*
|
|
29
|
-
* @param {Object} params - The object containing the params to the HttpParams constructor.
|
|
30
|
-
*
|
|
31
|
-
* @returns {HttpParams} - An instance of HttpParams created from the params object.
|
|
32
|
-
*/
|
|
33
|
-
export const httpParams = (params) => new HttpParams({
|
|
34
|
-
fromObject: params
|
|
35
|
-
});
|
|
36
|
-
/**
|
|
37
|
-
* Returns the headers for generating PDF files.
|
|
38
|
-
*
|
|
39
|
-
* @param {string} format - The format of the headers, 'object' or 'http_header'.
|
|
40
|
-
*
|
|
41
|
-
* @returns {HttpHeaders | { [header: string]: string | string[] }} - The headers for generating PDF files.
|
|
42
|
-
*/
|
|
43
|
-
export const pdfHeaders = (format = 'object') => {
|
|
44
|
-
const headers = {
|
|
45
|
-
'Accept': 'application/pdf'
|
|
46
|
-
};
|
|
47
|
-
return format === 'object'
|
|
48
|
-
? headers
|
|
49
|
-
: new HttpHeaders(headers);
|
|
50
|
-
};
|
|
51
|
-
/**
|
|
52
|
-
* Returns the headers for generating XML files.
|
|
53
|
-
*
|
|
54
|
-
* @param {string} format - The format of the headers, 'object' or 'http_header'.
|
|
55
|
-
*
|
|
56
|
-
* @returns {HttpHeaders | { [header: string]: string | string[] }} - The headers for generating XML files.
|
|
57
|
-
*/
|
|
58
|
-
export const xmlHeaders = (format = 'object') => {
|
|
59
|
-
const headers = {
|
|
60
|
-
'Accept': 'application/xml',
|
|
61
|
-
};
|
|
62
|
-
return format === 'object'
|
|
63
|
-
? headers
|
|
64
|
-
: new HttpHeaders(headers);
|
|
65
|
-
};
|
|
1
|
+
import { HttpHeaders, HttpParams } from '@angular/common/http';
|
|
2
|
+
/**
|
|
3
|
+
* Convert an object of key-value pairs into a URL query string.
|
|
4
|
+
*
|
|
5
|
+
* @param {Object} params - The key-value pairs to converted into a query string.
|
|
6
|
+
*
|
|
7
|
+
* @return {string} - The generated query string.
|
|
8
|
+
*/
|
|
9
|
+
export const queryString = (params) => {
|
|
10
|
+
let queryElements = [];
|
|
11
|
+
Object.entries(params).forEach(([key, value]) => {
|
|
12
|
+
if (Array.isArray(value)) {
|
|
13
|
+
const arrayQuery = value
|
|
14
|
+
.map((item) => `${encodeURIComponent(key)}=${encodeURIComponent(item)}`)
|
|
15
|
+
.join('&');
|
|
16
|
+
queryElements.push(arrayQuery);
|
|
17
|
+
}
|
|
18
|
+
else {
|
|
19
|
+
const encodedQuery = `${encodeURIComponent(key)}=${encodeURIComponent(value)}`;
|
|
20
|
+
queryElements.push(encodedQuery);
|
|
21
|
+
}
|
|
22
|
+
});
|
|
23
|
+
const queryString = queryElements.join('&');
|
|
24
|
+
return queryString.length ? `?${queryString}` : '';
|
|
25
|
+
};
|
|
26
|
+
/**
|
|
27
|
+
* Creates an instance of HttpParams using the provided params object.
|
|
28
|
+
*
|
|
29
|
+
* @param {Object} params - The object containing the params to the HttpParams constructor.
|
|
30
|
+
*
|
|
31
|
+
* @returns {HttpParams} - An instance of HttpParams created from the params object.
|
|
32
|
+
*/
|
|
33
|
+
export const httpParams = (params) => new HttpParams({
|
|
34
|
+
fromObject: params
|
|
35
|
+
});
|
|
36
|
+
/**
|
|
37
|
+
* Returns the headers for generating PDF files.
|
|
38
|
+
*
|
|
39
|
+
* @param {string} format - The format of the headers, 'object' or 'http_header'.
|
|
40
|
+
*
|
|
41
|
+
* @returns {HttpHeaders | { [header: string]: string | string[] }} - The headers for generating PDF files.
|
|
42
|
+
*/
|
|
43
|
+
export const pdfHeaders = (format = 'object') => {
|
|
44
|
+
const headers = {
|
|
45
|
+
'Accept': 'application/pdf'
|
|
46
|
+
};
|
|
47
|
+
return format === 'object'
|
|
48
|
+
? headers
|
|
49
|
+
: new HttpHeaders(headers);
|
|
50
|
+
};
|
|
51
|
+
/**
|
|
52
|
+
* Returns the headers for generating XML files.
|
|
53
|
+
*
|
|
54
|
+
* @param {string} format - The format of the headers, 'object' or 'http_header'.
|
|
55
|
+
*
|
|
56
|
+
* @returns {HttpHeaders | { [header: string]: string | string[] }} - The headers for generating XML files.
|
|
57
|
+
*/
|
|
58
|
+
export const xmlHeaders = (format = 'object') => {
|
|
59
|
+
const headers = {
|
|
60
|
+
'Accept': 'application/xml',
|
|
61
|
+
};
|
|
62
|
+
return format === 'object'
|
|
63
|
+
? headers
|
|
64
|
+
: new HttpHeaders(headers);
|
|
65
|
+
};
|
|
66
66
|
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiaHR0cC5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uLy4uLy4uLy4uLy4uL3Byb2plY3RzL2V4cGVydGVhbS9uZ3gtc2VydmljZXMvc3JjL2xpYi9oZWxwZXJzL2h0dHAudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBQUEsT0FBTyxFQUFFLFdBQVcsRUFBRSxVQUFVLEVBQUUsTUFBTSxzQkFBc0IsQ0FBQTtBQUc5RDs7Ozs7O0dBTUc7QUFDSCxNQUFNLENBQUMsTUFBTSxXQUFXLEdBQUcsQ0FBQyxNQUFtQixFQUFVLEVBQUU7SUFDekQsSUFBSSxhQUFhLEdBQWEsRUFBRSxDQUFBO0lBRWhDLE1BQU0sQ0FBQyxPQUFPLENBQUMsTUFBTSxDQUFDLENBQUMsT0FBTyxDQUFDLENBQUMsQ0FBQyxHQUFHLEVBQUUsS0FBSyxDQUFDLEVBQUUsRUFBRTtRQUM5QyxJQUFJLEtBQUssQ0FBQyxPQUFPLENBQUMsS0FBSyxDQUFDLEVBQUU7WUFDeEIsTUFBTSxVQUFVLEdBQUcsS0FBSztpQkFDckIsR0FBRyxDQUFDLENBQUMsSUFBSSxFQUFFLEVBQUUsQ0FBQyxHQUFHLGtCQUFrQixDQUFDLEdBQUcsQ0FBQyxJQUFJLGtCQUFrQixDQUFDLElBQWlDLENBQUMsRUFBRSxDQUFDO2lCQUNwRyxJQUFJLENBQUMsR0FBRyxDQUFDLENBQUE7WUFFWixhQUFhLENBQUMsSUFBSSxDQUFDLFVBQVUsQ0FBQyxDQUFBO1NBQy9CO2FBQU07WUFDTCxNQUFNLFlBQVksR0FBRyxHQUFHLGtCQUFrQixDQUFDLEdBQUcsQ0FBQyxJQUFJLGtCQUFrQixDQUFDLEtBQWtDLENBQUMsRUFBRSxDQUFBO1lBRTNHLGFBQWEsQ0FBQyxJQUFJLENBQUMsWUFBWSxDQUFDLENBQUE7U0FDakM7SUFDSCxDQUFDLENBQUMsQ0FBQTtJQUVGLE1BQU0sV0FBVyxHQUFHLGFBQWEsQ0FBQyxJQUFJLENBQUMsR0FBRyxDQUFDLENBQUE7SUFFM0MsT0FBTyxXQUFXLENBQUMsTUFBTSxDQUFDLENBQUMsQ0FBQyxJQUFJLFdBQVcsRUFBRSxDQUFDLENBQUMsQ0FBQyxFQUFFLENBQUE7QUFDcEQsQ0FBQyxDQUFBO0FBRUQ7Ozs7OztHQU1HO0FBQ0gsTUFBTSxDQUFDLE1BQU0sVUFBVSxHQUFHLENBQ3hCLE1BQW1CLEVBQ1AsRUFBRSxDQUFDLElBQUksVUFBVSxDQUFDO0lBQzlCLFVBQVUsRUFBRSxNQUFNO0NBQ25CLENBQUMsQ0FBQTtBQUVGOzs7Ozs7R0FNRztBQUNILE1BQU0sQ0FBQyxNQUFNLFVBQVUsR0FBRyxDQUFDLFNBQW1DLFFBQVEsRUFBeUQsRUFBRTtJQUMvSCxNQUFNLE9BQU8sR0FBRztRQUNkLFFBQVEsRUFBRSxpQkFBaUI7S0FDNUIsQ0FBQTtJQUVELE9BQU8sTUFBTSxLQUFLLFFBQVE7UUFDeEIsQ0FBQyxDQUFDLE9BQU87UUFDVCxDQUFDLENBQUMsSUFBSSxXQUFXLENBQUMsT0FBTyxDQUFDLENBQUE7QUFDOUIsQ0FBQyxDQUFBO0FBRUQ7Ozs7OztHQU1HO0FBQ0gsTUFBTSxDQUFDLE1BQU0sVUFBVSxHQUFHLENBQUMsU0FBbUMsUUFBUSxFQUF5RCxFQUFFO0lBQy9ILE1BQU0sT0FBTyxHQUFHO1FBQ2QsUUFBUSxFQUFFLGlCQUFpQjtLQUM1QixDQUFBO0lBRUQsT0FBTyxNQUFNLEtBQUssUUFBUTtRQUN4QixDQUFDLENBQUMsT0FBTztRQUNULENBQUMsQ0FBQyxJQUFJLFdBQVcsQ0FBQyxPQUFPLENBQUMsQ0FBQTtBQUM5QixDQUFDLENBQUEiLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQgeyBIdHRwSGVhZGVycywgSHR0cFBhcmFtcyB9IGZyb20gJ0Bhbmd1bGFyL2NvbW1vbi9odHRwJ1xyXG5pbXBvcnQgeyBRdWVyeVBhcmFtcyB9IGZyb20gJy4uL2FwaXMvbW9kZWxzL2FwaS5tb2RlbHMnXHJcblxyXG4vKipcclxuICogQ29udmVydCBhbiBvYmplY3Qgb2Yga2V5LXZhbHVlIHBhaXJzIGludG8gYSBVUkwgcXVlcnkgc3RyaW5nLlxyXG4gKlxyXG4gKiBAcGFyYW0ge09iamVjdH0gcGFyYW1zIC0gVGhlIGtleS12YWx1ZSBwYWlycyB0byBjb252ZXJ0ZWQgaW50byBhIHF1ZXJ5IHN0cmluZy5cclxuICpcclxuICogQHJldHVybiB7c3RyaW5nfSAtIFRoZSBnZW5lcmF0ZWQgcXVlcnkgc3RyaW5nLlxyXG4gKi9cclxuZXhwb3J0IGNvbnN0IHF1ZXJ5U3RyaW5nID0gKHBhcmFtczogUXVlcnlQYXJhbXMpOiBzdHJpbmcgPT4ge1xyXG4gIGxldCBxdWVyeUVsZW1lbnRzOiBzdHJpbmdbXSA9IFtdXHJcblxyXG4gIE9iamVjdC5lbnRyaWVzKHBhcmFtcykuZm9yRWFjaCgoW2tleSwgdmFsdWVdKSA9PiB7XHJcbiAgICBpZiAoQXJyYXkuaXNBcnJheSh2YWx1ZSkpIHtcclxuICAgICAgY29uc3QgYXJyYXlRdWVyeSA9IHZhbHVlXHJcbiAgICAgICAgLm1hcCgoaXRlbSkgPT4gYCR7ZW5jb2RlVVJJQ29tcG9uZW50KGtleSl9PSR7ZW5jb2RlVVJJQ29tcG9uZW50KGl0ZW0gYXMgc3RyaW5nIHwgbnVtYmVyIHwgYm9vbGVhbil9YClcclxuICAgICAgICAuam9pbignJicpXHJcblxyXG4gICAgICBxdWVyeUVsZW1lbnRzLnB1c2goYXJyYXlRdWVyeSlcclxuICAgIH0gZWxzZSB7XHJcbiAgICAgIGNvbnN0IGVuY29kZWRRdWVyeSA9IGAke2VuY29kZVVSSUNvbXBvbmVudChrZXkpfT0ke2VuY29kZVVSSUNvbXBvbmVudCh2YWx1ZSBhcyBzdHJpbmcgfCBudW1iZXIgfCBib29sZWFuKX1gXHJcblxyXG4gICAgICBxdWVyeUVsZW1lbnRzLnB1c2goZW5jb2RlZFF1ZXJ5KVxyXG4gICAgfVxyXG4gIH0pXHJcblxyXG4gIGNvbnN0IHF1ZXJ5U3RyaW5nID0gcXVlcnlFbGVtZW50cy5qb2luKCcmJylcclxuXHJcbiAgcmV0dXJuIHF1ZXJ5U3RyaW5nLmxlbmd0aCA/IGA/JHtxdWVyeVN0cmluZ31gIDogJydcclxufVxyXG5cclxuLyoqXHJcbiAqIENyZWF0ZXMgYW4gaW5zdGFuY2Ugb2YgSHR0cFBhcmFtcyB1c2luZyB0aGUgcHJvdmlkZWQgcGFyYW1zIG9iamVjdC5cclxuICpcclxuICogQHBhcmFtIHtPYmplY3R9IHBhcmFtcyAtIFRoZSBvYmplY3QgY29udGFpbmluZyB0aGUgcGFyYW1zIHRvIHRoZSBIdHRwUGFyYW1zIGNvbnN0cnVjdG9yLlxyXG4gKlxyXG4gKiBAcmV0dXJucyB7SHR0cFBhcmFtc30gLSBBbiBpbnN0YW5jZSBvZiBIdHRwUGFyYW1zIGNyZWF0ZWQgZnJvbSB0aGUgcGFyYW1zIG9iamVjdC5cclxuICovXHJcbmV4cG9ydCBjb25zdCBodHRwUGFyYW1zID0gKFxyXG4gIHBhcmFtczogUXVlcnlQYXJhbXNcclxuKTogSHR0cFBhcmFtcyA9PiBuZXcgSHR0cFBhcmFtcyh7XHJcbiAgZnJvbU9iamVjdDogcGFyYW1zXHJcbn0pXHJcblxyXG4vKipcclxuICogUmV0dXJucyB0aGUgaGVhZGVycyBmb3IgZ2VuZXJhdGluZyBQREYgZmlsZXMuXHJcbiAqXHJcbiAqIEBwYXJhbSB7c3RyaW5nfSBmb3JtYXQgLSBUaGUgZm9ybWF0IG9mIHRoZSBoZWFkZXJzLCAnb2JqZWN0JyBvciAnaHR0cF9oZWFkZXInLlxyXG4gKlxyXG4gKiBAcmV0dXJucyB7SHR0cEhlYWRlcnMgfCB7IFtoZWFkZXI6IHN0cmluZ106IHN0cmluZyB8IHN0cmluZ1tdIH19IC0gVGhlIGhlYWRlcnMgZm9yIGdlbmVyYXRpbmcgUERGIGZpbGVzLlxyXG4gKi9cclxuZXhwb3J0IGNvbnN0IHBkZkhlYWRlcnMgPSAoZm9ybWF0OiAnb2JqZWN0JyB8ICdodHRwX2hlYWRlcicgPSAnb2JqZWN0Jyk6IEh0dHBIZWFkZXJzIHwgeyBbaGVhZGVyOiBzdHJpbmddOiBzdHJpbmcgfCBzdHJpbmdbXSB9ID0+IHtcclxuICBjb25zdCBoZWFkZXJzID0ge1xyXG4gICAgJ0FjY2VwdCc6ICdhcHBsaWNhdGlvbi9wZGYnXHJcbiAgfVxyXG5cclxuICByZXR1cm4gZm9ybWF0ID09PSAnb2JqZWN0J1xyXG4gICAgPyBoZWFkZXJzXHJcbiAgICA6IG5ldyBIdHRwSGVhZGVycyhoZWFkZXJzKVxyXG59XHJcblxyXG4vKipcclxuICogUmV0dXJucyB0aGUgaGVhZGVycyBmb3IgZ2VuZXJhdGluZyBYTUwgZmlsZXMuXHJcbiAqXHJcbiAqIEBwYXJhbSB7c3RyaW5nfSBmb3JtYXQgLSBUaGUgZm9ybWF0IG9mIHRoZSBoZWFkZXJzLCAnb2JqZWN0JyBvciAnaHR0cF9oZWFkZXInLlxyXG4gKlxyXG4gKiBAcmV0dXJucyB7SHR0cEhlYWRlcnMgfCB7IFtoZWFkZXI6IHN0cmluZ106IHN0cmluZyB8IHN0cmluZ1tdIH19IC0gVGhlIGhlYWRlcnMgZm9yIGdlbmVyYXRpbmcgWE1MIGZpbGVzLlxyXG4gKi9cclxuZXhwb3J0IGNvbnN0IHhtbEhlYWRlcnMgPSAoZm9ybWF0OiAnb2JqZWN0JyB8ICdodHRwX2hlYWRlcicgPSAnb2JqZWN0Jyk6IEh0dHBIZWFkZXJzIHwgeyBbaGVhZGVyOiBzdHJpbmddOiBzdHJpbmcgfCBzdHJpbmdbXSB9ID0+IHtcclxuICBjb25zdCBoZWFkZXJzID0ge1xyXG4gICAgJ0FjY2VwdCc6ICdhcHBsaWNhdGlvbi94bWwnLFxyXG4gIH1cclxuXHJcbiAgcmV0dXJuIGZvcm1hdCA9PT0gJ29iamVjdCdcclxuICAgID8gaGVhZGVyc1xyXG4gICAgOiBuZXcgSHR0cEhlYWRlcnMoaGVhZGVycylcclxufVxyXG4iXX0=
|
|
@@ -1,34 +1,34 @@
|
|
|
1
|
-
import { Injectable } from '@angular/core';
|
|
2
|
-
import { HttpHeaders } from '@angular/common/http';
|
|
3
|
-
import * as i0 from "@angular/core";
|
|
4
|
-
export class ApiHeadersInterceptor {
|
|
5
|
-
/**
|
|
6
|
-
* Intercepts HTTP requests and adds common headers.
|
|
7
|
-
*
|
|
8
|
-
* @param {HttpRequest<unknown>} request - The HTTP request intercepted.
|
|
9
|
-
* @param {HttpHandler} next - The next handler in the chain.
|
|
10
|
-
*
|
|
11
|
-
* @returns {Observable<HttpEvent<unknown>>} - Observable of the HTTP event after interception.
|
|
12
|
-
*/
|
|
13
|
-
intercept(request, next) {
|
|
14
|
-
let headers = new HttpHeaders({
|
|
15
|
-
'cache-control': 'max-age=0, no-cache, no-store, must-revalidate',
|
|
16
|
-
'expires': '0',
|
|
17
|
-
'pragma': 'no-cache'
|
|
18
|
-
});
|
|
19
|
-
if (!request.headers.has('Content-Type'))
|
|
20
|
-
headers = headers.set('Content-Type', 'application/json');
|
|
21
|
-
if (!request.headers.has('Accept'))
|
|
22
|
-
headers = headers.set('Accept', 'application/json');
|
|
23
|
-
if (!request.headers.has('Accept-Language'))
|
|
24
|
-
headers = headers.set('Accept-Language', localStorage.getItem('lang') ?? 'en');
|
|
25
|
-
request = request.clone({ headers });
|
|
26
|
-
return next.handle(request);
|
|
27
|
-
}
|
|
28
|
-
}
|
|
29
|
-
|
|
30
|
-
|
|
31
|
-
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "
|
|
32
|
-
type: Injectable
|
|
33
|
-
}] });
|
|
34
|
-
//# sourceMappingURL=data:application/json;base64,
|
|
1
|
+
import { Injectable } from '@angular/core';
|
|
2
|
+
import { HttpHeaders } from '@angular/common/http';
|
|
3
|
+
import * as i0 from "@angular/core";
|
|
4
|
+
export class ApiHeadersInterceptor {
|
|
5
|
+
/**
|
|
6
|
+
* Intercepts HTTP requests and adds common headers.
|
|
7
|
+
*
|
|
8
|
+
* @param {HttpRequest<unknown>} request - The HTTP request intercepted.
|
|
9
|
+
* @param {HttpHandler} next - The next handler in the chain.
|
|
10
|
+
*
|
|
11
|
+
* @returns {Observable<HttpEvent<unknown>>} - Observable of the HTTP event after interception.
|
|
12
|
+
*/
|
|
13
|
+
intercept(request, next) {
|
|
14
|
+
let headers = new HttpHeaders({
|
|
15
|
+
'cache-control': 'max-age=0, no-cache, no-store, must-revalidate',
|
|
16
|
+
'expires': '0',
|
|
17
|
+
'pragma': 'no-cache'
|
|
18
|
+
});
|
|
19
|
+
if (!request.headers.has('Content-Type'))
|
|
20
|
+
headers = headers.set('Content-Type', 'application/json');
|
|
21
|
+
if (!request.headers.has('Accept'))
|
|
22
|
+
headers = headers.set('Accept', 'application/json');
|
|
23
|
+
if (!request.headers.has('Accept-Language'))
|
|
24
|
+
headers = headers.set('Accept-Language', localStorage.getItem('lang') ?? 'en');
|
|
25
|
+
request = request.clone({ headers });
|
|
26
|
+
return next.handle(request);
|
|
27
|
+
}
|
|
28
|
+
static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "16.2.12", ngImport: i0, type: ApiHeadersInterceptor, deps: [], target: i0.ɵɵFactoryTarget.Injectable }); }
|
|
29
|
+
static { this.ɵprov = i0.ɵɵngDeclareInjectable({ minVersion: "12.0.0", version: "16.2.12", ngImport: i0, type: ApiHeadersInterceptor }); }
|
|
30
|
+
}
|
|
31
|
+
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "16.2.12", ngImport: i0, type: ApiHeadersInterceptor, decorators: [{
|
|
32
|
+
type: Injectable
|
|
33
|
+
}] });
|
|
34
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiYXBpLWhlYWRlcnMuaW50ZXJjZXB0b3IuanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi8uLi8uLi8uLi9wcm9qZWN0cy9leHBlcnRlYW0vbmd4LXNlcnZpY2VzL3NyYy9saWIvaW50ZXJjZXB0b3JzL2FwaS1oZWFkZXJzLmludGVyY2VwdG9yLnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQUFBLE9BQU8sRUFBRSxVQUFVLEVBQUUsTUFBTSxlQUFlLENBQUE7QUFDMUMsT0FBTyxFQUEwQixXQUFXLEVBQWdDLE1BQU0sc0JBQXNCLENBQUE7O0FBSXhHLE1BQU0sT0FBTyxxQkFBcUI7SUFDaEM7Ozs7Ozs7T0FPRztJQUNILFNBQVMsQ0FBRSxPQUE2QixFQUFFLElBQWlCO1FBQ3pELElBQUksT0FBTyxHQUFHLElBQUksV0FBVyxDQUFDO1lBQzVCLGVBQWUsRUFBRSxnREFBZ0Q7WUFDakUsU0FBUyxFQUFFLEdBQUc7WUFDZCxRQUFRLEVBQUUsVUFBVTtTQUNyQixDQUFDLENBQUE7UUFFRixJQUFJLENBQUMsT0FBTyxDQUFDLE9BQU8sQ0FBQyxHQUFHLENBQUMsY0FBYyxDQUFDO1lBQ3RDLE9BQU8sR0FBRyxPQUFPLENBQUMsR0FBRyxDQUFDLGNBQWMsRUFBRSxrQkFBa0IsQ0FBQyxDQUFBO1FBRTNELElBQUksQ0FBQyxPQUFPLENBQUMsT0FBTyxDQUFDLEdBQUcsQ0FBQyxRQUFRLENBQUM7WUFDaEMsT0FBTyxHQUFHLE9BQU8sQ0FBQyxHQUFHLENBQUMsUUFBUSxFQUFFLGtCQUFrQixDQUFDLENBQUE7UUFFckQsSUFBSSxDQUFDLE9BQU8sQ0FBQyxPQUFPLENBQUMsR0FBRyxDQUFDLGlCQUFpQixDQUFDO1lBQ3pDLE9BQU8sR0FBRyxPQUFPLENBQUMsR0FBRyxDQUFDLGlCQUFpQixFQUFFLFlBQVksQ0FBQyxPQUFPLENBQUMsTUFBTSxDQUFDLElBQUksSUFBSSxDQUFDLENBQUE7UUFFaEYsT0FBTyxHQUFHLE9BQU8sQ0FBQyxLQUFLLENBQUMsRUFBRSxPQUFPLEVBQUUsQ0FBQyxDQUFBO1FBRXBDLE9BQU8sSUFBSSxDQUFDLE1BQU0sQ0FBQyxPQUFPLENBQUMsQ0FBQTtJQUM3QixDQUFDOytHQTVCVSxxQkFBcUI7bUhBQXJCLHFCQUFxQjs7NEZBQXJCLHFCQUFxQjtrQkFEakMsVUFBVSIsInNvdXJjZXNDb250ZW50IjpbImltcG9ydCB7IEluamVjdGFibGUgfSBmcm9tICdAYW5ndWxhci9jb3JlJ1xyXG5pbXBvcnQgeyBIdHRwRXZlbnQsIEh0dHBIYW5kbGVyLCBIdHRwSGVhZGVycywgSHR0cEludGVyY2VwdG9yLCBIdHRwUmVxdWVzdCB9IGZyb20gJ0Bhbmd1bGFyL2NvbW1vbi9odHRwJ1xyXG5pbXBvcnQgeyBPYnNlcnZhYmxlIH0gZnJvbSAncnhqcydcclxuXHJcbkBJbmplY3RhYmxlKClcclxuZXhwb3J0IGNsYXNzIEFwaUhlYWRlcnNJbnRlcmNlcHRvciBpbXBsZW1lbnRzIEh0dHBJbnRlcmNlcHRvciB7XHJcbiAgLyoqXHJcbiAgICogSW50ZXJjZXB0cyBIVFRQIHJlcXVlc3RzIGFuZCBhZGRzIGNvbW1vbiBoZWFkZXJzLlxyXG4gICAqXHJcbiAgICogQHBhcmFtIHtIdHRwUmVxdWVzdDx1bmtub3duPn0gcmVxdWVzdCAtIFRoZSBIVFRQIHJlcXVlc3QgaW50ZXJjZXB0ZWQuXHJcbiAgICogQHBhcmFtIHtIdHRwSGFuZGxlcn0gbmV4dCAtIFRoZSBuZXh0IGhhbmRsZXIgaW4gdGhlIGNoYWluLlxyXG4gICAqXHJcbiAgICogQHJldHVybnMge09ic2VydmFibGU8SHR0cEV2ZW50PHVua25vd24+Pn0gLSBPYnNlcnZhYmxlIG9mIHRoZSBIVFRQIGV2ZW50IGFmdGVyIGludGVyY2VwdGlvbi5cclxuICAgKi9cclxuICBpbnRlcmNlcHQgKHJlcXVlc3Q6IEh0dHBSZXF1ZXN0PHVua25vd24+LCBuZXh0OiBIdHRwSGFuZGxlcik6IE9ic2VydmFibGU8SHR0cEV2ZW50PHVua25vd24+PiB7XHJcbiAgICBsZXQgaGVhZGVycyA9IG5ldyBIdHRwSGVhZGVycyh7XHJcbiAgICAgICdjYWNoZS1jb250cm9sJzogJ21heC1hZ2U9MCwgbm8tY2FjaGUsIG5vLXN0b3JlLCBtdXN0LXJldmFsaWRhdGUnLFxyXG4gICAgICAnZXhwaXJlcyc6ICcwJyxcclxuICAgICAgJ3ByYWdtYSc6ICduby1jYWNoZSdcclxuICAgIH0pXHJcblxyXG4gICAgaWYgKCFyZXF1ZXN0LmhlYWRlcnMuaGFzKCdDb250ZW50LVR5cGUnKSlcclxuICAgICAgaGVhZGVycyA9IGhlYWRlcnMuc2V0KCdDb250ZW50LVR5cGUnLCAnYXBwbGljYXRpb24vanNvbicpXHJcblxyXG4gICAgaWYgKCFyZXF1ZXN0LmhlYWRlcnMuaGFzKCdBY2NlcHQnKSlcclxuICAgICAgaGVhZGVycyA9IGhlYWRlcnMuc2V0KCdBY2NlcHQnLCAnYXBwbGljYXRpb24vanNvbicpXHJcblxyXG4gICAgaWYgKCFyZXF1ZXN0LmhlYWRlcnMuaGFzKCdBY2NlcHQtTGFuZ3VhZ2UnKSlcclxuICAgICAgaGVhZGVycyA9IGhlYWRlcnMuc2V0KCdBY2NlcHQtTGFuZ3VhZ2UnLCBsb2NhbFN0b3JhZ2UuZ2V0SXRlbSgnbGFuZycpID8/ICdlbicpXHJcblxyXG4gICAgcmVxdWVzdCA9IHJlcXVlc3QuY2xvbmUoeyBoZWFkZXJzIH0pXHJcblxyXG4gICAgcmV0dXJuIG5leHQuaGFuZGxlKHJlcXVlc3QpXHJcbiAgfVxyXG59XHJcbiJdfQ==
|