@snabcentr/client-core 2.56.4 → 2.57.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/auth/services/sc-token.service.d.ts +1 -1
- package/esm2022/auth/services/sc-token.service.mjs +2 -2
- package/esm2022/user/services/sc-user.service.mjs +34 -9
- package/fesm2022/snabcentr-client-core.mjs +32 -10
- package/fesm2022/snabcentr-client-core.mjs.map +1 -1
- package/package.json +1 -1
- package/release_notes.tmp +2 -3
- package/user/services/sc-user.service.d.ts +20 -2
|
@@ -35,7 +35,7 @@ export declare class ScTokenService {
|
|
|
35
35
|
* @param isBrowser Признак, что скрипт выполняется в браузере.
|
|
36
36
|
* @param storage Хранилище {@link Storage}.
|
|
37
37
|
*/
|
|
38
|
-
constructor(event$: Observable<StorageEvent>, apiKeys: ScIApiKeys, storageService: Storage, guestStorageKey: string, accessAuthStorageKey: string, refreshAuthStorageKey: string, isBrowser: boolean, storage?:
|
|
38
|
+
constructor(event$: Observable<StorageEvent>, apiKeys: ScIApiKeys, storageService: Storage, guestStorageKey: string, accessAuthStorageKey: string, refreshAuthStorageKey: string, isBrowser: boolean, storage?: Storage | undefined);
|
|
39
39
|
/**
|
|
40
40
|
* Возвращает ключ доступа к API.
|
|
41
41
|
*/
|
|
@@ -143,10 +143,10 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.2.12", ngImpo
|
|
|
143
143
|
}] }, { type: undefined, decorators: [{
|
|
144
144
|
type: Inject,
|
|
145
145
|
args: [IS_BROWSER]
|
|
146
|
-
}] }, { type:
|
|
146
|
+
}] }, { type: Storage, decorators: [{
|
|
147
147
|
type: Optional
|
|
148
148
|
}, {
|
|
149
149
|
type: Inject,
|
|
150
150
|
args: [WA_LOCAL_STORAGE]
|
|
151
151
|
}] }] });
|
|
152
|
-
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"sc-token.service.js","sourceRoot":"","sources":["../../../../../projects/core/auth/services/sc-token.service.ts"],"names":[],"mappings":"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","sourcesContent":["import { HttpRequest } from '@angular/common/http';\nimport { Inject, Injectable, Optional } from '@angular/core';\nimport { WA_LOCAL_STORAGE } from '@ng-web-apis/common';\nimport { filterByKey, StorageService, toValue, WA_STORAGE_EVENT } from '@ng-web-apis/storage';\nimport { Observable, startWith } from 'rxjs';\n\nimport { ScIApiKeys } from '../../config';\nimport { IS_BROWSER } from '../../providers/ssr.providers';\nimport { SC_API_KEYS } from '../../tokens/sc-api-keys';\nimport { IAuthToken, IToken } from '../interfaces';\nimport { SC_ACCESS_AUTH_TOKEN_STORAGE_KEY, SC_GUEST_TOKEN_STORAGE_KEY, SC_REFRESH_AUTH_TOKEN_STORAGE_KEY } from '../tokens';\n\n/**\n * Сервис для работы с ключами аутентификации.\n */\n@Injectable({\n    providedIn: 'root',\n})\nexport class ScTokenService {\n    /**\n     * {@link Observable} ключа доступа гостя к API в {@link Storage}.\n     */\n    public readonly guestToken$: Observable<string | null> = this.event$.pipe(filterByKey(this.guestStorageKey), toValue(), startWith(this.getGuestToken()));\n\n    /**\n     * {@link Observable} ключа доступа пользователя к API в {@link Storage}.\n     */\n    public readonly accessAuthToken$: Observable<string | null> = this.event$.pipe(filterByKey(this.accessAuthStorageKey), toValue(), startWith(this.getAccessToken()));\n\n    /**\n     * Инициализирует экземпляр класса {@link ScTokenService}.\n     *\n     * @param event$ {@link Observable} Событие изменения в {@link Storage}.\n     * @param apiKeys Заголовки ключей доступа к API.\n     * @param storageService Сервис для работы с {@link Storage} и внедрению его через DI.\n     * @param guestStorageKey Токен, указывающий ключ токена доступа гостя к API в {@link Storage}.\n     * @param accessAuthStorageKey Ключ доступа пользователя к API в {@link Storage}.\n     * @param refreshAuthStorageKey Ключ обновления ключа доступа к API в {@link Storage}.\n     * @param isBrowser Признак, что скрипт выполняется в браузере.\n     * @param storage Хранилище {@link Storage}.\n     */\n    public constructor(\n        @Inject(WA_STORAGE_EVENT) private readonly event$: Observable<StorageEvent>,\n        @Inject(SC_API_KEYS) private readonly apiKeys: ScIApiKeys,\n        @Inject(StorageService) private readonly storageService: Storage,\n        @Inject(SC_GUEST_TOKEN_STORAGE_KEY) private readonly guestStorageKey: string,\n        @Inject(SC_ACCESS_AUTH_TOKEN_STORAGE_KEY) private readonly accessAuthStorageKey: string,\n        @Inject(SC_REFRESH_AUTH_TOKEN_STORAGE_KEY) private readonly refreshAuthStorageKey: string,\n        @Inject(IS_BROWSER) private readonly isBrowser: boolean,\n        @Optional() @Inject(WA_LOCAL_STORAGE) private readonly storage?: ScIApiKeys\n    ) {}\n\n    /**\n     * Возвращает ключ доступа к API.\n     */\n    public getAccessToken(): string | null {\n        return this.storage && this.isBrowser ? this.storageService.getItem(this.accessAuthStorageKey) : null;\n    }\n\n    /**\n     * Возвращает одноразовый ключ для обновления ключа доступа.\n     */\n    public getRefreshToken(): string | null {\n        return this.storage && this.isBrowser ? this.storageService.getItem(this.refreshAuthStorageKey) : null;\n    }\n\n    // TODO Сохранять весь объект при добавлении функционала связанного с временем жизни ключа.\n    /**\n     * Устанавливает ключ доступа пользователя к API или ресурсу.\n     *\n     * @param token Ключ доступа пользователя к API или ресурсу.\n     */\n    public setAuthToken(token: IAuthToken): void {\n        if (this.storage && this.isBrowser) {\n            this.storageService.setItem(this.refreshAuthStorageKey, token.refresh.token);\n            this.storageService.setItem(this.accessAuthStorageKey, token.access.token);\n        }\n    }\n\n    /**\n     * Удаляет ключ доступа пользователя к API или ресурсу.\n     */\n    public removeAuthToken(): void {\n        if (this.getAccessToken()) {\n            this.storageService.removeItem(this.refreshAuthStorageKey);\n            this.storageService.removeItem(this.accessAuthStorageKey);\n        }\n    }\n\n    /**\n     * Возвращает ключ доступа пользователя к API или ресурсу в роли Гостя.\n     */\n    public getGuestToken(): string | null {\n        return this.storage && this.isBrowser ? this.storageService.getItem(this.guestStorageKey) : null;\n    }\n\n    // TODO Сохранять весь объект при добавлении функционала связанного с временем жизни ключа.\n    /**\n     * Устанавливает ключ доступа пользователя к API или ресурсу в роли Гостя.\n     *\n     * @param tokenObject Ключ доступа пользователя к API или ресурсу в роли Гостя.\n     */\n    public setGuestToken(tokenObject: IToken): void {\n        if (this.storage && this.isBrowser) {\n            this.storageService.setItem(this.guestStorageKey, tokenObject.token);\n        }\n    }\n\n    /**\n     * Удаляет ключ доступа пользователя к API или ресурсу в роли Гостя.\n     */\n    public removeGuestToken(): void {\n        if (this.getGuestToken()) {\n            this.storageService.removeItem(this.guestStorageKey);\n        }\n    }\n\n    /**\n     * Добавляет в запрос заголовок для аутентификации пользователя или Гостя.\n     *\n     * @param request Данные запроса.\n     */\n    // eslint-disable-next-line @typescript-eslint/no-explicit-any\n    public addAuthHeader(request: HttpRequest<any>): HttpRequest<any> {\n        if (this.getAccessToken() !== null) {\n            return request.clone({ headers: request.headers.delete(this.apiKeys.guestKeyName).set(this.apiKeys.keyName, this.getAccessToken() ?? '') });\n        }\n\n        if (this.getGuestToken() !== null) {\n            return request.clone({ headers: request.headers.delete(this.apiKeys.keyName).set(this.apiKeys.guestKeyName, this.getGuestToken() ?? '') });\n        }\n\n        return request.clone();\n    }\n}\n"]}
|
|
152
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"sc-token.service.js","sourceRoot":"","sources":["../../../../../projects/core/auth/services/sc-token.service.ts"],"names":[],"mappings":"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","sourcesContent":["import { HttpRequest } from '@angular/common/http';\nimport { Inject, Injectable, Optional } from '@angular/core';\nimport { WA_LOCAL_STORAGE } from '@ng-web-apis/common';\nimport { filterByKey, StorageService, toValue, WA_STORAGE_EVENT } from '@ng-web-apis/storage';\nimport { Observable, startWith } from 'rxjs';\n\nimport { ScIApiKeys } from '../../config';\nimport { IS_BROWSER } from '../../providers/ssr.providers';\nimport { SC_API_KEYS } from '../../tokens/sc-api-keys';\nimport { IAuthToken, IToken } from '../interfaces';\nimport { SC_ACCESS_AUTH_TOKEN_STORAGE_KEY, SC_GUEST_TOKEN_STORAGE_KEY, SC_REFRESH_AUTH_TOKEN_STORAGE_KEY } from '../tokens';\n\n/**\n * Сервис для работы с ключами аутентификации.\n */\n@Injectable({\n    providedIn: 'root',\n})\nexport class ScTokenService {\n    /**\n     * {@link Observable} ключа доступа гостя к API в {@link Storage}.\n     */\n    public readonly guestToken$: Observable<string | null> = this.event$.pipe(filterByKey(this.guestStorageKey), toValue(), startWith(this.getGuestToken()));\n\n    /**\n     * {@link Observable} ключа доступа пользователя к API в {@link Storage}.\n     */\n    public readonly accessAuthToken$: Observable<string | null> = this.event$.pipe(filterByKey(this.accessAuthStorageKey), toValue(), startWith(this.getAccessToken()));\n\n    /**\n     * Инициализирует экземпляр класса {@link ScTokenService}.\n     *\n     * @param event$ {@link Observable} Событие изменения в {@link Storage}.\n     * @param apiKeys Заголовки ключей доступа к API.\n     * @param storageService Сервис для работы с {@link Storage} и внедрению его через DI.\n     * @param guestStorageKey Токен, указывающий ключ токена доступа гостя к API в {@link Storage}.\n     * @param accessAuthStorageKey Ключ доступа пользователя к API в {@link Storage}.\n     * @param refreshAuthStorageKey Ключ обновления ключа доступа к API в {@link Storage}.\n     * @param isBrowser Признак, что скрипт выполняется в браузере.\n     * @param storage Хранилище {@link Storage}.\n     */\n    public constructor(\n        @Inject(WA_STORAGE_EVENT) private readonly event$: Observable<StorageEvent>,\n        @Inject(SC_API_KEYS) private readonly apiKeys: ScIApiKeys,\n        @Inject(StorageService) private readonly storageService: Storage,\n        @Inject(SC_GUEST_TOKEN_STORAGE_KEY) private readonly guestStorageKey: string,\n        @Inject(SC_ACCESS_AUTH_TOKEN_STORAGE_KEY) private readonly accessAuthStorageKey: string,\n        @Inject(SC_REFRESH_AUTH_TOKEN_STORAGE_KEY) private readonly refreshAuthStorageKey: string,\n        @Inject(IS_BROWSER) private readonly isBrowser: boolean,\n        @Optional() @Inject(WA_LOCAL_STORAGE) private readonly storage?: Storage\n    ) {}\n\n    /**\n     * Возвращает ключ доступа к API.\n     */\n    public getAccessToken(): string | null {\n        return this.storage && this.isBrowser ? this.storageService.getItem(this.accessAuthStorageKey) : null;\n    }\n\n    /**\n     * Возвращает одноразовый ключ для обновления ключа доступа.\n     */\n    public getRefreshToken(): string | null {\n        return this.storage && this.isBrowser ? this.storageService.getItem(this.refreshAuthStorageKey) : null;\n    }\n\n    // TODO Сохранять весь объект при добавлении функционала связанного с временем жизни ключа.\n    /**\n     * Устанавливает ключ доступа пользователя к API или ресурсу.\n     *\n     * @param token Ключ доступа пользователя к API или ресурсу.\n     */\n    public setAuthToken(token: IAuthToken): void {\n        if (this.storage && this.isBrowser) {\n            this.storageService.setItem(this.refreshAuthStorageKey, token.refresh.token);\n            this.storageService.setItem(this.accessAuthStorageKey, token.access.token);\n        }\n    }\n\n    /**\n     * Удаляет ключ доступа пользователя к API или ресурсу.\n     */\n    public removeAuthToken(): void {\n        if (this.getAccessToken()) {\n            this.storageService.removeItem(this.refreshAuthStorageKey);\n            this.storageService.removeItem(this.accessAuthStorageKey);\n        }\n    }\n\n    /**\n     * Возвращает ключ доступа пользователя к API или ресурсу в роли Гостя.\n     */\n    public getGuestToken(): string | null {\n        return this.storage && this.isBrowser ? this.storageService.getItem(this.guestStorageKey) : null;\n    }\n\n    // TODO Сохранять весь объект при добавлении функционала связанного с временем жизни ключа.\n    /**\n     * Устанавливает ключ доступа пользователя к API или ресурсу в роли Гостя.\n     *\n     * @param tokenObject Ключ доступа пользователя к API или ресурсу в роли Гостя.\n     */\n    public setGuestToken(tokenObject: IToken): void {\n        if (this.storage && this.isBrowser) {\n            this.storageService.setItem(this.guestStorageKey, tokenObject.token);\n        }\n    }\n\n    /**\n     * Удаляет ключ доступа пользователя к API или ресурсу в роли Гостя.\n     */\n    public removeGuestToken(): void {\n        if (this.getGuestToken()) {\n            this.storageService.removeItem(this.guestStorageKey);\n        }\n    }\n\n    /**\n     * Добавляет в запрос заголовок для аутентификации пользователя или Гостя.\n     *\n     * @param request Данные запроса.\n     */\n    // eslint-disable-next-line @typescript-eslint/no-explicit-any\n    public addAuthHeader(request: HttpRequest<any>): HttpRequest<any> {\n        if (this.getAccessToken() !== null) {\n            return request.clone({ headers: request.headers.delete(this.apiKeys.guestKeyName).set(this.apiKeys.keyName, this.getAccessToken() ?? '') });\n        }\n\n        if (this.getGuestToken() !== null) {\n            return request.clone({ headers: request.headers.delete(this.apiKeys.keyName).set(this.apiKeys.guestKeyName, this.getGuestToken() ?? '') });\n        }\n\n        return request.clone();\n    }\n}\n"]}
|
|
@@ -1,6 +1,9 @@
|
|
|
1
1
|
import { HttpClient } from '@angular/common/http';
|
|
2
2
|
import { inject, Injectable } from '@angular/core';
|
|
3
|
-
import {
|
|
3
|
+
import { WA_LOCAL_STORAGE } from '@ng-web-apis/common';
|
|
4
|
+
import { filterByKey, StorageService, toValue, WA_STORAGE_EVENT } from '@ng-web-apis/storage';
|
|
5
|
+
import { tuiIsPresent } from '@taiga-ui/cdk';
|
|
6
|
+
import { filter, map, shareReplay, switchMap, tap } from 'rxjs';
|
|
4
7
|
import { ScAuthService } from '../../auth/services/sc-auth.service';
|
|
5
8
|
import { ScTokenService } from '../../auth/services/sc-token.service';
|
|
6
9
|
import { IS_BROWSER } from '../../providers/ssr.providers';
|
|
@@ -15,9 +18,21 @@ import * as i0 from "@angular/core";
|
|
|
15
18
|
export class ScUserService {
|
|
16
19
|
constructor() {
|
|
17
20
|
/**
|
|
18
|
-
* {@link
|
|
21
|
+
* {@link Observable} Событие изменения в {@link Storage}.
|
|
19
22
|
*/
|
|
20
|
-
this.
|
|
23
|
+
this.storageEvent$ = inject(WA_STORAGE_EVENT);
|
|
24
|
+
/**
|
|
25
|
+
* Сервис для работы с {@link Storage}.
|
|
26
|
+
*/
|
|
27
|
+
this.storageService = inject(StorageService);
|
|
28
|
+
/**
|
|
29
|
+
* {@link Storage}.
|
|
30
|
+
*/
|
|
31
|
+
this.storage = inject(WA_LOCAL_STORAGE, { optional: true });
|
|
32
|
+
/**
|
|
33
|
+
* {@link Observable} ключа доступа пользователя к API в {@link Storage}.
|
|
34
|
+
*/
|
|
35
|
+
this.user$ = this.storageEvent$.pipe(filterByKey('userData'), toValue(), map((userData) => (userData ? new ScUser(JSON.parse(userData)) : null)), filter(tuiIsPresent), shareReplay({ refCount: true, bufferSize: 1 }));
|
|
21
36
|
/**
|
|
22
37
|
* Сервис для работы с токенами.
|
|
23
38
|
*/
|
|
@@ -53,11 +68,21 @@ export class ScUserService {
|
|
|
53
68
|
.pipe(switchMap((state) => (state ? this.getUserInfo$() : this.getGuestInfo$())))
|
|
54
69
|
.subscribe((user) => {
|
|
55
70
|
this.userMetrikaService.setUserParams(user.id, user.userType);
|
|
56
|
-
this.
|
|
71
|
+
this.setUserToStorage(user);
|
|
57
72
|
});
|
|
58
73
|
}
|
|
59
74
|
else {
|
|
60
|
-
this.
|
|
75
|
+
this.setUserToStorage(new ScUser({ metadata: {} }));
|
|
76
|
+
}
|
|
77
|
+
}
|
|
78
|
+
/**
|
|
79
|
+
* Устанавливает данные пользователя в {@link Storage}.
|
|
80
|
+
*
|
|
81
|
+
* @param user Данные пользователя.
|
|
82
|
+
*/
|
|
83
|
+
setUserToStorage(user) {
|
|
84
|
+
if (this.storage && this.isBrowser) {
|
|
85
|
+
this.storageService.setItem('userData', JSON.stringify(user));
|
|
61
86
|
}
|
|
62
87
|
}
|
|
63
88
|
/**
|
|
@@ -116,14 +141,14 @@ export class ScUserService {
|
|
|
116
141
|
* Возвращает {@link Observable} текущего пользователя.
|
|
117
142
|
*/
|
|
118
143
|
getUserChange$() {
|
|
119
|
-
return this.user
|
|
144
|
+
return this.user$;
|
|
120
145
|
}
|
|
121
146
|
/**
|
|
122
147
|
* Обновляет данные {@link Observable} текущего пользователя.
|
|
123
148
|
*/
|
|
124
149
|
updateUserChange$() {
|
|
125
150
|
return this.getUserInfo$().pipe(tap((user) => {
|
|
126
|
-
this.
|
|
151
|
+
this.setUserToStorage(user);
|
|
127
152
|
}));
|
|
128
153
|
}
|
|
129
154
|
/**
|
|
@@ -137,7 +162,7 @@ export class ScUserService {
|
|
|
137
162
|
*/
|
|
138
163
|
updateGuestChange$() {
|
|
139
164
|
return this.getGuestInfo$().pipe(tap((user) => {
|
|
140
|
-
this.
|
|
165
|
+
this.setUserToStorage(user);
|
|
141
166
|
}));
|
|
142
167
|
}
|
|
143
168
|
/**
|
|
@@ -155,4 +180,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.2.12", ngImpo
|
|
|
155
180
|
providedIn: 'root',
|
|
156
181
|
}]
|
|
157
182
|
}] });
|
|
158
|
-
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"sc-user.service.js","sourceRoot":"","sources":["../../../../../projects/core/user/services/sc-user.service.ts"],"names":[],"mappings":"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","sourcesContent":["import { HttpClient } from '@angular/common/http';\nimport { inject, Injectable } from '@angular/core';\nimport { map, Observable, ReplaySubject, switchMap, tap } from 'rxjs';\n\nimport { IAuthToken } from '../../auth/interfaces';\nimport { ScAuthService } from '../../auth/services/sc-auth.service';\nimport { ScTokenService } from '../../auth/services/sc-token.service';\nimport { IS_BROWSER } from '../../providers/ssr.providers';\nimport { SC_URLS } from '../../tokens/sc-urls';\nimport { ScUserMetrikaGoalsEnum } from '../../user-metrika/enums/sc-user-metrika-goals-enum';\nimport { ScUserMetrikaService } from '../../user-metrika/services/sc-user-metrika.service';\nimport { ScISimpleUserOnDataCreate } from '../dto';\nimport { ScIChangePassword } from '../dto/sc-i-change-password';\nimport { ScIPasswordOnDataUpdate } from '../dto/sc-i-password-on-data-create';\nimport { ScIPhoneOnDataApprove } from '../dto/sc-i-phone-on-data-approve';\nimport { ScIUserOnDataCreate } from '../dto/sc-i-user-on-data-create';\nimport { ScIUserOnDataUpdate } from '../dto/sc-i-user-on-data-update';\nimport { ScUser } from '../dto/sc-user';\nimport { ScIUserDTO } from '../internal/dto';\n\n/**\n * Сервис информации о пользователе.\n */\n@Injectable({\n    providedIn: 'root',\n})\nexport class ScUserService {\n    /**\n     * {@link ReplaySubject} данных о текущем пользователе.\n     */\n    private user$: ReplaySubject<ScUser> = new ReplaySubject<ScUser>(1);\n\n    /**\n     * Сервис для работы с токенами.\n     */\n    private readonly tokenService = inject(ScTokenService);\n\n    /**\n     * Признак, что скрипт выполняется в браузере.\n     */\n    private readonly isBrowser: boolean = inject(IS_BROWSER);\n\n    /**\n     * Сервис аутентификации.\n     */\n    private readonly authService = inject(ScAuthService);\n\n    /**\n     * Список ссылок на разделы backend'a.\n     */\n    private readonly urls = inject(SC_URLS);\n\n    /**\n     * HTTP-клиент.\n     */\n    private readonly http = inject(HttpClient);\n\n    /**\n     * Сервис для сбора метрик о действиях пользователей.\n     */\n    private readonly userMetrikaService = inject(ScUserMetrikaService);\n\n    /**\n     * Выполняет инициализацию сервиса.\n     */\n    public initService(): void {\n        if (this.isBrowser) {\n            this.authService\n                .getAuthChange()\n                .pipe(switchMap((state) => (state ? this.getUserInfo$() : this.getGuestInfo$())))\n                .subscribe((user) => {\n                    this.userMetrikaService.setUserParams(user.id, user.userType);\n                    this.user$.next(user);\n                });\n        } else {\n            this.user$.next(new ScUser({ metadata: {} }));\n        }\n    }\n\n    /**\n     * Возвращает {@link Observable} запроса изменения информации о текущем пользователе.\n     *\n     * @param newData Данные пользователя, которые нужно обновить.\n     */\n    public updateUserInfo$(newData: ScIUserOnDataUpdate | ScIChangePassword | ScIPhoneOnDataApprove): Observable<undefined> {\n        return this.http.patch<undefined>(`${this.urls.apiUrl}/user`, newData).pipe(\n            tap(() => {\n                this.userMetrikaService.emitUserMetrikaEvent({\n                    target: ScUserMetrikaGoalsEnum.userProfileEdited,\n                });\n            })\n        );\n    }\n\n    /**\n     * Возвращает {@link Observable} запроса изменения информации о текущем пользователе-госте.\n     *\n     * @param newData Данные пользователя-гостя, которые нужно обновить.\n     */\n    public updateGuestInfo$(newData: Pick<ScIUserOnDataUpdate, 'metadata'>): Observable<undefined> {\n        return this.http.patch<undefined>(`${this.urls.apiUrl}/guest`, newData);\n    }\n\n    /**\n     * Возвращает {@link Observable} запроса регистрации пользователя.\n     *\n     * @param user Данные для регистрации.\n     * @param withAuth Флаг, указывающий, нужно ли устанавливать токен аутентификации.\n     */\n    public signUp$(user: ScIUserOnDataCreate | ScISimpleUserOnDataCreate, withAuth: boolean = true): Observable<IAuthToken> {\n        return this.http.post<IAuthToken>(`${this.urls.apiUrl}/user/register`, user).pipe(\n            tap((token) => {\n                this.userMetrikaService.emitUserMetrikaEvent({\n                    target: ScUserMetrikaGoalsEnum.signedUp,\n                });\n\n                if (withAuth) {\n                    this.tokenService.setAuthToken(token);\n                }\n            })\n        );\n    }\n\n    /**\n     * Возвращает {@link Observable} запроса на отправку кода изменения пароля на электронную почту.\n     *\n     * @param email Адрес электронной почты.\n     */\n    public sendResetPasswordCode$(email: string): Observable<undefined> {\n        return this.http.get<undefined>(`${this.urls.apiUrl}/auth/password/restore`, { params: { email: email } });\n    }\n\n    /**\n     * Возвращает {@link Observable} запроса изменения пароля.\n     *\n     * @param newPassword Данные для изменения пароля.\n     */\n    public resetPassword$(newPassword: ScIPasswordOnDataUpdate): Observable<undefined> {\n        return this.http.post<undefined>(`${this.urls.apiUrl}/auth/password/restore`, newPassword);\n    }\n\n    /**\n     * Возвращает {@link Observable} текущего пользователя.\n     */\n    public getUserChange$(): Observable<ScUser> {\n        return this.user$.asObservable();\n    }\n\n    /**\n     * Обновляет данные {@link Observable} текущего пользователя.\n     */\n    public updateUserChange$(): Observable<ScUser> {\n        return this.getUserInfo$().pipe(\n            tap((user) => {\n                this.user$.next(user);\n            })\n        );\n    }\n\n    /**\n     * Возвращает {@link Observable} запроса на получение информации о текущем пользователе.\n     */\n    public getUserInfo$(): Observable<ScUser> {\n        return this.http.get<ScIUserDTO>(`${this.urls.apiUrl}/user`).pipe(map((user) => new ScUser(user)));\n    }\n\n    /**\n     * Обновляет данные {@link Observable} текущего пользователя.\n     */\n    public updateGuestChange$(): Observable<ScUser> {\n        return this.getGuestInfo$().pipe(\n            tap((user) => {\n                this.user$.next(user);\n            })\n        );\n    }\n\n    /**\n     * Возвращает {@link Observable} запроса на получение информации о текущем пользователе.\n     */\n    private getGuestInfo$(): Observable<ScUser> {\n        return this.http.get<ScIUserDTO>(`${this.urls.apiUrl}/guest`).pipe(map((user) => new ScUser(user)));\n    }\n}\n"]}
|
|
183
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"sc-user.service.js","sourceRoot":"","sources":["../../../../../projects/core/user/services/sc-user.service.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,UAAU,EAAE,MAAM,sBAAsB,CAAC;AAClD,OAAO,EAAE,MAAM,EAAE,UAAU,EAAE,MAAM,eAAe,CAAC;AACnD,OAAO,EAAE,gBAAgB,EAAE,MAAM,qBAAqB,CAAC;AACvD,OAAO,EAAE,WAAW,EAAE,cAAc,EAAE,OAAO,EAAE,gBAAgB,EAAE,MAAM,sBAAsB,CAAC;AAC9F,OAAO,EAAE,YAAY,EAAE,MAAM,eAAe,CAAC;AAC7C,OAAO,EAAE,MAAM,EAAE,GAAG,EAAc,WAAW,EAAE,SAAS,EAAE,GAAG,EAAE,MAAM,MAAM,CAAC;AAG5E,OAAO,EAAE,aAAa,EAAE,MAAM,qCAAqC,CAAC;AACpE,OAAO,EAAE,cAAc,EAAE,MAAM,sCAAsC,CAAC;AACtE,OAAO,EAAE,UAAU,EAAE,MAAM,+BAA+B,CAAC;AAC3D,OAAO,EAAE,OAAO,EAAE,MAAM,sBAAsB,CAAC;AAC/C,OAAO,EAAE,sBAAsB,EAAE,MAAM,qDAAqD,CAAC;AAC7F,OAAO,EAAE,oBAAoB,EAAE,MAAM,qDAAqD,CAAC;AAO3F,OAAO,EAAE,MAAM,EAAE,MAAM,gBAAgB,CAAC;;AAGxC;;GAEG;AAIH,MAAM,OAAO,aAAa;IAH1B;QAII;;WAEG;QACc,kBAAa,GAA6B,MAAM,CAAC,gBAAgB,CAAC,CAAC;QAEpF;;WAEG;QACc,mBAAc,GAAY,MAAM,CAAC,cAAc,CAAC,CAAC;QAElE;;WAEG;QACc,YAAO,GAAmB,MAAM,CAAC,gBAAgB,EAAE,EAAE,QAAQ,EAAE,IAAI,EAAE,CAAC,CAAC;QAExF;;WAEG;QACc,UAAK,GAAuB,IAAI,CAAC,aAAa,CAAC,IAAI,CAChE,WAAW,CAAC,UAAU,CAAC,EACvB,OAAO,EAAE,EACT,GAAG,CAAC,CAAC,QAAQ,EAAE,EAAE,CAAC,CAAC,QAAQ,CAAC,CAAC,CAAC,IAAI,MAAM,CAAC,IAAI,CAAC,KAAK,CAAC,QAAQ,CAAe,CAAC,CAAC,CAAC,CAAC,IAAI,CAAC,CAAC,EACrF,MAAM,CAAC,YAAY,CAAC,EACpB,WAAW,CAAC,EAAE,QAAQ,EAAE,IAAI,EAAE,UAAU,EAAE,CAAC,EAAE,CAAC,CACjD,CAAC;QAEF;;WAEG;QACc,iBAAY,GAAG,MAAM,CAAC,cAAc,CAAC,CAAC;QAEvD;;WAEG;QACc,cAAS,GAAY,MAAM,CAAC,UAAU,CAAC,CAAC;QAEzD;;WAEG;QACc,gBAAW,GAAG,MAAM,CAAC,aAAa,CAAC,CAAC;QAErD;;WAEG;QACc,SAAI,GAAG,MAAM,CAAC,OAAO,CAAC,CAAC;QAExC;;WAEG;QACc,SAAI,GAAG,MAAM,CAAC,UAAU,CAAC,CAAC;QAE3C;;WAEG;QACc,uBAAkB,GAAG,MAAM,CAAC,oBAAoB,CAAC,CAAC;KAsItE;IApIG;;OAEG;IACI,WAAW;QACd,IAAI,IAAI,CAAC,SAAS,EAAE,CAAC;YACjB,IAAI,CAAC,WAAW;iBACX,aAAa,EAAE;iBACf,IAAI,CAAC,SAAS,CAAC,CAAC,KAAK,EAAE,EAAE,CAAC,CAAC,KAAK,CAAC,CAAC,CAAC,IAAI,CAAC,YAAY,EAAE,CAAC,CAAC,CAAC,IAAI,CAAC,aAAa,EAAE,CAAC,CAAC,CAAC;iBAChF,SAAS,CAAC,CAAC,IAAI,EAAE,EAAE;gBAChB,IAAI,CAAC,kBAAkB,CAAC,aAAa,CAAC,IAAI,CAAC,EAAE,EAAE,IAAI,CAAC,QAAQ,CAAC,CAAC;gBAC9D,IAAI,CAAC,gBAAgB,CAAC,IAAI,CAAC,CAAC;YAChC,CAAC,CAAC,CAAC;QACX,CAAC;aAAM,CAAC;YACJ,IAAI,CAAC,gBAAgB,CAAC,IAAI,MAAM,CAAC,EAAE,QAAQ,EAAE,EAAE,EAAE,CAAC,CAAC,CAAC;QACxD,CAAC;IACL,CAAC;IAED;;;;OAIG;IACK,gBAAgB,CAAC,IAAY;QACjC,IAAI,IAAI,CAAC,OAAO,IAAI,IAAI,CAAC,SAAS,EAAE,CAAC;YACjC,IAAI,CAAC,cAAc,CAAC,OAAO,CAAC,UAAU,EAAE,IAAI,CAAC,SAAS,CAAC,IAAI,CAAC,CAAC,CAAC;QAClE,CAAC;IACL,CAAC;IAED;;;;OAIG;IACI,eAAe,CAAC,OAAwE;QAC3F,OAAO,IAAI,CAAC,IAAI,CAAC,KAAK,CAAY,GAAG,IAAI,CAAC,IAAI,CAAC,MAAM,OAAO,EAAE,OAAO,CAAC,CAAC,IAAI,CACvE,GAAG,CAAC,GAAG,EAAE;YACL,IAAI,CAAC,kBAAkB,CAAC,oBAAoB,CAAC;gBACzC,MAAM,EAAE,sBAAsB,CAAC,iBAAiB;aACnD,CAAC,CAAC;QACP,CAAC,CAAC,CACL,CAAC;IACN,CAAC;IAED;;;;OAIG;IACI,gBAAgB,CAAC,OAA8C;QAClE,OAAO,IAAI,CAAC,IAAI,CAAC,KAAK,CAAY,GAAG,IAAI,CAAC,IAAI,CAAC,MAAM,QAAQ,EAAE,OAAO,CAAC,CAAC;IAC5E,CAAC;IAED;;;;;OAKG;IACI,OAAO,CAAC,IAAqD,EAAE,WAAoB,IAAI;QAC1F,OAAO,IAAI,CAAC,IAAI,CAAC,IAAI,CAAa,GAAG,IAAI,CAAC,IAAI,CAAC,MAAM,gBAAgB,EAAE,IAAI,CAAC,CAAC,IAAI,CAC7E,GAAG,CAAC,CAAC,KAAK,EAAE,EAAE;YACV,IAAI,CAAC,kBAAkB,CAAC,oBAAoB,CAAC;gBACzC,MAAM,EAAE,sBAAsB,CAAC,QAAQ;aAC1C,CAAC,CAAC;YAEH,IAAI,QAAQ,EAAE,CAAC;gBACX,IAAI,CAAC,YAAY,CAAC,YAAY,CAAC,KAAK,CAAC,CAAC;YAC1C,CAAC;QACL,CAAC,CAAC,CACL,CAAC;IACN,CAAC;IAED;;;;OAIG;IACI,sBAAsB,CAAC,KAAa;QACvC,OAAO,IAAI,CAAC,IAAI,CAAC,GAAG,CAAY,GAAG,IAAI,CAAC,IAAI,CAAC,MAAM,wBAAwB,EAAE,EAAE,MAAM,EAAE,EAAE,KAAK,EAAE,KAAK,EAAE,EAAE,CAAC,CAAC;IAC/G,CAAC;IAED;;;;OAIG;IACI,cAAc,CAAC,WAAoC;QACtD,OAAO,IAAI,CAAC,IAAI,CAAC,IAAI,CAAY,GAAG,IAAI,CAAC,IAAI,CAAC,MAAM,wBAAwB,EAAE,WAAW,CAAC,CAAC;IAC/F,CAAC;IAED;;OAEG;IACI,cAAc;QACjB,OAAO,IAAI,CAAC,KAAK,CAAC;IACtB,CAAC;IAED;;OAEG;IACI,iBAAiB;QACpB,OAAO,IAAI,CAAC,YAAY,EAAE,CAAC,IAAI,CAC3B,GAAG,CAAC,CAAC,IAAI,EAAE,EAAE;YACT,IAAI,CAAC,gBAAgB,CAAC,IAAI,CAAC,CAAC;QAChC,CAAC,CAAC,CACL,CAAC;IACN,CAAC;IAED;;OAEG;IACI,YAAY;QACf,OAAO,IAAI,CAAC,IAAI,CAAC,GAAG,CAAa,GAAG,IAAI,CAAC,IAAI,CAAC,MAAM,OAAO,CAAC,CAAC,IAAI,CAAC,GAAG,CAAC,CAAC,IAAI,EAAE,EAAE,CAAC,IAAI,MAAM,CAAC,IAAI,CAAC,CAAC,CAAC,CAAC;IACvG,CAAC;IAED;;OAEG;IACI,kBAAkB;QACrB,OAAO,IAAI,CAAC,aAAa,EAAE,CAAC,IAAI,CAC5B,GAAG,CAAC,CAAC,IAAI,EAAE,EAAE;YACT,IAAI,CAAC,gBAAgB,CAAC,IAAI,CAAC,CAAC;QAChC,CAAC,CAAC,CACL,CAAC;IACN,CAAC;IAED;;OAEG;IACK,aAAa;QACjB,OAAO,IAAI,CAAC,IAAI,CAAC,GAAG,CAAa,GAAG,IAAI,CAAC,IAAI,CAAC,MAAM,QAAQ,CAAC,CAAC,IAAI,CAAC,GAAG,CAAC,CAAC,IAAI,EAAE,EAAE,CAAC,IAAI,MAAM,CAAC,IAAI,CAAC,CAAC,CAAC,CAAC;IACxG,CAAC;+GA5LQ,aAAa;mHAAb,aAAa,cAFV,MAAM;;4FAET,aAAa;kBAHzB,UAAU;mBAAC;oBACR,UAAU,EAAE,MAAM;iBACrB","sourcesContent":["import { HttpClient } from '@angular/common/http';\nimport { inject, Injectable } from '@angular/core';\nimport { WA_LOCAL_STORAGE } from '@ng-web-apis/common';\nimport { filterByKey, StorageService, toValue, WA_STORAGE_EVENT } from '@ng-web-apis/storage';\nimport { tuiIsPresent } from '@taiga-ui/cdk';\nimport { filter, map, Observable, shareReplay, switchMap, tap } from 'rxjs';\n\nimport { IAuthToken } from '../../auth/interfaces';\nimport { ScAuthService } from '../../auth/services/sc-auth.service';\nimport { ScTokenService } from '../../auth/services/sc-token.service';\nimport { IS_BROWSER } from '../../providers/ssr.providers';\nimport { SC_URLS } from '../../tokens/sc-urls';\nimport { ScUserMetrikaGoalsEnum } from '../../user-metrika/enums/sc-user-metrika-goals-enum';\nimport { ScUserMetrikaService } from '../../user-metrika/services/sc-user-metrika.service';\nimport { ScISimpleUserOnDataCreate } from '../dto';\nimport { ScIChangePassword } from '../dto/sc-i-change-password';\nimport { ScIPasswordOnDataUpdate } from '../dto/sc-i-password-on-data-create';\nimport { ScIPhoneOnDataApprove } from '../dto/sc-i-phone-on-data-approve';\nimport { ScIUserOnDataCreate } from '../dto/sc-i-user-on-data-create';\nimport { ScIUserOnDataUpdate } from '../dto/sc-i-user-on-data-update';\nimport { ScUser } from '../dto/sc-user';\nimport { ScIUserDTO } from '../internal/dto';\n\n/**\n * Сервис информации о пользователе.\n */\n@Injectable({\n    providedIn: 'root',\n})\nexport class ScUserService {\n    /**\n     * {@link Observable} Событие изменения в {@link Storage}.\n     */\n    private readonly storageEvent$: Observable<StorageEvent> = inject(WA_STORAGE_EVENT);\n\n    /**\n     * Сервис для работы с {@link Storage}.\n     */\n    private readonly storageService: Storage = inject(StorageService);\n\n    /**\n     * {@link Storage}.\n     */\n    private readonly storage: Storage | null = inject(WA_LOCAL_STORAGE, { optional: true });\n\n    /**\n     * {@link Observable} ключа доступа пользователя к API в {@link Storage}.\n     */\n    private readonly user$: Observable<ScUser> = this.storageEvent$.pipe(\n        filterByKey('userData'),\n        toValue(),\n        map((userData) => (userData ? new ScUser(JSON.parse(userData) as ScIUserDTO) : null)),\n        filter(tuiIsPresent),\n        shareReplay({ refCount: true, bufferSize: 1 })\n    );\n\n    /**\n     * Сервис для работы с токенами.\n     */\n    private readonly tokenService = inject(ScTokenService);\n\n    /**\n     * Признак, что скрипт выполняется в браузере.\n     */\n    private readonly isBrowser: boolean = inject(IS_BROWSER);\n\n    /**\n     * Сервис аутентификации.\n     */\n    private readonly authService = inject(ScAuthService);\n\n    /**\n     * Список ссылок на разделы backend'a.\n     */\n    private readonly urls = inject(SC_URLS);\n\n    /**\n     * HTTP-клиент.\n     */\n    private readonly http = inject(HttpClient);\n\n    /**\n     * Сервис для сбора метрик о действиях пользователей.\n     */\n    private readonly userMetrikaService = inject(ScUserMetrikaService);\n\n    /**\n     * Выполняет инициализацию сервиса.\n     */\n    public initService(): void {\n        if (this.isBrowser) {\n            this.authService\n                .getAuthChange()\n                .pipe(switchMap((state) => (state ? this.getUserInfo$() : this.getGuestInfo$())))\n                .subscribe((user) => {\n                    this.userMetrikaService.setUserParams(user.id, user.userType);\n                    this.setUserToStorage(user);\n                });\n        } else {\n            this.setUserToStorage(new ScUser({ metadata: {} }));\n        }\n    }\n\n    /**\n     * Устанавливает данные пользователя в {@link Storage}.\n     *\n     * @param user Данные пользователя.\n     */\n    private setUserToStorage(user: ScUser): void {\n        if (this.storage && this.isBrowser) {\n            this.storageService.setItem('userData', JSON.stringify(user));\n        }\n    }\n\n    /**\n     * Возвращает {@link Observable} запроса изменения информации о текущем пользователе.\n     *\n     * @param newData Данные пользователя, которые нужно обновить.\n     */\n    public updateUserInfo$(newData: ScIUserOnDataUpdate | ScIChangePassword | ScIPhoneOnDataApprove): Observable<undefined> {\n        return this.http.patch<undefined>(`${this.urls.apiUrl}/user`, newData).pipe(\n            tap(() => {\n                this.userMetrikaService.emitUserMetrikaEvent({\n                    target: ScUserMetrikaGoalsEnum.userProfileEdited,\n                });\n            })\n        );\n    }\n\n    /**\n     * Возвращает {@link Observable} запроса изменения информации о текущем пользователе-госте.\n     *\n     * @param newData Данные пользователя-гостя, которые нужно обновить.\n     */\n    public updateGuestInfo$(newData: Pick<ScIUserOnDataUpdate, 'metadata'>): Observable<undefined> {\n        return this.http.patch<undefined>(`${this.urls.apiUrl}/guest`, newData);\n    }\n\n    /**\n     * Возвращает {@link Observable} запроса регистрации пользователя.\n     *\n     * @param user Данные для регистрации.\n     * @param withAuth Флаг, указывающий, нужно ли устанавливать токен аутентификации.\n     */\n    public signUp$(user: ScIUserOnDataCreate | ScISimpleUserOnDataCreate, withAuth: boolean = true): Observable<IAuthToken> {\n        return this.http.post<IAuthToken>(`${this.urls.apiUrl}/user/register`, user).pipe(\n            tap((token) => {\n                this.userMetrikaService.emitUserMetrikaEvent({\n                    target: ScUserMetrikaGoalsEnum.signedUp,\n                });\n\n                if (withAuth) {\n                    this.tokenService.setAuthToken(token);\n                }\n            })\n        );\n    }\n\n    /**\n     * Возвращает {@link Observable} запроса на отправку кода изменения пароля на электронную почту.\n     *\n     * @param email Адрес электронной почты.\n     */\n    public sendResetPasswordCode$(email: string): Observable<undefined> {\n        return this.http.get<undefined>(`${this.urls.apiUrl}/auth/password/restore`, { params: { email: email } });\n    }\n\n    /**\n     * Возвращает {@link Observable} запроса изменения пароля.\n     *\n     * @param newPassword Данные для изменения пароля.\n     */\n    public resetPassword$(newPassword: ScIPasswordOnDataUpdate): Observable<undefined> {\n        return this.http.post<undefined>(`${this.urls.apiUrl}/auth/password/restore`, newPassword);\n    }\n\n    /**\n     * Возвращает {@link Observable} текущего пользователя.\n     */\n    public getUserChange$(): Observable<ScUser> {\n        return this.user$;\n    }\n\n    /**\n     * Обновляет данные {@link Observable} текущего пользователя.\n     */\n    public updateUserChange$(): Observable<ScUser> {\n        return this.getUserInfo$().pipe(\n            tap((user) => {\n                this.setUserToStorage(user);\n            })\n        );\n    }\n\n    /**\n     * Возвращает {@link Observable} запроса на получение информации о текущем пользователе.\n     */\n    public getUserInfo$(): Observable<ScUser> {\n        return this.http.get<ScIUserDTO>(`${this.urls.apiUrl}/user`).pipe(map((user) => new ScUser(user)));\n    }\n\n    /**\n     * Обновляет данные {@link Observable} текущего пользователя.\n     */\n    public updateGuestChange$(): Observable<ScUser> {\n        return this.getGuestInfo$().pipe(\n            tap((user) => {\n                this.setUserToStorage(user);\n            })\n        );\n    }\n\n    /**\n     * Возвращает {@link Observable} запроса на получение информации о текущем пользователе.\n     */\n    private getGuestInfo$(): Observable<ScUser> {\n        return this.http.get<ScIUserDTO>(`${this.urls.apiUrl}/guest`).pipe(map((user) => new ScUser(user)));\n    }\n}\n"]}
|
|
@@ -3,9 +3,9 @@ import { InjectionToken, inject, PLATFORM_ID, Injectable, Inject, Optional, LOCA
|
|
|
3
3
|
import { WA_LOCAL_STORAGE, WA_USER_AGENT, WA_WINDOW } from '@ng-web-apis/common';
|
|
4
4
|
import { filterByKey, toValue, WA_STORAGE_EVENT, StorageService } from '@ng-web-apis/storage';
|
|
5
5
|
import * as i1 from 'rxjs';
|
|
6
|
-
import { startWith, Subject, ReplaySubject, partition, combineLatest, map, debounceTime, switchMap, of, tap,
|
|
6
|
+
import { startWith, Subject, ReplaySubject, partition, combineLatest, map, debounceTime, switchMap, of, tap, filter, shareReplay, distinctUntilChanged, distinctUntilKeyChanged, skip, first, BehaviorSubject, expand, takeWhile, toArray, catchError, throwError, concatMap, finalize, takeUntil, interval, share, scan } from 'rxjs';
|
|
7
7
|
import { isPlatformBrowser, isPlatformServer, DOCUMENT, formatDate } from '@angular/common';
|
|
8
|
-
import { tuiCreateTokenFromFactory, tuiCreateToken,
|
|
8
|
+
import { tuiCreateTokenFromFactory, tuiCreateToken, tuiIsPresent, TuiDay, tuiPure } from '@taiga-ui/cdk';
|
|
9
9
|
import * as i1$1 from '@angular/common/http';
|
|
10
10
|
import { HttpContextToken, HttpContext, HttpHeaders, HttpClient, HttpParams, HttpResponse, HttpErrorResponse } from '@angular/common/http';
|
|
11
11
|
import { takeUntilDestroyed } from '@angular/core/rxjs-interop';
|
|
@@ -215,7 +215,7 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.2.12", ngImpo
|
|
|
215
215
|
}] }, { type: undefined, decorators: [{
|
|
216
216
|
type: Inject,
|
|
217
217
|
args: [IS_BROWSER]
|
|
218
|
-
}] }, { type:
|
|
218
|
+
}] }, { type: Storage, decorators: [{
|
|
219
219
|
type: Optional
|
|
220
220
|
}, {
|
|
221
221
|
type: Inject,
|
|
@@ -980,9 +980,21 @@ class ScUser {
|
|
|
980
980
|
class ScUserService {
|
|
981
981
|
constructor() {
|
|
982
982
|
/**
|
|
983
|
-
* {@link
|
|
983
|
+
* {@link Observable} Событие изменения в {@link Storage}.
|
|
984
984
|
*/
|
|
985
|
-
this.
|
|
985
|
+
this.storageEvent$ = inject(WA_STORAGE_EVENT);
|
|
986
|
+
/**
|
|
987
|
+
* Сервис для работы с {@link Storage}.
|
|
988
|
+
*/
|
|
989
|
+
this.storageService = inject(StorageService);
|
|
990
|
+
/**
|
|
991
|
+
* {@link Storage}.
|
|
992
|
+
*/
|
|
993
|
+
this.storage = inject(WA_LOCAL_STORAGE, { optional: true });
|
|
994
|
+
/**
|
|
995
|
+
* {@link Observable} ключа доступа пользователя к API в {@link Storage}.
|
|
996
|
+
*/
|
|
997
|
+
this.user$ = this.storageEvent$.pipe(filterByKey('userData'), toValue(), map((userData) => (userData ? new ScUser(JSON.parse(userData)) : null)), filter(tuiIsPresent), shareReplay({ refCount: true, bufferSize: 1 }));
|
|
986
998
|
/**
|
|
987
999
|
* Сервис для работы с токенами.
|
|
988
1000
|
*/
|
|
@@ -1018,11 +1030,21 @@ class ScUserService {
|
|
|
1018
1030
|
.pipe(switchMap((state) => (state ? this.getUserInfo$() : this.getGuestInfo$())))
|
|
1019
1031
|
.subscribe((user) => {
|
|
1020
1032
|
this.userMetrikaService.setUserParams(user.id, user.userType);
|
|
1021
|
-
this.
|
|
1033
|
+
this.setUserToStorage(user);
|
|
1022
1034
|
});
|
|
1023
1035
|
}
|
|
1024
1036
|
else {
|
|
1025
|
-
this.
|
|
1037
|
+
this.setUserToStorage(new ScUser({ metadata: {} }));
|
|
1038
|
+
}
|
|
1039
|
+
}
|
|
1040
|
+
/**
|
|
1041
|
+
* Устанавливает данные пользователя в {@link Storage}.
|
|
1042
|
+
*
|
|
1043
|
+
* @param user Данные пользователя.
|
|
1044
|
+
*/
|
|
1045
|
+
setUserToStorage(user) {
|
|
1046
|
+
if (this.storage && this.isBrowser) {
|
|
1047
|
+
this.storageService.setItem('userData', JSON.stringify(user));
|
|
1026
1048
|
}
|
|
1027
1049
|
}
|
|
1028
1050
|
/**
|
|
@@ -1081,14 +1103,14 @@ class ScUserService {
|
|
|
1081
1103
|
* Возвращает {@link Observable} текущего пользователя.
|
|
1082
1104
|
*/
|
|
1083
1105
|
getUserChange$() {
|
|
1084
|
-
return this.user
|
|
1106
|
+
return this.user$;
|
|
1085
1107
|
}
|
|
1086
1108
|
/**
|
|
1087
1109
|
* Обновляет данные {@link Observable} текущего пользователя.
|
|
1088
1110
|
*/
|
|
1089
1111
|
updateUserChange$() {
|
|
1090
1112
|
return this.getUserInfo$().pipe(tap((user) => {
|
|
1091
|
-
this.
|
|
1113
|
+
this.setUserToStorage(user);
|
|
1092
1114
|
}));
|
|
1093
1115
|
}
|
|
1094
1116
|
/**
|
|
@@ -1102,7 +1124,7 @@ class ScUserService {
|
|
|
1102
1124
|
*/
|
|
1103
1125
|
updateGuestChange$() {
|
|
1104
1126
|
return this.getGuestInfo$().pipe(tap((user) => {
|
|
1105
|
-
this.
|
|
1127
|
+
this.setUserToStorage(user);
|
|
1106
1128
|
}));
|
|
1107
1129
|
}
|
|
1108
1130
|
/**
|