@huntsman-cancer-institute/user 16.0.1 → 17.0.0

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
@@ -1,32 +1,32 @@
1
- /**
2
- * An immutable representation of an HCI role entity, which represents an authorization claim associated with an authenticated
3
- * subject.
4
- *
5
- * @since 1.0.0
6
- */
7
- export class RoleEntity {
8
- constructor(roleName, permissions) {
9
- this.roleName = roleName;
10
- this.permissions = permissions;
11
- }
12
- /**
13
- * An accessor for the name of this role.
14
- *
15
- * @returns {string} the role name
16
- * @constructor
17
- */
18
- get RoleName() {
19
- return this.roleName;
20
- }
21
- /**
22
- * An accessor for a collection of {@link PermissionEntity} authorization claims that define this role. Permissions
23
- * provide a finer grained authorization claim description and are not required.
24
- *
25
- * @returns {PermissionEntity[]} a collection of permission entities
26
- * @constructor
27
- */
28
- get Permissions() {
29
- return this.permissions;
30
- }
31
- }
1
+ /**
2
+ * An immutable representation of an HCI role entity, which represents an authorization claim associated with an authenticated
3
+ * subject.
4
+ *
5
+ * @since 1.0.0
6
+ */
7
+ export class RoleEntity {
8
+ constructor(roleName, permissions) {
9
+ this.roleName = roleName;
10
+ this.permissions = permissions;
11
+ }
12
+ /**
13
+ * An accessor for the name of this role.
14
+ *
15
+ * @returns {string} the role name
16
+ * @constructor
17
+ */
18
+ get RoleName() {
19
+ return this.roleName;
20
+ }
21
+ /**
22
+ * An accessor for a collection of {@link PermissionEntity} authorization claims that define this role. Permissions
23
+ * provide a finer grained authorization claim description and are not required.
24
+ *
25
+ * @returns {PermissionEntity[]} a collection of permission entities
26
+ * @constructor
27
+ */
28
+ get Permissions() {
29
+ return this.permissions;
30
+ }
31
+ }
32
32
  //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoicm9sZS5lbnRpdHkuanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi8uLi9wcm9qZWN0cy91c2VyL3NyYy9hdXRob3JpemF0aW9uL3JvbGUuZW50aXR5LnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQUtBOzs7OztHQUtHO0FBQ0gsTUFBTSxPQUFPLFVBQVU7SUFDckIsWUFBcUIsUUFBZ0IsRUFBVSxXQUFnQztRQUExRCxhQUFRLEdBQVIsUUFBUSxDQUFRO1FBQVUsZ0JBQVcsR0FBWCxXQUFXLENBQXFCO0lBQUcsQ0FBQztJQUVuRjs7Ozs7T0FLRztJQUNILElBQUksUUFBUTtRQUNWLE9BQU8sSUFBSSxDQUFDLFFBQVEsQ0FBQztJQUN2QixDQUFDO0lBRUQ7Ozs7OztPQU1HO0lBQ0gsSUFBSSxXQUFXO1FBQ2IsT0FBTyxJQUFJLENBQUMsV0FBVyxDQUFDO0lBQzFCLENBQUM7Q0FDRiIsInNvdXJjZXNDb250ZW50IjpbIi8qXHJcbiAqIENvcHlyaWdodCAoYykgMjAxNiBIdW50c21hbiBDYW5jZXIgSW5zdGl0dXRlIGF0IHRoZSBVbml2ZXJzaXR5IG9mIFV0YWgsIENvbmZpZGVudGlhbCBhbmQgUHJvcHJpZXRhcnlcclxuICovXHJcbmltcG9ydCB7UGVybWlzc2lvbkVudGl0eX0gZnJvbSBcIi4vcGVybWlzc2lvbi5lbnRpdHlcIjtcclxuXHJcbi8qKlxyXG4gKiBBbiBpbW11dGFibGUgcmVwcmVzZW50YXRpb24gb2YgYW4gSENJIHJvbGUgZW50aXR5LCB3aGljaCByZXByZXNlbnRzIGFuIGF1dGhvcml6YXRpb24gY2xhaW0gYXNzb2NpYXRlZCB3aXRoIGFuIGF1dGhlbnRpY2F0ZWRcclxuICogc3ViamVjdC5cclxuICpcclxuICogQHNpbmNlIDEuMC4wXHJcbiAqL1xyXG5leHBvcnQgY2xhc3MgUm9sZUVudGl0eSB7XHJcbiAgY29uc3RydWN0b3IoIHByaXZhdGUgcm9sZU5hbWU6IHN0cmluZywgcHJpdmF0ZSBwZXJtaXNzaW9ucz86IFBlcm1pc3Npb25FbnRpdHlbXSkge31cclxuXHJcbiAgLyoqXHJcbiAgICogQW4gYWNjZXNzb3IgZm9yIHRoZSBuYW1lIG9mIHRoaXMgcm9sZS5cclxuICAgKlxyXG4gICAqIEByZXR1cm5zIHtzdHJpbmd9IHRoZSByb2xlIG5hbWVcclxuICAgKiBAY29uc3RydWN0b3JcclxuICAgKi9cclxuICBnZXQgUm9sZU5hbWUoKTogc3RyaW5nIHtcclxuICAgIHJldHVybiB0aGlzLnJvbGVOYW1lO1xyXG4gIH1cclxuXHJcbiAgLyoqXHJcbiAgICogQW4gYWNjZXNzb3IgZm9yIGEgY29sbGVjdGlvbiBvZiB7QGxpbmsgUGVybWlzc2lvbkVudGl0eX0gYXV0aG9yaXphdGlvbiBjbGFpbXMgdGhhdCBkZWZpbmUgdGhpcyByb2xlLiBQZXJtaXNzaW9uc1xyXG4gICAqIHByb3ZpZGUgYSBmaW5lciBncmFpbmVkIGF1dGhvcml6YXRpb24gY2xhaW0gZGVzY3JpcHRpb24gYW5kIGFyZSBub3QgcmVxdWlyZWQuXHJcbiAgICpcclxuICAgKiBAcmV0dXJucyB7UGVybWlzc2lvbkVudGl0eVtdfSBhIGNvbGxlY3Rpb24gb2YgcGVybWlzc2lvbiBlbnRpdGllc1xyXG4gICAqIEBjb25zdHJ1Y3RvclxyXG4gICAqL1xyXG4gIGdldCBQZXJtaXNzaW9ucygpOiBQZXJtaXNzaW9uRW50aXR5W10ge1xyXG4gICAgcmV0dXJuIHRoaXMucGVybWlzc2lvbnM7XHJcbiAgfVxyXG59XHJcbiJdfQ==
@@ -1,5 +1,5 @@
1
- /**
2
- * Generated bundle index. Do not edit.
3
- */
4
- export * from './index';
1
+ /**
2
+ * Generated bundle index. Do not edit.
3
+ */
4
+ export * from './index';
5
5
  //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiaHVudHNtYW4tY2FuY2VyLWluc3RpdHV0ZS11c2VyLmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vLi4vLi4vcHJvamVjdHMvdXNlci9zcmMvaHVudHNtYW4tY2FuY2VyLWluc3RpdHV0ZS11c2VyLnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQUFBOztHQUVHO0FBRUgsY0FBYyxTQUFTLENBQUMiLCJzb3VyY2VzQ29udGVudCI6WyIvKipcbiAqIEdlbmVyYXRlZCBidW5kbGUgaW5kZXguIERvIG5vdCBlZGl0LlxuICovXG5cbmV4cG9ydCAqIGZyb20gJy4vaW5kZXgnO1xuIl19
package/esm2022/index.mjs CHANGED
@@ -1,20 +1,20 @@
1
- /*
2
- * Copyright (c) 2016 Huntsman Cancer Institute at the University of Utah, Confidential and Proprietary
3
- */
4
- /**
5
- * A barrel file for the HCI ng2 user package.
6
- *
7
- * @since 1.0.0
8
- */
9
- export { UserModule } from "./user.module";
10
- export { UserEntity } from "./user.entity";
11
- export { RoleEntity } from "./authorization/role.entity";
12
- export { PermissionEntity } from "./authorization/permission.entity";
13
- /**
14
- * The opaque tokens for service configuration.
15
- */
16
- export { AUTHENTICATED_USER_ENDPOINT } from "./user.service";
17
- export { UserService } from "./user.service";
18
- export { RoleCheckDirective } from "./authorization/role-check.directive";
19
- export { RoleCheckUnlessNullDirective } from "./authorization/role-check-unless-null.directive";
1
+ /*
2
+ * Copyright (c) 2016 Huntsman Cancer Institute at the University of Utah, Confidential and Proprietary
3
+ */
4
+ /**
5
+ * A barrel file for the HCI ng2 user package.
6
+ *
7
+ * @since 1.0.0
8
+ */
9
+ export { UserModule } from "./user.module";
10
+ export { UserEntity } from "./user.entity";
11
+ export { RoleEntity } from "./authorization/role.entity";
12
+ export { PermissionEntity } from "./authorization/permission.entity";
13
+ /**
14
+ * The opaque tokens for service configuration.
15
+ */
16
+ export { AUTHENTICATED_USER_ENDPOINT } from "./user.service";
17
+ export { UserService } from "./user.service";
18
+ export { RoleCheckDirective } from "./authorization/role-check.directive";
19
+ export { RoleCheckUnlessNullDirective } from "./authorization/role-check-unless-null.directive";
20
20
  //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiaW5kZXguanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi9wcm9qZWN0cy91c2VyL3NyYy9pbmRleC50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFBQTs7R0FFRztBQUVIOzs7O0dBSUc7QUFDSCxPQUFPLEVBQUMsVUFBVSxFQUFDLE1BQU0sZUFBZSxDQUFBO0FBQ3hDLE9BQU8sRUFBQyxVQUFVLEVBQUMsTUFBTSxlQUFlLENBQUE7QUFDeEMsT0FBTyxFQUFDLFVBQVUsRUFBQyxNQUFNLDZCQUE2QixDQUFBO0FBQ3RELE9BQU8sRUFBQyxnQkFBZ0IsRUFBQyxNQUFNLG1DQUFtQyxDQUFBO0FBRWxFOztHQUVHO0FBQ0gsT0FBTyxFQUNMLDJCQUEyQixFQUM1QixNQUFNLGdCQUFnQixDQUFBO0FBRXZCLE9BQU8sRUFBQyxXQUFXLEVBQUMsTUFBTSxnQkFBZ0IsQ0FBQTtBQUUxQyxPQUFPLEVBQUMsa0JBQWtCLEVBQUMsTUFBTSxzQ0FBc0MsQ0FBQztBQUN4RSxPQUFPLEVBQUMsNEJBQTRCLEVBQUMsTUFBTSxrREFBa0QsQ0FBQyIsInNvdXJjZXNDb250ZW50IjpbIi8qXHJcbiAqIENvcHlyaWdodCAoYykgMjAxNiBIdW50c21hbiBDYW5jZXIgSW5zdGl0dXRlIGF0IHRoZSBVbml2ZXJzaXR5IG9mIFV0YWgsIENvbmZpZGVudGlhbCBhbmQgUHJvcHJpZXRhcnlcclxuICovXHJcblxyXG4vKipcclxuICogQSBiYXJyZWwgZmlsZSBmb3IgdGhlIEhDSSBuZzIgdXNlciBwYWNrYWdlLlxyXG4gKlxyXG4gKiBAc2luY2UgMS4wLjBcclxuICovXHJcbmV4cG9ydCB7VXNlck1vZHVsZX0gZnJvbSBcIi4vdXNlci5tb2R1bGVcIlxyXG5leHBvcnQge1VzZXJFbnRpdHl9IGZyb20gXCIuL3VzZXIuZW50aXR5XCJcclxuZXhwb3J0IHtSb2xlRW50aXR5fSBmcm9tIFwiLi9hdXRob3JpemF0aW9uL3JvbGUuZW50aXR5XCJcclxuZXhwb3J0IHtQZXJtaXNzaW9uRW50aXR5fSBmcm9tIFwiLi9hdXRob3JpemF0aW9uL3Blcm1pc3Npb24uZW50aXR5XCJcclxuXHJcbi8qKlxyXG4gKiBUaGUgb3BhcXVlIHRva2VucyBmb3Igc2VydmljZSBjb25maWd1cmF0aW9uLlxyXG4gKi9cclxuZXhwb3J0IHtcclxuICBBVVRIRU5USUNBVEVEX1VTRVJfRU5EUE9JTlRcclxufSBmcm9tIFwiLi91c2VyLnNlcnZpY2VcIlxyXG5cclxuZXhwb3J0IHtVc2VyU2VydmljZX0gZnJvbSBcIi4vdXNlci5zZXJ2aWNlXCJcclxuXHJcbmV4cG9ydCB7Um9sZUNoZWNrRGlyZWN0aXZlfSBmcm9tIFwiLi9hdXRob3JpemF0aW9uL3JvbGUtY2hlY2suZGlyZWN0aXZlXCI7XHJcbmV4cG9ydCB7Um9sZUNoZWNrVW5sZXNzTnVsbERpcmVjdGl2ZX0gZnJvbSBcIi4vYXV0aG9yaXphdGlvbi9yb2xlLWNoZWNrLXVubGVzcy1udWxsLmRpcmVjdGl2ZVwiO1xyXG5cclxuIl19
@@ -1,70 +1,70 @@
1
- /**
2
- * An immutable representation of an HCI user entity.
3
- *
4
- * @since 1.0.0
5
- */
6
- export class UserEntity {
7
- constructor(id, username, roles, firstname, lastname, href) {
8
- this.id = id;
9
- this.username = username;
10
- this.roles = roles;
11
- this.firstname = firstname;
12
- this.lastname = lastname;
13
- this.href = href;
14
- }
15
- /**
16
- * An accessor for the users system id.
17
- *
18
- * @returns {string} the system id
19
- * @constructor
20
- */
21
- get Id() {
22
- return this.id;
23
- }
24
- /**
25
- * An accessor for the users application identifier/username.
26
- *
27
- * @returns {string} the application id/username
28
- * @constructor
29
- */
30
- get Username() {
31
- return this.username;
32
- }
33
- /**
34
- * An accessor for the users assigned role authorization claims.
35
- *
36
- * @returns {@code RoleEntity[]} the role authorization claims
37
- * @constructor
38
- */
39
- get Roles() {
40
- return this.roles;
41
- }
42
- /**
43
- * An accessor for the users firstname.
44
- *
45
- * @return {string} the firstname
46
- * @constructor
47
- */
48
- get Firstname() {
49
- return this.firstname;
50
- }
51
- /**
52
- * A accessor for the users lastname.
53
- *
54
- * @return {string} the lastname
55
- * @constructor
56
- */
57
- get Lastname() {
58
- return this.lastname;
59
- }
60
- /**
61
- * A access for the users fully qualified href location on the system.
62
- *
63
- * @return {string} the href location
64
- * @constructor
65
- */
66
- get Href() {
67
- return this.href;
68
- }
69
- }
1
+ /**
2
+ * An immutable representation of an HCI user entity.
3
+ *
4
+ * @since 1.0.0
5
+ */
6
+ export class UserEntity {
7
+ constructor(id, username, roles, firstname, lastname, href) {
8
+ this.id = id;
9
+ this.username = username;
10
+ this.roles = roles;
11
+ this.firstname = firstname;
12
+ this.lastname = lastname;
13
+ this.href = href;
14
+ }
15
+ /**
16
+ * An accessor for the users system id.
17
+ *
18
+ * @returns {string} the system id
19
+ * @constructor
20
+ */
21
+ get Id() {
22
+ return this.id;
23
+ }
24
+ /**
25
+ * An accessor for the users application identifier/username.
26
+ *
27
+ * @returns {string} the application id/username
28
+ * @constructor
29
+ */
30
+ get Username() {
31
+ return this.username;
32
+ }
33
+ /**
34
+ * An accessor for the users assigned role authorization claims.
35
+ *
36
+ * @returns {@code RoleEntity[]} the role authorization claims
37
+ * @constructor
38
+ */
39
+ get Roles() {
40
+ return this.roles;
41
+ }
42
+ /**
43
+ * An accessor for the users firstname.
44
+ *
45
+ * @return {string} the firstname
46
+ * @constructor
47
+ */
48
+ get Firstname() {
49
+ return this.firstname;
50
+ }
51
+ /**
52
+ * A accessor for the users lastname.
53
+ *
54
+ * @return {string} the lastname
55
+ * @constructor
56
+ */
57
+ get Lastname() {
58
+ return this.lastname;
59
+ }
60
+ /**
61
+ * A access for the users fully qualified href location on the system.
62
+ *
63
+ * @return {string} the href location
64
+ * @constructor
65
+ */
66
+ get Href() {
67
+ return this.href;
68
+ }
69
+ }
70
70
  //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoidXNlci5lbnRpdHkuanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi9wcm9qZWN0cy91c2VyL3NyYy91c2VyLmVudGl0eS50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFLQTs7OztHQUlHO0FBQ0gsTUFBTSxPQUFPLFVBQVU7SUFDckIsWUFBb0IsRUFBVSxFQUNWLFFBQWdCLEVBQ2hCLEtBQW9CLEVBQ3BCLFNBQWtCLEVBQ2xCLFFBQWlCLEVBQ2pCLElBQWE7UUFMYixPQUFFLEdBQUYsRUFBRSxDQUFRO1FBQ1YsYUFBUSxHQUFSLFFBQVEsQ0FBUTtRQUNoQixVQUFLLEdBQUwsS0FBSyxDQUFlO1FBQ3BCLGNBQVMsR0FBVCxTQUFTLENBQVM7UUFDbEIsYUFBUSxHQUFSLFFBQVEsQ0FBUztRQUNqQixTQUFJLEdBQUosSUFBSSxDQUFTO0lBQ2pDLENBQUM7SUFFRDs7Ozs7T0FLRztJQUNILElBQUksRUFBRTtRQUNKLE9BQU8sSUFBSSxDQUFDLEVBQUUsQ0FBQztJQUNqQixDQUFDO0lBRUQ7Ozs7O09BS0c7SUFDSCxJQUFJLFFBQVE7UUFDVixPQUFPLElBQUksQ0FBQyxRQUFRLENBQUM7SUFDdkIsQ0FBQztJQUVEOzs7OztPQUtHO0lBQ0gsSUFBSSxLQUFLO1FBQ1AsT0FBTyxJQUFJLENBQUMsS0FBSyxDQUFDO0lBQ3BCLENBQUM7SUFFRDs7Ozs7T0FLRztJQUNILElBQUksU0FBUztRQUNYLE9BQU8sSUFBSSxDQUFDLFNBQVMsQ0FBQztJQUN4QixDQUFDO0lBRUQ7Ozs7O09BS0c7SUFDSCxJQUFJLFFBQVE7UUFDVixPQUFPLElBQUksQ0FBQyxRQUFRLENBQUM7SUFDdkIsQ0FBQztJQUVEOzs7OztPQUtHO0lBQ0gsSUFBSSxJQUFJO1FBQ04sT0FBTyxJQUFJLENBQUMsSUFBSSxDQUFDO0lBQ25CLENBQUM7Q0FFRiIsInNvdXJjZXNDb250ZW50IjpbIi8qXHJcbiAqIENvcHlyaWdodCAoYykgMjAxNiBIdW50c21hbiBDYW5jZXIgSW5zdGl0dXRlIGF0IHRoZSBVbml2ZXJzaXR5IG9mIFV0YWgsIENvbmZpZGVudGlhbCBhbmQgUHJvcHJpZXRhcnlcclxuICovXHJcbmltcG9ydCB7Um9sZUVudGl0eX0gZnJvbSBcIi4vYXV0aG9yaXphdGlvbi9yb2xlLmVudGl0eVwiO1xyXG5cclxuLyoqXHJcbiAqIEFuIGltbXV0YWJsZSByZXByZXNlbnRhdGlvbiBvZiBhbiBIQ0kgdXNlciBlbnRpdHkuXHJcbiAqXHJcbiAqIEBzaW5jZSAxLjAuMFxyXG4gKi9cclxuZXhwb3J0IGNsYXNzIFVzZXJFbnRpdHkge1xyXG4gIGNvbnN0cnVjdG9yKHByaXZhdGUgaWQ6IHN0cmluZyxcclxuICAgICAgICAgICAgICBwcml2YXRlIHVzZXJuYW1lOiBzdHJpbmcsXHJcbiAgICAgICAgICAgICAgcHJpdmF0ZSByb2xlcz86IFJvbGVFbnRpdHlbXSxcclxuICAgICAgICAgICAgICBwcml2YXRlIGZpcnN0bmFtZT86IHN0cmluZyxcclxuICAgICAgICAgICAgICBwcml2YXRlIGxhc3RuYW1lPzogc3RyaW5nLFxyXG4gICAgICAgICAgICAgIHByaXZhdGUgaHJlZj86IHN0cmluZykge1xyXG4gIH1cclxuXHJcbiAgLyoqXHJcbiAgICogQW4gYWNjZXNzb3IgZm9yIHRoZSB1c2VycyBzeXN0ZW0gaWQuXHJcbiAgICpcclxuICAgKiBAcmV0dXJucyB7c3RyaW5nfSB0aGUgc3lzdGVtIGlkXHJcbiAgICogQGNvbnN0cnVjdG9yXHJcbiAgICovXHJcbiAgZ2V0IElkKCk6IHN0cmluZyB7XHJcbiAgICByZXR1cm4gdGhpcy5pZDtcclxuICB9XHJcblxyXG4gIC8qKlxyXG4gICAqIEFuIGFjY2Vzc29yIGZvciB0aGUgdXNlcnMgYXBwbGljYXRpb24gaWRlbnRpZmllci91c2VybmFtZS5cclxuICAgKlxyXG4gICAqIEByZXR1cm5zIHtzdHJpbmd9IHRoZSBhcHBsaWNhdGlvbiBpZC91c2VybmFtZVxyXG4gICAqIEBjb25zdHJ1Y3RvclxyXG4gICAqL1xyXG4gIGdldCBVc2VybmFtZSgpOiBzdHJpbmcge1xyXG4gICAgcmV0dXJuIHRoaXMudXNlcm5hbWU7XHJcbiAgfVxyXG5cclxuICAvKipcclxuICAgKiBBbiBhY2Nlc3NvciBmb3IgdGhlIHVzZXJzIGFzc2lnbmVkIHJvbGUgYXV0aG9yaXphdGlvbiBjbGFpbXMuXHJcbiAgICpcclxuICAgKiBAcmV0dXJucyB7QGNvZGUgUm9sZUVudGl0eVtdfSB0aGUgcm9sZSBhdXRob3JpemF0aW9uIGNsYWltc1xyXG4gICAqIEBjb25zdHJ1Y3RvclxyXG4gICAqL1xyXG4gIGdldCBSb2xlcygpOiBSb2xlRW50aXR5W10ge1xyXG4gICAgcmV0dXJuIHRoaXMucm9sZXM7XHJcbiAgfVxyXG5cclxuICAvKipcclxuICAgKiBBbiBhY2Nlc3NvciBmb3IgdGhlIHVzZXJzIGZpcnN0bmFtZS5cclxuICAgKlxyXG4gICAqIEByZXR1cm4ge3N0cmluZ30gdGhlIGZpcnN0bmFtZVxyXG4gICAqIEBjb25zdHJ1Y3RvclxyXG4gICAqL1xyXG4gIGdldCBGaXJzdG5hbWUoKTogc3RyaW5nIHtcclxuICAgIHJldHVybiB0aGlzLmZpcnN0bmFtZTtcclxuICB9XHJcblxyXG4gIC8qKlxyXG4gICAqIEEgYWNjZXNzb3IgZm9yIHRoZSB1c2VycyBsYXN0bmFtZS5cclxuICAgKlxyXG4gICAqIEByZXR1cm4ge3N0cmluZ30gdGhlIGxhc3RuYW1lXHJcbiAgICogQGNvbnN0cnVjdG9yXHJcbiAgICovXHJcbiAgZ2V0IExhc3RuYW1lKCk6IHN0cmluZyB7XHJcbiAgICByZXR1cm4gdGhpcy5sYXN0bmFtZTtcclxuICB9XHJcblxyXG4gIC8qKlxyXG4gICAqIEEgYWNjZXNzIGZvciB0aGUgdXNlcnMgZnVsbHkgcXVhbGlmaWVkIGhyZWYgbG9jYXRpb24gb24gdGhlIHN5c3RlbS5cclxuICAgKlxyXG4gICAqIEByZXR1cm4ge3N0cmluZ30gdGhlIGhyZWYgbG9jYXRpb25cclxuICAgKiBAY29uc3RydWN0b3JcclxuICAgKi9cclxuICBnZXQgSHJlZigpOiBzdHJpbmcge1xyXG4gICAgcmV0dXJuIHRoaXMuaHJlZjtcclxuICB9XHJcblxyXG59XHJcbiJdfQ==
@@ -1,53 +1,53 @@
1
- /*
2
- * Copyright (c) 2016 Huntsman Cancer Institute at the University of Utah, Confidential and Proprietary
3
- */
4
- import { NgModule } from "@angular/core";
5
- import { CommonModule } from "@angular/common";
6
- import { ReactiveFormsModule, FormsModule } from "@angular/forms";
7
- import { UserService } from "./user.service";
8
- import { RoleCheckDirective } from "./authorization/role-check.directive";
9
- import { RoleCheckUnlessNullDirective } from "./authorization/role-check-unless-null.directive";
10
- import * as i0 from "@angular/core";
11
- /**
12
- * A feature module for user related services, directives, pipes, etc...
13
- *
14
- * @since 1.0.0
15
- */
16
- export class UserModule {
17
- static forRoot() {
18
- return {
19
- providers: [
20
- UserService
21
- ],
22
- ngModule: UserModule
23
- };
24
- }
25
- static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "16.2.12", ngImport: i0, type: UserModule, deps: [], target: i0.ɵɵFactoryTarget.NgModule }); }
26
- static { this.ɵmod = i0.ɵɵngDeclareNgModule({ minVersion: "14.0.0", version: "16.2.12", ngImport: i0, type: UserModule, declarations: [RoleCheckDirective,
27
- RoleCheckUnlessNullDirective], imports: [CommonModule,
28
- ReactiveFormsModule,
29
- FormsModule], exports: [RoleCheckDirective,
30
- RoleCheckUnlessNullDirective] }); }
31
- static { this.ɵinj = i0.ɵɵngDeclareInjector({ minVersion: "12.0.0", version: "16.2.12", ngImport: i0, type: UserModule, imports: [CommonModule,
32
- ReactiveFormsModule,
33
- FormsModule] }); }
34
- }
35
- i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "16.2.12", ngImport: i0, type: UserModule, decorators: [{
36
- type: NgModule,
37
- args: [{
38
- imports: [
39
- CommonModule,
40
- ReactiveFormsModule,
41
- FormsModule
42
- ],
43
- declarations: [
44
- RoleCheckDirective,
45
- RoleCheckUnlessNullDirective
46
- ],
47
- exports: [
48
- RoleCheckDirective,
49
- RoleCheckUnlessNullDirective
50
- ]
51
- }]
52
- }] });
53
- //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoidXNlci5tb2R1bGUuanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi9wcm9qZWN0cy91c2VyL3NyYy91c2VyLm1vZHVsZS50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFBQTs7R0FFRztBQUNILE9BQU8sRUFBc0IsUUFBUSxFQUFDLE1BQU0sZUFBZSxDQUFDO0FBQzVELE9BQU8sRUFBQyxZQUFZLEVBQUMsTUFBTSxpQkFBaUIsQ0FBQztBQUM3QyxPQUFPLEVBQUMsbUJBQW1CLEVBQUUsV0FBVyxFQUFDLE1BQU0sZ0JBQWdCLENBQUM7QUFFaEUsT0FBTyxFQUFDLFdBQVcsRUFBQyxNQUFNLGdCQUFnQixDQUFDO0FBQzNDLE9BQU8sRUFBQyxrQkFBa0IsRUFBQyxNQUFNLHNDQUFzQyxDQUFDO0FBQ3hFLE9BQU8sRUFBQyw0QkFBNEIsRUFBQyxNQUFNLGtEQUFrRCxDQUFDOztBQUU5Rjs7OztHQUlHO0FBZ0JILE1BQU0sT0FBTyxVQUFVO0lBQ3JCLE1BQU0sQ0FBQyxPQUFPO1FBQ1osT0FBTztZQUNMLFNBQVMsRUFBRTtnQkFDVCxXQUFXO2FBQ1o7WUFDRCxRQUFRLEVBQUUsVUFBVTtTQUNyQixDQUFDO0lBQ0osQ0FBQzsrR0FSVSxVQUFVO2dIQUFWLFVBQVUsaUJBUm5CLGtCQUFrQjtZQUNsQiw0QkFBNEIsYUFONUIsWUFBWTtZQUNaLG1CQUFtQjtZQUNuQixXQUFXLGFBT1gsa0JBQWtCO1lBQ2xCLDRCQUE0QjtnSEFHbkIsVUFBVSxZQWJuQixZQUFZO1lBQ1osbUJBQW1CO1lBQ25CLFdBQVc7OzRGQVdGLFVBQVU7a0JBZnRCLFFBQVE7bUJBQUM7b0JBQ1IsT0FBTyxFQUFFO3dCQUNQLFlBQVk7d0JBQ1osbUJBQW1CO3dCQUNuQixXQUFXO3FCQUNaO29CQUNELFlBQVksRUFBRTt3QkFDWixrQkFBa0I7d0JBQ2xCLDRCQUE0QjtxQkFDN0I7b0JBQ0QsT0FBTyxFQUFFO3dCQUNQLGtCQUFrQjt3QkFDbEIsNEJBQTRCO3FCQUM3QjtpQkFDRiIsInNvdXJjZXNDb250ZW50IjpbIi8qXHJcbiAqIENvcHlyaWdodCAoYykgMjAxNiBIdW50c21hbiBDYW5jZXIgSW5zdGl0dXRlIGF0IHRoZSBVbml2ZXJzaXR5IG9mIFV0YWgsIENvbmZpZGVudGlhbCBhbmQgUHJvcHJpZXRhcnlcclxuICovXHJcbmltcG9ydCB7TW9kdWxlV2l0aFByb3ZpZGVycywgTmdNb2R1bGV9IGZyb20gXCJAYW5ndWxhci9jb3JlXCI7XHJcbmltcG9ydCB7Q29tbW9uTW9kdWxlfSBmcm9tIFwiQGFuZ3VsYXIvY29tbW9uXCI7XHJcbmltcG9ydCB7UmVhY3RpdmVGb3Jtc01vZHVsZSwgRm9ybXNNb2R1bGV9IGZyb20gXCJAYW5ndWxhci9mb3Jtc1wiO1xyXG5cclxuaW1wb3J0IHtVc2VyU2VydmljZX0gZnJvbSBcIi4vdXNlci5zZXJ2aWNlXCI7XHJcbmltcG9ydCB7Um9sZUNoZWNrRGlyZWN0aXZlfSBmcm9tIFwiLi9hdXRob3JpemF0aW9uL3JvbGUtY2hlY2suZGlyZWN0aXZlXCI7XHJcbmltcG9ydCB7Um9sZUNoZWNrVW5sZXNzTnVsbERpcmVjdGl2ZX0gZnJvbSBcIi4vYXV0aG9yaXphdGlvbi9yb2xlLWNoZWNrLXVubGVzcy1udWxsLmRpcmVjdGl2ZVwiO1xyXG5cclxuLyoqXHJcbiAqIEEgZmVhdHVyZSBtb2R1bGUgZm9yIHVzZXIgcmVsYXRlZCBzZXJ2aWNlcywgZGlyZWN0aXZlcywgcGlwZXMsIGV0Yy4uLlxyXG4gKlxyXG4gKiBAc2luY2UgMS4wLjBcclxuICovXHJcbkBOZ01vZHVsZSh7XHJcbiAgaW1wb3J0czogW1xyXG4gICAgQ29tbW9uTW9kdWxlLFxyXG4gICAgUmVhY3RpdmVGb3Jtc01vZHVsZSxcclxuICAgIEZvcm1zTW9kdWxlXHJcbiAgXSxcclxuICBkZWNsYXJhdGlvbnM6IFtcclxuICAgIFJvbGVDaGVja0RpcmVjdGl2ZSxcclxuICAgIFJvbGVDaGVja1VubGVzc051bGxEaXJlY3RpdmVcclxuICBdLFxyXG4gIGV4cG9ydHM6IFtcclxuICAgIFJvbGVDaGVja0RpcmVjdGl2ZSxcclxuICAgIFJvbGVDaGVja1VubGVzc051bGxEaXJlY3RpdmVcclxuICBdXHJcbn0pXHJcbmV4cG9ydCBjbGFzcyBVc2VyTW9kdWxlIHtcclxuICBzdGF0aWMgZm9yUm9vdCgpOiBNb2R1bGVXaXRoUHJvdmlkZXJzPFVzZXJNb2R1bGU+IHtcclxuICAgIHJldHVybiB7XHJcbiAgICAgIHByb3ZpZGVyczogW1xyXG4gICAgICAgIFVzZXJTZXJ2aWNlXHJcbiAgICAgIF0sXHJcbiAgICAgIG5nTW9kdWxlOiBVc2VyTW9kdWxlXHJcbiAgICB9O1xyXG4gIH1cclxufVxyXG4iXX0=
1
+ /*
2
+ * Copyright (c) 2016 Huntsman Cancer Institute at the University of Utah, Confidential and Proprietary
3
+ */
4
+ import { NgModule } from "@angular/core";
5
+ import { CommonModule } from "@angular/common";
6
+ import { ReactiveFormsModule, FormsModule } from "@angular/forms";
7
+ import { UserService } from "./user.service";
8
+ import { RoleCheckDirective } from "./authorization/role-check.directive";
9
+ import { RoleCheckUnlessNullDirective } from "./authorization/role-check-unless-null.directive";
10
+ import * as i0 from "@angular/core";
11
+ /**
12
+ * A feature module for user related services, directives, pipes, etc...
13
+ *
14
+ * @since 1.0.0
15
+ */
16
+ export class UserModule {
17
+ static forRoot() {
18
+ return {
19
+ providers: [
20
+ UserService
21
+ ],
22
+ ngModule: UserModule
23
+ };
24
+ }
25
+ static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "17.1.2", ngImport: i0, type: UserModule, deps: [], target: i0.ɵɵFactoryTarget.NgModule }); }
26
+ static { this.ɵmod = i0.ɵɵngDeclareNgModule({ minVersion: "14.0.0", version: "17.1.2", ngImport: i0, type: UserModule, declarations: [RoleCheckDirective,
27
+ RoleCheckUnlessNullDirective], imports: [CommonModule,
28
+ ReactiveFormsModule,
29
+ FormsModule], exports: [RoleCheckDirective,
30
+ RoleCheckUnlessNullDirective] }); }
31
+ static { this.ɵinj = i0.ɵɵngDeclareInjector({ minVersion: "12.0.0", version: "17.1.2", ngImport: i0, type: UserModule, imports: [CommonModule,
32
+ ReactiveFormsModule,
33
+ FormsModule] }); }
34
+ }
35
+ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "17.1.2", ngImport: i0, type: UserModule, decorators: [{
36
+ type: NgModule,
37
+ args: [{
38
+ imports: [
39
+ CommonModule,
40
+ ReactiveFormsModule,
41
+ FormsModule
42
+ ],
43
+ declarations: [
44
+ RoleCheckDirective,
45
+ RoleCheckUnlessNullDirective
46
+ ],
47
+ exports: [
48
+ RoleCheckDirective,
49
+ RoleCheckUnlessNullDirective
50
+ ]
51
+ }]
52
+ }] });
53
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoidXNlci5tb2R1bGUuanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi9wcm9qZWN0cy91c2VyL3NyYy91c2VyLm1vZHVsZS50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFBQTs7R0FFRztBQUNILE9BQU8sRUFBc0IsUUFBUSxFQUFDLE1BQU0sZUFBZSxDQUFDO0FBQzVELE9BQU8sRUFBQyxZQUFZLEVBQUMsTUFBTSxpQkFBaUIsQ0FBQztBQUM3QyxPQUFPLEVBQUMsbUJBQW1CLEVBQUUsV0FBVyxFQUFDLE1BQU0sZ0JBQWdCLENBQUM7QUFFaEUsT0FBTyxFQUFDLFdBQVcsRUFBQyxNQUFNLGdCQUFnQixDQUFDO0FBQzNDLE9BQU8sRUFBQyxrQkFBa0IsRUFBQyxNQUFNLHNDQUFzQyxDQUFDO0FBQ3hFLE9BQU8sRUFBQyw0QkFBNEIsRUFBQyxNQUFNLGtEQUFrRCxDQUFDOztBQUU5Rjs7OztHQUlHO0FBZ0JILE1BQU0sT0FBTyxVQUFVO0lBQ3JCLE1BQU0sQ0FBQyxPQUFPO1FBQ1osT0FBTztZQUNMLFNBQVMsRUFBRTtnQkFDVCxXQUFXO2FBQ1o7WUFDRCxRQUFRLEVBQUUsVUFBVTtTQUNyQixDQUFDO0lBQ0osQ0FBQzs4R0FSVSxVQUFVOytHQUFWLFVBQVUsaUJBUm5CLGtCQUFrQjtZQUNsQiw0QkFBNEIsYUFONUIsWUFBWTtZQUNaLG1CQUFtQjtZQUNuQixXQUFXLGFBT1gsa0JBQWtCO1lBQ2xCLDRCQUE0QjsrR0FHbkIsVUFBVSxZQWJuQixZQUFZO1lBQ1osbUJBQW1CO1lBQ25CLFdBQVc7OzJGQVdGLFVBQVU7a0JBZnRCLFFBQVE7bUJBQUM7b0JBQ1IsT0FBTyxFQUFFO3dCQUNQLFlBQVk7d0JBQ1osbUJBQW1CO3dCQUNuQixXQUFXO3FCQUNaO29CQUNELFlBQVksRUFBRTt3QkFDWixrQkFBa0I7d0JBQ2xCLDRCQUE0QjtxQkFDN0I7b0JBQ0QsT0FBTyxFQUFFO3dCQUNQLGtCQUFrQjt3QkFDbEIsNEJBQTRCO3FCQUM3QjtpQkFDRiIsInNvdXJjZXNDb250ZW50IjpbIi8qXHJcbiAqIENvcHlyaWdodCAoYykgMjAxNiBIdW50c21hbiBDYW5jZXIgSW5zdGl0dXRlIGF0IHRoZSBVbml2ZXJzaXR5IG9mIFV0YWgsIENvbmZpZGVudGlhbCBhbmQgUHJvcHJpZXRhcnlcclxuICovXHJcbmltcG9ydCB7TW9kdWxlV2l0aFByb3ZpZGVycywgTmdNb2R1bGV9IGZyb20gXCJAYW5ndWxhci9jb3JlXCI7XHJcbmltcG9ydCB7Q29tbW9uTW9kdWxlfSBmcm9tIFwiQGFuZ3VsYXIvY29tbW9uXCI7XHJcbmltcG9ydCB7UmVhY3RpdmVGb3Jtc01vZHVsZSwgRm9ybXNNb2R1bGV9IGZyb20gXCJAYW5ndWxhci9mb3Jtc1wiO1xyXG5cclxuaW1wb3J0IHtVc2VyU2VydmljZX0gZnJvbSBcIi4vdXNlci5zZXJ2aWNlXCI7XHJcbmltcG9ydCB7Um9sZUNoZWNrRGlyZWN0aXZlfSBmcm9tIFwiLi9hdXRob3JpemF0aW9uL3JvbGUtY2hlY2suZGlyZWN0aXZlXCI7XHJcbmltcG9ydCB7Um9sZUNoZWNrVW5sZXNzTnVsbERpcmVjdGl2ZX0gZnJvbSBcIi4vYXV0aG9yaXphdGlvbi9yb2xlLWNoZWNrLXVubGVzcy1udWxsLmRpcmVjdGl2ZVwiO1xyXG5cclxuLyoqXHJcbiAqIEEgZmVhdHVyZSBtb2R1bGUgZm9yIHVzZXIgcmVsYXRlZCBzZXJ2aWNlcywgZGlyZWN0aXZlcywgcGlwZXMsIGV0Yy4uLlxyXG4gKlxyXG4gKiBAc2luY2UgMS4wLjBcclxuICovXHJcbkBOZ01vZHVsZSh7XHJcbiAgaW1wb3J0czogW1xyXG4gICAgQ29tbW9uTW9kdWxlLFxyXG4gICAgUmVhY3RpdmVGb3Jtc01vZHVsZSxcclxuICAgIEZvcm1zTW9kdWxlXHJcbiAgXSxcclxuICBkZWNsYXJhdGlvbnM6IFtcclxuICAgIFJvbGVDaGVja0RpcmVjdGl2ZSxcclxuICAgIFJvbGVDaGVja1VubGVzc051bGxEaXJlY3RpdmVcclxuICBdLFxyXG4gIGV4cG9ydHM6IFtcclxuICAgIFJvbGVDaGVja0RpcmVjdGl2ZSxcclxuICAgIFJvbGVDaGVja1VubGVzc051bGxEaXJlY3RpdmVcclxuICBdXHJcbn0pXHJcbmV4cG9ydCBjbGFzcyBVc2VyTW9kdWxlIHtcclxuICBzdGF0aWMgZm9yUm9vdCgpOiBNb2R1bGVXaXRoUHJvdmlkZXJzPFVzZXJNb2R1bGU+IHtcclxuICAgIHJldHVybiB7XHJcbiAgICAgIHByb3ZpZGVyczogW1xyXG4gICAgICAgIFVzZXJTZXJ2aWNlXHJcbiAgICAgIF0sXHJcbiAgICAgIG5nTW9kdWxlOiBVc2VyTW9kdWxlXHJcbiAgICB9O1xyXG4gIH1cclxufVxyXG4iXX0=
@@ -1,98 +1,98 @@
1
- /*
2
- * Copyright (c) 2016 Huntsman Cancer Institute at the University of Utah, Confidential and Proprietary
3
- */
4
- import { Injectable, InjectionToken, Inject, isDevMode } from "@angular/core";
5
- import { HttpClient, HttpHeaders } from "@angular/common/http";
6
- import { of, throwError } from "rxjs";
7
- import { catchError, map } from "rxjs/operators";
8
- import { UserEntity } from "./user.entity";
9
- import { RoleEntity } from "./authorization/role.entity";
10
- import { PermissionEntity } from "./authorization/permission.entity";
11
- import * as i0 from "@angular/core";
12
- import * as i1 from "@angular/common/http";
13
- export let AUTHENTICATED_USER_ENDPOINT = new InjectionToken("authenticated_user_url");
14
- /**
15
- * @since 1.0.0
16
- */
17
- export class UserService {
18
- /**
19
- * The generic error message used when a server error is thrown without a status.
20
- *
21
- * @type {string}
22
- */
23
- static { this.GENERIC_ERR_MSG = "Server error"; }
24
- constructor(_http, _authenticationUserEndpoint) {
25
- this._http = _http;
26
- this._authenticationUserEndpoint = _authenticationUserEndpoint;
27
- this._authenticatedUser = null;
28
- }
29
- /**
30
- * An accessor for an {@code Observable<UserEntity>} reflecting the currently authenticated user. If no subject is
31
- * available, the appropriate response status should be returned from the server to indicate that condition
32
- * (i.e. 404 - Not Found).
33
- *
34
- * @returns {Observable<UserEntity>} the currently authenticated user representation
35
- */
36
- getAuthenticatedUser() {
37
- if (isDevMode() && console && console.debug) {
38
- console.debug("getAuthenticatedUser");
39
- }
40
- if (!this._authenticatedUser) {
41
- if (isDevMode() && console && console.debug) {
42
- console.debug("_authenticationUserEndpoint: " + this._authenticationUserEndpoint);
43
- }
44
- return this._http.get(this._authenticationUserEndpoint, { observe: "response" }).pipe(map((resp) => {
45
- if (resp.status === 200) {
46
- this._authenticatedUser = this.buildUserEntity(resp.body);
47
- return this._authenticatedUser;
48
- }
49
- else {
50
- throw new Error("Get authenticated user failed. " + resp.status + ": " + resp.statusText);
51
- }
52
- }), catchError(this.handleError));
53
- }
54
- else {
55
- return of(this._authenticatedUser);
56
- }
57
- }
58
- handleError(error) {
59
- let errMsg = (error.message) ? error.message : UserService.GENERIC_ERR_MSG;
60
- return throwError(() => new Error(errMsg));
61
- }
62
- /**
63
- * TODO: Add in a deserializer into the entity.
64
- *
65
- * @param userJson
66
- * @returns {UserEntity}
67
- */
68
- buildUserEntity(userJson) {
69
- let roles = [];
70
- if (userJson.roles) {
71
- userJson.roles.map((role) => {
72
- let permissions;
73
- if (role.permissions) {
74
- /* TODO: JEH (10/27/16) - Revisit when we determine how permission are communicated to the client, if necessary */
75
- permissions = role.permissions.map((permission) => {
76
- return new PermissionEntity(permission.domain, permission.actions, permission.instances);
77
- });
78
- }
79
- roles.push(new RoleEntity(role.roleName, permissions));
80
- });
81
- }
82
- return new UserEntity(userJson.idUser, userJson.username, roles, userJson.firstname, userJson.lastname, userJson.href);
83
- }
84
- getPermissions(governorClass, governorId, governedClass) {
85
- let headers = new HttpHeaders()
86
- .set("SecurityGovernorClass", governorClass).set("SecurityGovernorId", String(governorId));
87
- return this._http.get("/core/api/user/permissions/" + governedClass, { headers: headers });
88
- }
89
- static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "16.2.12", ngImport: i0, type: UserService, deps: [{ token: i1.HttpClient }, { token: AUTHENTICATED_USER_ENDPOINT }], target: i0.ɵɵFactoryTarget.Injectable }); }
90
- static { this.ɵprov = i0.ɵɵngDeclareInjectable({ minVersion: "12.0.0", version: "16.2.12", ngImport: i0, type: UserService }); }
91
- }
92
- i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "16.2.12", ngImport: i0, type: UserService, decorators: [{
93
- type: Injectable
94
- }], ctorParameters: function () { return [{ type: i1.HttpClient }, { type: undefined, decorators: [{
95
- type: Inject,
96
- args: [AUTHENTICATED_USER_ENDPOINT]
97
- }] }]; } });
98
- //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"user.service.js","sourceRoot":"","sources":["../../../projects/user/src/user.service.ts"],"names":[],"mappings":"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","sourcesContent":["/*\r\n * Copyright (c) 2016 Huntsman Cancer Institute at the University of Utah, Confidential and Proprietary\r\n */\r\nimport {Injectable, InjectionToken, Inject, isDevMode} from \"@angular/core\";\r\nimport {HttpClient, HttpResponse, HttpHeaders} from \"@angular/common/http\";\r\n\r\nimport {Observable, of, throwError} from \"rxjs\";\r\nimport {catchError, map} from \"rxjs/operators\";\r\n\r\nimport {UserEntity} from \"./user.entity\";\r\nimport {RoleEntity} from \"./authorization/role.entity\";\r\nimport {PermissionEntity} from \"./authorization/permission.entity\";\r\n\r\nexport let AUTHENTICATED_USER_ENDPOINT = new InjectionToken<string>(\"authenticated_user_url\");\r\n\r\n/**\r\n * @since 1.0.0\r\n */\r\n@Injectable()\r\nexport class UserService {\r\n  /**\r\n   * The generic error message used when a server error is thrown without a status.\r\n   *\r\n   * @type {string}\r\n   */\r\n  public static GENERIC_ERR_MSG: string = \"Server error\";\r\n\r\n  private _authenticatedUser: UserEntity = null;\r\n\r\n  constructor(private _http: HttpClient, @Inject(AUTHENTICATED_USER_ENDPOINT) private _authenticationUserEndpoint: string) {}\r\n\r\n  /**\r\n   * An accessor for an {@code Observable<UserEntity>} reflecting the currently authenticated user. If no subject is\r\n   * available, the appropriate response status should be returned from the server to indicate that condition\r\n   * (i.e. 404 - Not Found).\r\n   *\r\n   * @returns {Observable<UserEntity>} the currently authenticated user representation\r\n   */\r\n  public getAuthenticatedUser(): Observable<UserEntity> {\r\n    if (isDevMode() && <any>console && <any>console.debug) {\r\n      console.debug(\"getAuthenticatedUser\");\r\n    }\r\n\r\n    if (!this._authenticatedUser) {\r\n      if (isDevMode() && <any>console && <any>console.debug) {\r\n        console.debug(\"_authenticationUserEndpoint: \" + this._authenticationUserEndpoint);\r\n      }\r\n\r\n      return this._http.get(this._authenticationUserEndpoint, { observe: \"response\" }).pipe(map((resp: HttpResponse<any>) => {\r\n        if (resp.status === 200) {\r\n          this._authenticatedUser = this.buildUserEntity(resp.body);\r\n          return this._authenticatedUser;\r\n        } else {\r\n          throw new Error(\"Get authenticated user failed. \" + resp.status + \": \" + resp.statusText);\r\n        }\r\n      }),\r\n        catchError(this.handleError));\r\n    } else {\r\n      return of(this._authenticatedUser);\r\n    }\r\n  }\r\n\r\n  private handleError(error: any) {\r\n    let errMsg = (error.message) ? error.message : UserService.GENERIC_ERR_MSG;\r\n    \r\n    return throwError(() => new Error(errMsg));\r\n  }\r\n\r\n  /**\r\n   * TODO: Add in a deserializer into the entity.\r\n   *\r\n   * @param userJson\r\n   * @returns {UserEntity}\r\n   */\r\n  private buildUserEntity(userJson: any): UserEntity {\r\n    let roles: RoleEntity[] = [];\r\n    if (userJson.roles) {\r\n      userJson.roles.map((role: any) => {\r\n        let permissions: PermissionEntity[];\r\n        if (role.permissions) {\r\n          /* TODO: JEH (10/27/16) - Revisit when we determine how permission are communicated to the client, if necessary */\r\n          permissions = role.permissions.map((permission: any) => {\r\n            return new PermissionEntity(permission.domain, permission.actions, permission.instances);\r\n          });\r\n        }\r\n        roles.push(new RoleEntity(role.roleName, permissions));\r\n      });\r\n    }\r\n\r\n    return new UserEntity(userJson.idUser, userJson.username, roles, userJson.firstname, userJson.lastname, userJson.href);\r\n  }\r\n  \r\n  public getPermissions(governorClass: string, governorId: number, governedClass: string): Observable<any>  {\r\n      let headers = new HttpHeaders()\r\n      .set(\"SecurityGovernorClass\", governorClass).set(\"SecurityGovernorId\", String(governorId));\r\n      return this._http.get(\"/core/api/user/permissions/\" + governedClass, {headers: headers});\r\n  }\r\n}\r\n"]}
1
+ /*
2
+ * Copyright (c) 2016 Huntsman Cancer Institute at the University of Utah, Confidential and Proprietary
3
+ */
4
+ import { Injectable, InjectionToken, Inject, isDevMode } from "@angular/core";
5
+ import { HttpClient, HttpHeaders } from "@angular/common/http";
6
+ import { of, throwError } from "rxjs";
7
+ import { catchError, map } from "rxjs/operators";
8
+ import { UserEntity } from "./user.entity";
9
+ import { RoleEntity } from "./authorization/role.entity";
10
+ import { PermissionEntity } from "./authorization/permission.entity";
11
+ import * as i0 from "@angular/core";
12
+ import * as i1 from "@angular/common/http";
13
+ export let AUTHENTICATED_USER_ENDPOINT = new InjectionToken("authenticated_user_url");
14
+ /**
15
+ * @since 1.0.0
16
+ */
17
+ export class UserService {
18
+ /**
19
+ * The generic error message used when a server error is thrown without a status.
20
+ *
21
+ * @type {string}
22
+ */
23
+ static { this.GENERIC_ERR_MSG = "Server error"; }
24
+ constructor(_http, _authenticationUserEndpoint) {
25
+ this._http = _http;
26
+ this._authenticationUserEndpoint = _authenticationUserEndpoint;
27
+ this._authenticatedUser = null;
28
+ }
29
+ /**
30
+ * An accessor for an {@code Observable<UserEntity>} reflecting the currently authenticated user. If no subject is
31
+ * available, the appropriate response status should be returned from the server to indicate that condition
32
+ * (i.e. 404 - Not Found).
33
+ *
34
+ * @returns {Observable<UserEntity>} the currently authenticated user representation
35
+ */
36
+ getAuthenticatedUser() {
37
+ if (isDevMode() && console && console.debug) {
38
+ console.debug("getAuthenticatedUser");
39
+ }
40
+ if (!this._authenticatedUser) {
41
+ if (isDevMode() && console && console.debug) {
42
+ console.debug("_authenticationUserEndpoint: " + this._authenticationUserEndpoint);
43
+ }
44
+ return this._http.get(this._authenticationUserEndpoint, { observe: "response" }).pipe(map((resp) => {
45
+ if (resp.status === 200) {
46
+ this._authenticatedUser = this.buildUserEntity(resp.body);
47
+ return this._authenticatedUser;
48
+ }
49
+ else {
50
+ throw new Error("Get authenticated user failed. " + resp.status + ": " + resp.statusText);
51
+ }
52
+ }), catchError(this.handleError));
53
+ }
54
+ else {
55
+ return of(this._authenticatedUser);
56
+ }
57
+ }
58
+ handleError(error) {
59
+ let errMsg = (error.message) ? error.message : UserService.GENERIC_ERR_MSG;
60
+ return throwError(() => new Error(errMsg));
61
+ }
62
+ /**
63
+ * TODO: Add in a deserializer into the entity.
64
+ *
65
+ * @param userJson
66
+ * @returns {UserEntity}
67
+ */
68
+ buildUserEntity(userJson) {
69
+ let roles = [];
70
+ if (userJson.roles) {
71
+ userJson.roles.map((role) => {
72
+ let permissions;
73
+ if (role.permissions) {
74
+ /* TODO: JEH (10/27/16) - Revisit when we determine how permission are communicated to the client, if necessary */
75
+ permissions = role.permissions.map((permission) => {
76
+ return new PermissionEntity(permission.domain, permission.actions, permission.instances);
77
+ });
78
+ }
79
+ roles.push(new RoleEntity(role.roleName, permissions));
80
+ });
81
+ }
82
+ return new UserEntity(userJson.idUser, userJson.username, roles, userJson.firstname, userJson.lastname, userJson.href);
83
+ }
84
+ getPermissions(governorClass, governorId, governedClass) {
85
+ let headers = new HttpHeaders()
86
+ .set("SecurityGovernorClass", governorClass).set("SecurityGovernorId", String(governorId));
87
+ return this._http.get("/core/api/user/permissions/" + governedClass, { headers: headers });
88
+ }
89
+ static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "17.1.2", ngImport: i0, type: UserService, deps: [{ token: i1.HttpClient }, { token: AUTHENTICATED_USER_ENDPOINT }], target: i0.ɵɵFactoryTarget.Injectable }); }
90
+ static { this.ɵprov = i0.ɵɵngDeclareInjectable({ minVersion: "12.0.0", version: "17.1.2", ngImport: i0, type: UserService }); }
91
+ }
92
+ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "17.1.2", ngImport: i0, type: UserService, decorators: [{
93
+ type: Injectable
94
+ }], ctorParameters: () => [{ type: i1.HttpClient }, { type: undefined, decorators: [{
95
+ type: Inject,
96
+ args: [AUTHENTICATED_USER_ENDPOINT]
97
+ }] }] });
98
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"user.service.js","sourceRoot":"","sources":["../../../projects/user/src/user.service.ts"],"names":[],"mappings":"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","sourcesContent":["/*\r\n * Copyright (c) 2016 Huntsman Cancer Institute at the University of Utah, Confidential and Proprietary\r\n */\r\nimport {Injectable, InjectionToken, Inject, isDevMode} from \"@angular/core\";\r\nimport {HttpClient, HttpResponse, HttpHeaders} from \"@angular/common/http\";\r\n\r\nimport {Observable, of, throwError} from \"rxjs\";\r\nimport {catchError, map} from \"rxjs/operators\";\r\n\r\nimport {UserEntity} from \"./user.entity\";\r\nimport {RoleEntity} from \"./authorization/role.entity\";\r\nimport {PermissionEntity} from \"./authorization/permission.entity\";\r\n\r\nexport let AUTHENTICATED_USER_ENDPOINT = new InjectionToken<string>(\"authenticated_user_url\");\r\n\r\n/**\r\n * @since 1.0.0\r\n */\r\n@Injectable()\r\nexport class UserService {\r\n  /**\r\n   * The generic error message used when a server error is thrown without a status.\r\n   *\r\n   * @type {string}\r\n   */\r\n  public static GENERIC_ERR_MSG: string = \"Server error\";\r\n\r\n  private _authenticatedUser: UserEntity = null;\r\n\r\n  constructor(private _http: HttpClient, @Inject(AUTHENTICATED_USER_ENDPOINT) private _authenticationUserEndpoint: string) {}\r\n\r\n  /**\r\n   * An accessor for an {@code Observable<UserEntity>} reflecting the currently authenticated user. If no subject is\r\n   * available, the appropriate response status should be returned from the server to indicate that condition\r\n   * (i.e. 404 - Not Found).\r\n   *\r\n   * @returns {Observable<UserEntity>} the currently authenticated user representation\r\n   */\r\n  public getAuthenticatedUser(): Observable<UserEntity> {\r\n    if (isDevMode() && <any>console && <any>console.debug) {\r\n      console.debug(\"getAuthenticatedUser\");\r\n    }\r\n\r\n    if (!this._authenticatedUser) {\r\n      if (isDevMode() && <any>console && <any>console.debug) {\r\n        console.debug(\"_authenticationUserEndpoint: \" + this._authenticationUserEndpoint);\r\n      }\r\n\r\n      return this._http.get(this._authenticationUserEndpoint, { observe: \"response\" }).pipe(map((resp: HttpResponse<any>) => {\r\n        if (resp.status === 200) {\r\n          this._authenticatedUser = this.buildUserEntity(resp.body);\r\n          return this._authenticatedUser;\r\n        } else {\r\n          throw new Error(\"Get authenticated user failed. \" + resp.status + \": \" + resp.statusText);\r\n        }\r\n      }),\r\n        catchError(this.handleError));\r\n    } else {\r\n      return of(this._authenticatedUser);\r\n    }\r\n  }\r\n\r\n  private handleError(error: any) {\r\n    let errMsg = (error.message) ? error.message : UserService.GENERIC_ERR_MSG;\r\n    \r\n    return throwError(() => new Error(errMsg));\r\n  }\r\n\r\n  /**\r\n   * TODO: Add in a deserializer into the entity.\r\n   *\r\n   * @param userJson\r\n   * @returns {UserEntity}\r\n   */\r\n  private buildUserEntity(userJson: any): UserEntity {\r\n    let roles: RoleEntity[] = [];\r\n    if (userJson.roles) {\r\n      userJson.roles.map((role: any) => {\r\n        let permissions: PermissionEntity[];\r\n        if (role.permissions) {\r\n          /* TODO: JEH (10/27/16) - Revisit when we determine how permission are communicated to the client, if necessary */\r\n          permissions = role.permissions.map((permission: any) => {\r\n            return new PermissionEntity(permission.domain, permission.actions, permission.instances);\r\n          });\r\n        }\r\n        roles.push(new RoleEntity(role.roleName, permissions));\r\n      });\r\n    }\r\n\r\n    return new UserEntity(userJson.idUser, userJson.username, roles, userJson.firstname, userJson.lastname, userJson.href);\r\n  }\r\n  \r\n  public getPermissions(governorClass: string, governorId: number, governedClass: string): Observable<any>  {\r\n      let headers = new HttpHeaders()\r\n      .set(\"SecurityGovernorClass\", governorClass).set(\"SecurityGovernorId\", String(governorId));\r\n      return this._http.get(\"/core/api/user/permissions/\" + governedClass, {headers: headers});\r\n  }\r\n}\r\n"]}