@netgrif/components-core 7.0.0-rc.6 → 7.0.0-rc.7
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/commons/schema.d.ts +8 -0
- package/esm2022/assets/i18n/de.json +1 -0
- package/esm2022/assets/i18n/en.json +1 -0
- package/esm2022/assets/i18n/sk.json +1 -0
- package/esm2022/commons/schema.mjs +1 -1
- package/esm2022/lib/forms/login/abstract-login-form.component.mjs +10 -4
- package/esm2022/lib/forms/login/login-sso/abstract-login-sso.component.mjs +102 -0
- package/esm2022/lib/forms/public-api.mjs +2 -1
- package/esm2022/lib/utility/public-api.mjs +2 -1
- package/esm2022/lib/utility/tests/mocks/mock-case-resource.service.mjs +49 -0
- package/esm2022/lib/utility/tests/mocks/mock-task-resource.service.mjs +6 -5
- package/fesm2022/netgrif-components-core.mjs +154 -8
- package/fesm2022/netgrif-components-core.mjs.map +1 -1
- package/lib/forms/login/abstract-login-form.component.d.ts +4 -1
- package/lib/forms/login/login-sso/abstract-login-sso.component.d.ts +31 -0
- package/lib/forms/public-api.d.ts +1 -0
- package/lib/utility/public-api.d.ts +1 -0
- package/lib/utility/tests/mocks/mock-case-resource.service.d.ts +11 -0
- package/lib/utility/tests/mocks/mock-task-resource.service.d.ts +2 -4
- package/package.json +1 -1
- package/src/assets/i18n/de.json +1 -0
- package/src/assets/i18n/en.json +1 -0
- package/src/assets/i18n/sk.json +1 -0
package/commons/schema.d.ts
CHANGED
|
@@ -33,8 +33,16 @@ export interface Auth {
|
|
|
33
33
|
endpoints?: string | {
|
|
34
34
|
[k: string]: string;
|
|
35
35
|
};
|
|
36
|
+
sso?: Sso;
|
|
36
37
|
[k: string]: any;
|
|
37
38
|
}
|
|
39
|
+
export interface Sso {
|
|
40
|
+
enable: boolean;
|
|
41
|
+
redirectUrl: string;
|
|
42
|
+
refreshUrl: string;
|
|
43
|
+
clientId: string;
|
|
44
|
+
scopes: Array<string>;
|
|
45
|
+
}
|
|
38
46
|
export interface Resource {
|
|
39
47
|
name: string;
|
|
40
48
|
address: string;
|
|
@@ -313,6 +313,7 @@
|
|
|
313
313
|
"login": "Benutzername",
|
|
314
314
|
"wrongCredentials": "Falsche Anmeldeinformationen!",
|
|
315
315
|
"loginButton": "Anmelden",
|
|
316
|
+
"ssoButton": "SSO-Anmeldung",
|
|
316
317
|
"reset": "Kennwort wiederherstellen",
|
|
317
318
|
"sign": "Registrieren",
|
|
318
319
|
"enterPass": "Ihre Kennwort eingeben"
|
|
@@ -313,6 +313,7 @@
|
|
|
313
313
|
"login": "Prihlasovacie meno",
|
|
314
314
|
"wrongCredentials": "Nesprávne prihlasovacie údaje!",
|
|
315
315
|
"loginButton": "Prihlásiť",
|
|
316
|
+
"ssoButton": "Prihlásiť sa pomocou SSO",
|
|
316
317
|
"reset": "Obnova hesla",
|
|
317
318
|
"sign": "Registrovať",
|
|
318
319
|
"enterPass": "Zadajte svoje heslo"
|
|
@@ -4,4 +4,4 @@
|
|
|
4
4
|
// noticing. However as soon as we include other interfaces from the lib here, schematics will reference them and fail to compile.
|
|
5
5
|
// We need to find a good solution for this.
|
|
6
6
|
export {};
|
|
7
|
-
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"schema.js","sourceRoot":"","sources":["../../../../projects/netgrif-components-core/src/commons/schema.ts"],"names":[],"mappings":"AAAA,4IAA4I;AAC5I,2IAA2I;AAC3I,2IAA2I;AAC3I,mIAAmI;AACnI,6CAA6C","sourcesContent":["// TODO BUG 17.4.2020 - this file should contain very precise information about the intended structure of nae.json BUT this is a .d.ts file.\n//  If we include other interfaces from the lib into this file, schematic compilation fails. Schematics reference this file without problem\n//  but they can't reference files above their sourceRoot declared in their tsconfig file. Since this file is .d.ts it runs without anybody\n//  noticing. However as soon as we include other interfaces from the lib here, schematics will reference them and fail to compile.\n//  We need to find a good solution for this.\n\n/**\n * This file is single point of truth for NAE frontend configuration schema.\n */\n\nexport type Resources =\n    | Resource\n    | Array<Resource>;\n\n/**\n * Schema for NAE configuration object\n */\nexport interface NetgrifApplicationEngine {\n    providers: SetAuthAndResourcesAddress;\n    theme: Theme;\n    locales?: Locales;\n    filters?: Filters;\n    views: Views;\n    services?: Services;\n\n    [k: string]: any;\n}\n\nexport interface Locales {\n    /**\n     * Key is locale code (ISO639-1 '-' ISO3166-1)\n     * Value is a file of translation\n     */\n    [k: string]: string;\n}\n\nexport interface SetAuthAndResourcesAddress {\n    auth: Auth;\n    resources: Resources;\n\n    [k: string]: any;\n}\n\nexport interface Auth {\n    address: string;\n    authentication: string;\n    sessionBearer?: string;\n    endpoints?: string | { [k: string]: string };\n\n    [k: string]: any;\n}\n\nexport interface Resource {\n    name: string;\n    address: string;\n    format: string;\n    openApi?: string;\n}\n\nexport interface Theme {\n    name: string;\n    pallets: {\n        light: {\n            primary:\n                string\n                | {\n                '50'?: string;\n                '100'?: string;\n                '200'?: string;\n                '300'?: string;\n                '400'?: string;\n                '500'?: string;\n                '600'?: string;\n                '700'?: string;\n                '800'?: string;\n                '900'?: string;\n                contrast?: { 'light': Array<string>; 'dark': Array<string>; };\n                [k: string]: any;\n            };\n            secondary?:\n                string\n                | {\n                '50'?: string;\n                '100'?: string;\n                '200'?: string;\n                '300'?: string;\n                '400'?: string;\n                '500'?: string;\n                '600'?: string;\n                '700'?: string;\n                '800'?: string;\n                '900'?: string;\n                contrast?: { 'light': Array<string>; 'dark': Array<string>; };\n                [k: string]: any;\n            };\n            warn?:\n                string\n                | {\n                '50'?: string;\n                '100'?: string;\n                '200'?: string;\n                '300'?: string;\n                '400'?: string;\n                '500'?: string;\n                '600'?: string;\n                '700'?: string;\n                '800'?: string;\n                '900'?: string;\n                contrast?: { 'light': Array<string>; 'dark': Array<string>; };\n                [k: string]: any;\n            };\n            [k: string]: any;\n        };\n        dark?: {\n            primary?:\n                string\n                | {\n                '50'?: string;\n                '100'?: string;\n                '200'?: string;\n                '300'?: string;\n                '400'?: string;\n                '500'?: string;\n                '600'?: string;\n                '700'?: string;\n                '800'?: string;\n                '900'?: string;\n                contrast?: { 'light': Array<string>; 'dark': Array<string>; };\n                [k: string]: any;\n            };\n            secondary?:\n                string\n                | {\n                '50'?: string;\n                '100'?: string;\n                '200'?: string;\n                '300'?: string;\n                '400'?: string;\n                '500'?: string;\n                '600'?: string;\n                '700'?: string;\n                '800'?: string;\n                '900'?: string;\n                contrast?: { 'light': Array<string>; 'dark': Array<string>; };\n                [k: string]: any;\n            };\n            warn?:\n                string\n                | {\n                '50'?: string;\n                '100'?: string;\n                '200'?: string;\n                '300'?: string;\n                '400'?: string;\n                '500'?: string;\n                '600'?: string;\n                '700'?: string;\n                '800'?: string;\n                '900'?: string;\n                contrast?: { 'light': Array<string>; 'dark': Array<string>; };\n                [k: string]: any;\n            };\n            [k: string]: any;\n        };\n        [k: string]: any;\n    };\n\n    [k: string]: any;\n}\n\nexport interface Filters {\n    [k: string]: ConfigFilter;\n}\n\nexport interface ConfigFilter {\n    title: string;\n    access?: string;\n    body: object | Array<object>;\n    type: 'Task' | 'Case';\n    mergeOperator?: 'AND' | 'OR';\n\n    [k: string]: any;\n}\n\nexport interface Views {\n    /**\n     * This interface was referenced by `undefined`'s JSON-Schema definition\n     * via the `patternProperty` \"^[a-zA-Z0-9_]+$\".\n     */\n    [k: string]: View;\n}\n\nexport interface View {\n    layout?: {\n        name: string;\n        enableCaseTitle?: boolean;\n        isCaseTitleRequired?: boolean;\n        showDeleteMenu?: boolean;\n        confirmWorkflowDeletion?: boolean;\n        params?: {\n            orientation?: string;\n            [k: string]: any;\n        };\n        /**\n         * Override autogenerated name. 'Component' will be appended automatically.\n         */\n        componentName?: string;\n        [k: string]: any;\n    };\n    /**\n     * Use own custom component for this view\n     */\n    component?: {\n        class: string;\n        from: string;\n    };\n    // layout: CaseLayout | TaskLayout;\n    access:\n        | 'public' | 'private'\n        | Access;\n    navigation:\n        | boolean\n        | {\n        title?: string;\n        icon?: string;\n        translate?: boolean;\n        [k: string]: any;\n    };\n    children?: Views;\n    routing: {\n        path: string;\n        match?: boolean;\n    };\n\n    [k: string]: any;\n}\n\n/**\n * Defines the access constraints of an application view\n */\nexport interface Access {\n    /**\n     * `string` and `Array<string>` types are deprecated and support for them will be removed in a future version.\n     *\n     *  For `string` values the format is: <net import id>.<role name>\n     */\n    role?: Array<string> | string | RoleAccess | Array<RoleAccess>;\n    bannedRole?: Array<string> | string | RoleAccess | Array<RoleAccess>;\n    group?: Array<string> | string;\n    authority?: Array<string> | string;\n\n    [k: string]: any;\n}\n\n/**\n * Defines a single role access constraint\n */\nexport interface RoleAccess {\n    /**\n     * Process identifier (import ID)\n     */\n    processId: string;\n    /**\n     * Role import ID\n     */\n    roleId: string;\n}\n\nexport interface CaseLayout {\n    name: 'caseView';\n    params: object;\n}\n\nexport interface TaskLayout {\n    name: 'taskView';\n    params: object;\n}\n\nexport interface Services {\n    log?: {\n        level?: string;\n        logWithDate?: boolean;\n        serializeParams?: boolean;\n        includeLogLevel?: boolean;\n        publishers?: Array<any>;\n        [k: string]: any;\n    };\n    auth?: {\n        /**\n         * @deprecated in 6.3.0 use [onLogoutRedirect]{@link Services#auth.onLogoutRedirect} instead\n         *\n         * Determines the route the application should redirect to when the logout action is performed\n         *\n         * This value should be retrieved by calling the [getOnLogoutPath]{@link ConfigurationService#getOnLogoutPath} method of the\n         * {@link ConfigurationService} as it handles fall backs on deprecated attributes.\n         */\n        logoutRedirect?: string;\n        /**\n         * @deprecated in 6.3.0 use [toLoginRedirect]{@link Services#auth.toLoginRedirect} instead\n         *\n         * Determines the route the application should redirect to when a guard prevents entry to some route\n         *\n         * This value should be retrieved by calling the [getToLoginPath]{@link ConfigurationService#getToLoginPath} method of the\n         * {@link ConfigurationService} as it handles fall backs on deprecated attributes.\n         */\n        loginRedirect?: string;\n        /**\n         * Determines the route the application should redirect to when the logout action is performed\n         *\n         * This value should be retrieved by calling the [getOnLogoutPath]{@link ConfigurationService#getOnLogoutPath} method of the\n         * {@link ConfigurationService} as it handles fall backs on deprecated attributes.\n         */\n        onLogoutRedirect?: string;\n        /**\n         * Determines the route the application should redirect to when a guard prevents entry to some route\n         *\n         * This value should be retrieved by calling the [getToLoginPath]{@link ConfigurationService#getToLoginPath} method of the\n         * {@link ConfigurationService} as it handles fall backs on deprecated attributes.\n         */\n        toLoginRedirect?: string;\n        /**\n         * Determines the route the application should redirect to when the login action is performed\n         *\n         * This value should be retrieved by calling the [getOnLoginPath]{@link ConfigurationService#getOnLoginPath} method of the\n         * {@link ConfigurationService}\n         */\n        onLoginRedirect?: string;\n    };\n    routing?: {\n        defaultRedirect?: string;\n        wildcardRedirect?: string;\n    };\n    dataFields?: {\n        template?: string,\n        appearance?: string\n    };\n    legal: {\n        termsOfService: string,\n        privacyPolicy: string\n    };\n    groupNavigation?: {\n        groupNavigationRoute: string,\n    };\n    doubleDrawer?: {\n        url: string,\n    }\n\n    [k: string]: any;\n}\n"]}
|
|
7
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"schema.js","sourceRoot":"","sources":["../../../../projects/netgrif-components-core/src/commons/schema.ts"],"names":[],"mappings":"AAAA,4IAA4I;AAC5I,2IAA2I;AAC3I,2IAA2I;AAC3I,mIAAmI;AACnI,6CAA6C","sourcesContent":["// TODO BUG 17.4.2020 - this file should contain very precise information about the intended structure of nae.json BUT this is a .d.ts file.\n//  If we include other interfaces from the lib into this file, schematic compilation fails. Schematics reference this file without problem\n//  but they can't reference files above their sourceRoot declared in their tsconfig file. Since this file is .d.ts it runs without anybody\n//  noticing. However as soon as we include other interfaces from the lib here, schematics will reference them and fail to compile.\n//  We need to find a good solution for this.\n\n/**\n * This file is single point of truth for NAE frontend configuration schema.\n */\n\nexport type Resources =\n    | Resource\n    | Array<Resource>;\n\n/**\n * Schema for NAE configuration object\n */\nexport interface NetgrifApplicationEngine {\n    providers: SetAuthAndResourcesAddress;\n    theme: Theme;\n    locales?: Locales;\n    filters?: Filters;\n    views: Views;\n    services?: Services;\n\n    [k: string]: any;\n}\n\nexport interface Locales {\n    /**\n     * Key is locale code (ISO639-1 '-' ISO3166-1)\n     * Value is a file of translation\n     */\n    [k: string]: string;\n}\n\nexport interface SetAuthAndResourcesAddress {\n    auth: Auth;\n    resources: Resources;\n\n    [k: string]: any;\n}\n\nexport interface Auth {\n    address: string;\n    authentication: string;\n    sessionBearer?: string;\n    endpoints?: string | { [k: string]: string };\n    sso?: Sso;\n\n    [k: string]: any;\n}\n\nexport interface Sso {\n    enable: boolean;\n    redirectUrl: string;\n    refreshUrl: string;\n    clientId: string;\n    scopes: Array<string>;\n}\n\nexport interface Resource {\n    name: string;\n    address: string;\n    format: string;\n    openApi?: string;\n}\n\nexport interface Theme {\n    name: string;\n    pallets: {\n        light: {\n            primary:\n                string\n                | {\n                '50'?: string;\n                '100'?: string;\n                '200'?: string;\n                '300'?: string;\n                '400'?: string;\n                '500'?: string;\n                '600'?: string;\n                '700'?: string;\n                '800'?: string;\n                '900'?: string;\n                contrast?: { 'light': Array<string>; 'dark': Array<string>; };\n                [k: string]: any;\n            };\n            secondary?:\n                string\n                | {\n                '50'?: string;\n                '100'?: string;\n                '200'?: string;\n                '300'?: string;\n                '400'?: string;\n                '500'?: string;\n                '600'?: string;\n                '700'?: string;\n                '800'?: string;\n                '900'?: string;\n                contrast?: { 'light': Array<string>; 'dark': Array<string>; };\n                [k: string]: any;\n            };\n            warn?:\n                string\n                | {\n                '50'?: string;\n                '100'?: string;\n                '200'?: string;\n                '300'?: string;\n                '400'?: string;\n                '500'?: string;\n                '600'?: string;\n                '700'?: string;\n                '800'?: string;\n                '900'?: string;\n                contrast?: { 'light': Array<string>; 'dark': Array<string>; };\n                [k: string]: any;\n            };\n            [k: string]: any;\n        };\n        dark?: {\n            primary?:\n                string\n                | {\n                '50'?: string;\n                '100'?: string;\n                '200'?: string;\n                '300'?: string;\n                '400'?: string;\n                '500'?: string;\n                '600'?: string;\n                '700'?: string;\n                '800'?: string;\n                '900'?: string;\n                contrast?: { 'light': Array<string>; 'dark': Array<string>; };\n                [k: string]: any;\n            };\n            secondary?:\n                string\n                | {\n                '50'?: string;\n                '100'?: string;\n                '200'?: string;\n                '300'?: string;\n                '400'?: string;\n                '500'?: string;\n                '600'?: string;\n                '700'?: string;\n                '800'?: string;\n                '900'?: string;\n                contrast?: { 'light': Array<string>; 'dark': Array<string>; };\n                [k: string]: any;\n            };\n            warn?:\n                string\n                | {\n                '50'?: string;\n                '100'?: string;\n                '200'?: string;\n                '300'?: string;\n                '400'?: string;\n                '500'?: string;\n                '600'?: string;\n                '700'?: string;\n                '800'?: string;\n                '900'?: string;\n                contrast?: { 'light': Array<string>; 'dark': Array<string>; };\n                [k: string]: any;\n            };\n            [k: string]: any;\n        };\n        [k: string]: any;\n    };\n\n    [k: string]: any;\n}\n\nexport interface Filters {\n    [k: string]: ConfigFilter;\n}\n\nexport interface ConfigFilter {\n    title: string;\n    access?: string;\n    body: object | Array<object>;\n    type: 'Task' | 'Case';\n    mergeOperator?: 'AND' | 'OR';\n\n    [k: string]: any;\n}\n\nexport interface Views {\n    /**\n     * This interface was referenced by `undefined`'s JSON-Schema definition\n     * via the `patternProperty` \"^[a-zA-Z0-9_]+$\".\n     */\n    [k: string]: View;\n}\n\nexport interface View {\n    layout?: {\n        name: string;\n        enableCaseTitle?: boolean;\n        isCaseTitleRequired?: boolean;\n        showDeleteMenu?: boolean;\n        confirmWorkflowDeletion?: boolean;\n        params?: {\n            orientation?: string;\n            [k: string]: any;\n        };\n        /**\n         * Override autogenerated name. 'Component' will be appended automatically.\n         */\n        componentName?: string;\n        [k: string]: any;\n    };\n    /**\n     * Use own custom component for this view\n     */\n    component?: {\n        class: string;\n        from: string;\n    };\n    // layout: CaseLayout | TaskLayout;\n    access:\n        | 'public' | 'private'\n        | Access;\n    navigation:\n        | boolean\n        | {\n        title?: string;\n        icon?: string;\n        translate?: boolean;\n        [k: string]: any;\n    };\n    children?: Views;\n    routing: {\n        path: string;\n        match?: boolean;\n    };\n\n    [k: string]: any;\n}\n\n/**\n * Defines the access constraints of an application view\n */\nexport interface Access {\n    /**\n     * `string` and `Array<string>` types are deprecated and support for them will be removed in a future version.\n     *\n     *  For `string` values the format is: <net import id>.<role name>\n     */\n    role?: Array<string> | string | RoleAccess | Array<RoleAccess>;\n    bannedRole?: Array<string> | string | RoleAccess | Array<RoleAccess>;\n    group?: Array<string> | string;\n    authority?: Array<string> | string;\n\n    [k: string]: any;\n}\n\n/**\n * Defines a single role access constraint\n */\nexport interface RoleAccess {\n    /**\n     * Process identifier (import ID)\n     */\n    processId: string;\n    /**\n     * Role import ID\n     */\n    roleId: string;\n}\n\nexport interface CaseLayout {\n    name: 'caseView';\n    params: object;\n}\n\nexport interface TaskLayout {\n    name: 'taskView';\n    params: object;\n}\n\nexport interface Services {\n    log?: {\n        level?: string;\n        logWithDate?: boolean;\n        serializeParams?: boolean;\n        includeLogLevel?: boolean;\n        publishers?: Array<any>;\n        [k: string]: any;\n    };\n    auth?: {\n        /**\n         * @deprecated in 6.3.0 use [onLogoutRedirect]{@link Services#auth.onLogoutRedirect} instead\n         *\n         * Determines the route the application should redirect to when the logout action is performed\n         *\n         * This value should be retrieved by calling the [getOnLogoutPath]{@link ConfigurationService#getOnLogoutPath} method of the\n         * {@link ConfigurationService} as it handles fall backs on deprecated attributes.\n         */\n        logoutRedirect?: string;\n        /**\n         * @deprecated in 6.3.0 use [toLoginRedirect]{@link Services#auth.toLoginRedirect} instead\n         *\n         * Determines the route the application should redirect to when a guard prevents entry to some route\n         *\n         * This value should be retrieved by calling the [getToLoginPath]{@link ConfigurationService#getToLoginPath} method of the\n         * {@link ConfigurationService} as it handles fall backs on deprecated attributes.\n         */\n        loginRedirect?: string;\n        /**\n         * Determines the route the application should redirect to when the logout action is performed\n         *\n         * This value should be retrieved by calling the [getOnLogoutPath]{@link ConfigurationService#getOnLogoutPath} method of the\n         * {@link ConfigurationService} as it handles fall backs on deprecated attributes.\n         */\n        onLogoutRedirect?: string;\n        /**\n         * Determines the route the application should redirect to when a guard prevents entry to some route\n         *\n         * This value should be retrieved by calling the [getToLoginPath]{@link ConfigurationService#getToLoginPath} method of the\n         * {@link ConfigurationService} as it handles fall backs on deprecated attributes.\n         */\n        toLoginRedirect?: string;\n        /**\n         * Determines the route the application should redirect to when the login action is performed\n         *\n         * This value should be retrieved by calling the [getOnLoginPath]{@link ConfigurationService#getOnLoginPath} method of the\n         * {@link ConfigurationService}\n         */\n        onLoginRedirect?: string;\n    };\n    routing?: {\n        defaultRedirect?: string;\n        wildcardRedirect?: string;\n    };\n    dataFields?: {\n        template?: string,\n        appearance?: string\n    };\n    legal: {\n        termsOfService: string,\n        privacyPolicy: string\n    };\n    groupNavigation?: {\n        groupNavigationRoute: string,\n    };\n    doubleDrawer?: {\n        url: string,\n    }\n\n    [k: string]: any;\n}\n"]}
|
|
@@ -4,19 +4,23 @@ import { take } from 'rxjs/operators';
|
|
|
4
4
|
import * as i0 from "@angular/core";
|
|
5
5
|
import * as i1 from "@angular/forms";
|
|
6
6
|
import * as i2 from "../../user/services/user.service";
|
|
7
|
+
import * as i3 from "../../configuration/configuration.service";
|
|
7
8
|
export class AbstractLoginFormComponent {
|
|
8
9
|
_userService;
|
|
10
|
+
_config;
|
|
9
11
|
rootFormGroup;
|
|
10
12
|
hidePassword = true;
|
|
11
13
|
loading;
|
|
14
|
+
showSsoButton;
|
|
12
15
|
showSignUpButton;
|
|
13
16
|
showForgottenPasswordButton;
|
|
14
17
|
login;
|
|
15
18
|
resetPassword;
|
|
16
19
|
signUp;
|
|
17
20
|
formSubmit;
|
|
18
|
-
constructor(formBuilder, _userService) {
|
|
21
|
+
constructor(formBuilder, _userService, _config) {
|
|
19
22
|
this._userService = _userService;
|
|
23
|
+
this._config = _config;
|
|
20
24
|
this.rootFormGroup = formBuilder.group({
|
|
21
25
|
login: [''],
|
|
22
26
|
password: ['']
|
|
@@ -26,6 +30,8 @@ export class AbstractLoginFormComponent {
|
|
|
26
30
|
this.signUp = new EventEmitter();
|
|
27
31
|
this.formSubmit = new EventEmitter();
|
|
28
32
|
this.loading = new LoadingEmitter();
|
|
33
|
+
let ssoConfig = this._config.getConfigurationSubtree(['providers', 'auth', 'sso']);
|
|
34
|
+
this.showSsoButton = ssoConfig?.enable;
|
|
29
35
|
}
|
|
30
36
|
ngOnDestroy() {
|
|
31
37
|
this.loading.complete();
|
|
@@ -58,7 +64,7 @@ export class AbstractLoginFormComponent {
|
|
|
58
64
|
}
|
|
59
65
|
return 'end';
|
|
60
66
|
}
|
|
61
|
-
static ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "17.3.12", ngImport: i0, type: AbstractLoginFormComponent, deps: [{ token: i1.FormBuilder }, { token: i2.UserService }], target: i0.ɵɵFactoryTarget.Component });
|
|
67
|
+
static ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "17.3.12", ngImport: i0, type: AbstractLoginFormComponent, deps: [{ token: i1.FormBuilder }, { token: i2.UserService }, { token: i3.ConfigurationService }], target: i0.ɵɵFactoryTarget.Component });
|
|
62
68
|
static ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "17.3.12", type: AbstractLoginFormComponent, selector: "ncc-abstract-login-field", inputs: { showSignUpButton: "showSignUpButton", showForgottenPasswordButton: "showForgottenPasswordButton" }, outputs: { login: "login", resetPassword: "resetPassword", signUp: "signUp", formSubmit: "formSubmit" }, ngImport: i0, template: '', isInline: true });
|
|
63
69
|
}
|
|
64
70
|
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "17.3.12", ngImport: i0, type: AbstractLoginFormComponent, decorators: [{
|
|
@@ -67,7 +73,7 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "17.3.12", ngImpo
|
|
|
67
73
|
selector: 'ncc-abstract-login-field',
|
|
68
74
|
template: ''
|
|
69
75
|
}]
|
|
70
|
-
}], ctorParameters: () => [{ type: i1.FormBuilder }, { type: i2.UserService }], propDecorators: { showSignUpButton: [{
|
|
76
|
+
}], ctorParameters: () => [{ type: i1.FormBuilder }, { type: i2.UserService }, { type: i3.ConfigurationService }], propDecorators: { showSignUpButton: [{
|
|
71
77
|
type: Input
|
|
72
78
|
}], showForgottenPasswordButton: [{
|
|
73
79
|
type: Input
|
|
@@ -80,4 +86,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "17.3.12", ngImpo
|
|
|
80
86
|
}], formSubmit: [{
|
|
81
87
|
type: Output
|
|
82
88
|
}] } });
|
|
83
|
-
//# sourceMappingURL=data:application/json;base64,
|
|
89
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiYWJzdHJhY3QtbG9naW4tZm9ybS5jb21wb25lbnQuanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi8uLi8uLi8uLi9wcm9qZWN0cy9uZXRncmlmLWNvbXBvbmVudHMtY29yZS9zcmMvbGliL2Zvcm1zL2xvZ2luL2Fic3RyYWN0LWxvZ2luLWZvcm0uY29tcG9uZW50LnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQUFBLE9BQU8sRUFBQyxTQUFTLEVBQUUsWUFBWSxFQUFFLEtBQUssRUFBYSxNQUFNLEVBQUMsTUFBTSxlQUFlLENBQUM7QUFLaEYsT0FBTyxFQUFDLGNBQWMsRUFBQyxNQUFNLCtCQUErQixDQUFDO0FBQzdELE9BQU8sRUFBQyxJQUFJLEVBQUMsTUFBTSxnQkFBZ0IsQ0FBQzs7Ozs7QUFRcEMsTUFBTSxPQUFnQiwwQkFBMEI7SUFjYztJQUFxQztJQVp4RixhQUFhLENBQVk7SUFDekIsWUFBWSxHQUFHLElBQUksQ0FBQztJQUNwQixPQUFPLENBQWlCO0lBQ3JCLGFBQWEsQ0FBVTtJQUVqQixnQkFBZ0IsQ0FBVTtJQUMxQiwyQkFBMkIsQ0FBVTtJQUNwQyxLQUFLLENBQXFCO0lBQzFCLGFBQWEsQ0FBcUI7SUFDbEMsTUFBTSxDQUFxQjtJQUMzQixVQUFVLENBQWdDO0lBRTNELFlBQXNCLFdBQXdCLEVBQVksWUFBeUIsRUFBWSxPQUE2QjtRQUFsRSxpQkFBWSxHQUFaLFlBQVksQ0FBYTtRQUFZLFlBQU8sR0FBUCxPQUFPLENBQXNCO1FBQ3hILElBQUksQ0FBQyxhQUFhLEdBQUcsV0FBVyxDQUFDLEtBQUssQ0FBQztZQUNuQyxLQUFLLEVBQUUsQ0FBQyxFQUFFLENBQUM7WUFDWCxRQUFRLEVBQUUsQ0FBQyxFQUFFLENBQUM7U0FDakIsQ0FBQyxDQUFDO1FBQ0gsSUFBSSxDQUFDLEtBQUssR0FBRyxJQUFJLFlBQVksRUFBUSxDQUFDO1FBQ3RDLElBQUksQ0FBQyxhQUFhLEdBQUcsSUFBSSxZQUFZLEVBQVEsQ0FBQztRQUM5QyxJQUFJLENBQUMsTUFBTSxHQUFHLElBQUksWUFBWSxFQUFRLENBQUM7UUFDdkMsSUFBSSxDQUFDLFVBQVUsR0FBRyxJQUFJLFlBQVksRUFBbUIsQ0FBQztRQUN0RCxJQUFJLENBQUMsT0FBTyxHQUFHLElBQUksY0FBYyxFQUFFLENBQUM7UUFDcEMsSUFBSSxTQUFTLEdBQVEsSUFBSSxDQUFDLE9BQU8sQ0FBQyx1QkFBdUIsQ0FBQyxDQUFDLFdBQVcsRUFBRSxNQUFNLEVBQUUsS0FBSyxDQUFDLENBQUMsQ0FBQTtRQUN2RixJQUFJLENBQUMsYUFBYSxHQUFHLFNBQVMsRUFBRSxNQUFNLENBQUE7SUFDMUMsQ0FBQztJQUVELFdBQVc7UUFDUCxJQUFJLENBQUMsT0FBTyxDQUFDLFFBQVEsRUFBRSxDQUFDO1FBQ3hCLElBQUksQ0FBQyxLQUFLLENBQUMsUUFBUSxFQUFFLENBQUM7UUFDdEIsSUFBSSxDQUFDLGFBQWEsQ0FBQyxRQUFRLEVBQUUsQ0FBQztRQUM5QixJQUFJLENBQUMsTUFBTSxDQUFDLFFBQVEsRUFBRSxDQUFDO1FBQ3ZCLElBQUksQ0FBQyxVQUFVLENBQUMsUUFBUSxFQUFFLENBQUM7SUFDL0IsQ0FBQztJQUVELFFBQVE7UUFDSixJQUFJLENBQUMsSUFBSSxDQUFDLGFBQWEsQ0FBQyxLQUFLLElBQUksSUFBSSxDQUFDLE9BQU8sQ0FBQyxRQUFRLEVBQUU7WUFDcEQsT0FBTztTQUNWO1FBQ0QsTUFBTSxVQUFVLEdBQUcsRUFBQyxRQUFRLEVBQUUsSUFBSSxDQUFDLGFBQWEsQ0FBQyxRQUFRLENBQUMsT0FBTyxDQUFDLENBQUMsS0FBSyxFQUFFLFFBQVEsRUFBRSxJQUFJLENBQUMsYUFBYSxDQUFDLFFBQVEsQ0FBQyxVQUFVLENBQUMsQ0FBQyxLQUFLLEVBQUMsQ0FBQztRQUVuSSxJQUFJLENBQUMsT0FBTyxDQUFDLEVBQUUsRUFBRSxDQUFDO1FBQ2xCLElBQUksQ0FBQyxVQUFVLENBQUMsSUFBSSxDQUFDLFVBQVUsQ0FBQyxDQUFDO1FBQ2pDLElBQUksQ0FBQyxZQUFZLENBQUMsS0FBSyxDQUFDLFVBQVUsQ0FBQyxDQUFDLElBQUksQ0FBQyxJQUFJLENBQUMsQ0FBQyxDQUFDLENBQUMsQ0FBQyxTQUFTLENBQUMsQ0FBQyxJQUFVLEVBQUUsRUFBRTtZQUN2RSxJQUFJLENBQUMsS0FBSyxDQUFDLElBQUksQ0FBQyxJQUFJLENBQUMsQ0FBQztZQUN0QixJQUFJLENBQUMsT0FBTyxDQUFDLEdBQUcsRUFBRSxDQUFDO1FBQ3ZCLENBQUMsQ0FBQyxDQUFDO0lBQ1AsQ0FBQztJQUVELFNBQVM7UUFDTCxJQUFJLENBQUMsYUFBYSxDQUFDLElBQUksRUFBRSxDQUFDO0lBQzlCLENBQUM7SUFFRCxVQUFVO1FBQ04sSUFBSSxDQUFDLE1BQU0sQ0FBQyxJQUFJLEVBQUUsQ0FBQztJQUN2QixDQUFDO0lBRUQsdUJBQXVCO1FBQ25CLElBQUksSUFBSSxDQUFDLGdCQUFnQixJQUFJLElBQUksQ0FBQywyQkFBMkIsRUFBRTtZQUMzRCxPQUFPLGVBQWUsQ0FBQztTQUMxQjtRQUNELE9BQU8sS0FBSyxDQUFDO0lBQ2pCLENBQUM7d0dBL0RpQiwwQkFBMEI7NEZBQTFCLDBCQUEwQix1UkFGbEMsRUFBRTs7NEZBRU0sMEJBQTBCO2tCQUovQyxTQUFTO21CQUFDO29CQUNQLFFBQVEsRUFBRSwwQkFBMEI7b0JBQ3BDLFFBQVEsRUFBRSxFQUFFO2lCQUNmOzZJQVFtQixnQkFBZ0I7c0JBQS9CLEtBQUs7Z0JBQ1UsMkJBQTJCO3NCQUExQyxLQUFLO2dCQUNXLEtBQUs7c0JBQXJCLE1BQU07Z0JBQ1UsYUFBYTtzQkFBN0IsTUFBTTtnQkFDVSxNQUFNO3NCQUF0QixNQUFNO2dCQUNVLFVBQVU7c0JBQTFCLE1BQU0iLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQge0NvbXBvbmVudCwgRXZlbnRFbWl0dGVyLCBJbnB1dCwgT25EZXN0cm95LCBPdXRwdXR9IGZyb20gJ0Bhbmd1bGFyL2NvcmUnO1xuaW1wb3J0IHtGb3JtQnVpbGRlciwgRm9ybUdyb3VwfSBmcm9tICdAYW5ndWxhci9mb3Jtcyc7XG5pbXBvcnQge0Zvcm1TdWJtaXRFdmVudCwgSGFzRm9ybX0gZnJvbSAnLi4vaGFzLWZvcm0nO1xuaW1wb3J0IHtVc2VyU2VydmljZX0gZnJvbSAnLi4vLi4vdXNlci9zZXJ2aWNlcy91c2VyLnNlcnZpY2UnO1xuaW1wb3J0IHtVc2VyfSBmcm9tICcuLi8uLi91c2VyL21vZGVscy91c2VyJztcbmltcG9ydCB7TG9hZGluZ0VtaXR0ZXJ9IGZyb20gJy4uLy4uL3V0aWxpdHkvbG9hZGluZy1lbWl0dGVyJztcbmltcG9ydCB7dGFrZX0gZnJvbSAncnhqcy9vcGVyYXRvcnMnO1xuaW1wb3J0IHtDb25maWd1cmF0aW9uU2VydmljZX0gZnJvbSBcIi4uLy4uL2NvbmZpZ3VyYXRpb24vY29uZmlndXJhdGlvbi5zZXJ2aWNlXCI7XG5pbXBvcnQge1Nzb30gZnJvbSBcIi4uLy4uLy4uL2NvbW1vbnMvc2NoZW1hXCI7XG5cbkBDb21wb25lbnQoe1xuICAgIHNlbGVjdG9yOiAnbmNjLWFic3RyYWN0LWxvZ2luLWZpZWxkJyxcbiAgICB0ZW1wbGF0ZTogJydcbn0pXG5leHBvcnQgYWJzdHJhY3QgY2xhc3MgQWJzdHJhY3RMb2dpbkZvcm1Db21wb25lbnQgaW1wbGVtZW50cyBIYXNGb3JtLCBPbkRlc3Ryb3kge1xuXG4gICAgcHVibGljIHJvb3RGb3JtR3JvdXA6IEZvcm1Hcm91cDtcbiAgICBwdWJsaWMgaGlkZVBhc3N3b3JkID0gdHJ1ZTtcbiAgICBwdWJsaWMgbG9hZGluZzogTG9hZGluZ0VtaXR0ZXI7XG4gICAgcHJvdGVjdGVkIHNob3dTc29CdXR0b246IGJvb2xlYW47XG5cbiAgICBASW5wdXQoKSBwdWJsaWMgc2hvd1NpZ25VcEJ1dHRvbjogYm9vbGVhbjtcbiAgICBASW5wdXQoKSBwdWJsaWMgc2hvd0ZvcmdvdHRlblBhc3N3b3JkQnV0dG9uOiBib29sZWFuO1xuICAgIEBPdXRwdXQoKSBwdWJsaWMgbG9naW46IEV2ZW50RW1pdHRlcjxVc2VyPjtcbiAgICBAT3V0cHV0KCkgcHVibGljIHJlc2V0UGFzc3dvcmQ6IEV2ZW50RW1pdHRlcjx2b2lkPjtcbiAgICBAT3V0cHV0KCkgcHVibGljIHNpZ25VcDogRXZlbnRFbWl0dGVyPHZvaWQ+O1xuICAgIEBPdXRwdXQoKSBwdWJsaWMgZm9ybVN1Ym1pdDogRXZlbnRFbWl0dGVyPEZvcm1TdWJtaXRFdmVudD47XG5cbiAgICBwcm90ZWN0ZWQgY29uc3RydWN0b3IoZm9ybUJ1aWxkZXI6IEZvcm1CdWlsZGVyLCBwcm90ZWN0ZWQgX3VzZXJTZXJ2aWNlOiBVc2VyU2VydmljZSwgcHJvdGVjdGVkIF9jb25maWc6IENvbmZpZ3VyYXRpb25TZXJ2aWNlKSB7XG4gICAgICAgIHRoaXMucm9vdEZvcm1Hcm91cCA9IGZvcm1CdWlsZGVyLmdyb3VwKHtcbiAgICAgICAgICAgIGxvZ2luOiBbJyddLFxuICAgICAgICAgICAgcGFzc3dvcmQ6IFsnJ11cbiAgICAgICAgfSk7XG4gICAgICAgIHRoaXMubG9naW4gPSBuZXcgRXZlbnRFbWl0dGVyPFVzZXI+KCk7XG4gICAgICAgIHRoaXMucmVzZXRQYXNzd29yZCA9IG5ldyBFdmVudEVtaXR0ZXI8dm9pZD4oKTtcbiAgICAgICAgdGhpcy5zaWduVXAgPSBuZXcgRXZlbnRFbWl0dGVyPHZvaWQ+KCk7XG4gICAgICAgIHRoaXMuZm9ybVN1Ym1pdCA9IG5ldyBFdmVudEVtaXR0ZXI8Rm9ybVN1Ym1pdEV2ZW50PigpO1xuICAgICAgICB0aGlzLmxvYWRpbmcgPSBuZXcgTG9hZGluZ0VtaXR0ZXIoKTtcbiAgICAgICAgbGV0IHNzb0NvbmZpZzogU3NvID0gdGhpcy5fY29uZmlnLmdldENvbmZpZ3VyYXRpb25TdWJ0cmVlKFsncHJvdmlkZXJzJywgJ2F1dGgnLCAnc3NvJ10pXG4gICAgICAgIHRoaXMuc2hvd1Nzb0J1dHRvbiA9IHNzb0NvbmZpZz8uZW5hYmxlXG4gICAgfVxuXG4gICAgbmdPbkRlc3Ryb3koKTogdm9pZCB7XG4gICAgICAgIHRoaXMubG9hZGluZy5jb21wbGV0ZSgpO1xuICAgICAgICB0aGlzLmxvZ2luLmNvbXBsZXRlKCk7XG4gICAgICAgIHRoaXMucmVzZXRQYXNzd29yZC5jb21wbGV0ZSgpO1xuICAgICAgICB0aGlzLnNpZ25VcC5jb21wbGV0ZSgpO1xuICAgICAgICB0aGlzLmZvcm1TdWJtaXQuY29tcGxldGUoKTtcbiAgICB9XG5cbiAgICBvblN1Ym1pdCgpIHtcbiAgICAgICAgaWYgKCF0aGlzLnJvb3RGb3JtR3JvdXAudmFsaWQgfHwgdGhpcy5sb2FkaW5nLmlzQWN0aXZlKSB7XG4gICAgICAgICAgICByZXR1cm47XG4gICAgICAgIH1cbiAgICAgICAgY29uc3QgY3JlZGVudGlhbCA9IHt1c2VybmFtZTogdGhpcy5yb290Rm9ybUdyb3VwLmNvbnRyb2xzWydsb2dpbiddLnZhbHVlLCBwYXNzd29yZDogdGhpcy5yb290Rm9ybUdyb3VwLmNvbnRyb2xzWydwYXNzd29yZCddLnZhbHVlfTtcblxuICAgICAgICB0aGlzLmxvYWRpbmcub24oKTtcbiAgICAgICAgdGhpcy5mb3JtU3VibWl0LmVtaXQoY3JlZGVudGlhbCk7XG4gICAgICAgIHRoaXMuX3VzZXJTZXJ2aWNlLmxvZ2luKGNyZWRlbnRpYWwpLnBpcGUodGFrZSgxKSkuc3Vic2NyaWJlKCh1c2VyOiBVc2VyKSA9PiB7XG4gICAgICAgICAgICB0aGlzLmxvZ2luLmVtaXQodXNlcik7XG4gICAgICAgICAgICB0aGlzLmxvYWRpbmcub2ZmKCk7XG4gICAgICAgIH0pO1xuICAgIH1cblxuICAgIHJlc2V0RW1pdCgpIHtcbiAgICAgICAgdGhpcy5yZXNldFBhc3N3b3JkLmVtaXQoKTtcbiAgICB9XG5cbiAgICBzaWduVXBFbWl0KCkge1xuICAgICAgICB0aGlzLnNpZ25VcC5lbWl0KCk7XG4gICAgfVxuXG4gICAgZ2V0QnV0dG9uc0Z4TGF5b3V0QWxpZ24oKTogc3RyaW5nIHtcbiAgICAgICAgaWYgKHRoaXMuc2hvd1NpZ25VcEJ1dHRvbiB8fCB0aGlzLnNob3dGb3Jnb3R0ZW5QYXNzd29yZEJ1dHRvbikge1xuICAgICAgICAgICAgcmV0dXJuICdzcGFjZS1iZXR3ZWVuJztcbiAgICAgICAgfVxuICAgICAgICByZXR1cm4gJ2VuZCc7XG4gICAgfVxufVxuIl19
|
|
@@ -0,0 +1,102 @@
|
|
|
1
|
+
import { Component } from "@angular/core";
|
|
2
|
+
import { throwError } from "rxjs";
|
|
3
|
+
import { catchError } from "rxjs/operators";
|
|
4
|
+
import { LoadingEmitter } from '../../../utility/loading-emitter';
|
|
5
|
+
import * as i0 from "@angular/core";
|
|
6
|
+
import * as i1 from "../../../configuration/configuration.service";
|
|
7
|
+
import * as i2 from "@angular/common/http";
|
|
8
|
+
import * as i3 from "../../../snack-bar/services/snack-bar.service";
|
|
9
|
+
import * as i4 from "../../../logger/services/logger.service";
|
|
10
|
+
import * as i5 from "@angular/router";
|
|
11
|
+
import * as i6 from "@ngx-translate/core";
|
|
12
|
+
export class AbstractLoginSsoComponent {
|
|
13
|
+
_config;
|
|
14
|
+
_http;
|
|
15
|
+
_snackbar;
|
|
16
|
+
_log;
|
|
17
|
+
_router;
|
|
18
|
+
_activeRouter;
|
|
19
|
+
_translate;
|
|
20
|
+
_ssoConfig;
|
|
21
|
+
loading;
|
|
22
|
+
constructor(_config, _http, _snackbar, _log, _router, _activeRouter, _translate) {
|
|
23
|
+
this._config = _config;
|
|
24
|
+
this._http = _http;
|
|
25
|
+
this._snackbar = _snackbar;
|
|
26
|
+
this._log = _log;
|
|
27
|
+
this._router = _router;
|
|
28
|
+
this._activeRouter = _activeRouter;
|
|
29
|
+
this._translate = _translate;
|
|
30
|
+
this._ssoConfig = this._config.getConfigurationSubtree(['providers', 'auth', 'sso']);
|
|
31
|
+
this.loading = new LoadingEmitter();
|
|
32
|
+
this._activeRouter.queryParams.subscribe((params) => {
|
|
33
|
+
if (!!params.code) {
|
|
34
|
+
this.loginFromCode(params);
|
|
35
|
+
}
|
|
36
|
+
});
|
|
37
|
+
}
|
|
38
|
+
ngOnDestroy() {
|
|
39
|
+
this.loading.complete();
|
|
40
|
+
}
|
|
41
|
+
redirectToSso() {
|
|
42
|
+
let redirectUrl = this.getRedirectUrl();
|
|
43
|
+
this._log.info("Redirecting to " + redirectUrl);
|
|
44
|
+
window.location.href = redirectUrl;
|
|
45
|
+
}
|
|
46
|
+
loginFromCode(params) {
|
|
47
|
+
if (!params.code) {
|
|
48
|
+
return;
|
|
49
|
+
}
|
|
50
|
+
this.loading.on();
|
|
51
|
+
this._log.debug('Handling access token: ' + params.code);
|
|
52
|
+
const token$ = this.getToken({
|
|
53
|
+
grantType: 'authorization_code',
|
|
54
|
+
code: params.code,
|
|
55
|
+
realmId: '',
|
|
56
|
+
redirectUri: location.origin + '/' + this._config.getConfigurationSubtree(['services', 'auth', 'toLoginRedirect']),
|
|
57
|
+
});
|
|
58
|
+
token$.subscribe(token => {
|
|
59
|
+
this.loading.off();
|
|
60
|
+
if (!!token) {
|
|
61
|
+
this.redirectToHome();
|
|
62
|
+
}
|
|
63
|
+
});
|
|
64
|
+
}
|
|
65
|
+
getRedirectUrl() {
|
|
66
|
+
const myQuery = this._ssoConfig.redirectUrl + '?';
|
|
67
|
+
const options = {
|
|
68
|
+
client_id: this._ssoConfig.clientId,
|
|
69
|
+
redirect_uri: location.origin + '/' + this._config.getConfigurationSubtree(['services', 'auth', 'toLoginRedirect']),
|
|
70
|
+
response_type: 'code',
|
|
71
|
+
scope: this._ssoConfig.scopes.join(' '),
|
|
72
|
+
};
|
|
73
|
+
return myQuery + Object.keys(options).map(key => {
|
|
74
|
+
return encodeURIComponent(key) + '=' + encodeURIComponent(options[key]);
|
|
75
|
+
}).join('&');
|
|
76
|
+
}
|
|
77
|
+
getToken(body) {
|
|
78
|
+
const url = this._ssoConfig.refreshUrl;
|
|
79
|
+
if (!url) {
|
|
80
|
+
return throwError(() => new Error('Refresh URL is not defined in the config [nae.providers.auth.sso.refreshUrl]'));
|
|
81
|
+
}
|
|
82
|
+
return this._http.post(url, body, { headers: { 'Content-Type': 'application/json' } }).pipe(catchError(error => {
|
|
83
|
+
this.loading.off();
|
|
84
|
+
this._snackbar.openErrorSnackBar(this._translate.instant('forms.login.wrongCredentials'));
|
|
85
|
+
return throwError(() => error);
|
|
86
|
+
}));
|
|
87
|
+
}
|
|
88
|
+
redirectToHome() {
|
|
89
|
+
this._router.navigate(['/' + this._config.getConfigurationSubtree(['services', 'auth', 'onLoginRedirect'])])
|
|
90
|
+
.then((value) => { this._log.debug('Routed to ' + value); });
|
|
91
|
+
}
|
|
92
|
+
static ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "17.3.12", ngImport: i0, type: AbstractLoginSsoComponent, deps: [{ token: i1.ConfigurationService }, { token: i2.HttpClient }, { token: i3.SnackBarService }, { token: i4.LoggerService }, { token: i5.Router }, { token: i5.ActivatedRoute }, { token: i6.TranslateService }], target: i0.ɵɵFactoryTarget.Component });
|
|
93
|
+
static ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "17.3.12", type: AbstractLoginSsoComponent, selector: "ncc-abstract-login-field", ngImport: i0, template: '', isInline: true });
|
|
94
|
+
}
|
|
95
|
+
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "17.3.12", ngImport: i0, type: AbstractLoginSsoComponent, decorators: [{
|
|
96
|
+
type: Component,
|
|
97
|
+
args: [{
|
|
98
|
+
selector: 'ncc-abstract-login-field',
|
|
99
|
+
template: ''
|
|
100
|
+
}]
|
|
101
|
+
}], ctorParameters: () => [{ type: i1.ConfigurationService }, { type: i2.HttpClient }, { type: i3.SnackBarService }, { type: i4.LoggerService }, { type: i5.Router }, { type: i5.ActivatedRoute }, { type: i6.TranslateService }] });
|
|
102
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"abstract-login-sso.component.js","sourceRoot":"","sources":["../../../../../../../projects/netgrif-components-core/src/lib/forms/login/login-sso/abstract-login-sso.component.ts"],"names":[],"mappings":"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","sourcesContent":["import {Component, OnDestroy} from \"@angular/core\";\nimport {ActivatedRoute, Params, Router} from \"@angular/router\";\nimport {Observable, throwError} from \"rxjs\";\nimport {catchError} from \"rxjs/operators\";\nimport {HttpClient} from \"@angular/common/http\";\nimport {ConfigurationService} from \"../../../configuration/configuration.service\";\nimport {LoggerService} from '../../../logger/services/logger.service';\nimport {LoadingEmitter} from '../../../utility/loading-emitter';\nimport {SnackBarService} from \"../../../snack-bar/services/snack-bar.service\";\nimport {Sso} from \"../../../../commons/schema\";\nimport {TranslateService} from \"@ngx-translate/core\";\n\n\n@Component({\n    selector: 'ncc-abstract-login-field',\n    template: ''\n})\nexport abstract class AbstractLoginSsoComponent implements OnDestroy {\n\n    protected _ssoConfig: Sso;\n    protected loading: LoadingEmitter;\n\n    protected constructor(\n        protected _config: ConfigurationService,\n        protected _http: HttpClient,\n        protected _snackbar: SnackBarService,\n        protected _log: LoggerService,\n        protected _router: Router,\n        protected _activeRouter: ActivatedRoute,\n        protected _translate: TranslateService\n    ) {\n        this._ssoConfig = this._config.getConfigurationSubtree(['providers', 'auth', 'sso']);\n        this.loading = new LoadingEmitter();\n        this._activeRouter.queryParams.subscribe((params) => {\n            if (!!params.code) {\n                this.loginFromCode(params);\n            }\n        });\n    }\n\n    ngOnDestroy(): void {\n        this.loading.complete();\n    }\n\n    public redirectToSso(): void {\n        let redirectUrl: string = this.getRedirectUrl();\n        this._log.info(\"Redirecting to \" + redirectUrl)\n        window.location.href = redirectUrl;\n    }\n\n    public loginFromCode(params: Params) {\n        if (!params.code) {\n            return;\n        }\n\n        this.loading.on();\n        this._log.debug('Handling access token: ' + params.code)\n        const token$ = this.getToken({\n            grantType: 'authorization_code',\n            code: params.code,\n            realmId: '', // todo send realm id\n            redirectUri: location.origin + '/' + this._config.getConfigurationSubtree(['services', 'auth', 'toLoginRedirect']),\n        });\n        token$.subscribe(\n            token => {\n                this.loading.off();\n                if (!!token) {\n                    this.redirectToHome();\n                }\n            },\n        );\n    }\n\n    protected getRedirectUrl(): string {\n        const myQuery = this._ssoConfig.redirectUrl + '?';\n        const options: { [index: string]: string } = {\n            client_id: this._ssoConfig.clientId,\n            redirect_uri: location.origin + '/' + this._config.getConfigurationSubtree(['services', 'auth', 'toLoginRedirect']),\n            response_type: 'code',\n            scope: this._ssoConfig.scopes.join(' '),\n        };\n        return myQuery + Object.keys(options).map(\n            key => {\n                return encodeURIComponent(key) + '=' + encodeURIComponent(options[key]);\n            },\n        ).join('&');\n    }\n\n    protected getToken(body: any): Observable<any> {\n        const url = this._ssoConfig.refreshUrl;\n        if (!url) {\n            return throwError(() => new Error('Refresh URL is not defined in the config [nae.providers.auth.sso.refreshUrl]'));\n        }\n        return this._http.post(url, body,\n            {headers: {'Content-Type': 'application/json'}}).pipe(\n            catchError(error => {\n                this.loading.off();\n                this._snackbar.openErrorSnackBar(this._translate.instant('forms.login.wrongCredentials'));\n                return throwError(() => error);\n            }),\n        );\n    }\n\n    protected redirectToHome() {\n        this._router.navigate(['/' + this._config.getConfigurationSubtree(['services', 'auth', 'onLoginRedirect'])])\n            .then((value) => { this._log.debug('Routed to ' + value); });\n    }\n}\n"]}
|
|
@@ -1,9 +1,10 @@
|
|
|
1
1
|
export * from './email-submission/abstract-email-submission-form.component';
|
|
2
2
|
export * from './login/abstract-login-form.component';
|
|
3
|
+
export * from './login/login-sso/abstract-login-sso.component';
|
|
3
4
|
export * from './registration/abstract-registration-form.component';
|
|
4
5
|
export * from './forgotten-password/abstract-forgotten-password.component';
|
|
5
6
|
export * from './models/abstract-registration.component';
|
|
6
7
|
export * from './change-password/abstract-change-password.component';
|
|
7
8
|
export * from './min-password-length-token';
|
|
8
9
|
export * from './has-form';
|
|
9
|
-
//# sourceMappingURL=data:application/json;base64,
|
|
10
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoicHVibGljLWFwaS5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uLy4uLy4uLy4uL3Byb2plY3RzL25ldGdyaWYtY29tcG9uZW50cy1jb3JlL3NyYy9saWIvZm9ybXMvcHVibGljLWFwaS50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFBQSxjQUFjLDZEQUE2RCxDQUFDO0FBQzVFLGNBQWMsdUNBQXVDLENBQUM7QUFDdEQsY0FBYyxnREFBZ0QsQ0FBQztBQUMvRCxjQUFjLHFEQUFxRCxDQUFDO0FBQ3BFLGNBQWMsNERBQTRELENBQUM7QUFDM0UsY0FBYywwQ0FBMEMsQ0FBQztBQUN6RCxjQUFjLHNEQUFzRCxDQUFBO0FBRXBFLGNBQWMsNkJBQTZCLENBQUE7QUFDM0MsY0FBYyxZQUFZLENBQUMiLCJzb3VyY2VzQ29udGVudCI6WyJleHBvcnQgKiBmcm9tICcuL2VtYWlsLXN1Ym1pc3Npb24vYWJzdHJhY3QtZW1haWwtc3VibWlzc2lvbi1mb3JtLmNvbXBvbmVudCc7XG5leHBvcnQgKiBmcm9tICcuL2xvZ2luL2Fic3RyYWN0LWxvZ2luLWZvcm0uY29tcG9uZW50JztcbmV4cG9ydCAqIGZyb20gJy4vbG9naW4vbG9naW4tc3NvL2Fic3RyYWN0LWxvZ2luLXNzby5jb21wb25lbnQnO1xuZXhwb3J0ICogZnJvbSAnLi9yZWdpc3RyYXRpb24vYWJzdHJhY3QtcmVnaXN0cmF0aW9uLWZvcm0uY29tcG9uZW50JztcbmV4cG9ydCAqIGZyb20gJy4vZm9yZ290dGVuLXBhc3N3b3JkL2Fic3RyYWN0LWZvcmdvdHRlbi1wYXNzd29yZC5jb21wb25lbnQnO1xuZXhwb3J0ICogZnJvbSAnLi9tb2RlbHMvYWJzdHJhY3QtcmVnaXN0cmF0aW9uLmNvbXBvbmVudCc7XG5leHBvcnQgKiBmcm9tICcuL2NoYW5nZS1wYXNzd29yZC9hYnN0cmFjdC1jaGFuZ2UtcGFzc3dvcmQuY29tcG9uZW50J1xuXG5leHBvcnQgKiBmcm9tICcuL21pbi1wYXNzd29yZC1sZW5ndGgtdG9rZW4nXG5leHBvcnQgKiBmcm9tICcuL2hhcy1mb3JtJztcbiJdfQ==
|
|
@@ -59,4 +59,5 @@ export * from './tests/mocks/mock-profile.service';
|
|
|
59
59
|
export * from './tests/mocks/mock-process.service';
|
|
60
60
|
export * from './tests/mocks/mock-petrinet-resource.service';
|
|
61
61
|
export * from './tests/mocks/mock-task-resource.service';
|
|
62
|
-
|
|
62
|
+
export * from './tests/mocks/mock-case-resource.service';
|
|
63
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoicHVibGljLWFwaS5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uLy4uLy4uLy4uL3Byb2plY3RzL25ldGdyaWYtY29tcG9uZW50cy1jb3JlL3NyYy9saWIvdXRpbGl0eS9wdWJsaWMtYXBpLnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQUFBLGNBQWMsV0FBVyxDQUFDO0FBQzFCLGNBQWMsbUJBQW1CLENBQUM7QUFDbEMsY0FBYywrQkFBK0IsQ0FBQztBQUM5QyxjQUFjLHNCQUFzQixDQUFDO0FBQ3JDLGNBQWMsYUFBYSxDQUFDO0FBQzVCLGNBQWMsaUNBQWlDLENBQUM7QUFDaEQsY0FBYywyQkFBMkIsQ0FBQztBQUMxQyxjQUFjLCtCQUErQixDQUFDO0FBQzlDLGNBQWMsNkJBQTZCLENBQUM7QUFDNUMsY0FBYyxnQ0FBZ0MsQ0FBQztBQUMvQyxjQUFjLDhCQUE4QixDQUFDO0FBQzdDLGNBQWMsbUNBQW1DLENBQUM7QUFDbEQsY0FBYyx3Q0FBd0MsQ0FBQztBQUN2RCxjQUFjLHdCQUF3QixDQUFDO0FBQ3ZDLGNBQWMsdUJBQXVCLENBQUM7QUFDdEMsY0FBYyw0QkFBNEIsQ0FBQztBQUMzQyxjQUFjLDZCQUE2QixDQUFDO0FBQzVDLGNBQWMsMEJBQTBCLENBQUM7QUFDekMsY0FBYyxnQkFBZ0IsQ0FBQztBQUMvQixjQUFjLHdCQUF3QixDQUFDO0FBQ3ZDLGNBQWMsdUNBQXVDLENBQUM7QUFDdEQsY0FBYyxrREFBa0QsQ0FBQztBQUNqRSxjQUFjLDJDQUEyQyxDQUFDO0FBQzFELGNBQWMsaUJBQWlCLENBQUM7QUFDaEMsY0FBYyxxQkFBcUIsQ0FBQztBQUNwQyxjQUFjLGlCQUFpQixDQUFDO0FBQ2hDLGNBQWMsa0JBQWtCLENBQUM7QUFDakMsY0FBYyw0QkFBNEIsQ0FBQztBQUMzQyxjQUFjLFVBQVUsQ0FBQztBQUN6QixjQUFjLHNCQUFzQixDQUFDO0FBRXJDLFdBQVc7QUFDWCxjQUFjLDJDQUEyQyxDQUFDO0FBQzFELGNBQWMsNENBQTRDLENBQUM7QUFDM0QsY0FBYywwQ0FBMEMsQ0FBQztBQUN6RCxjQUFjLGlDQUFpQyxDQUFDO0FBQ2hELGNBQWMsa0RBQWtELENBQUM7QUFDakUsY0FBYyxvQ0FBb0MsQ0FBQztBQUNuRCxjQUFjLDRDQUE0QyxDQUFDO0FBQzNELGNBQWMsa0NBQWtDLENBQUM7QUFDakQsY0FBYyxrQ0FBa0MsQ0FBQztBQUNqRCxjQUFjLDRDQUE0QyxDQUFDO0FBQzNELGNBQWMsa0NBQWtDLENBQUM7QUFDakQsY0FBYyxpQ0FBaUMsQ0FBQztBQUNoRCxjQUFjLHVDQUF1QyxDQUFDO0FBQ3RELGNBQWMsbUNBQW1DLENBQUM7QUFDbEQsY0FBYywwQ0FBMEMsQ0FBQztBQUN6RCxjQUFjLDBDQUEwQyxDQUFDO0FBQ3pELGNBQWMsOENBQThDLENBQUM7QUFDN0QsY0FBYyw4Q0FBOEMsQ0FBQztBQUM3RCxjQUFjLCtDQUErQyxDQUFDO0FBQzlELGNBQWMsb0NBQW9DLENBQUM7QUFDbkQsY0FBYywyQ0FBMkMsQ0FBQztBQUMxRCxjQUFjLHFCQUFxQixDQUFDO0FBQ3BDLGNBQWMsOEJBQThCLENBQUM7QUFDN0MsY0FBYywyQkFBMkIsQ0FBQztBQUMxQyxjQUFjLDZCQUE2QixDQUFDO0FBQzVDLGNBQWMsdUNBQXVDLENBQUM7QUFDdEQsY0FBYyxvQ0FBb0MsQ0FBQztBQUNuRCxjQUFjLG9DQUFvQyxDQUFDO0FBQ25ELGNBQWMsOENBQThDLENBQUM7QUFDN0QsY0FBYywwQ0FBMEMsQ0FBQztBQUN6RCxjQUFjLDBDQUEwQyxDQUFDIiwic291cmNlc0NvbnRlbnQiOlsiZXhwb3J0ICogZnJvbSAnLi9vZi12b2lkJztcbmV4cG9ydCAqIGZyb20gJy4vbG9hZGluZy1lbWl0dGVyJztcbmV4cG9ydCAqIGZyb20gJy4vbG9hZGluZy13aXRoLWZpbHRlci1lbWl0dGVyJztcbmV4cG9ydCAqIGZyb20gJy4vZ2V0LWltbWVkaWF0ZS1kYXRhJztcbmV4cG9ydCAqIGZyb20gJy4vZ2V0LWZpZWxkJztcbmV4cG9ydCAqIGZyb20gJy4vY2FsbC1jaGFpbi9jYWxsLWNoYWluLnNlcnZpY2UnO1xuZXhwb3J0ICogZnJvbSAnLi9jYWxsLWNoYWluL2FmdGVyLWFjdGlvbic7XG5leHBvcnQgKiBmcm9tICcuL3BhZ2luYXRpb24vcGFnZS1oYXMtY29udGVudCc7XG5leHBvcnQgKiBmcm9tICcuL3BhZ2luYXRpb24vbG9hZC1hbGwtcGFnZXMnO1xuZXhwb3J0ICogZnJvbSAnLi9wYWdpbmF0aW9uL3BhZ2luYXRpb24tcGFyYW1zJztcbmV4cG9ydCAqIGZyb20gJy4vcGFnaW5hdGlvbi9wYWdpbmF0aW9uLXNvcnQnO1xuZXhwb3J0ICogZnJvbSAnLi9zZXJ2aWNlL3NwaW5uZXItb3ZlcmxheS5zZXJ2aWNlJztcbmV4cG9ydCAqIGZyb20gJy4vc2VydmljZS9jYXNlLWxpc3QtZm9udC1jb2xvci5zZXJ2aWNlJztcbmV4cG9ydCAqIGZyb20gJy4vaW5jcmVtZW50aW5nLWNvdW50ZXInO1xuZXhwb3J0ICogZnJvbSAnLi9hcnJheS10by1vYnNlcnZhYmxlJztcbmV4cG9ydCAqIGZyb20gJy4vcHJvY2Vzcy1tZXNzYWdlLXJlc3BvbnNlJztcbmV4cG9ydCAqIGZyb20gJy4vcmVzdWx0LXdpdGgtYWZ0ZXItYWN0aW9ucyc7XG5leHBvcnQgKiBmcm9tICcuL2NsZWFyLXRpbWUtaW5mb3JtYXRpb24nO1xuZXhwb3J0ICogZnJvbSAnLi9yZWZyZXNoLXRyZWUnO1xuZXhwb3J0ICogZnJvbSAnLi9kZXN0cm95LXN1YnNjcmlwdGlvbic7XG5leHBvcnQgKiBmcm9tICcuL25hdmlnYXRpb24taXRlbS10YXNrLWZpbHRlci1mYWN0b3J5JztcbmV4cG9ydCAqIGZyb20gJy4vbmF2aWdhdGlvbi1pdGVtLXRhc2stc2VhcmNoLWNhdGVnb3JpZXMtZmFjdG9yeSc7XG5leHBvcnQgKiBmcm9tICcuL25hdmlnYXRpb24taXRlbS1kZWZhdWx0LWhlYWRlcnMtZmFjdG9yeSc7XG5leHBvcnQgKiBmcm9tICcuL2lzLWVtcHR5LnBpcGUnO1xuZXhwb3J0ICogZnJvbSAnLi9pcy1ub24tZW1wdHkucGlwZSc7XG5leHBvcnQgKiBmcm9tICcuL2NvbnRhaW5zLnBpcGUnO1xuZXhwb3J0ICogZnJvbSAnLi91dGlsaXR5Lm1vZHVsZSc7XG5leHBvcnQgKiBmcm9tICcuL2RpcmVjdGl2ZXMvbGV0LmRpcmVjdGl2ZSc7XG5leHBvcnQgKiBmcm9tICcuL2Jhc2U2NCc7XG5leHBvcnQgKiBmcm9tICcuL2xvYWQtY29uZmlndXJhdGlvbic7XG5cbi8qIFRFU1RTICovXG5leHBvcnQgKiBmcm9tICcuL3Rlc3RzL21vY2tzL21vY2stYXV0aGVudGljYXRpb24uc2VydmljZSc7XG5leHBvcnQgKiBmcm9tICcuL3Rlc3RzL21vY2tzL21vY2stdXNlci1wcmVmZXJlbmNlLnNlcnZpY2UnO1xuZXhwb3J0ICogZnJvbSAnLi90ZXN0cy9tb2Nrcy9tb2NrLXVzZXItcmVzb3VyY2Uuc2VydmljZSc7XG5leHBvcnQgKiBmcm9tICcuL3Rlc3RzL21vY2tzL21vY2stdXNlci5zZXJ2aWNlJztcbmV4cG9ydCAqIGZyb20gJy4vdGVzdHMvbW9ja3MvbW9jay1hdXRoZW50aWNhdGlvbi1tZXRob2Qtc2VydmljZSc7XG5leHBvcnQgKiBmcm9tICcuL3Rlc3RzL21vY2tzL21vY2stc2lnbi11cC5zZXJ2aWNlJztcbmV4cG9ydCAqIGZyb20gJy4vdGVzdHMvbW9ja3MvbW9jay11c2VyLWF1dG9jb21wbGV0ZS12YWx1ZSc7XG5leHBvcnQgKiBmcm9tICcuL3Rlc3RzL3V0aWxpdHkvY3JlYXRlLW1vY2stdGFzayc7XG5leHBvcnQgKiBmcm9tICcuL3Rlc3RzL3V0aWxpdHkvY3JlYXRlLW1vY2stY2FzZSc7XG5leHBvcnQgKiBmcm9tICcuL3Rlc3RzL3V0aWxpdHkvY3JlYXRlLW1vY2staW1tZWRpYXRlLWRhdGEnO1xuZXhwb3J0ICogZnJvbSAnLi90ZXN0cy91dGlsaXR5L2NyZWF0ZS1tb2NrLXBhZ2UnO1xuZXhwb3J0ICogZnJvbSAnLi90ZXN0cy91dGlsaXR5L2NyZWF0ZS1tb2NrLW5ldCc7XG5leHBvcnQgKiBmcm9tICcuL3Rlc3RzL3V0aWxpdHkvY3JlYXRlLW1vY2stZGF0YWdyb3VwJztcbmV4cG9ydCAqIGZyb20gJy4vdGVzdHMvdXRpbGl0eS9jcmVhdGUtbW9jay1maWVsZCc7XG5leHBvcnQgKiBmcm9tICcuL3Rlc3RzL3V0aWxpdHkvY3JlYXRlLW1vY2stY2FzZS1vdXRjb21lJztcbmV4cG9ydCAqIGZyb20gJy4vdGVzdHMvdXRpbGl0eS9jcmVhdGUtbW9jay10YXNrLW91dGNvbWUnO1xuZXhwb3J0ICogZnJvbSAnLi90ZXN0cy91dGlsaXR5L2NyZWF0ZS1tb2NrLWdldC1kYXRhLW91dGNvbWUnO1xuZXhwb3J0ICogZnJvbSAnLi90ZXN0cy91dGlsaXR5L2NyZWF0ZS1tb2NrLXNldC1kYXRhLW91dGNvbWUnO1xuZXhwb3J0ICogZnJvbSAnLi90ZXN0cy91dGlsaXR5L2NyZWF0ZS1tb2NrLXBldHJpLW5ldC1vdXRjb21lJztcbmV4cG9ydCAqIGZyb20gJy4vdGVzdHMvdXRpbGl0eS9jb25maWd1cmUtY2F0ZWdvcnknO1xuZXhwb3J0ICogZnJvbSAnLi90ZXN0cy9zZWFyY2gtY2F0ZWdvcnktbW9jay1kZXBlbmRlbmNpZXMnO1xuZXhwb3J0ICogZnJvbSAnLi90ZXN0cy90ZXN0LWNvbmZpZyc7XG5leHBvcnQgKiBmcm9tICcuL3Rlc3RzL3Rlc3QtZmFjdG9yeS1tZXRob2RzJztcbmV4cG9ydCAqIGZyb20gJy4vdGVzdHMvdGVzdC12aWV3LXNlcnZpY2UnO1xuZXhwb3J0ICogZnJvbSAnLi90ZXN0cy9tb2Nrcy9tb2NrLWVuZHBvaW50JztcbmV4cG9ydCAqIGZyb20gJy4vdGVzdHMvdGVzdC1tb2NrLWRlcGVuZGVuY2llcy5tb2R1bGUnO1xuZXhwb3J0ICogZnJvbSAnLi90ZXN0cy9tb2Nrcy9tb2NrLXByb2ZpbGUuc2VydmljZSc7XG5leHBvcnQgKiBmcm9tICcuL3Rlc3RzL21vY2tzL21vY2stcHJvY2Vzcy5zZXJ2aWNlJztcbmV4cG9ydCAqIGZyb20gJy4vdGVzdHMvbW9ja3MvbW9jay1wZXRyaW5ldC1yZXNvdXJjZS5zZXJ2aWNlJztcbmV4cG9ydCAqIGZyb20gJy4vdGVzdHMvbW9ja3MvbW9jay10YXNrLXJlc291cmNlLnNlcnZpY2UnO1xuZXhwb3J0ICogZnJvbSAnLi90ZXN0cy9tb2Nrcy9tb2NrLWNhc2UtcmVzb3VyY2Uuc2VydmljZSc7XG4iXX0=
|
|
@@ -0,0 +1,49 @@
|
|
|
1
|
+
import { Injectable } from '@angular/core';
|
|
2
|
+
import { of } from 'rxjs';
|
|
3
|
+
import * as i0 from "@angular/core";
|
|
4
|
+
export class MockCaseResourceService {
|
|
5
|
+
searchCases(filter, params) {
|
|
6
|
+
if (filter.getRequestBody().uriNodeId) {
|
|
7
|
+
return of({
|
|
8
|
+
content: [
|
|
9
|
+
{
|
|
10
|
+
lastModified: [2022, 11, 28],
|
|
11
|
+
visualId: 'TST-123548',
|
|
12
|
+
petriNetObjectId: undefined,
|
|
13
|
+
processIdentifier: 'test-process',
|
|
14
|
+
title: 'test case',
|
|
15
|
+
color: 'black',
|
|
16
|
+
creationDate: [2022, 11, 28],
|
|
17
|
+
immediateData: [{
|
|
18
|
+
stringId: 'objectid',
|
|
19
|
+
type: 'text',
|
|
20
|
+
}],
|
|
21
|
+
author: {
|
|
22
|
+
email: 'test@example.com',
|
|
23
|
+
fullName: 'Test',
|
|
24
|
+
},
|
|
25
|
+
resetArcTokens: {},
|
|
26
|
+
stringId: 'objectid',
|
|
27
|
+
petriNetId: 'objectid',
|
|
28
|
+
permissions: {
|
|
29
|
+
'objectid': {},
|
|
30
|
+
},
|
|
31
|
+
},
|
|
32
|
+
],
|
|
33
|
+
pagination: {
|
|
34
|
+
totalElements: 1,
|
|
35
|
+
number: 0,
|
|
36
|
+
size: 1,
|
|
37
|
+
totalPages: 1,
|
|
38
|
+
},
|
|
39
|
+
});
|
|
40
|
+
}
|
|
41
|
+
return of(undefined);
|
|
42
|
+
}
|
|
43
|
+
static ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "17.3.12", ngImport: i0, type: MockCaseResourceService, deps: [], target: i0.ɵɵFactoryTarget.Injectable });
|
|
44
|
+
static ɵprov = i0.ɵɵngDeclareInjectable({ minVersion: "12.0.0", version: "17.3.12", ngImport: i0, type: MockCaseResourceService });
|
|
45
|
+
}
|
|
46
|
+
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "17.3.12", ngImport: i0, type: MockCaseResourceService, decorators: [{
|
|
47
|
+
type: Injectable
|
|
48
|
+
}] });
|
|
49
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoibW9jay1jYXNlLXJlc291cmNlLnNlcnZpY2UuanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi8uLi8uLi8uLi8uLi9wcm9qZWN0cy9uZXRncmlmLWNvbXBvbmVudHMtY29yZS9zcmMvbGliL3V0aWxpdHkvdGVzdHMvbW9ja3MvbW9jay1jYXNlLXJlc291cmNlLnNlcnZpY2UudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBQUEsT0FBTyxFQUFDLFVBQVUsRUFBQyxNQUFNLGVBQWUsQ0FBQztBQUN6QyxPQUFPLEVBQWEsRUFBRSxFQUFDLE1BQU0sTUFBTSxDQUFDOztBQVFwQyxNQUFNLE9BQU8sdUJBQXVCO0lBRXpCLFdBQVcsQ0FBQyxNQUFjLEVBQUUsTUFBZTtRQUM5QyxJQUFLLE1BQU0sQ0FBQyxjQUFjLEVBQTRCLENBQUMsU0FBUyxFQUFFO1lBQzlELE9BQU8sRUFBRSxDQUFDO2dCQUNOLE9BQU8sRUFBRTtvQkFDTDt3QkFDSSxZQUFZLEVBQUUsQ0FBQyxJQUFJLEVBQUUsRUFBRSxFQUFFLEVBQUUsQ0FBQzt3QkFDNUIsUUFBUSxFQUFFLFlBQVk7d0JBQ3RCLGdCQUFnQixFQUFFLFNBQVM7d0JBQzNCLGlCQUFpQixFQUFFLGNBQWM7d0JBQ2pDLEtBQUssRUFBRSxXQUFXO3dCQUNsQixLQUFLLEVBQUUsT0FBTzt3QkFDZCxZQUFZLEVBQUUsQ0FBQyxJQUFJLEVBQUUsRUFBRSxFQUFFLEVBQUUsQ0FBQzt3QkFDNUIsYUFBYSxFQUFFLENBQUM7Z0NBQ1osUUFBUSxFQUFFLFVBQVU7Z0NBQ3BCLElBQUksRUFBRSxNQUFNOzZCQUNmLENBQUM7d0JBQ0YsTUFBTSxFQUFFOzRCQUNKLEtBQUssRUFBRSxrQkFBa0I7NEJBQ3pCLFFBQVEsRUFBRSxNQUFNO3lCQUNuQjt3QkFDRCxjQUFjLEVBQUUsRUFBRTt3QkFDbEIsUUFBUSxFQUFFLFVBQVU7d0JBQ3BCLFVBQVUsRUFBRSxVQUFVO3dCQUN0QixXQUFXLEVBQUU7NEJBQ1QsVUFBVSxFQUFFLEVBQUU7eUJBQ2pCO3FCQUNKO2lCQUNKO2dCQUNELFVBQVUsRUFBRTtvQkFDUixhQUFhLEVBQUUsQ0FBQztvQkFDaEIsTUFBTSxFQUFFLENBQUM7b0JBQ1QsSUFBSSxFQUFFLENBQUM7b0JBQ1AsVUFBVSxFQUFFLENBQUM7aUJBQ2hCO2FBQ0osQ0FBQyxDQUFDO1NBQ047UUFDRCxPQUFPLEVBQUUsQ0FBQyxTQUFTLENBQUMsQ0FBQztJQUN6QixDQUFDO3dHQXZDUSx1QkFBdUI7NEdBQXZCLHVCQUF1Qjs7NEZBQXZCLHVCQUF1QjtrQkFEbkMsVUFBVSIsInNvdXJjZXNDb250ZW50IjpbImltcG9ydCB7SW5qZWN0YWJsZX0gZnJvbSAnQGFuZ3VsYXIvY29yZSc7XG5pbXBvcnQge09ic2VydmFibGUsIG9mfSBmcm9tICdyeGpzJztcbmltcG9ydCB7Q2FzZVNlYXJjaFJlcXVlc3RCb2R5fSBmcm9tICcuLi8uLi8uLi9maWx0ZXIvbW9kZWxzL2Nhc2Utc2VhcmNoLXJlcXVlc3QtYm9keSc7XG5pbXBvcnQge0ZpbHRlcn0gZnJvbSAnLi4vLi4vLi4vZmlsdGVyL21vZGVscy9maWx0ZXInO1xuaW1wb3J0IHtDYXNlfSBmcm9tICcuLi8uLi8uLi9yZXNvdXJjZXMvaW50ZXJmYWNlL2Nhc2UnO1xuaW1wb3J0IHtQYWdlfSBmcm9tICcuLi8uLi8uLi9yZXNvdXJjZXMvaW50ZXJmYWNlL3BhZ2UnO1xuaW1wb3J0IHtQYXJhbXN9IGZyb20gJy4uLy4uLy4uL3Jlc291cmNlcy9yZXNvdXJjZS1wcm92aWRlci5zZXJ2aWNlJztcblxuQEluamVjdGFibGUoKVxuZXhwb3J0IGNsYXNzIE1vY2tDYXNlUmVzb3VyY2VTZXJ2aWNlIHtcblxuICAgIHB1YmxpYyBzZWFyY2hDYXNlcyhmaWx0ZXI6IEZpbHRlciwgcGFyYW1zPzogUGFyYW1zKTogT2JzZXJ2YWJsZTxQYWdlPENhc2U+PiB7XG4gICAgICAgIGlmICgoZmlsdGVyLmdldFJlcXVlc3RCb2R5KCkgYXMgQ2FzZVNlYXJjaFJlcXVlc3RCb2R5KS51cmlOb2RlSWQpIHtcbiAgICAgICAgICAgIHJldHVybiBvZih7XG4gICAgICAgICAgICAgICAgY29udGVudDogW1xuICAgICAgICAgICAgICAgICAgICB7XG4gICAgICAgICAgICAgICAgICAgICAgICBsYXN0TW9kaWZpZWQ6IFsyMDIyLCAxMSwgMjhdLFxuICAgICAgICAgICAgICAgICAgICAgICAgdmlzdWFsSWQ6ICdUU1QtMTIzNTQ4JyxcbiAgICAgICAgICAgICAgICAgICAgICAgIHBldHJpTmV0T2JqZWN0SWQ6IHVuZGVmaW5lZCxcbiAgICAgICAgICAgICAgICAgICAgICAgIHByb2Nlc3NJZGVudGlmaWVyOiAndGVzdC1wcm9jZXNzJyxcbiAgICAgICAgICAgICAgICAgICAgICAgIHRpdGxlOiAndGVzdCBjYXNlJyxcbiAgICAgICAgICAgICAgICAgICAgICAgIGNvbG9yOiAnYmxhY2snLFxuICAgICAgICAgICAgICAgICAgICAgICAgY3JlYXRpb25EYXRlOiBbMjAyMiwgMTEsIDI4XSxcbiAgICAgICAgICAgICAgICAgICAgICAgIGltbWVkaWF0ZURhdGE6IFt7XG4gICAgICAgICAgICAgICAgICAgICAgICAgICAgc3RyaW5nSWQ6ICdvYmplY3RpZCcsXG4gICAgICAgICAgICAgICAgICAgICAgICAgICAgdHlwZTogJ3RleHQnLFxuICAgICAgICAgICAgICAgICAgICAgICAgfV0sXG4gICAgICAgICAgICAgICAgICAgICAgICBhdXRob3I6IHtcbiAgICAgICAgICAgICAgICAgICAgICAgICAgICBlbWFpbDogJ3Rlc3RAZXhhbXBsZS5jb20nLFxuICAgICAgICAgICAgICAgICAgICAgICAgICAgIGZ1bGxOYW1lOiAnVGVzdCcsXG4gICAgICAgICAgICAgICAgICAgICAgICB9LFxuICAgICAgICAgICAgICAgICAgICAgICAgcmVzZXRBcmNUb2tlbnM6IHt9LFxuICAgICAgICAgICAgICAgICAgICAgICAgc3RyaW5nSWQ6ICdvYmplY3RpZCcsXG4gICAgICAgICAgICAgICAgICAgICAgICBwZXRyaU5ldElkOiAnb2JqZWN0aWQnLFxuICAgICAgICAgICAgICAgICAgICAgICAgcGVybWlzc2lvbnM6IHtcbiAgICAgICAgICAgICAgICAgICAgICAgICAgICAnb2JqZWN0aWQnOiB7fSxcbiAgICAgICAgICAgICAgICAgICAgICAgIH0sXG4gICAgICAgICAgICAgICAgICAgIH0sXG4gICAgICAgICAgICAgICAgXSxcbiAgICAgICAgICAgICAgICBwYWdpbmF0aW9uOiB7XG4gICAgICAgICAgICAgICAgICAgIHRvdGFsRWxlbWVudHM6IDEsXG4gICAgICAgICAgICAgICAgICAgIG51bWJlcjogMCxcbiAgICAgICAgICAgICAgICAgICAgc2l6ZTogMSxcbiAgICAgICAgICAgICAgICAgICAgdG90YWxQYWdlczogMSxcbiAgICAgICAgICAgICAgICB9LFxuICAgICAgICAgICAgfSk7XG4gICAgICAgIH1cbiAgICAgICAgcmV0dXJuIG9mKHVuZGVmaW5lZCk7XG4gICAgfVxufVxuIl19
|
|
@@ -2,10 +2,11 @@ import { Injectable } from "@angular/core";
|
|
|
2
2
|
import { of } from "rxjs";
|
|
3
3
|
import * as i0 from "@angular/core";
|
|
4
4
|
export class MockTaskResourceService {
|
|
5
|
-
|
|
6
|
-
|
|
7
|
-
|
|
8
|
-
|
|
5
|
+
searchTask() {
|
|
6
|
+
return of();
|
|
7
|
+
}
|
|
8
|
+
getTasks() {
|
|
9
|
+
return of();
|
|
9
10
|
}
|
|
10
11
|
static ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "17.3.12", ngImport: i0, type: MockTaskResourceService, deps: [], target: i0.ɵɵFactoryTarget.Injectable });
|
|
11
12
|
static ɵprov = i0.ɵɵngDeclareInjectable({ minVersion: "12.0.0", version: "17.3.12", ngImport: i0, type: MockTaskResourceService });
|
|
@@ -13,4 +14,4 @@ export class MockTaskResourceService {
|
|
|
13
14
|
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "17.3.12", ngImport: i0, type: MockTaskResourceService, decorators: [{
|
|
14
15
|
type: Injectable
|
|
15
16
|
}] });
|
|
16
|
-
//# sourceMappingURL=data:application/json;base64,
|
|
17
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoibW9jay10YXNrLXJlc291cmNlLnNlcnZpY2UuanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi8uLi8uLi8uLi8uLi9wcm9qZWN0cy9uZXRncmlmLWNvbXBvbmVudHMtY29yZS9zcmMvbGliL3V0aWxpdHkvdGVzdHMvbW9ja3MvbW9jay10YXNrLXJlc291cmNlLnNlcnZpY2UudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBQUEsT0FBTyxFQUFDLFVBQVUsRUFBQyxNQUFNLGVBQWUsQ0FBQztBQUN6QyxPQUFPLEVBQWEsRUFBRSxFQUFDLE1BQU0sTUFBTSxDQUFDOztBQUtwQyxNQUFNLE9BQU8sdUJBQXVCO0lBRWhDLFVBQVU7UUFDTixPQUFPLEVBQUUsRUFBRSxDQUFDO0lBQ2hCLENBQUM7SUFFRCxRQUFRO1FBQ0osT0FBTyxFQUFFLEVBQUUsQ0FBQztJQUNoQixDQUFDO3dHQVJRLHVCQUF1Qjs0R0FBdkIsdUJBQXVCOzs0RkFBdkIsdUJBQXVCO2tCQURuQyxVQUFVIiwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IHtJbmplY3RhYmxlfSBmcm9tIFwiQGFuZ3VsYXIvY29yZVwiO1xuaW1wb3J0IHtPYnNlcnZhYmxlLCBvZn0gZnJvbSBcInJ4anNcIjtcbmltcG9ydCB7UGFnZX0gZnJvbSBcIi4uLy4uLy4uL3Jlc291cmNlcy9pbnRlcmZhY2UvcGFnZVwiO1xuaW1wb3J0IHtUYXNrfSBmcm9tIFwiLi4vLi4vLi4vcmVzb3VyY2VzL2ludGVyZmFjZS90YXNrXCI7XG5cbkBJbmplY3RhYmxlKClcbmV4cG9ydCBjbGFzcyBNb2NrVGFza1Jlc291cmNlU2VydmljZSB7XG5cbiAgICBzZWFyY2hUYXNrKCk6IE9ic2VydmFibGU8UGFnZTxUYXNrPj4ge1xuICAgICAgICByZXR1cm4gb2YoKTtcbiAgICB9XG5cbiAgICBnZXRUYXNrcygpOiBPYnNlcnZhYmxlPFBhZ2U8VGFzaz4+IHtcbiAgICAgICAgcmV0dXJuIG9mKCk7XG4gICAgfVxufVxuIl19
|