@dereekb/dbx-core 9.20.2 → 9.20.3

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.
@@ -0,0 +1,54 @@
1
+ import { DbxAuthService } from '../../../auth/service/auth.service';
2
+ import { map, first, switchMap, firstValueFrom, of } from 'rxjs';
3
+ export const DEFAULT_REDIRECT_FOR_IDENTIFIER_PARAM_VALUE = '0';
4
+ export const DEFAULT_REDIRECT_FOR_IDENTIFIER_PARAM_KEY = 'id';
5
+ /**
6
+ * This hook asserts the user is allowed to view a route with an identifier as a state parameter.
7
+ */
8
+ export function redirectForIdentifierParamHook(input) {
9
+ const { defaultAllowedValue, idParam = DEFAULT_REDIRECT_FOR_IDENTIFIER_PARAM_KEY, defaultParamValue = DEFAULT_REDIRECT_FOR_IDENTIFIER_PARAM_VALUE, priority = 100, transitionService, canViewModelWithId: canViewUser } = input;
10
+ const criteria = typeof input.criteria === 'string' ? { entering: input.criteria } : input.criteria;
11
+ // https://ui-router.github.io/ng2/docs/latest/modules/transition.html#hookresult
12
+ const assertAllowedId = (transition) => {
13
+ const $state = transition.router.stateService;
14
+ const injector = transition.injector();
15
+ const authService = injector.get(DbxAuthService);
16
+ const params = transition.params();
17
+ const transitionTargetId = params[idParam];
18
+ const defaultAllowedValueObs$ = defaultAllowedValue(authService, injector, transition);
19
+ return firstValueFrom(defaultAllowedValueObs$.pipe(first(), switchMap((defaultAllowedIdValue) => {
20
+ let result = of(true);
21
+ let redirectToId;
22
+ if (!transitionTargetId || transitionTargetId === defaultParamValue) {
23
+ // If the param isn't set, default to the default value
24
+ redirectToId = of(defaultAllowedIdValue);
25
+ }
26
+ else if (defaultAllowedIdValue !== transitionTargetId) {
27
+ redirectToId = canViewUser(transitionTargetId, authService, injector).pipe(map((x) => {
28
+ if (x == null || typeof x === 'boolean') {
29
+ return x ? transitionTargetId : defaultAllowedIdValue;
30
+ }
31
+ else {
32
+ return x;
33
+ }
34
+ }));
35
+ }
36
+ if (redirectToId != null) {
37
+ result = redirectToId.pipe(first(), map((targetId) => {
38
+ if (targetId !== transitionTargetId) {
39
+ const target = transition.targetState();
40
+ const state = target.state();
41
+ return $state.target(state, { ...params, [idParam]: targetId }, { location: true });
42
+ }
43
+ else {
44
+ return true;
45
+ }
46
+ }));
47
+ }
48
+ return result;
49
+ })));
50
+ };
51
+ // Register the "requires auth" hook with the TransitionsService
52
+ transitionService.onBefore(criteria, assertAllowedId, { priority });
53
+ }
54
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"id.hook.js","sourceRoot":"","sources":["../../../../../../../../packages/dbx-core/src/lib/router/auth/hook/id.hook.ts"],"names":[],"mappings":"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","sourcesContent":["import { DbxAuthService } from '../../../auth/service/auth.service';\nimport { TransitionService, TransitionHookFn, Transition, HookResult, StateService, HookMatchCriteria } from '@uirouter/core';\nimport { Maybe, ModelKey } from '@dereekb/util';\nimport { map, first, switchMap, firstValueFrom, Observable, of } from 'rxjs';\nimport { Injector } from '@angular/core';\n\nexport const DEFAULT_REDIRECT_FOR_IDENTIFIER_PARAM_VALUE = '0';\nexport const DEFAULT_REDIRECT_FOR_IDENTIFIER_PARAM_KEY = 'id';\n\nexport interface RedirectForIdentifierParamHookInput {\n  /**\n   * Factory that returns an observable that sends the default allowed identifier to use when accessing the resource.\n   */\n  readonly defaultAllowedValue: (authService: DbxAuthService, injector: Injector, transition: Transition) => Observable<ModelKey>;\n  /**\n   * Route parameter to use.\n   *\n   * Defaults to \"uid\"\n   */\n  readonly idParam?: string;\n  /**\n   * The default param value to check against.\n   *\n   * Defaults to 0.\n   */\n  readonly defaultParamValue?: string;\n  /**\n   * Criteria or route to watch and intercept.\n   */\n  readonly criteria: HookMatchCriteria | string;\n  readonly transitionService: TransitionService;\n  /**\n   * Whether or not the current user can view the target id.\n   *\n   * Can return another identifier, or true to allow access, or false/null/undefined to deny access.\n   */\n  readonly canViewModelWithId: (targetId: ModelKey, authService: DbxAuthService, injector: Injector) => Observable<Maybe<boolean | ModelKey>>;\n  /**\n   * Hook priority\n   */\n  readonly priority?: number;\n}\n\n/**\n * This hook asserts the user is allowed to view a route with an identifier as a state parameter.\n */\nexport function redirectForIdentifierParamHook(input: RedirectForIdentifierParamHookInput): void {\n  const { defaultAllowedValue, idParam = DEFAULT_REDIRECT_FOR_IDENTIFIER_PARAM_KEY, defaultParamValue = DEFAULT_REDIRECT_FOR_IDENTIFIER_PARAM_VALUE, priority = 100, transitionService, canViewModelWithId: canViewUser } = input;\n  const criteria: HookMatchCriteria = typeof input.criteria === 'string' ? { entering: input.criteria } : input.criteria;\n\n  // https://ui-router.github.io/ng2/docs/latest/modules/transition.html#hookresult\n  const assertAllowedId: TransitionHookFn = (transition: Transition): HookResult => {\n    const $state: StateService = transition.router.stateService;\n    const injector = transition.injector();\n    const authService: DbxAuthService = injector.get(DbxAuthService);\n    const params = transition.params();\n\n    const transitionTargetId: Maybe<string> = params[idParam];\n    const defaultAllowedValueObs$ = defaultAllowedValue(authService, injector, transition);\n\n    return firstValueFrom(\n      defaultAllowedValueObs$.pipe(\n        first(),\n        switchMap((defaultAllowedIdValue) => {\n          let result: Observable<HookResult> = of(true);\n\n          let redirectToId: Maybe<Observable<Maybe<ModelKey>>>;\n\n          if (!transitionTargetId || transitionTargetId === defaultParamValue) {\n            // If the param isn't set, default to the default value\n            redirectToId = of(defaultAllowedIdValue);\n          } else if (defaultAllowedIdValue !== transitionTargetId) {\n            redirectToId = canViewUser(transitionTargetId, authService, injector).pipe(\n              map((x) => {\n                if (x == null || typeof x === 'boolean') {\n                  return x ? transitionTargetId : defaultAllowedIdValue;\n                } else {\n                  return x;\n                }\n              })\n            );\n          }\n\n          if (redirectToId != null) {\n            result = redirectToId.pipe(\n              first(),\n              map((targetId) => {\n                if (targetId !== transitionTargetId) {\n                  const target = transition.targetState();\n                  const state = target.state();\n                  return $state.target(state, { ...params, [idParam]: targetId }, { location: true });\n                } else {\n                  return true;\n                }\n              })\n            );\n          }\n\n          return result;\n        })\n      )\n    ) as HookResult;\n  };\n\n  // Register the \"requires auth\" hook with the TransitionsService\n  transitionService.onBefore(criteria, assertAllowedId, { priority });\n}\n"]}
@@ -1,2 +1,3 @@
1
+ export * from './id.hook';
1
2
  export * from './uid.hook';
2
- //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiaW5kZXguanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi8uLi8uLi8uLi8uLi8uLi9wYWNrYWdlcy9kYngtY29yZS9zcmMvbGliL3JvdXRlci9hdXRoL2hvb2svaW5kZXgudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBQUEsY0FBYyxZQUFZLENBQUMiLCJzb3VyY2VzQ29udGVudCI6WyJleHBvcnQgKiBmcm9tICcuL3VpZC5ob29rJztcbiJdfQ==
3
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiaW5kZXguanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi8uLi8uLi8uLi8uLi8uLi9wYWNrYWdlcy9kYngtY29yZS9zcmMvbGliL3JvdXRlci9hdXRoL2hvb2svaW5kZXgudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBQUEsY0FBYyxXQUFXLENBQUM7QUFDMUIsY0FBYyxZQUFZLENBQUMiLCJzb3VyY2VzQ29udGVudCI6WyJleHBvcnQgKiBmcm9tICcuL2lkLmhvb2snO1xuZXhwb3J0ICogZnJvbSAnLi91aWQuaG9vayc7XG4iXX0=
@@ -1,55 +1,19 @@
1
- import { DbxAuthService } from '../../../auth/service/auth.service';
2
- import { map, first, switchMap, firstValueFrom, of } from 'rxjs';
1
+ import { redirectForIdentifierParamHook } from './id.hook';
3
2
  export const DEFAULT_REDIRECT_FOR_USER_IDENTIFIER_PARAM_VALUE = '0';
4
3
  export const DEFAULT_REDIRECT_FOR_USER_IDENTIFIER_PARAM_KEY = 'uid';
5
4
  /**
6
5
  * This hook asserts the user is allowed to view a route with a user identifier as a parameter.
7
- *
8
- * If not, or
9
6
  */
10
7
  export function redirectForUserIdentifierParamHook(input) {
11
- const { uidParam = DEFAULT_REDIRECT_FOR_USER_IDENTIFIER_PARAM_KEY, defaultParamValue = DEFAULT_REDIRECT_FOR_USER_IDENTIFIER_PARAM_VALUE, priority = 100, transitionService, canViewUser } = input;
12
- const criteria = typeof input.criteria === 'string' ? { entering: input.criteria } : input.criteria;
13
- // https://ui-router.github.io/ng2/docs/latest/modules/transition.html#hookresult
14
- const assertAllowedUid = (transition) => {
15
- const $state = transition.router.stateService;
16
- const injector = transition.injector();
17
- const authService = injector.get(DbxAuthService);
18
- const params = transition.params();
19
- const transitionTargetUid = params[uidParam];
20
- return firstValueFrom(authService.userIdentifier$.pipe(first(), switchMap((currentUserId) => {
21
- let result = of(true);
22
- let redirectToUid;
23
- if (!transitionTargetUid || transitionTargetUid === defaultParamValue) {
24
- // If uid isn't set, default to the current user.
25
- redirectToUid = of(currentUserId);
26
- }
27
- else if (currentUserId !== transitionTargetUid) {
28
- redirectToUid = canViewUser(transitionTargetUid, authService, injector).pipe(map((x) => {
29
- if (x == null || typeof x === 'boolean') {
30
- return x ? transitionTargetUid : currentUserId;
31
- }
32
- else {
33
- return x;
34
- }
35
- }));
36
- }
37
- if (redirectToUid != null) {
38
- result = redirectToUid.pipe(first(), map((targetUid) => {
39
- if (targetUid !== transitionTargetUid) {
40
- const target = transition.targetState();
41
- const state = target.state();
42
- return $state.target(state, { ...params, uid: targetUid }, { location: true });
43
- }
44
- else {
45
- return true;
46
- }
47
- }));
48
- }
49
- return result;
50
- })));
51
- };
52
- // Register the "requires auth" hook with the TransitionsService
53
- transitionService.onBefore(criteria, assertAllowedUid, { priority });
8
+ const { uidParam = DEFAULT_REDIRECT_FOR_USER_IDENTIFIER_PARAM_KEY, defaultParamValue = DEFAULT_REDIRECT_FOR_USER_IDENTIFIER_PARAM_VALUE, criteria, priority = 100, transitionService, canViewUser } = input;
9
+ return redirectForIdentifierParamHook({
10
+ defaultAllowedValue: (authService) => authService.userIdentifier$,
11
+ idParam: uidParam,
12
+ defaultParamValue,
13
+ criteria,
14
+ transitionService,
15
+ canViewModelWithId: canViewUser,
16
+ priority
17
+ });
54
18
  }
55
- //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"uid.hook.js","sourceRoot":"","sources":["../../../../../../../../packages/dbx-core/src/lib/router/auth/hook/uid.hook.ts"],"names":[],"mappings":"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","sourcesContent":["import { AuthUserIdentifier } from '../../../auth/auth.user';\nimport { DbxAuthService } from '../../../auth/service/auth.service';\nimport { TransitionService, TransitionHookFn, Transition, HookResult, StateService, HookMatchCriteria } from '@uirouter/core';\nimport { Maybe } from '@dereekb/util';\nimport { map, first, switchMap, firstValueFrom, Observable, of } from 'rxjs';\nimport { Injector } from '@angular/core';\n\nexport const DEFAULT_REDIRECT_FOR_USER_IDENTIFIER_PARAM_VALUE = '0';\nexport const DEFAULT_REDIRECT_FOR_USER_IDENTIFIER_PARAM_KEY = 'uid';\n\nexport interface RedirectForUserIdentifierParamHookInput {\n  /**\n   * Route parameter to use.\n   *\n   * Defaults to \"uid\"\n   */\n  readonly uidParam?: string;\n  /**\n   * The default param value to check against.\n   *\n   * Defaults to 0.\n   */\n  readonly defaultParamValue?: string;\n  /**\n   * Criteria or route to watch and intercept.\n   */\n  readonly criteria: HookMatchCriteria | string;\n  readonly transitionService: TransitionService;\n  /**\n   * Whether or not the current user can view the target user.\n   *\n   * Can return another users identifier, or true to allow access, or false/null/undefined to deny access.\n   */\n  readonly canViewUser: (targetUid: AuthUserIdentifier, authService: DbxAuthService, injector: Injector) => Observable<Maybe<boolean | AuthUserIdentifier>>;\n  /**\n   * Hook priority\n   */\n  readonly priority?: number;\n}\n\n/**\n * This hook asserts the user is allowed to view a route with a user identifier as a parameter.\n *\n * If not, or\n */\nexport function redirectForUserIdentifierParamHook(input: RedirectForUserIdentifierParamHookInput): void {\n  const { uidParam = DEFAULT_REDIRECT_FOR_USER_IDENTIFIER_PARAM_KEY, defaultParamValue = DEFAULT_REDIRECT_FOR_USER_IDENTIFIER_PARAM_VALUE, priority = 100, transitionService, canViewUser } = input;\n  const criteria: HookMatchCriteria = typeof input.criteria === 'string' ? { entering: input.criteria } : input.criteria;\n\n  // https://ui-router.github.io/ng2/docs/latest/modules/transition.html#hookresult\n  const assertAllowedUid: TransitionHookFn = (transition: Transition): HookResult => {\n    const $state: StateService = transition.router.stateService;\n    const injector = transition.injector();\n    const authService: DbxAuthService = injector.get(DbxAuthService);\n    const params = transition.params();\n\n    const transitionTargetUid: Maybe<string> = params[uidParam];\n\n    return firstValueFrom(\n      authService.userIdentifier$.pipe(\n        first(),\n        switchMap((currentUserId) => {\n          let result: Observable<HookResult> = of(true);\n\n          let redirectToUid: Maybe<Observable<Maybe<AuthUserIdentifier>>>;\n\n          if (!transitionTargetUid || transitionTargetUid === defaultParamValue) {\n            // If uid isn't set, default to the current user.\n            redirectToUid = of(currentUserId);\n          } else if (currentUserId !== transitionTargetUid) {\n            redirectToUid = canViewUser(transitionTargetUid, authService, injector).pipe(\n              map((x) => {\n                if (x == null || typeof x === 'boolean') {\n                  return x ? transitionTargetUid : currentUserId;\n                } else {\n                  return x;\n                }\n              })\n            );\n          }\n\n          if (redirectToUid != null) {\n            result = redirectToUid.pipe(\n              first(),\n              map((targetUid) => {\n                if (targetUid !== transitionTargetUid) {\n                  const target = transition.targetState();\n                  const state = target.state();\n                  return $state.target(state, { ...params, uid: targetUid }, { location: true });\n                } else {\n                  return true;\n                }\n              })\n            );\n          }\n\n          return result;\n        })\n      )\n    ) as HookResult;\n  };\n\n  // Register the \"requires auth\" hook with the TransitionsService\n  transitionService.onBefore(criteria, assertAllowedUid, { priority });\n}\n"]}
19
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoidWlkLmhvb2suanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi8uLi8uLi8uLi8uLi8uLi9wYWNrYWdlcy9kYngtY29yZS9zcmMvbGliL3JvdXRlci9hdXRoL2hvb2svdWlkLmhvb2sudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBTUEsT0FBTyxFQUFFLDhCQUE4QixFQUFFLE1BQU0sV0FBVyxDQUFDO0FBRTNELE1BQU0sQ0FBQyxNQUFNLGdEQUFnRCxHQUFHLEdBQUcsQ0FBQztBQUNwRSxNQUFNLENBQUMsTUFBTSw4Q0FBOEMsR0FBRyxLQUFLLENBQUM7QUFnQ3BFOztHQUVHO0FBQ0gsTUFBTSxVQUFVLGtDQUFrQyxDQUFDLEtBQThDO0lBQy9GLE1BQU0sRUFBRSxRQUFRLEdBQUcsOENBQThDLEVBQUUsaUJBQWlCLEdBQUcsZ0RBQWdELEVBQUUsUUFBUSxFQUFFLFFBQVEsR0FBRyxHQUFHLEVBQUUsaUJBQWlCLEVBQUUsV0FBVyxFQUFFLEdBQUcsS0FBSyxDQUFDO0lBRTVNLE9BQU8sOEJBQThCLENBQUM7UUFDcEMsbUJBQW1CLEVBQUUsQ0FBQyxXQUEyQixFQUFFLEVBQUUsQ0FBQyxXQUFXLENBQUMsZUFBZTtRQUNqRixPQUFPLEVBQUUsUUFBUTtRQUNqQixpQkFBaUI7UUFDakIsUUFBUTtRQUNSLGlCQUFpQjtRQUNqQixrQkFBa0IsRUFBRSxXQUFXO1FBQy9CLFFBQVE7S0FDVCxDQUFDLENBQUM7QUFDTCxDQUFDIiwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IHsgQXV0aFVzZXJJZGVudGlmaWVyIH0gZnJvbSAnLi4vLi4vLi4vYXV0aC9hdXRoLnVzZXInO1xuaW1wb3J0IHsgRGJ4QXV0aFNlcnZpY2UgfSBmcm9tICcuLi8uLi8uLi9hdXRoL3NlcnZpY2UvYXV0aC5zZXJ2aWNlJztcbmltcG9ydCB7IFRyYW5zaXRpb25TZXJ2aWNlLCBIb29rTWF0Y2hDcml0ZXJpYSB9IGZyb20gJ0B1aXJvdXRlci9jb3JlJztcbmltcG9ydCB7IE1heWJlIH0gZnJvbSAnQGRlcmVla2IvdXRpbCc7XG5pbXBvcnQgeyBPYnNlcnZhYmxlIH0gZnJvbSAncnhqcyc7XG5pbXBvcnQgeyBJbmplY3RvciB9IGZyb20gJ0Bhbmd1bGFyL2NvcmUnO1xuaW1wb3J0IHsgcmVkaXJlY3RGb3JJZGVudGlmaWVyUGFyYW1Ib29rIH0gZnJvbSAnLi9pZC5ob29rJztcblxuZXhwb3J0IGNvbnN0IERFRkFVTFRfUkVESVJFQ1RfRk9SX1VTRVJfSURFTlRJRklFUl9QQVJBTV9WQUxVRSA9ICcwJztcbmV4cG9ydCBjb25zdCBERUZBVUxUX1JFRElSRUNUX0ZPUl9VU0VSX0lERU5USUZJRVJfUEFSQU1fS0VZID0gJ3VpZCc7XG5cbmV4cG9ydCBpbnRlcmZhY2UgUmVkaXJlY3RGb3JVc2VySWRlbnRpZmllclBhcmFtSG9va0lucHV0IHtcbiAgLyoqXG4gICAqIFJvdXRlIHBhcmFtZXRlciB0byB1c2UuXG4gICAqXG4gICAqIERlZmF1bHRzIHRvIFwidWlkXCJcbiAgICovXG4gIHJlYWRvbmx5IHVpZFBhcmFtPzogc3RyaW5nO1xuICAvKipcbiAgICogVGhlIGRlZmF1bHQgcGFyYW0gdmFsdWUgdG8gY2hlY2sgYWdhaW5zdC5cbiAgICpcbiAgICogRGVmYXVsdHMgdG8gMC5cbiAgICovXG4gIHJlYWRvbmx5IGRlZmF1bHRQYXJhbVZhbHVlPzogc3RyaW5nO1xuICAvKipcbiAgICogQ3JpdGVyaWEgb3Igcm91dGUgdG8gd2F0Y2ggYW5kIGludGVyY2VwdC5cbiAgICovXG4gIHJlYWRvbmx5IGNyaXRlcmlhOiBIb29rTWF0Y2hDcml0ZXJpYSB8IHN0cmluZztcbiAgcmVhZG9ubHkgdHJhbnNpdGlvblNlcnZpY2U6IFRyYW5zaXRpb25TZXJ2aWNlO1xuICAvKipcbiAgICogV2hldGhlciBvciBub3QgdGhlIGN1cnJlbnQgdXNlciBjYW4gdmlldyB0aGUgdGFyZ2V0IHVzZXIuXG4gICAqXG4gICAqIENhbiByZXR1cm4gYW5vdGhlciB1c2VycyBpZGVudGlmaWVyLCBvciB0cnVlIHRvIGFsbG93IGFjY2Vzcywgb3IgZmFsc2UvbnVsbC91bmRlZmluZWQgdG8gZGVueSBhY2Nlc3MuXG4gICAqL1xuICByZWFkb25seSBjYW5WaWV3VXNlcjogKHRhcmdldFVpZDogQXV0aFVzZXJJZGVudGlmaWVyLCBhdXRoU2VydmljZTogRGJ4QXV0aFNlcnZpY2UsIGluamVjdG9yOiBJbmplY3RvcikgPT4gT2JzZXJ2YWJsZTxNYXliZTxib29sZWFuIHwgQXV0aFVzZXJJZGVudGlmaWVyPj47XG4gIC8qKlxuICAgKiBIb29rIHByaW9yaXR5XG4gICAqL1xuICByZWFkb25seSBwcmlvcml0eT86IG51bWJlcjtcbn1cblxuLyoqXG4gKiBUaGlzIGhvb2sgYXNzZXJ0cyB0aGUgdXNlciBpcyBhbGxvd2VkIHRvIHZpZXcgYSByb3V0ZSB3aXRoIGEgdXNlciBpZGVudGlmaWVyIGFzIGEgcGFyYW1ldGVyLlxuICovXG5leHBvcnQgZnVuY3Rpb24gcmVkaXJlY3RGb3JVc2VySWRlbnRpZmllclBhcmFtSG9vayhpbnB1dDogUmVkaXJlY3RGb3JVc2VySWRlbnRpZmllclBhcmFtSG9va0lucHV0KTogdm9pZCB7XG4gIGNvbnN0IHsgdWlkUGFyYW0gPSBERUZBVUxUX1JFRElSRUNUX0ZPUl9VU0VSX0lERU5USUZJRVJfUEFSQU1fS0VZLCBkZWZhdWx0UGFyYW1WYWx1ZSA9IERFRkFVTFRfUkVESVJFQ1RfRk9SX1VTRVJfSURFTlRJRklFUl9QQVJBTV9WQUxVRSwgY3JpdGVyaWEsIHByaW9yaXR5ID0gMTAwLCB0cmFuc2l0aW9uU2VydmljZSwgY2FuVmlld1VzZXIgfSA9IGlucHV0O1xuXG4gIHJldHVybiByZWRpcmVjdEZvcklkZW50aWZpZXJQYXJhbUhvb2soe1xuICAgIGRlZmF1bHRBbGxvd2VkVmFsdWU6IChhdXRoU2VydmljZTogRGJ4QXV0aFNlcnZpY2UpID0+IGF1dGhTZXJ2aWNlLnVzZXJJZGVudGlmaWVyJCxcbiAgICBpZFBhcmFtOiB1aWRQYXJhbSxcbiAgICBkZWZhdWx0UGFyYW1WYWx1ZSxcbiAgICBjcml0ZXJpYSxcbiAgICB0cmFuc2l0aW9uU2VydmljZSxcbiAgICBjYW5WaWV3TW9kZWxXaXRoSWQ6IGNhblZpZXdVc2VyLFxuICAgIHByaW9yaXR5XG4gIH0pO1xufVxuIl19
@@ -2400,46 +2400,45 @@ function clickableUrlTel(tel) {
2400
2400
  };
2401
2401
  }
2402
2402
 
2403
- const DEFAULT_REDIRECT_FOR_USER_IDENTIFIER_PARAM_VALUE = '0';
2404
- const DEFAULT_REDIRECT_FOR_USER_IDENTIFIER_PARAM_KEY = 'uid';
2403
+ const DEFAULT_REDIRECT_FOR_IDENTIFIER_PARAM_VALUE = '0';
2404
+ const DEFAULT_REDIRECT_FOR_IDENTIFIER_PARAM_KEY = 'id';
2405
2405
  /**
2406
- * This hook asserts the user is allowed to view a route with a user identifier as a parameter.
2407
- *
2408
- * If not, or
2406
+ * This hook asserts the user is allowed to view a route with an identifier as a state parameter.
2409
2407
  */
2410
- function redirectForUserIdentifierParamHook(input) {
2411
- const { uidParam = DEFAULT_REDIRECT_FOR_USER_IDENTIFIER_PARAM_KEY, defaultParamValue = DEFAULT_REDIRECT_FOR_USER_IDENTIFIER_PARAM_VALUE, priority = 100, transitionService, canViewUser } = input;
2408
+ function redirectForIdentifierParamHook(input) {
2409
+ const { defaultAllowedValue, idParam = DEFAULT_REDIRECT_FOR_IDENTIFIER_PARAM_KEY, defaultParamValue = DEFAULT_REDIRECT_FOR_IDENTIFIER_PARAM_VALUE, priority = 100, transitionService, canViewModelWithId: canViewUser } = input;
2412
2410
  const criteria = typeof input.criteria === 'string' ? { entering: input.criteria } : input.criteria;
2413
2411
  // https://ui-router.github.io/ng2/docs/latest/modules/transition.html#hookresult
2414
- const assertAllowedUid = (transition) => {
2412
+ const assertAllowedId = (transition) => {
2415
2413
  const $state = transition.router.stateService;
2416
2414
  const injector = transition.injector();
2417
2415
  const authService = injector.get(DbxAuthService);
2418
2416
  const params = transition.params();
2419
- const transitionTargetUid = params[uidParam];
2420
- return firstValueFrom(authService.userIdentifier$.pipe(first(), switchMap((currentUserId) => {
2417
+ const transitionTargetId = params[idParam];
2418
+ const defaultAllowedValueObs$ = defaultAllowedValue(authService, injector, transition);
2419
+ return firstValueFrom(defaultAllowedValueObs$.pipe(first(), switchMap((defaultAllowedIdValue) => {
2421
2420
  let result = of(true);
2422
- let redirectToUid;
2423
- if (!transitionTargetUid || transitionTargetUid === defaultParamValue) {
2424
- // If uid isn't set, default to the current user.
2425
- redirectToUid = of(currentUserId);
2421
+ let redirectToId;
2422
+ if (!transitionTargetId || transitionTargetId === defaultParamValue) {
2423
+ // If the param isn't set, default to the default value
2424
+ redirectToId = of(defaultAllowedIdValue);
2426
2425
  }
2427
- else if (currentUserId !== transitionTargetUid) {
2428
- redirectToUid = canViewUser(transitionTargetUid, authService, injector).pipe(map((x) => {
2426
+ else if (defaultAllowedIdValue !== transitionTargetId) {
2427
+ redirectToId = canViewUser(transitionTargetId, authService, injector).pipe(map((x) => {
2429
2428
  if (x == null || typeof x === 'boolean') {
2430
- return x ? transitionTargetUid : currentUserId;
2429
+ return x ? transitionTargetId : defaultAllowedIdValue;
2431
2430
  }
2432
2431
  else {
2433
2432
  return x;
2434
2433
  }
2435
2434
  }));
2436
2435
  }
2437
- if (redirectToUid != null) {
2438
- result = redirectToUid.pipe(first(), map((targetUid) => {
2439
- if (targetUid !== transitionTargetUid) {
2436
+ if (redirectToId != null) {
2437
+ result = redirectToId.pipe(first(), map((targetId) => {
2438
+ if (targetId !== transitionTargetId) {
2440
2439
  const target = transition.targetState();
2441
2440
  const state = target.state();
2442
- return $state.target(state, Object.assign(Object.assign({}, params), { uid: targetUid }), { location: true });
2441
+ return $state.target(state, Object.assign(Object.assign({}, params), { [idParam]: targetId }), { location: true });
2443
2442
  }
2444
2443
  else {
2445
2444
  return true;
@@ -2450,7 +2449,25 @@ function redirectForUserIdentifierParamHook(input) {
2450
2449
  })));
2451
2450
  };
2452
2451
  // Register the "requires auth" hook with the TransitionsService
2453
- transitionService.onBefore(criteria, assertAllowedUid, { priority });
2452
+ transitionService.onBefore(criteria, assertAllowedId, { priority });
2453
+ }
2454
+
2455
+ const DEFAULT_REDIRECT_FOR_USER_IDENTIFIER_PARAM_VALUE = '0';
2456
+ const DEFAULT_REDIRECT_FOR_USER_IDENTIFIER_PARAM_KEY = 'uid';
2457
+ /**
2458
+ * This hook asserts the user is allowed to view a route with a user identifier as a parameter.
2459
+ */
2460
+ function redirectForUserIdentifierParamHook(input) {
2461
+ const { uidParam = DEFAULT_REDIRECT_FOR_USER_IDENTIFIER_PARAM_KEY, defaultParamValue = DEFAULT_REDIRECT_FOR_USER_IDENTIFIER_PARAM_VALUE, criteria, priority = 100, transitionService, canViewUser } = input;
2462
+ return redirectForIdentifierParamHook({
2463
+ defaultAllowedValue: (authService) => authService.userIdentifier$,
2464
+ idParam: uidParam,
2465
+ defaultParamValue,
2466
+ criteria,
2467
+ transitionService,
2468
+ canViewModelWithId: canViewUser,
2469
+ priority
2470
+ });
2454
2471
  }
2455
2472
 
2456
2473
  var DbxRouterTransitionEventType;
@@ -5016,5 +5033,5 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "14.2.12", ngImpo
5016
5033
  * Generated bundle index. Do not edit.
5017
5034
  */
5018
5035
 
5019
- export { APP_ACTION_DISABLED_DIRECTIVE_KEY, APP_ACTION_DISABLED_ON_SUCCESS_DIRECTIVE_KEY, APP_ACTION_ENFORCE_MODIFIED_DIRECTIVE_KEY, AbstractDbxActionHandlerDirective, AbstractDbxActionValueOnTriggerDirective, AbstractDbxAnchorDirective, AbstractDbxButtonDirective, AbstractDbxFilterMapInstanceDirective, AbstractDbxInjectionDirective, AbstractFilterSourceConnectorDirective, AbstractFilterSourceDirective, AbstractForwardDbxInjectionContextDirective, AbstractIfDirective, AbstractLockSetSubscriptionDirective, AbstractSubscriptionDirective, AbstractTransitionDirective, AbstractTransitionWatcherDirective, ActionContextStore, ActionContextStoreSource, ActionContextStoreSourceMap, AnchorType, DBX_ACTION_HANDLER_LOCK_KEY, DBX_APP_APP_CONTEXT_STATE, DBX_APP_AUTH_ROUTER_EFFECTS_TOKEN, DBX_AUTH_APP_CONTEXT_STATE, DBX_INIT_APP_CONTEXT_STATE, DBX_INJECTION_COMPONENT_DATA, DBX_KNOWN_APP_CONTEXT_STATES, DBX_ONBOARDING_APP_CONTEXT_STATE, DBX_ONBOARD_APP_CONTEXT_STATE, DBX_PUBLIC_APP_CONTEXT_STATE, DEFAULT_ACTION_DISABLED_KEY, DEFAULT_ACTION_MAP_WORKING_DISABLED_KEY, DEFAULT_REDIRECT_FOR_USER_IDENTIFIER_PARAM_KEY, DEFAULT_REDIRECT_FOR_USER_IDENTIFIER_PARAM_VALUE, DEFAULT_STORAGE_ACCESSOR_FACTORY_TOKEN, DEFAULT_STORAGE_OBJECT_TOKEN, DateDistancePipe, DateFormatDistancePipe, DateFromToTimePipe, DbxActionAutoModifyDirective, DbxActionAutoTriggerDirective, DbxActionButtonDirective, DbxActionButtonTriggerDirective, DbxActionContextBaseSource, DbxActionContextLoggerDirective, DbxActionContextMachine, DbxActionContextMachineAsService, DbxActionContextMapDirective, DbxActionContextMapDirectiveSourceInstance, DbxActionContextStoreSourceInstance, DbxActionDirective, DbxActionDisabledDirective, DbxActionDisabledOnSuccessDirective, DbxActionEnforceModifiedDirective, DbxActionFromMapDirective, DbxActionHandlerDirective, DbxActionHandlerInstance, DbxActionHasSuccessDirective, DbxActionIsWorkingDirective, DbxActionMapSourceDirective, DbxActionMapWorkingDisableDirective, DbxActionPreSuccessDirective, DbxActionSourceDirective, DbxActionState, DbxActionSuccessHandlerDirective, DbxActionValueDirective, DbxActionValueOnTriggerInstance, DbxActionValueTriggerDirective, DbxActionWorkInstanceDelegate, DbxAnchor, DbxAngularRouterService, DbxAppAuthRouterEffects, DbxAppAuthRouterModule, DbxAppAuthRouterService, DbxAppAuthRouterStateModule, DbxAppAuthRoutes, DbxAppAuthStateModule, DbxAppAuthStateService, DbxAppContextService, DbxAppContextStateDirective, DbxAppContextStateModule, DbxAuthHasAnyRoleDirective, DbxAuthHasRolesDirective, DbxAuthNotAnyRolesDirective, DbxAuthService, DbxButton, DbxButtonDirective, DbxButtonSegueDirective, DbxCoreActionModule, DbxCoreAngularRouterSegueModule, DbxCoreAuthModule, DbxCoreButtonModule, DbxCoreFilterModule, DbxCoreUIRouterSegueModule, DbxDatePipeModule, DbxFilterConnectSourceDirective, DbxFilterMapDirective, DbxFilterMapSourceConnectorDirective, DbxFilterMapSourceDirective, DbxFilterSourceConnectorDirective, DbxFilterSourceDirective, DbxInjectionComponent, DbxInjectionComponentModule, DbxInjectionContext, DbxInjectionContextDirective, DbxInjectionInstance, DbxLoadingButtonDirective, DbxMiscPipeModule, DbxPipesModule, DbxRouteParamDefaultRedirectInstance, DbxRouteParamReaderInstance, DbxRouterService, DbxRouterTransitionEventType, DbxRouterTransitionService, DbxStorageModule, DbxUIRouterService, FilterSourceDirective, FullLocalStorageObject, InstantStorageAccessor, LimitedStorageAccessor, LockSetComponentStore, MemoryStorageObject, MinutesStringPipe, NO_AUTH_USER_IDENTIFIER, PrettyJsonPipe, SecondaryActionContextStoreSource, SimpleStorageAccessor, SimpleStorageAccessorFactory, StorageAccessor, StringStorageAccessor, StringifySimpleStorageAccessorConverter, TimeDistanceCountdownPipe, TimeDistancePipe, ToJsDatePipe, ToMinutesPipe, WrapperSimpleStorageAccessorDelegate, actionContextHasNoErrorAndIsModifiedAndCanTrigger, actionContextIsModifiedAndCanTrigger, actionContextStoreSourceInstanceFactory, actionContextStoreSourceMachineFactory, actionContextStoreSourcePipe, anchorTypeForAnchor, asSegueRef, asSegueRefString, authRolesSetContainsAllRolesFrom, authRolesSetContainsAnyRoleFrom, authRolesSetContainsNoRolesFrom, authUserIdentifier, canReadyValue, canTriggerAction, canTriggerActionState, checkNgContentWrapperHasContent, clickableUrlInNewTab, clickableUrlMailTo, clickableUrlTel, dbxActionValueStreamDirective, defaultStorageObjectFactory, enableHasAuthRoleHook, enableHasAuthStateHook, enableIsLoggedInHook, expandClickableAnchorLinkTree, expandClickableAnchorLinkTreeNode, expandClickableAnchorLinkTrees, filterTransitionEvent, filterTransitionSuccess, flattenExpandedClickableAnchorLinkTree, flattenExpandedClickableAnchorLinkTreeToLinks, index as fromDbxAppAuth, index$2 as fromDbxAppContext, goWithRouter, isActionContextDisabled, isActionContextEnabled, isDisabledActionContextState, isIdleActionState, isLatestSuccessfulRoute, isSegueRef, isSegueRefActive, isSegueRefActiveFunction, isSegueRefActiveOnTransitionSuccess, isWorkingActionState, loadingStateForActionContextState, loadingStateTypeForActionContextState, loadingStateTypeForActionState, loggedInObsFromIsLoggedIn, loggedOutObsFromIsLoggedIn, makeAuthTransitionHook, makeDbxActionContextSourceReference, mapRefStringObsToSegueRefObs, mergeDbxInjectionComponentConfigs, index$1 as onDbxAppAuth, index$3 as onDbxAppContext, onRouterTransitionEventType, onRouterTransitionSuccessEvent, pipeActionStore, provideActionStoreSource, provideDbxAnchor, provideDbxButton, provideDbxInjectionContext, provideFilterSource, provideFilterSourceConnector, provideFilterSourceDirective, provideSecondaryActionStoreSource, redirectBasedOnAuthUserState, redirectForUserIdentifierParamHook, refStringToSegueRef, safeDetectChanges, safeMarkForCheck, safeUseCdRef, successTransition, tapDetectChanges, tapSafeMarkForCheck, useActionStore };
5036
+ export { APP_ACTION_DISABLED_DIRECTIVE_KEY, APP_ACTION_DISABLED_ON_SUCCESS_DIRECTIVE_KEY, APP_ACTION_ENFORCE_MODIFIED_DIRECTIVE_KEY, AbstractDbxActionHandlerDirective, AbstractDbxActionValueOnTriggerDirective, AbstractDbxAnchorDirective, AbstractDbxButtonDirective, AbstractDbxFilterMapInstanceDirective, AbstractDbxInjectionDirective, AbstractFilterSourceConnectorDirective, AbstractFilterSourceDirective, AbstractForwardDbxInjectionContextDirective, AbstractIfDirective, AbstractLockSetSubscriptionDirective, AbstractSubscriptionDirective, AbstractTransitionDirective, AbstractTransitionWatcherDirective, ActionContextStore, ActionContextStoreSource, ActionContextStoreSourceMap, AnchorType, DBX_ACTION_HANDLER_LOCK_KEY, DBX_APP_APP_CONTEXT_STATE, DBX_APP_AUTH_ROUTER_EFFECTS_TOKEN, DBX_AUTH_APP_CONTEXT_STATE, DBX_INIT_APP_CONTEXT_STATE, DBX_INJECTION_COMPONENT_DATA, DBX_KNOWN_APP_CONTEXT_STATES, DBX_ONBOARDING_APP_CONTEXT_STATE, DBX_ONBOARD_APP_CONTEXT_STATE, DBX_PUBLIC_APP_CONTEXT_STATE, DEFAULT_ACTION_DISABLED_KEY, DEFAULT_ACTION_MAP_WORKING_DISABLED_KEY, DEFAULT_REDIRECT_FOR_IDENTIFIER_PARAM_KEY, DEFAULT_REDIRECT_FOR_IDENTIFIER_PARAM_VALUE, DEFAULT_REDIRECT_FOR_USER_IDENTIFIER_PARAM_KEY, DEFAULT_REDIRECT_FOR_USER_IDENTIFIER_PARAM_VALUE, DEFAULT_STORAGE_ACCESSOR_FACTORY_TOKEN, DEFAULT_STORAGE_OBJECT_TOKEN, DateDistancePipe, DateFormatDistancePipe, DateFromToTimePipe, DbxActionAutoModifyDirective, DbxActionAutoTriggerDirective, DbxActionButtonDirective, DbxActionButtonTriggerDirective, DbxActionContextBaseSource, DbxActionContextLoggerDirective, DbxActionContextMachine, DbxActionContextMachineAsService, DbxActionContextMapDirective, DbxActionContextMapDirectiveSourceInstance, DbxActionContextStoreSourceInstance, DbxActionDirective, DbxActionDisabledDirective, DbxActionDisabledOnSuccessDirective, DbxActionEnforceModifiedDirective, DbxActionFromMapDirective, DbxActionHandlerDirective, DbxActionHandlerInstance, DbxActionHasSuccessDirective, DbxActionIsWorkingDirective, DbxActionMapSourceDirective, DbxActionMapWorkingDisableDirective, DbxActionPreSuccessDirective, DbxActionSourceDirective, DbxActionState, DbxActionSuccessHandlerDirective, DbxActionValueDirective, DbxActionValueOnTriggerInstance, DbxActionValueTriggerDirective, DbxActionWorkInstanceDelegate, DbxAnchor, DbxAngularRouterService, DbxAppAuthRouterEffects, DbxAppAuthRouterModule, DbxAppAuthRouterService, DbxAppAuthRouterStateModule, DbxAppAuthRoutes, DbxAppAuthStateModule, DbxAppAuthStateService, DbxAppContextService, DbxAppContextStateDirective, DbxAppContextStateModule, DbxAuthHasAnyRoleDirective, DbxAuthHasRolesDirective, DbxAuthNotAnyRolesDirective, DbxAuthService, DbxButton, DbxButtonDirective, DbxButtonSegueDirective, DbxCoreActionModule, DbxCoreAngularRouterSegueModule, DbxCoreAuthModule, DbxCoreButtonModule, DbxCoreFilterModule, DbxCoreUIRouterSegueModule, DbxDatePipeModule, DbxFilterConnectSourceDirective, DbxFilterMapDirective, DbxFilterMapSourceConnectorDirective, DbxFilterMapSourceDirective, DbxFilterSourceConnectorDirective, DbxFilterSourceDirective, DbxInjectionComponent, DbxInjectionComponentModule, DbxInjectionContext, DbxInjectionContextDirective, DbxInjectionInstance, DbxLoadingButtonDirective, DbxMiscPipeModule, DbxPipesModule, DbxRouteParamDefaultRedirectInstance, DbxRouteParamReaderInstance, DbxRouterService, DbxRouterTransitionEventType, DbxRouterTransitionService, DbxStorageModule, DbxUIRouterService, FilterSourceDirective, FullLocalStorageObject, InstantStorageAccessor, LimitedStorageAccessor, LockSetComponentStore, MemoryStorageObject, MinutesStringPipe, NO_AUTH_USER_IDENTIFIER, PrettyJsonPipe, SecondaryActionContextStoreSource, SimpleStorageAccessor, SimpleStorageAccessorFactory, StorageAccessor, StringStorageAccessor, StringifySimpleStorageAccessorConverter, TimeDistanceCountdownPipe, TimeDistancePipe, ToJsDatePipe, ToMinutesPipe, WrapperSimpleStorageAccessorDelegate, actionContextHasNoErrorAndIsModifiedAndCanTrigger, actionContextIsModifiedAndCanTrigger, actionContextStoreSourceInstanceFactory, actionContextStoreSourceMachineFactory, actionContextStoreSourcePipe, anchorTypeForAnchor, asSegueRef, asSegueRefString, authRolesSetContainsAllRolesFrom, authRolesSetContainsAnyRoleFrom, authRolesSetContainsNoRolesFrom, authUserIdentifier, canReadyValue, canTriggerAction, canTriggerActionState, checkNgContentWrapperHasContent, clickableUrlInNewTab, clickableUrlMailTo, clickableUrlTel, dbxActionValueStreamDirective, defaultStorageObjectFactory, enableHasAuthRoleHook, enableHasAuthStateHook, enableIsLoggedInHook, expandClickableAnchorLinkTree, expandClickableAnchorLinkTreeNode, expandClickableAnchorLinkTrees, filterTransitionEvent, filterTransitionSuccess, flattenExpandedClickableAnchorLinkTree, flattenExpandedClickableAnchorLinkTreeToLinks, index as fromDbxAppAuth, index$2 as fromDbxAppContext, goWithRouter, isActionContextDisabled, isActionContextEnabled, isDisabledActionContextState, isIdleActionState, isLatestSuccessfulRoute, isSegueRef, isSegueRefActive, isSegueRefActiveFunction, isSegueRefActiveOnTransitionSuccess, isWorkingActionState, loadingStateForActionContextState, loadingStateTypeForActionContextState, loadingStateTypeForActionState, loggedInObsFromIsLoggedIn, loggedOutObsFromIsLoggedIn, makeAuthTransitionHook, makeDbxActionContextSourceReference, mapRefStringObsToSegueRefObs, mergeDbxInjectionComponentConfigs, index$1 as onDbxAppAuth, index$3 as onDbxAppContext, onRouterTransitionEventType, onRouterTransitionSuccessEvent, pipeActionStore, provideActionStoreSource, provideDbxAnchor, provideDbxButton, provideDbxInjectionContext, provideFilterSource, provideFilterSourceConnector, provideFilterSourceDirective, provideSecondaryActionStoreSource, redirectBasedOnAuthUserState, redirectForIdentifierParamHook, redirectForUserIdentifierParamHook, refStringToSegueRef, safeDetectChanges, safeMarkForCheck, safeUseCdRef, successTransition, tapDetectChanges, tapSafeMarkForCheck, useActionStore };
5020
5037
  //# sourceMappingURL=dereekb-dbx-core.mjs.map