@abp/ng.account.core 7.2.2 → 7.3.0-rc.2
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 +129 -2
- package/{esm2020 → esm2022}/abp-ng.account.core.mjs +4 -4
- package/esm2022/lib/auth-wrapper.service.mjs +43 -0
- package/esm2022/lib/tenant-box.service.mjs +56 -0
- package/{esm2020 → esm2022}/proxy/abp-ng.account.core-proxy.mjs +4 -4
- package/{esm2020 → esm2022}/proxy/lib/index.mjs +2 -2
- package/esm2022/proxy/lib/proxy/account/account.service.mjs +35 -0
- package/{esm2020 → esm2022}/proxy/lib/proxy/account/index.mjs +5 -5
- package/{esm2020 → esm2022}/proxy/lib/proxy/account/models.mjs +1 -1
- package/esm2022/proxy/lib/proxy/account/profile.service.mjs +34 -0
- package/esm2022/proxy/lib/proxy/account/web/areas/account/controllers/account.service.mjs +34 -0
- package/{esm2020 → esm2022}/proxy/lib/proxy/account/web/areas/account/controllers/index.mjs +3 -3
- package/{esm2020 → esm2022}/proxy/lib/proxy/account/web/areas/account/controllers/models/index.mjs +2 -2
- package/{esm2020 → esm2022}/proxy/lib/proxy/account/web/areas/account/controllers/models/login-result-type.enum.mjs +10 -10
- package/{esm2020 → esm2022}/proxy/lib/proxy/account/web/areas/account/controllers/models/models.mjs +1 -1
- package/{esm2020 → esm2022}/proxy/lib/proxy/account/web/areas/account/index.mjs +2 -2
- package/{esm2020 → esm2022}/proxy/lib/proxy/account/web/areas/index.mjs +2 -2
- package/{esm2020 → esm2022}/proxy/lib/proxy/account/web/index.mjs +2 -2
- package/{esm2020 → esm2022}/proxy/lib/proxy/identity/index.mjs +1 -1
- package/{esm2020 → esm2022}/proxy/lib/proxy/identity/models.mjs +1 -1
- package/{esm2020 → esm2022}/proxy/public-api.mjs +1 -1
- package/{esm2020 → esm2022}/public-api.mjs +5 -5
- package/{fesm2020 → fesm2022}/abp-ng.account.core-proxy.mjs +92 -92
- package/{fesm2020 → fesm2022}/abp-ng.account.core-proxy.mjs.map +1 -1
- package/{fesm2020 → fesm2022}/abp-ng.account.core.mjs +84 -84
- package/{fesm2020 → fesm2022}/abp-ng.account.core.mjs.map +1 -1
- package/index.d.ts +5 -5
- package/lib/auth-wrapper.service.d.ts +19 -19
- package/lib/tenant-box.service.d.ts +20 -20
- package/package.json +24 -18
- package/proxy/index.d.ts +5 -5
- package/proxy/lib/index.d.ts +2 -2
- package/proxy/lib/proxy/account/account.service.d.ts +14 -14
- package/proxy/lib/proxy/account/index.d.ts +5 -5
- package/proxy/lib/proxy/account/models.d.ts +40 -40
- package/proxy/lib/proxy/account/profile.service.d.ts +13 -13
- package/proxy/lib/proxy/account/web/areas/account/controllers/account.service.d.ts +13 -13
- package/proxy/lib/proxy/account/web/areas/account/controllers/index.d.ts +3 -3
- package/proxy/lib/proxy/account/web/areas/account/controllers/models/index.d.ts +2 -2
- package/proxy/lib/proxy/account/web/areas/account/controllers/models/login-result-type.enum.d.ts +8 -8
- package/proxy/lib/proxy/account/web/areas/account/controllers/models/models.d.ts +10 -10
- package/proxy/lib/proxy/account/web/areas/account/index.d.ts +2 -2
- package/proxy/lib/proxy/account/web/areas/index.d.ts +2 -2
- package/proxy/lib/proxy/account/web/index.d.ts +2 -2
- package/proxy/lib/proxy/identity/index.d.ts +1 -1
- package/proxy/lib/proxy/identity/models.d.ts +15 -15
- package/proxy/public-api.d.ts +1 -1
- package/public-api.d.ts +2 -2
- package/esm2020/lib/auth-wrapper.service.mjs +0 -42
- package/esm2020/lib/tenant-box.service.mjs +0 -55
- package/esm2020/proxy/lib/proxy/account/account.service.mjs +0 -34
- package/esm2020/proxy/lib/proxy/account/profile.service.mjs +0 -33
- package/esm2020/proxy/lib/proxy/account/web/areas/account/controllers/account.service.mjs +0 -33
- package/fesm2015/abp-ng.account.core-proxy.mjs +0 -136
- package/fesm2015/abp-ng.account.core-proxy.mjs.map +0 -1
- package/fesm2015/abp-ng.account.core.mjs +0 -104
- package/fesm2015/abp-ng.account.core.mjs.map +0 -1
- package/proxy/src/lib/proxy/README.md +0 -17
package/package.json
CHANGED
|
@@ -1,14 +1,14 @@
|
|
|
1
1
|
{
|
|
2
2
|
"name": "@abp/ng.account.core",
|
|
3
|
-
"version": "7.
|
|
3
|
+
"version": "7.3.0-rc.2",
|
|
4
4
|
"homepage": "https://abp.io",
|
|
5
5
|
"repository": {
|
|
6
6
|
"type": "git",
|
|
7
7
|
"url": "https://github.com/abpframework/abp.git"
|
|
8
8
|
},
|
|
9
9
|
"peerDependencies": {
|
|
10
|
-
"@abp/ng.core": "~7.2
|
|
11
|
-
"@abp/ng.theme.shared": "~7.2
|
|
10
|
+
"@abp/ng.core": "~7.3.0-rc.2",
|
|
11
|
+
"@abp/ng.theme.shared": "~7.3.0-rc.2",
|
|
12
12
|
"@angular/common": ">=12.0.0",
|
|
13
13
|
"@angular/core": ">=12.0.0"
|
|
14
14
|
},
|
|
@@ -18,11 +18,21 @@
|
|
|
18
18
|
"publishConfig": {
|
|
19
19
|
"access": "public"
|
|
20
20
|
},
|
|
21
|
-
"
|
|
22
|
-
"
|
|
23
|
-
|
|
24
|
-
|
|
25
|
-
|
|
21
|
+
"license": "LGPL-3.0",
|
|
22
|
+
"keywords": [
|
|
23
|
+
"aspnetcore",
|
|
24
|
+
"boilerplate",
|
|
25
|
+
"framework",
|
|
26
|
+
"web",
|
|
27
|
+
"best-practices",
|
|
28
|
+
"angular",
|
|
29
|
+
"maui",
|
|
30
|
+
"blazor",
|
|
31
|
+
"mvc",
|
|
32
|
+
"csharp",
|
|
33
|
+
"webapp"
|
|
34
|
+
],
|
|
35
|
+
"module": "fesm2022/abp-ng.account.core.mjs",
|
|
26
36
|
"typings": "index.d.ts",
|
|
27
37
|
"exports": {
|
|
28
38
|
"./package.json": {
|
|
@@ -30,19 +40,15 @@
|
|
|
30
40
|
},
|
|
31
41
|
".": {
|
|
32
42
|
"types": "./index.d.ts",
|
|
33
|
-
"
|
|
34
|
-
"
|
|
35
|
-
"
|
|
36
|
-
"node": "./fesm2015/abp-ng.account.core.mjs",
|
|
37
|
-
"default": "./fesm2020/abp-ng.account.core.mjs"
|
|
43
|
+
"esm2022": "./esm2022/abp-ng.account.core.mjs",
|
|
44
|
+
"esm": "./esm2022/abp-ng.account.core.mjs",
|
|
45
|
+
"default": "./fesm2022/abp-ng.account.core.mjs"
|
|
38
46
|
},
|
|
39
47
|
"./proxy": {
|
|
40
48
|
"types": "./proxy/index.d.ts",
|
|
41
|
-
"
|
|
42
|
-
"
|
|
43
|
-
"
|
|
44
|
-
"node": "./fesm2015/abp-ng.account.core-proxy.mjs",
|
|
45
|
-
"default": "./fesm2020/abp-ng.account.core-proxy.mjs"
|
|
49
|
+
"esm2022": "./esm2022/proxy/abp-ng.account.core-proxy.mjs",
|
|
50
|
+
"esm": "./esm2022/proxy/abp-ng.account.core-proxy.mjs",
|
|
51
|
+
"default": "./fesm2022/abp-ng.account.core-proxy.mjs"
|
|
46
52
|
}
|
|
47
53
|
},
|
|
48
54
|
"sideEffects": false
|
package/proxy/index.d.ts
CHANGED
|
@@ -1,5 +1,5 @@
|
|
|
1
|
-
/**
|
|
2
|
-
* Generated bundle index. Do not edit.
|
|
3
|
-
*/
|
|
4
|
-
/// <amd-module name="@abp/ng.account.core/proxy" />
|
|
5
|
-
export * from './public-api';
|
|
1
|
+
/**
|
|
2
|
+
* Generated bundle index. Do not edit.
|
|
3
|
+
*/
|
|
4
|
+
/// <amd-module name="@abp/ng.account.core/proxy" />
|
|
5
|
+
export * from './public-api';
|
package/proxy/lib/index.d.ts
CHANGED
|
@@ -1,2 +1,2 @@
|
|
|
1
|
-
export * from './proxy/account';
|
|
2
|
-
export * from './proxy/identity';
|
|
1
|
+
export * from './proxy/account';
|
|
2
|
+
export * from './proxy/identity';
|
|
@@ -1,14 +1,14 @@
|
|
|
1
|
-
import type { RegisterDto, ResetPasswordDto, SendPasswordResetCodeDto } from './models';
|
|
2
|
-
import { RestService } from '@abp/ng.core';
|
|
3
|
-
import type { IdentityUserDto } from '../identity/models';
|
|
4
|
-
import * as i0 from "@angular/core";
|
|
5
|
-
export declare class AccountService {
|
|
6
|
-
private restService;
|
|
7
|
-
apiName: string;
|
|
8
|
-
register: (input: RegisterDto) => import("rxjs").Observable<IdentityUserDto>;
|
|
9
|
-
resetPassword: (input: ResetPasswordDto) => import("rxjs").Observable<void>;
|
|
10
|
-
sendPasswordResetCode: (input: SendPasswordResetCodeDto) => import("rxjs").Observable<void>;
|
|
11
|
-
constructor(restService: RestService);
|
|
12
|
-
static ɵfac: i0.ɵɵFactoryDeclaration<AccountService, never>;
|
|
13
|
-
static ɵprov: i0.ɵɵInjectableDeclaration<AccountService>;
|
|
14
|
-
}
|
|
1
|
+
import type { RegisterDto, ResetPasswordDto, SendPasswordResetCodeDto } from './models';
|
|
2
|
+
import { RestService } from '@abp/ng.core';
|
|
3
|
+
import type { IdentityUserDto } from '../identity/models';
|
|
4
|
+
import * as i0 from "@angular/core";
|
|
5
|
+
export declare class AccountService {
|
|
6
|
+
private restService;
|
|
7
|
+
apiName: string;
|
|
8
|
+
register: (input: RegisterDto) => import("rxjs").Observable<IdentityUserDto>;
|
|
9
|
+
resetPassword: (input: ResetPasswordDto) => import("rxjs").Observable<void>;
|
|
10
|
+
sendPasswordResetCode: (input: SendPasswordResetCodeDto) => import("rxjs").Observable<void>;
|
|
11
|
+
constructor(restService: RestService);
|
|
12
|
+
static ɵfac: i0.ɵɵFactoryDeclaration<AccountService, never>;
|
|
13
|
+
static ɵprov: i0.ɵɵInjectableDeclaration<AccountService>;
|
|
14
|
+
}
|
|
@@ -1,5 +1,5 @@
|
|
|
1
|
-
import * as Web from './web';
|
|
2
|
-
export * from './account.service';
|
|
3
|
-
export * from './models';
|
|
4
|
-
export * from './profile.service';
|
|
5
|
-
export { Web };
|
|
1
|
+
import * as Web from './web';
|
|
2
|
+
export * from './account.service';
|
|
3
|
+
export * from './models';
|
|
4
|
+
export * from './profile.service';
|
|
5
|
+
export { Web };
|
|
@@ -1,40 +1,40 @@
|
|
|
1
|
-
import type { ExtensibleObject } from '@abp/ng.core';
|
|
2
|
-
export interface ChangePasswordInput {
|
|
3
|
-
currentPassword?: string;
|
|
4
|
-
newPassword: string;
|
|
5
|
-
}
|
|
6
|
-
export interface ProfileDto extends ExtensibleObject {
|
|
7
|
-
userName?: string;
|
|
8
|
-
email?: string;
|
|
9
|
-
name?: string;
|
|
10
|
-
surname?: string;
|
|
11
|
-
phoneNumber?: string;
|
|
12
|
-
isExternal: boolean;
|
|
13
|
-
hasPassword: boolean;
|
|
14
|
-
concurrencyStamp?: string;
|
|
15
|
-
}
|
|
16
|
-
export interface RegisterDto extends ExtensibleObject {
|
|
17
|
-
userName: string;
|
|
18
|
-
emailAddress: string;
|
|
19
|
-
password: string;
|
|
20
|
-
appName: string;
|
|
21
|
-
}
|
|
22
|
-
export interface ResetPasswordDto {
|
|
23
|
-
userId?: string;
|
|
24
|
-
resetToken: string;
|
|
25
|
-
password: string;
|
|
26
|
-
}
|
|
27
|
-
export interface SendPasswordResetCodeDto {
|
|
28
|
-
email: string;
|
|
29
|
-
appName: string;
|
|
30
|
-
returnUrl?: string;
|
|
31
|
-
returnUrlHash?: string;
|
|
32
|
-
}
|
|
33
|
-
export interface UpdateProfileDto extends ExtensibleObject {
|
|
34
|
-
userName?: string;
|
|
35
|
-
email?: string;
|
|
36
|
-
name?: string;
|
|
37
|
-
surname?: string;
|
|
38
|
-
phoneNumber?: string;
|
|
39
|
-
concurrencyStamp?: string;
|
|
40
|
-
}
|
|
1
|
+
import type { ExtensibleObject } from '@abp/ng.core';
|
|
2
|
+
export interface ChangePasswordInput {
|
|
3
|
+
currentPassword?: string;
|
|
4
|
+
newPassword: string;
|
|
5
|
+
}
|
|
6
|
+
export interface ProfileDto extends ExtensibleObject {
|
|
7
|
+
userName?: string;
|
|
8
|
+
email?: string;
|
|
9
|
+
name?: string;
|
|
10
|
+
surname?: string;
|
|
11
|
+
phoneNumber?: string;
|
|
12
|
+
isExternal: boolean;
|
|
13
|
+
hasPassword: boolean;
|
|
14
|
+
concurrencyStamp?: string;
|
|
15
|
+
}
|
|
16
|
+
export interface RegisterDto extends ExtensibleObject {
|
|
17
|
+
userName: string;
|
|
18
|
+
emailAddress: string;
|
|
19
|
+
password: string;
|
|
20
|
+
appName: string;
|
|
21
|
+
}
|
|
22
|
+
export interface ResetPasswordDto {
|
|
23
|
+
userId?: string;
|
|
24
|
+
resetToken: string;
|
|
25
|
+
password: string;
|
|
26
|
+
}
|
|
27
|
+
export interface SendPasswordResetCodeDto {
|
|
28
|
+
email: string;
|
|
29
|
+
appName: string;
|
|
30
|
+
returnUrl?: string;
|
|
31
|
+
returnUrlHash?: string;
|
|
32
|
+
}
|
|
33
|
+
export interface UpdateProfileDto extends ExtensibleObject {
|
|
34
|
+
userName?: string;
|
|
35
|
+
email?: string;
|
|
36
|
+
name?: string;
|
|
37
|
+
surname?: string;
|
|
38
|
+
phoneNumber?: string;
|
|
39
|
+
concurrencyStamp?: string;
|
|
40
|
+
}
|
|
@@ -1,13 +1,13 @@
|
|
|
1
|
-
import type { ChangePasswordInput, ProfileDto, UpdateProfileDto } from './models';
|
|
2
|
-
import { RestService } from '@abp/ng.core';
|
|
3
|
-
import * as i0 from "@angular/core";
|
|
4
|
-
export declare class ProfileService {
|
|
5
|
-
private restService;
|
|
6
|
-
apiName: string;
|
|
7
|
-
changePassword: (input: ChangePasswordInput) => import("rxjs").Observable<void>;
|
|
8
|
-
get: () => import("rxjs").Observable<ProfileDto>;
|
|
9
|
-
update: (input: UpdateProfileDto) => import("rxjs").Observable<ProfileDto>;
|
|
10
|
-
constructor(restService: RestService);
|
|
11
|
-
static ɵfac: i0.ɵɵFactoryDeclaration<ProfileService, never>;
|
|
12
|
-
static ɵprov: i0.ɵɵInjectableDeclaration<ProfileService>;
|
|
13
|
-
}
|
|
1
|
+
import type { ChangePasswordInput, ProfileDto, UpdateProfileDto } from './models';
|
|
2
|
+
import { RestService } from '@abp/ng.core';
|
|
3
|
+
import * as i0 from "@angular/core";
|
|
4
|
+
export declare class ProfileService {
|
|
5
|
+
private restService;
|
|
6
|
+
apiName: string;
|
|
7
|
+
changePassword: (input: ChangePasswordInput) => import("rxjs").Observable<void>;
|
|
8
|
+
get: () => import("rxjs").Observable<ProfileDto>;
|
|
9
|
+
update: (input: UpdateProfileDto) => import("rxjs").Observable<ProfileDto>;
|
|
10
|
+
constructor(restService: RestService);
|
|
11
|
+
static ɵfac: i0.ɵɵFactoryDeclaration<ProfileService, never>;
|
|
12
|
+
static ɵprov: i0.ɵɵInjectableDeclaration<ProfileService>;
|
|
13
|
+
}
|
|
@@ -1,13 +1,13 @@
|
|
|
1
|
-
import type { AbpLoginResult, UserLoginInfo } from './models/models';
|
|
2
|
-
import { RestService } from '@abp/ng.core';
|
|
3
|
-
import * as i0 from "@angular/core";
|
|
4
|
-
export declare class AccountService {
|
|
5
|
-
private restService;
|
|
6
|
-
apiName: string;
|
|
7
|
-
checkPasswordByLogin: (login: UserLoginInfo) => import("rxjs").Observable<AbpLoginResult>;
|
|
8
|
-
loginByLogin: (login: UserLoginInfo) => import("rxjs").Observable<AbpLoginResult>;
|
|
9
|
-
logout: () => import("rxjs").Observable<void>;
|
|
10
|
-
constructor(restService: RestService);
|
|
11
|
-
static ɵfac: i0.ɵɵFactoryDeclaration<AccountService, never>;
|
|
12
|
-
static ɵprov: i0.ɵɵInjectableDeclaration<AccountService>;
|
|
13
|
-
}
|
|
1
|
+
import type { AbpLoginResult, UserLoginInfo } from './models/models';
|
|
2
|
+
import { RestService } from '@abp/ng.core';
|
|
3
|
+
import * as i0 from "@angular/core";
|
|
4
|
+
export declare class AccountService {
|
|
5
|
+
private restService;
|
|
6
|
+
apiName: string;
|
|
7
|
+
checkPasswordByLogin: (login: UserLoginInfo) => import("rxjs").Observable<AbpLoginResult>;
|
|
8
|
+
loginByLogin: (login: UserLoginInfo) => import("rxjs").Observable<AbpLoginResult>;
|
|
9
|
+
logout: () => import("rxjs").Observable<void>;
|
|
10
|
+
constructor(restService: RestService);
|
|
11
|
+
static ɵfac: i0.ɵɵFactoryDeclaration<AccountService, never>;
|
|
12
|
+
static ɵprov: i0.ɵɵInjectableDeclaration<AccountService>;
|
|
13
|
+
}
|
|
@@ -1,3 +1,3 @@
|
|
|
1
|
-
import * as Models from './models';
|
|
2
|
-
export * from './account.service';
|
|
3
|
-
export { Models };
|
|
1
|
+
import * as Models from './models';
|
|
2
|
+
export * from './account.service';
|
|
3
|
+
export { Models };
|
|
@@ -1,2 +1,2 @@
|
|
|
1
|
-
export * from './login-result-type.enum';
|
|
2
|
-
export * from './models';
|
|
1
|
+
export * from './login-result-type.enum';
|
|
2
|
+
export * from './models';
|
package/proxy/lib/proxy/account/web/areas/account/controllers/models/login-result-type.enum.d.ts
CHANGED
|
@@ -1,8 +1,8 @@
|
|
|
1
|
-
export declare enum LoginResultType {
|
|
2
|
-
Success = 1,
|
|
3
|
-
InvalidUserNameOrPassword = 2,
|
|
4
|
-
NotAllowed = 3,
|
|
5
|
-
LockedOut = 4,
|
|
6
|
-
RequiresTwoFactor = 5
|
|
7
|
-
}
|
|
8
|
-
export declare const loginResultTypeOptions: import("@abp/ng.core").ABP.Option<typeof LoginResultType>[];
|
|
1
|
+
export declare enum LoginResultType {
|
|
2
|
+
Success = 1,
|
|
3
|
+
InvalidUserNameOrPassword = 2,
|
|
4
|
+
NotAllowed = 3,
|
|
5
|
+
LockedOut = 4,
|
|
6
|
+
RequiresTwoFactor = 5
|
|
7
|
+
}
|
|
8
|
+
export declare const loginResultTypeOptions: import("@abp/ng.core").ABP.Option<typeof LoginResultType>[];
|
|
@@ -1,10 +1,10 @@
|
|
|
1
|
-
import type { LoginResultType } from './login-result-type.enum';
|
|
2
|
-
export interface AbpLoginResult {
|
|
3
|
-
result: LoginResultType;
|
|
4
|
-
description?: string;
|
|
5
|
-
}
|
|
6
|
-
export interface UserLoginInfo {
|
|
7
|
-
userNameOrEmailAddress: string;
|
|
8
|
-
password: string;
|
|
9
|
-
rememberMe: boolean;
|
|
10
|
-
}
|
|
1
|
+
import type { LoginResultType } from './login-result-type.enum';
|
|
2
|
+
export interface AbpLoginResult {
|
|
3
|
+
result: LoginResultType;
|
|
4
|
+
description?: string;
|
|
5
|
+
}
|
|
6
|
+
export interface UserLoginInfo {
|
|
7
|
+
userNameOrEmailAddress: string;
|
|
8
|
+
password: string;
|
|
9
|
+
rememberMe: boolean;
|
|
10
|
+
}
|
|
@@ -1,2 +1,2 @@
|
|
|
1
|
-
import * as Controllers from './controllers';
|
|
2
|
-
export { Controllers };
|
|
1
|
+
import * as Controllers from './controllers';
|
|
2
|
+
export { Controllers };
|
|
@@ -1,2 +1,2 @@
|
|
|
1
|
-
import * as Account from './account';
|
|
2
|
-
export { Account };
|
|
1
|
+
import * as Account from './account';
|
|
2
|
+
export { Account };
|
|
@@ -1,2 +1,2 @@
|
|
|
1
|
-
import * as Areas from './areas';
|
|
2
|
-
export { Areas };
|
|
1
|
+
import * as Areas from './areas';
|
|
2
|
+
export { Areas };
|
|
@@ -1 +1 @@
|
|
|
1
|
-
export * from './models';
|
|
1
|
+
export * from './models';
|
|
@@ -1,15 +1,15 @@
|
|
|
1
|
-
import type { ExtensibleFullAuditedEntityDto } from '@abp/ng.core';
|
|
2
|
-
export interface IdentityUserDto extends ExtensibleFullAuditedEntityDto<string> {
|
|
3
|
-
tenantId?: string;
|
|
4
|
-
userName?: string;
|
|
5
|
-
name?: string;
|
|
6
|
-
surname?: string;
|
|
7
|
-
email?: string;
|
|
8
|
-
emailConfirmed: boolean;
|
|
9
|
-
phoneNumber?: string;
|
|
10
|
-
phoneNumberConfirmed: boolean;
|
|
11
|
-
isActive: boolean;
|
|
12
|
-
lockoutEnabled: boolean;
|
|
13
|
-
lockoutEnd?: string;
|
|
14
|
-
concurrencyStamp?: string;
|
|
15
|
-
}
|
|
1
|
+
import type { ExtensibleFullAuditedEntityDto } from '@abp/ng.core';
|
|
2
|
+
export interface IdentityUserDto extends ExtensibleFullAuditedEntityDto<string> {
|
|
3
|
+
tenantId?: string;
|
|
4
|
+
userName?: string;
|
|
5
|
+
name?: string;
|
|
6
|
+
surname?: string;
|
|
7
|
+
email?: string;
|
|
8
|
+
emailConfirmed: boolean;
|
|
9
|
+
phoneNumber?: string;
|
|
10
|
+
phoneNumberConfirmed: boolean;
|
|
11
|
+
isActive: boolean;
|
|
12
|
+
lockoutEnabled: boolean;
|
|
13
|
+
lockoutEnd?: string;
|
|
14
|
+
concurrencyStamp?: string;
|
|
15
|
+
}
|
package/proxy/public-api.d.ts
CHANGED
|
@@ -1 +1 @@
|
|
|
1
|
-
export * from './lib/index';
|
|
1
|
+
export * from './lib/index';
|
package/public-api.d.ts
CHANGED
|
@@ -1,2 +1,2 @@
|
|
|
1
|
-
export * from './lib/auth-wrapper.service';
|
|
2
|
-
export * from './lib/tenant-box.service';
|
|
1
|
+
export * from './lib/auth-wrapper.service';
|
|
2
|
+
export * from './lib/tenant-box.service';
|
|
@@ -1,42 +0,0 @@
|
|
|
1
|
-
import { Injectable, Injector } from '@angular/core';
|
|
2
|
-
import { map } from 'rxjs/operators';
|
|
3
|
-
import { ActivatedRoute } from '@angular/router';
|
|
4
|
-
import { ConfigStateService, MultiTenancyService } from '@abp/ng.core';
|
|
5
|
-
import * as i0 from "@angular/core";
|
|
6
|
-
import * as i1 from "@abp/ng.core";
|
|
7
|
-
export class AuthWrapperService {
|
|
8
|
-
constructor(multiTenancy, configState, injector) {
|
|
9
|
-
this.multiTenancy = multiTenancy;
|
|
10
|
-
this.configState = configState;
|
|
11
|
-
this.isMultiTenancyEnabled$ = this.configState.getDeep$('multiTenancy.isEnabled');
|
|
12
|
-
this.tenantBoxKey = 'Account.TenantBoxComponent';
|
|
13
|
-
this.route = injector.get(ActivatedRoute);
|
|
14
|
-
}
|
|
15
|
-
get enableLocalLogin$() {
|
|
16
|
-
return this.configState
|
|
17
|
-
.getSetting$('Abp.Account.EnableLocalLogin')
|
|
18
|
-
.pipe(map(value => value?.toLowerCase() !== 'false'));
|
|
19
|
-
}
|
|
20
|
-
get isTenantBoxVisibleForCurrentRoute() {
|
|
21
|
-
return this.getMostInnerChild().data.tenantBoxVisible ?? true;
|
|
22
|
-
}
|
|
23
|
-
get isTenantBoxVisible() {
|
|
24
|
-
return this.isTenantBoxVisibleForCurrentRoute && this.multiTenancy.isTenantBoxVisible;
|
|
25
|
-
}
|
|
26
|
-
getMostInnerChild() {
|
|
27
|
-
let child = this.route.snapshot;
|
|
28
|
-
let depth = 0;
|
|
29
|
-
const depthLimit = 10;
|
|
30
|
-
while (child.firstChild && depth < depthLimit) {
|
|
31
|
-
child = child.firstChild;
|
|
32
|
-
depth++;
|
|
33
|
-
}
|
|
34
|
-
return child;
|
|
35
|
-
}
|
|
36
|
-
}
|
|
37
|
-
AuthWrapperService.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "15.0.4", ngImport: i0, type: AuthWrapperService, deps: [{ token: i1.MultiTenancyService }, { token: i1.ConfigStateService }, { token: i0.Injector }], target: i0.ɵɵFactoryTarget.Injectable });
|
|
38
|
-
AuthWrapperService.ɵprov = i0.ɵɵngDeclareInjectable({ minVersion: "12.0.0", version: "15.0.4", ngImport: i0, type: AuthWrapperService });
|
|
39
|
-
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "15.0.4", ngImport: i0, type: AuthWrapperService, decorators: [{
|
|
40
|
-
type: Injectable
|
|
41
|
-
}], ctorParameters: function () { return [{ type: i1.MultiTenancyService }, { type: i1.ConfigStateService }, { type: i0.Injector }]; } });
|
|
42
|
-
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiYXV0aC13cmFwcGVyLnNlcnZpY2UuanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi8uLi8uLi9wYWNrYWdlcy9hY2NvdW50LWNvcmUvc3JjL2xpYi9hdXRoLXdyYXBwZXIuc2VydmljZS50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFBQSxPQUFPLEVBQUUsVUFBVSxFQUFFLFFBQVEsRUFBRSxNQUFNLGVBQWUsQ0FBQztBQUVyRCxPQUFPLEVBQUUsR0FBRyxFQUFFLE1BQU0sZ0JBQWdCLENBQUM7QUFDckMsT0FBTyxFQUFFLGNBQWMsRUFBRSxNQUFNLGlCQUFpQixDQUFDO0FBQ2pELE9BQU8sRUFBRSxrQkFBa0IsRUFBRSxtQkFBbUIsRUFBRSxNQUFNLGNBQWMsQ0FBQzs7O0FBR3ZFLE1BQU0sT0FBTyxrQkFBa0I7SUFvQjdCLFlBQ2tCLFlBQWlDLEVBQ3pDLFdBQStCLEVBQ3ZDLFFBQWtCO1FBRkYsaUJBQVksR0FBWixZQUFZLENBQXFCO1FBQ3pDLGdCQUFXLEdBQVgsV0FBVyxDQUFvQjtRQXJCekMsMkJBQXNCLEdBQUcsSUFBSSxDQUFDLFdBQVcsQ0FBQyxRQUFRLENBQUMsd0JBQXdCLENBQUMsQ0FBQztRQVE3RSxpQkFBWSxHQUFHLDRCQUE0QixDQUFDO1FBZ0IxQyxJQUFJLENBQUMsS0FBSyxHQUFHLFFBQVEsQ0FBQyxHQUFHLENBQUMsY0FBYyxDQUFDLENBQUM7SUFDNUMsQ0FBQztJQXZCRCxJQUFJLGlCQUFpQjtRQUNuQixPQUFPLElBQUksQ0FBQyxXQUFXO2FBQ3BCLFdBQVcsQ0FBQyw4QkFBOEIsQ0FBQzthQUMzQyxJQUFJLENBQUMsR0FBRyxDQUFDLEtBQUssQ0FBQyxFQUFFLENBQUMsS0FBSyxFQUFFLFdBQVcsRUFBRSxLQUFLLE9BQU8sQ0FBQyxDQUFDLENBQUM7SUFDMUQsQ0FBQztJQUtELElBQUksaUNBQWlDO1FBQ25DLE9BQU8sSUFBSSxDQUFDLGlCQUFpQixFQUFFLENBQUMsSUFBSSxDQUFDLGdCQUFnQixJQUFJLElBQUksQ0FBQztJQUNoRSxDQUFDO0lBRUQsSUFBSSxrQkFBa0I7UUFDcEIsT0FBTyxJQUFJLENBQUMsaUNBQWlDLElBQUksSUFBSSxDQUFDLFlBQVksQ0FBQyxrQkFBa0IsQ0FBQztJQUN4RixDQUFDO0lBVU8saUJBQWlCO1FBQ3ZCLElBQUksS0FBSyxHQUFHLElBQUksQ0FBQyxLQUFLLENBQUMsUUFBUSxDQUFDO1FBQ2hDLElBQUksS0FBSyxHQUFHLENBQUMsQ0FBQztRQUNkLE1BQU0sVUFBVSxHQUFHLEVBQUUsQ0FBQztRQUN0QixPQUFPLEtBQUssQ0FBQyxVQUFVLElBQUksS0FBSyxHQUFHLFVBQVUsRUFBRTtZQUM3QyxLQUFLLEdBQUcsS0FBSyxDQUFDLFVBQVUsQ0FBQztZQUN6QixLQUFLLEVBQUUsQ0FBQztTQUNUO1FBQ0QsT0FBTyxLQUFLLENBQUM7SUFDZixDQUFDOzsrR0FyQ1Usa0JBQWtCO21IQUFsQixrQkFBa0I7MkZBQWxCLGtCQUFrQjtrQkFEOUIsVUFBVSIsInNvdXJjZXNDb250ZW50IjpbImltcG9ydCB7IEluamVjdGFibGUsIEluamVjdG9yIH0gZnJvbSAnQGFuZ3VsYXIvY29yZSc7XHJcbmltcG9ydCB7IE9ic2VydmFibGUgfSBmcm9tICdyeGpzJztcclxuaW1wb3J0IHsgbWFwIH0gZnJvbSAncnhqcy9vcGVyYXRvcnMnO1xyXG5pbXBvcnQgeyBBY3RpdmF0ZWRSb3V0ZSB9IGZyb20gJ0Bhbmd1bGFyL3JvdXRlcic7XHJcbmltcG9ydCB7IENvbmZpZ1N0YXRlU2VydmljZSwgTXVsdGlUZW5hbmN5U2VydmljZSB9IGZyb20gJ0BhYnAvbmcuY29yZSc7XHJcblxyXG5ASW5qZWN0YWJsZSgpXHJcbmV4cG9ydCBjbGFzcyBBdXRoV3JhcHBlclNlcnZpY2Uge1xyXG4gIGlzTXVsdGlUZW5hbmN5RW5hYmxlZCQgPSB0aGlzLmNvbmZpZ1N0YXRlLmdldERlZXAkKCdtdWx0aVRlbmFuY3kuaXNFbmFibGVkJyk7XHJcblxyXG4gIGdldCBlbmFibGVMb2NhbExvZ2luJCgpOiBPYnNlcnZhYmxlPGJvb2xlYW4+IHtcclxuICAgIHJldHVybiB0aGlzLmNvbmZpZ1N0YXRlXHJcbiAgICAgIC5nZXRTZXR0aW5nJCgnQWJwLkFjY291bnQuRW5hYmxlTG9jYWxMb2dpbicpXHJcbiAgICAgIC5waXBlKG1hcCh2YWx1ZSA9PiB2YWx1ZT8udG9Mb3dlckNhc2UoKSAhPT0gJ2ZhbHNlJykpO1xyXG4gIH1cclxuXHJcbiAgdGVuYW50Qm94S2V5ID0gJ0FjY291bnQuVGVuYW50Qm94Q29tcG9uZW50JztcclxuICByb3V0ZTogQWN0aXZhdGVkUm91dGU7XHJcblxyXG4gIGdldCBpc1RlbmFudEJveFZpc2libGVGb3JDdXJyZW50Um91dGUoKSB7XHJcbiAgICByZXR1cm4gdGhpcy5nZXRNb3N0SW5uZXJDaGlsZCgpLmRhdGEudGVuYW50Qm94VmlzaWJsZSA/PyB0cnVlO1xyXG4gIH1cclxuXHJcbiAgZ2V0IGlzVGVuYW50Qm94VmlzaWJsZSgpIHtcclxuICAgIHJldHVybiB0aGlzLmlzVGVuYW50Qm94VmlzaWJsZUZvckN1cnJlbnRSb3V0ZSAmJiB0aGlzLm11bHRpVGVuYW5jeS5pc1RlbmFudEJveFZpc2libGU7XHJcbiAgfVxyXG5cclxuICBjb25zdHJ1Y3RvcihcclxuICAgIHB1YmxpYyByZWFkb25seSBtdWx0aVRlbmFuY3k6IE11bHRpVGVuYW5jeVNlcnZpY2UsXHJcbiAgICBwcml2YXRlIGNvbmZpZ1N0YXRlOiBDb25maWdTdGF0ZVNlcnZpY2UsXHJcbiAgICBpbmplY3RvcjogSW5qZWN0b3IsXHJcbiAgKSB7XHJcbiAgICB0aGlzLnJvdXRlID0gaW5qZWN0b3IuZ2V0KEFjdGl2YXRlZFJvdXRlKTtcclxuICB9XHJcblxyXG4gIHByaXZhdGUgZ2V0TW9zdElubmVyQ2hpbGQoKSB7XHJcbiAgICBsZXQgY2hpbGQgPSB0aGlzLnJvdXRlLnNuYXBzaG90O1xyXG4gICAgbGV0IGRlcHRoID0gMDtcclxuICAgIGNvbnN0IGRlcHRoTGltaXQgPSAxMDtcclxuICAgIHdoaWxlIChjaGlsZC5maXJzdENoaWxkICYmIGRlcHRoIDwgZGVwdGhMaW1pdCkge1xyXG4gICAgICBjaGlsZCA9IGNoaWxkLmZpcnN0Q2hpbGQ7XHJcbiAgICAgIGRlcHRoKys7XHJcbiAgICB9XHJcbiAgICByZXR1cm4gY2hpbGQ7XHJcbiAgfVxyXG59XHJcbiJdfQ==
|
|
@@ -1,55 +0,0 @@
|
|
|
1
|
-
import { AbpTenantService, ConfigStateService, SessionStateService, } from '@abp/ng.core';
|
|
2
|
-
import { ToasterService } from '@abp/ng.theme.shared';
|
|
3
|
-
import { Injectable } from '@angular/core';
|
|
4
|
-
import { finalize } from 'rxjs/operators';
|
|
5
|
-
import * as i0 from "@angular/core";
|
|
6
|
-
import * as i1 from "@abp/ng.theme.shared";
|
|
7
|
-
import * as i2 from "@abp/ng.core";
|
|
8
|
-
export class TenantBoxService {
|
|
9
|
-
constructor(toasterService, tenantService, sessionState, configState) {
|
|
10
|
-
this.toasterService = toasterService;
|
|
11
|
-
this.tenantService = tenantService;
|
|
12
|
-
this.sessionState = sessionState;
|
|
13
|
-
this.configState = configState;
|
|
14
|
-
this.currentTenant$ = this.sessionState.getTenant$();
|
|
15
|
-
}
|
|
16
|
-
onSwitch() {
|
|
17
|
-
const tenant = this.sessionState.getTenant();
|
|
18
|
-
this.name = tenant?.name || '';
|
|
19
|
-
this.isModalVisible = true;
|
|
20
|
-
}
|
|
21
|
-
save() {
|
|
22
|
-
if (!this.name) {
|
|
23
|
-
this.setTenant(null);
|
|
24
|
-
this.isModalVisible = false;
|
|
25
|
-
return;
|
|
26
|
-
}
|
|
27
|
-
this.modalBusy = true;
|
|
28
|
-
this.tenantService
|
|
29
|
-
.findTenantByName(this.name)
|
|
30
|
-
.pipe(finalize(() => (this.modalBusy = false)))
|
|
31
|
-
.subscribe(({ success, tenantId: id, ...tenant }) => {
|
|
32
|
-
if (!success) {
|
|
33
|
-
this.showError();
|
|
34
|
-
return;
|
|
35
|
-
}
|
|
36
|
-
this.setTenant({ ...tenant, id, isAvailable: true });
|
|
37
|
-
this.isModalVisible = false;
|
|
38
|
-
});
|
|
39
|
-
}
|
|
40
|
-
setTenant(tenant) {
|
|
41
|
-
this.sessionState.setTenant(tenant);
|
|
42
|
-
this.configState.refreshAppState();
|
|
43
|
-
}
|
|
44
|
-
showError() {
|
|
45
|
-
this.toasterService.error('AbpUiMultiTenancy::GivenTenantIsNotAvailable', 'AbpUi::Error', {
|
|
46
|
-
messageLocalizationParams: [this.name || ''],
|
|
47
|
-
});
|
|
48
|
-
}
|
|
49
|
-
}
|
|
50
|
-
TenantBoxService.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "15.0.4", ngImport: i0, type: TenantBoxService, deps: [{ token: i1.ToasterService }, { token: i2.AbpTenantService }, { token: i2.SessionStateService }, { token: i2.ConfigStateService }], target: i0.ɵɵFactoryTarget.Injectable });
|
|
51
|
-
TenantBoxService.ɵprov = i0.ɵɵngDeclareInjectable({ minVersion: "12.0.0", version: "15.0.4", ngImport: i0, type: TenantBoxService });
|
|
52
|
-
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "15.0.4", ngImport: i0, type: TenantBoxService, decorators: [{
|
|
53
|
-
type: Injectable
|
|
54
|
-
}], ctorParameters: function () { return [{ type: i1.ToasterService }, { type: i2.AbpTenantService }, { type: i2.SessionStateService }, { type: i2.ConfigStateService }]; } });
|
|
55
|
-
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoidGVuYW50LWJveC5zZXJ2aWNlLmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vLi4vLi4vLi4vLi4vcGFja2FnZXMvYWNjb3VudC1jb3JlL3NyYy9saWIvdGVuYW50LWJveC5zZXJ2aWNlLnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQUFBLE9BQU8sRUFDTCxnQkFBZ0IsRUFDaEIsa0JBQWtCLEVBRWxCLG1CQUFtQixHQUNwQixNQUFNLGNBQWMsQ0FBQztBQUN0QixPQUFPLEVBQUUsY0FBYyxFQUFFLE1BQU0sc0JBQXNCLENBQUM7QUFDdEQsT0FBTyxFQUFFLFVBQVUsRUFBRSxNQUFNLGVBQWUsQ0FBQztBQUMzQyxPQUFPLEVBQUUsUUFBUSxFQUFFLE1BQU0sZ0JBQWdCLENBQUM7Ozs7QUFHMUMsTUFBTSxPQUFPLGdCQUFnQjtJQVMzQixZQUNVLGNBQThCLEVBQzlCLGFBQStCLEVBQy9CLFlBQWlDLEVBQ2pDLFdBQStCO1FBSC9CLG1CQUFjLEdBQWQsY0FBYyxDQUFnQjtRQUM5QixrQkFBYSxHQUFiLGFBQWEsQ0FBa0I7UUFDL0IsaUJBQVksR0FBWixZQUFZLENBQXFCO1FBQ2pDLGdCQUFXLEdBQVgsV0FBVyxDQUFvQjtRQVp6QyxtQkFBYyxHQUFHLElBQUksQ0FBQyxZQUFZLENBQUMsVUFBVSxFQUFFLENBQUM7SUFhN0MsQ0FBQztJQUVKLFFBQVE7UUFDTixNQUFNLE1BQU0sR0FBRyxJQUFJLENBQUMsWUFBWSxDQUFDLFNBQVMsRUFBRSxDQUFDO1FBQzdDLElBQUksQ0FBQyxJQUFJLEdBQUcsTUFBTSxFQUFFLElBQUksSUFBSSxFQUFFLENBQUM7UUFDL0IsSUFBSSxDQUFDLGNBQWMsR0FBRyxJQUFJLENBQUM7SUFDN0IsQ0FBQztJQUVELElBQUk7UUFDRixJQUFJLENBQUMsSUFBSSxDQUFDLElBQUksRUFBRTtZQUNkLElBQUksQ0FBQyxTQUFTLENBQUMsSUFBSSxDQUFDLENBQUM7WUFDckIsSUFBSSxDQUFDLGNBQWMsR0FBRyxLQUFLLENBQUM7WUFDNUIsT0FBTztTQUNSO1FBRUQsSUFBSSxDQUFDLFNBQVMsR0FBRyxJQUFJLENBQUM7UUFDdEIsSUFBSSxDQUFDLGFBQWE7YUFDZixnQkFBZ0IsQ0FBQyxJQUFJLENBQUMsSUFBSSxDQUFDO2FBQzNCLElBQUksQ0FBQyxRQUFRLENBQUMsR0FBRyxFQUFFLENBQUMsQ0FBQyxJQUFJLENBQUMsU0FBUyxHQUFHLEtBQUssQ0FBQyxDQUFDLENBQUM7YUFDOUMsU0FBUyxDQUFDLENBQUMsRUFBRSxPQUFPLEVBQUUsUUFBUSxFQUFFLEVBQUUsRUFBRSxHQUFHLE1BQU0sRUFBRSxFQUFFLEVBQUU7WUFDbEQsSUFBSSxDQUFDLE9BQU8sRUFBRTtnQkFDWixJQUFJLENBQUMsU0FBUyxFQUFFLENBQUM7Z0JBQ2pCLE9BQU87YUFDUjtZQUVELElBQUksQ0FBQyxTQUFTLENBQUMsRUFBRSxHQUFHLE1BQU0sRUFBRSxFQUFFLEVBQUUsV0FBVyxFQUFFLElBQUksRUFBRSxDQUFDLENBQUM7WUFDckQsSUFBSSxDQUFDLGNBQWMsR0FBRyxLQUFLLENBQUM7UUFDOUIsQ0FBQyxDQUFDLENBQUM7SUFDUCxDQUFDO0lBRU8sU0FBUyxDQUFDLE1BQStCO1FBQy9DLElBQUksQ0FBQyxZQUFZLENBQUMsU0FBUyxDQUFDLE1BQU0sQ0FBQyxDQUFDO1FBQ3BDLElBQUksQ0FBQyxXQUFXLENBQUMsZUFBZSxFQUFFLENBQUM7SUFDckMsQ0FBQztJQUVPLFNBQVM7UUFDZixJQUFJLENBQUMsY0FBYyxDQUFDLEtBQUssQ0FBQyw4Q0FBOEMsRUFBRSxjQUFjLEVBQUU7WUFDeEYseUJBQXlCLEVBQUUsQ0FBQyxJQUFJLENBQUMsSUFBSSxJQUFJLEVBQUUsQ0FBQztTQUM3QyxDQUFDLENBQUM7SUFDTCxDQUFDOzs2R0FyRFUsZ0JBQWdCO2lIQUFoQixnQkFBZ0I7MkZBQWhCLGdCQUFnQjtrQkFENUIsVUFBVSIsInNvdXJjZXNDb250ZW50IjpbImltcG9ydCB7XHJcbiAgQWJwVGVuYW50U2VydmljZSxcclxuICBDb25maWdTdGF0ZVNlcnZpY2UsXHJcbiAgQ3VycmVudFRlbmFudER0byxcclxuICBTZXNzaW9uU3RhdGVTZXJ2aWNlLFxyXG59IGZyb20gJ0BhYnAvbmcuY29yZSc7XHJcbmltcG9ydCB7IFRvYXN0ZXJTZXJ2aWNlIH0gZnJvbSAnQGFicC9uZy50aGVtZS5zaGFyZWQnO1xyXG5pbXBvcnQgeyBJbmplY3RhYmxlIH0gZnJvbSAnQGFuZ3VsYXIvY29yZSc7XHJcbmltcG9ydCB7IGZpbmFsaXplIH0gZnJvbSAncnhqcy9vcGVyYXRvcnMnO1xyXG5cclxuQEluamVjdGFibGUoKVxyXG5leHBvcnQgY2xhc3MgVGVuYW50Qm94U2VydmljZSB7XHJcbiAgY3VycmVudFRlbmFudCQgPSB0aGlzLnNlc3Npb25TdGF0ZS5nZXRUZW5hbnQkKCk7XHJcblxyXG4gIG5hbWU/OiBzdHJpbmc7XHJcblxyXG4gIGlzTW9kYWxWaXNpYmxlITogYm9vbGVhbjtcclxuXHJcbiAgbW9kYWxCdXN5ITogYm9vbGVhbjtcclxuXHJcbiAgY29uc3RydWN0b3IoXHJcbiAgICBwcml2YXRlIHRvYXN0ZXJTZXJ2aWNlOiBUb2FzdGVyU2VydmljZSxcclxuICAgIHByaXZhdGUgdGVuYW50U2VydmljZTogQWJwVGVuYW50U2VydmljZSxcclxuICAgIHByaXZhdGUgc2Vzc2lvblN0YXRlOiBTZXNzaW9uU3RhdGVTZXJ2aWNlLFxyXG4gICAgcHJpdmF0ZSBjb25maWdTdGF0ZTogQ29uZmlnU3RhdGVTZXJ2aWNlLFxyXG4gICkge31cclxuXHJcbiAgb25Td2l0Y2goKSB7XHJcbiAgICBjb25zdCB0ZW5hbnQgPSB0aGlzLnNlc3Npb25TdGF0ZS5nZXRUZW5hbnQoKTtcclxuICAgIHRoaXMubmFtZSA9IHRlbmFudD8ubmFtZSB8fCAnJztcclxuICAgIHRoaXMuaXNNb2RhbFZpc2libGUgPSB0cnVlO1xyXG4gIH1cclxuXHJcbiAgc2F2ZSgpIHtcclxuICAgIGlmICghdGhpcy5uYW1lKSB7XHJcbiAgICAgIHRoaXMuc2V0VGVuYW50KG51bGwpO1xyXG4gICAgICB0aGlzLmlzTW9kYWxWaXNpYmxlID0gZmFsc2U7XHJcbiAgICAgIHJldHVybjtcclxuICAgIH1cclxuXHJcbiAgICB0aGlzLm1vZGFsQnVzeSA9IHRydWU7XHJcbiAgICB0aGlzLnRlbmFudFNlcnZpY2VcclxuICAgICAgLmZpbmRUZW5hbnRCeU5hbWUodGhpcy5uYW1lKVxyXG4gICAgICAucGlwZShmaW5hbGl6ZSgoKSA9PiAodGhpcy5tb2RhbEJ1c3kgPSBmYWxzZSkpKVxyXG4gICAgICAuc3Vic2NyaWJlKCh7IHN1Y2Nlc3MsIHRlbmFudElkOiBpZCwgLi4udGVuYW50IH0pID0+IHtcclxuICAgICAgICBpZiAoIXN1Y2Nlc3MpIHtcclxuICAgICAgICAgIHRoaXMuc2hvd0Vycm9yKCk7XHJcbiAgICAgICAgICByZXR1cm47XHJcbiAgICAgICAgfVxyXG5cclxuICAgICAgICB0aGlzLnNldFRlbmFudCh7IC4uLnRlbmFudCwgaWQsIGlzQXZhaWxhYmxlOiB0cnVlIH0pO1xyXG4gICAgICAgIHRoaXMuaXNNb2RhbFZpc2libGUgPSBmYWxzZTtcclxuICAgICAgfSk7XHJcbiAgfVxyXG5cclxuICBwcml2YXRlIHNldFRlbmFudCh0ZW5hbnQ6IEN1cnJlbnRUZW5hbnREdG8gfCBudWxsKSB7XHJcbiAgICB0aGlzLnNlc3Npb25TdGF0ZS5zZXRUZW5hbnQodGVuYW50KTtcclxuICAgIHRoaXMuY29uZmlnU3RhdGUucmVmcmVzaEFwcFN0YXRlKCk7XHJcbiAgfVxyXG5cclxuICBwcml2YXRlIHNob3dFcnJvcigpIHtcclxuICAgIHRoaXMudG9hc3RlclNlcnZpY2UuZXJyb3IoJ0FicFVpTXVsdGlUZW5hbmN5OjpHaXZlblRlbmFudElzTm90QXZhaWxhYmxlJywgJ0FicFVpOjpFcnJvcicsIHtcclxuICAgICAgbWVzc2FnZUxvY2FsaXphdGlvblBhcmFtczogW3RoaXMubmFtZSB8fCAnJ10sXHJcbiAgICB9KTtcclxuICB9XHJcbn1cclxuIl19
|
|
@@ -1,34 +0,0 @@
|
|
|
1
|
-
import { RestService } from '@abp/ng.core';
|
|
2
|
-
import { Injectable } from '@angular/core';
|
|
3
|
-
import * as i0 from "@angular/core";
|
|
4
|
-
import * as i1 from "@abp/ng.core";
|
|
5
|
-
export class AccountService {
|
|
6
|
-
constructor(restService) {
|
|
7
|
-
this.restService = restService;
|
|
8
|
-
this.apiName = 'AbpAccount';
|
|
9
|
-
this.register = (input) => this.restService.request({
|
|
10
|
-
method: 'POST',
|
|
11
|
-
url: '/api/account/register',
|
|
12
|
-
body: input,
|
|
13
|
-
}, { apiName: this.apiName });
|
|
14
|
-
this.resetPassword = (input) => this.restService.request({
|
|
15
|
-
method: 'POST',
|
|
16
|
-
url: '/api/account/reset-password',
|
|
17
|
-
body: input,
|
|
18
|
-
}, { apiName: this.apiName });
|
|
19
|
-
this.sendPasswordResetCode = (input) => this.restService.request({
|
|
20
|
-
method: 'POST',
|
|
21
|
-
url: '/api/account/send-password-reset-code',
|
|
22
|
-
body: input,
|
|
23
|
-
}, { apiName: this.apiName });
|
|
24
|
-
}
|
|
25
|
-
}
|
|
26
|
-
AccountService.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "15.0.4", ngImport: i0, type: AccountService, deps: [{ token: i1.RestService }], target: i0.ɵɵFactoryTarget.Injectable });
|
|
27
|
-
AccountService.ɵprov = i0.ɵɵngDeclareInjectable({ minVersion: "12.0.0", version: "15.0.4", ngImport: i0, type: AccountService, providedIn: 'root' });
|
|
28
|
-
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "15.0.4", ngImport: i0, type: AccountService, decorators: [{
|
|
29
|
-
type: Injectable,
|
|
30
|
-
args: [{
|
|
31
|
-
providedIn: 'root',
|
|
32
|
-
}]
|
|
33
|
-
}], ctorParameters: function () { return [{ type: i1.RestService }]; } });
|
|
34
|
-
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiYWNjb3VudC5zZXJ2aWNlLmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vLi4vLi4vLi4vLi4vLi4vLi4vLi4vcGFja2FnZXMvYWNjb3VudC1jb3JlL3Byb3h5L3NyYy9saWIvcHJveHkvYWNjb3VudC9hY2NvdW50LnNlcnZpY2UudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBQ0EsT0FBTyxFQUFFLFdBQVcsRUFBRSxNQUFNLGNBQWMsQ0FBQztBQUMzQyxPQUFPLEVBQUUsVUFBVSxFQUFFLE1BQU0sZUFBZSxDQUFDOzs7QUFNM0MsTUFBTSxPQUFPLGNBQWM7SUEyQnpCLFlBQW9CLFdBQXdCO1FBQXhCLGdCQUFXLEdBQVgsV0FBVyxDQUFhO1FBMUI1QyxZQUFPLEdBQUcsWUFBWSxDQUFDO1FBRXZCLGFBQVEsR0FBRyxDQUFDLEtBQWtCLEVBQUUsRUFBRSxDQUNoQyxJQUFJLENBQUMsV0FBVyxDQUFDLE9BQU8sQ0FBdUI7WUFDN0MsTUFBTSxFQUFFLE1BQU07WUFDZCxHQUFHLEVBQUUsdUJBQXVCO1lBQzVCLElBQUksRUFBRSxLQUFLO1NBQ1osRUFDRCxFQUFFLE9BQU8sRUFBRSxJQUFJLENBQUMsT0FBTyxFQUFFLENBQUMsQ0FBQztRQUU3QixrQkFBYSxHQUFHLENBQUMsS0FBdUIsRUFBRSxFQUFFLENBQzFDLElBQUksQ0FBQyxXQUFXLENBQUMsT0FBTyxDQUFZO1lBQ2xDLE1BQU0sRUFBRSxNQUFNO1lBQ2QsR0FBRyxFQUFFLDZCQUE2QjtZQUNsQyxJQUFJLEVBQUUsS0FBSztTQUNaLEVBQ0QsRUFBRSxPQUFPLEVBQUUsSUFBSSxDQUFDLE9BQU8sRUFBRSxDQUFDLENBQUM7UUFFN0IsMEJBQXFCLEdBQUcsQ0FBQyxLQUErQixFQUFFLEVBQUUsQ0FDMUQsSUFBSSxDQUFDLFdBQVcsQ0FBQyxPQUFPLENBQVk7WUFDbEMsTUFBTSxFQUFFLE1BQU07WUFDZCxHQUFHLEVBQUUsdUNBQXVDO1lBQzVDLElBQUksRUFBRSxLQUFLO1NBQ1osRUFDRCxFQUFFLE9BQU8sRUFBRSxJQUFJLENBQUMsT0FBTyxFQUFFLENBQUMsQ0FBQztJQUVrQixDQUFDOzsyR0EzQnJDLGNBQWM7K0dBQWQsY0FBYyxjQUZiLE1BQU07MkZBRVAsY0FBYztrQkFIMUIsVUFBVTttQkFBQztvQkFDVixVQUFVLEVBQUUsTUFBTTtpQkFDbkIiLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQgdHlwZSB7IFJlZ2lzdGVyRHRvLCBSZXNldFBhc3N3b3JkRHRvLCBTZW5kUGFzc3dvcmRSZXNldENvZGVEdG8gfSBmcm9tICcuL21vZGVscyc7XHJcbmltcG9ydCB7IFJlc3RTZXJ2aWNlIH0gZnJvbSAnQGFicC9uZy5jb3JlJztcclxuaW1wb3J0IHsgSW5qZWN0YWJsZSB9IGZyb20gJ0Bhbmd1bGFyL2NvcmUnO1xyXG5pbXBvcnQgdHlwZSB7IElkZW50aXR5VXNlckR0byB9IGZyb20gJy4uL2lkZW50aXR5L21vZGVscyc7XHJcblxyXG5ASW5qZWN0YWJsZSh7XHJcbiAgcHJvdmlkZWRJbjogJ3Jvb3QnLFxyXG59KVxyXG5leHBvcnQgY2xhc3MgQWNjb3VudFNlcnZpY2Uge1xyXG4gIGFwaU5hbWUgPSAnQWJwQWNjb3VudCc7XHJcblxyXG4gIHJlZ2lzdGVyID0gKGlucHV0OiBSZWdpc3RlckR0bykgPT5cclxuICAgIHRoaXMucmVzdFNlcnZpY2UucmVxdWVzdDxhbnksIElkZW50aXR5VXNlckR0bz4oe1xyXG4gICAgICBtZXRob2Q6ICdQT1NUJyxcclxuICAgICAgdXJsOiAnL2FwaS9hY2NvdW50L3JlZ2lzdGVyJyxcclxuICAgICAgYm9keTogaW5wdXQsXHJcbiAgICB9LFxyXG4gICAgeyBhcGlOYW1lOiB0aGlzLmFwaU5hbWUgfSk7XHJcblxyXG4gIHJlc2V0UGFzc3dvcmQgPSAoaW5wdXQ6IFJlc2V0UGFzc3dvcmREdG8pID0+XHJcbiAgICB0aGlzLnJlc3RTZXJ2aWNlLnJlcXVlc3Q8YW55LCB2b2lkPih7XHJcbiAgICAgIG1ldGhvZDogJ1BPU1QnLFxyXG4gICAgICB1cmw6ICcvYXBpL2FjY291bnQvcmVzZXQtcGFzc3dvcmQnLFxyXG4gICAgICBib2R5OiBpbnB1dCxcclxuICAgIH0sXHJcbiAgICB7IGFwaU5hbWU6IHRoaXMuYXBpTmFtZSB9KTtcclxuXHJcbiAgc2VuZFBhc3N3b3JkUmVzZXRDb2RlID0gKGlucHV0OiBTZW5kUGFzc3dvcmRSZXNldENvZGVEdG8pID0+XHJcbiAgICB0aGlzLnJlc3RTZXJ2aWNlLnJlcXVlc3Q8YW55LCB2b2lkPih7XHJcbiAgICAgIG1ldGhvZDogJ1BPU1QnLFxyXG4gICAgICB1cmw6ICcvYXBpL2FjY291bnQvc2VuZC1wYXNzd29yZC1yZXNldC1jb2RlJyxcclxuICAgICAgYm9keTogaW5wdXQsXHJcbiAgICB9LFxyXG4gICAgeyBhcGlOYW1lOiB0aGlzLmFwaU5hbWUgfSk7XHJcblxyXG4gIGNvbnN0cnVjdG9yKHByaXZhdGUgcmVzdFNlcnZpY2U6IFJlc3RTZXJ2aWNlKSB7fVxyXG59XHJcbiJdfQ==
|
|
@@ -1,33 +0,0 @@
|
|
|
1
|
-
import { RestService } from '@abp/ng.core';
|
|
2
|
-
import { Injectable } from '@angular/core';
|
|
3
|
-
import * as i0 from "@angular/core";
|
|
4
|
-
import * as i1 from "@abp/ng.core";
|
|
5
|
-
export class ProfileService {
|
|
6
|
-
constructor(restService) {
|
|
7
|
-
this.restService = restService;
|
|
8
|
-
this.apiName = 'AbpAccount';
|
|
9
|
-
this.changePassword = (input) => this.restService.request({
|
|
10
|
-
method: 'POST',
|
|
11
|
-
url: '/api/account/my-profile/change-password',
|
|
12
|
-
body: input,
|
|
13
|
-
}, { apiName: this.apiName });
|
|
14
|
-
this.get = () => this.restService.request({
|
|
15
|
-
method: 'GET',
|
|
16
|
-
url: '/api/account/my-profile',
|
|
17
|
-
}, { apiName: this.apiName });
|
|
18
|
-
this.update = (input) => this.restService.request({
|
|
19
|
-
method: 'PUT',
|
|
20
|
-
url: '/api/account/my-profile',
|
|
21
|
-
body: input,
|
|
22
|
-
}, { apiName: this.apiName });
|
|
23
|
-
}
|
|
24
|
-
}
|
|
25
|
-
ProfileService.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "15.0.4", ngImport: i0, type: ProfileService, deps: [{ token: i1.RestService }], target: i0.ɵɵFactoryTarget.Injectable });
|
|
26
|
-
ProfileService.ɵprov = i0.ɵɵngDeclareInjectable({ minVersion: "12.0.0", version: "15.0.4", ngImport: i0, type: ProfileService, providedIn: 'root' });
|
|
27
|
-
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "15.0.4", ngImport: i0, type: ProfileService, decorators: [{
|
|
28
|
-
type: Injectable,
|
|
29
|
-
args: [{
|
|
30
|
-
providedIn: 'root',
|
|
31
|
-
}]
|
|
32
|
-
}], ctorParameters: function () { return [{ type: i1.RestService }]; } });
|
|
33
|
-
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoicHJvZmlsZS5zZXJ2aWNlLmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vLi4vLi4vLi4vLi4vLi4vLi4vLi4vcGFja2FnZXMvYWNjb3VudC1jb3JlL3Byb3h5L3NyYy9saWIvcHJveHkvYWNjb3VudC9wcm9maWxlLnNlcnZpY2UudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBQ0EsT0FBTyxFQUFFLFdBQVcsRUFBRSxNQUFNLGNBQWMsQ0FBQztBQUMzQyxPQUFPLEVBQUUsVUFBVSxFQUFFLE1BQU0sZUFBZSxDQUFDOzs7QUFLM0MsTUFBTSxPQUFPLGNBQWM7SUEwQnpCLFlBQW9CLFdBQXdCO1FBQXhCLGdCQUFXLEdBQVgsV0FBVyxDQUFhO1FBekI1QyxZQUFPLEdBQUcsWUFBWSxDQUFDO1FBRXZCLG1CQUFjLEdBQUcsQ0FBQyxLQUEwQixFQUFFLEVBQUUsQ0FDOUMsSUFBSSxDQUFDLFdBQVcsQ0FBQyxPQUFPLENBQVk7WUFDbEMsTUFBTSxFQUFFLE1BQU07WUFDZCxHQUFHLEVBQUUseUNBQXlDO1lBQzlDLElBQUksRUFBRSxLQUFLO1NBQ1osRUFDRCxFQUFFLE9BQU8sRUFBRSxJQUFJLENBQUMsT0FBTyxFQUFFLENBQUMsQ0FBQztRQUU3QixRQUFHLEdBQUcsR0FBRyxFQUFFLENBQ1QsSUFBSSxDQUFDLFdBQVcsQ0FBQyxPQUFPLENBQWtCO1lBQ3hDLE1BQU0sRUFBRSxLQUFLO1lBQ2IsR0FBRyxFQUFFLHlCQUF5QjtTQUMvQixFQUNELEVBQUUsT0FBTyxFQUFFLElBQUksQ0FBQyxPQUFPLEVBQUUsQ0FBQyxDQUFDO1FBRTdCLFdBQU0sR0FBRyxDQUFDLEtBQXVCLEVBQUUsRUFBRSxDQUNuQyxJQUFJLENBQUMsV0FBVyxDQUFDLE9BQU8sQ0FBa0I7WUFDeEMsTUFBTSxFQUFFLEtBQUs7WUFDYixHQUFHLEVBQUUseUJBQXlCO1lBQzlCLElBQUksRUFBRSxLQUFLO1NBQ1osRUFDRCxFQUFFLE9BQU8sRUFBRSxJQUFJLENBQUMsT0FBTyxFQUFFLENBQUMsQ0FBQztJQUVrQixDQUFDOzsyR0ExQnJDLGNBQWM7K0dBQWQsY0FBYyxjQUZiLE1BQU07MkZBRVAsY0FBYztrQkFIMUIsVUFBVTttQkFBQztvQkFDVixVQUFVLEVBQUUsTUFBTTtpQkFDbkIiLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQgdHlwZSB7IENoYW5nZVBhc3N3b3JkSW5wdXQsIFByb2ZpbGVEdG8sIFVwZGF0ZVByb2ZpbGVEdG8gfSBmcm9tICcuL21vZGVscyc7XHJcbmltcG9ydCB7IFJlc3RTZXJ2aWNlIH0gZnJvbSAnQGFicC9uZy5jb3JlJztcclxuaW1wb3J0IHsgSW5qZWN0YWJsZSB9IGZyb20gJ0Bhbmd1bGFyL2NvcmUnO1xyXG5cclxuQEluamVjdGFibGUoe1xyXG4gIHByb3ZpZGVkSW46ICdyb290JyxcclxufSlcclxuZXhwb3J0IGNsYXNzIFByb2ZpbGVTZXJ2aWNlIHtcclxuICBhcGlOYW1lID0gJ0FicEFjY291bnQnO1xyXG5cclxuICBjaGFuZ2VQYXNzd29yZCA9IChpbnB1dDogQ2hhbmdlUGFzc3dvcmRJbnB1dCkgPT5cclxuICAgIHRoaXMucmVzdFNlcnZpY2UucmVxdWVzdDxhbnksIHZvaWQ+KHtcclxuICAgICAgbWV0aG9kOiAnUE9TVCcsXHJcbiAgICAgIHVybDogJy9hcGkvYWNjb3VudC9teS1wcm9maWxlL2NoYW5nZS1wYXNzd29yZCcsXHJcbiAgICAgIGJvZHk6IGlucHV0LFxyXG4gICAgfSxcclxuICAgIHsgYXBpTmFtZTogdGhpcy5hcGlOYW1lIH0pO1xyXG5cclxuICBnZXQgPSAoKSA9PlxyXG4gICAgdGhpcy5yZXN0U2VydmljZS5yZXF1ZXN0PGFueSwgUHJvZmlsZUR0bz4oe1xyXG4gICAgICBtZXRob2Q6ICdHRVQnLFxyXG4gICAgICB1cmw6ICcvYXBpL2FjY291bnQvbXktcHJvZmlsZScsXHJcbiAgICB9LFxyXG4gICAgeyBhcGlOYW1lOiB0aGlzLmFwaU5hbWUgfSk7XHJcblxyXG4gIHVwZGF0ZSA9IChpbnB1dDogVXBkYXRlUHJvZmlsZUR0bykgPT5cclxuICAgIHRoaXMucmVzdFNlcnZpY2UucmVxdWVzdDxhbnksIFByb2ZpbGVEdG8+KHtcclxuICAgICAgbWV0aG9kOiAnUFVUJyxcclxuICAgICAgdXJsOiAnL2FwaS9hY2NvdW50L215LXByb2ZpbGUnLFxyXG4gICAgICBib2R5OiBpbnB1dCxcclxuICAgIH0sXHJcbiAgICB7IGFwaU5hbWU6IHRoaXMuYXBpTmFtZSB9KTtcclxuXHJcbiAgY29uc3RydWN0b3IocHJpdmF0ZSByZXN0U2VydmljZTogUmVzdFNlcnZpY2UpIHt9XHJcbn1cclxuIl19
|
|
@@ -1,33 +0,0 @@
|
|
|
1
|
-
import { RestService } from '@abp/ng.core';
|
|
2
|
-
import { Injectable } from '@angular/core';
|
|
3
|
-
import * as i0 from "@angular/core";
|
|
4
|
-
import * as i1 from "@abp/ng.core";
|
|
5
|
-
export class AccountService {
|
|
6
|
-
constructor(restService) {
|
|
7
|
-
this.restService = restService;
|
|
8
|
-
this.apiName = 'AbpAccount';
|
|
9
|
-
this.checkPasswordByLogin = (login) => this.restService.request({
|
|
10
|
-
method: 'POST',
|
|
11
|
-
url: '/api/account/check-password',
|
|
12
|
-
body: login,
|
|
13
|
-
}, { apiName: this.apiName });
|
|
14
|
-
this.loginByLogin = (login) => this.restService.request({
|
|
15
|
-
method: 'POST',
|
|
16
|
-
url: '/api/account/login',
|
|
17
|
-
body: login,
|
|
18
|
-
}, { apiName: this.apiName });
|
|
19
|
-
this.logout = () => this.restService.request({
|
|
20
|
-
method: 'GET',
|
|
21
|
-
url: '/api/account/logout',
|
|
22
|
-
}, { apiName: this.apiName });
|
|
23
|
-
}
|
|
24
|
-
}
|
|
25
|
-
AccountService.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "15.0.4", ngImport: i0, type: AccountService, deps: [{ token: i1.RestService }], target: i0.ɵɵFactoryTarget.Injectable });
|
|
26
|
-
AccountService.ɵprov = i0.ɵɵngDeclareInjectable({ minVersion: "12.0.0", version: "15.0.4", ngImport: i0, type: AccountService, providedIn: 'root' });
|
|
27
|
-
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "15.0.4", ngImport: i0, type: AccountService, decorators: [{
|
|
28
|
-
type: Injectable,
|
|
29
|
-
args: [{
|
|
30
|
-
providedIn: 'root',
|
|
31
|
-
}]
|
|
32
|
-
}], ctorParameters: function () { return [{ type: i1.RestService }]; } });
|
|
33
|
-
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiYWNjb3VudC5zZXJ2aWNlLmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vLi4vLi4vLi4vLi4vLi4vLi4vLi4vLi4vLi4vLi4vLi4vcGFja2FnZXMvYWNjb3VudC1jb3JlL3Byb3h5L3NyYy9saWIvcHJveHkvYWNjb3VudC93ZWIvYXJlYXMvYWNjb3VudC9jb250cm9sbGVycy9hY2NvdW50LnNlcnZpY2UudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBQ0EsT0FBTyxFQUFFLFdBQVcsRUFBRSxNQUFNLGNBQWMsQ0FBQztBQUMzQyxPQUFPLEVBQUUsVUFBVSxFQUFFLE1BQU0sZUFBZSxDQUFDOzs7QUFLM0MsTUFBTSxPQUFPLGNBQWM7SUEwQnpCLFlBQW9CLFdBQXdCO1FBQXhCLGdCQUFXLEdBQVgsV0FBVyxDQUFhO1FBekI1QyxZQUFPLEdBQUcsWUFBWSxDQUFDO1FBRXZCLHlCQUFvQixHQUFHLENBQUMsS0FBb0IsRUFBRSxFQUFFLENBQzlDLElBQUksQ0FBQyxXQUFXLENBQUMsT0FBTyxDQUFzQjtZQUM1QyxNQUFNLEVBQUUsTUFBTTtZQUNkLEdBQUcsRUFBRSw2QkFBNkI7WUFDbEMsSUFBSSxFQUFFLEtBQUs7U0FDWixFQUNELEVBQUUsT0FBTyxFQUFFLElBQUksQ0FBQyxPQUFPLEVBQUUsQ0FBQyxDQUFDO1FBRTdCLGlCQUFZLEdBQUcsQ0FBQyxLQUFvQixFQUFFLEVBQUUsQ0FDdEMsSUFBSSxDQUFDLFdBQVcsQ0FBQyxPQUFPLENBQXNCO1lBQzVDLE1BQU0sRUFBRSxNQUFNO1lBQ2QsR0FBRyxFQUFFLG9CQUFvQjtZQUN6QixJQUFJLEVBQUUsS0FBSztTQUNaLEVBQ0QsRUFBRSxPQUFPLEVBQUUsSUFBSSxDQUFDLE9BQU8sRUFBRSxDQUFDLENBQUM7UUFFN0IsV0FBTSxHQUFHLEdBQUcsRUFBRSxDQUNaLElBQUksQ0FBQyxXQUFXLENBQUMsT0FBTyxDQUFZO1lBQ2xDLE1BQU0sRUFBRSxLQUFLO1lBQ2IsR0FBRyxFQUFFLHFCQUFxQjtTQUMzQixFQUNELEVBQUUsT0FBTyxFQUFFLElBQUksQ0FBQyxPQUFPLEVBQUUsQ0FBQyxDQUFDO0lBRWtCLENBQUM7OzJHQTFCckMsY0FBYzsrR0FBZCxjQUFjLGNBRmIsTUFBTTsyRkFFUCxjQUFjO2tCQUgxQixVQUFVO21CQUFDO29CQUNWLFVBQVUsRUFBRSxNQUFNO2lCQUNuQiIsInNvdXJjZXNDb250ZW50IjpbImltcG9ydCB0eXBlIHsgQWJwTG9naW5SZXN1bHQsIFVzZXJMb2dpbkluZm8gfSBmcm9tICcuL21vZGVscy9tb2RlbHMnO1xyXG5pbXBvcnQgeyBSZXN0U2VydmljZSB9IGZyb20gJ0BhYnAvbmcuY29yZSc7XHJcbmltcG9ydCB7IEluamVjdGFibGUgfSBmcm9tICdAYW5ndWxhci9jb3JlJztcclxuXHJcbkBJbmplY3RhYmxlKHtcclxuICBwcm92aWRlZEluOiAncm9vdCcsXHJcbn0pXHJcbmV4cG9ydCBjbGFzcyBBY2NvdW50U2VydmljZSB7XHJcbiAgYXBpTmFtZSA9ICdBYnBBY2NvdW50JztcclxuXHJcbiAgY2hlY2tQYXNzd29yZEJ5TG9naW4gPSAobG9naW46IFVzZXJMb2dpbkluZm8pID0+XHJcbiAgICB0aGlzLnJlc3RTZXJ2aWNlLnJlcXVlc3Q8YW55LCBBYnBMb2dpblJlc3VsdD4oe1xyXG4gICAgICBtZXRob2Q6ICdQT1NUJyxcclxuICAgICAgdXJsOiAnL2FwaS9hY2NvdW50L2NoZWNrLXBhc3N3b3JkJyxcclxuICAgICAgYm9keTogbG9naW4sXHJcbiAgICB9LFxyXG4gICAgeyBhcGlOYW1lOiB0aGlzLmFwaU5hbWUgfSk7XHJcblxyXG4gIGxvZ2luQnlMb2dpbiA9IChsb2dpbjogVXNlckxvZ2luSW5mbykgPT5cclxuICAgIHRoaXMucmVzdFNlcnZpY2UucmVxdWVzdDxhbnksIEFicExvZ2luUmVzdWx0Pih7XHJcbiAgICAgIG1ldGhvZDogJ1BPU1QnLFxyXG4gICAgICB1cmw6ICcvYXBpL2FjY291bnQvbG9naW4nLFxyXG4gICAgICBib2R5OiBsb2dpbixcclxuICAgIH0sXHJcbiAgICB7IGFwaU5hbWU6IHRoaXMuYXBpTmFtZSB9KTtcclxuXHJcbiAgbG9nb3V0ID0gKCkgPT5cclxuICAgIHRoaXMucmVzdFNlcnZpY2UucmVxdWVzdDxhbnksIHZvaWQ+KHtcclxuICAgICAgbWV0aG9kOiAnR0VUJyxcclxuICAgICAgdXJsOiAnL2FwaS9hY2NvdW50L2xvZ291dCcsXHJcbiAgICB9LFxyXG4gICAgeyBhcGlOYW1lOiB0aGlzLmFwaU5hbWUgfSk7XHJcblxyXG4gIGNvbnN0cnVjdG9yKHByaXZhdGUgcmVzdFNlcnZpY2U6IFJlc3RTZXJ2aWNlKSB7fVxyXG59XHJcbiJdfQ==
|