@node-c/domain-iam 1.0.0-alpha3

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.
Files changed (71) hide show
  1. package/LICENSE +1 -0
  2. package/README.md +4 -0
  3. package/dist/common/definitions/common.constants.d.ts +3 -0
  4. package/dist/common/definitions/common.constants.js +8 -0
  5. package/dist/common/definitions/common.constants.js.map +1 -0
  6. package/dist/common/definitions/index.d.ts +1 -0
  7. package/dist/common/definitions/index.js +18 -0
  8. package/dist/common/definitions/index.js.map +1 -0
  9. package/dist/index.d.ts +3 -0
  10. package/dist/index.js +20 -0
  11. package/dist/index.js.map +1 -0
  12. package/dist/module/iam.definitions.d.ts +13 -0
  13. package/dist/module/iam.definitions.js +3 -0
  14. package/dist/module/iam.definitions.js.map +1 -0
  15. package/dist/module/iam.module.d.ts +5 -0
  16. package/dist/module/iam.module.js +28 -0
  17. package/dist/module/iam.module.js.map +1 -0
  18. package/dist/module/index.d.ts +2 -0
  19. package/dist/module/index.js +19 -0
  20. package/dist/module/index.js.map +1 -0
  21. package/dist/services/authentication/iam.authentication.definitions.d.ts +20 -0
  22. package/dist/services/authentication/iam.authentication.definitions.js +12 -0
  23. package/dist/services/authentication/iam.authentication.definitions.js.map +1 -0
  24. package/dist/services/authentication/iam.authentication.service.d.ts +8 -0
  25. package/dist/services/authentication/iam.authentication.service.js +26 -0
  26. package/dist/services/authentication/iam.authentication.service.js.map +1 -0
  27. package/dist/services/authentication/index.d.ts +2 -0
  28. package/dist/services/authentication/index.js +19 -0
  29. package/dist/services/authentication/index.js.map +1 -0
  30. package/dist/services/authenticationLocal/iam.authenticationLocal.definitions.d.ts +11 -0
  31. package/dist/services/authenticationLocal/iam.authenticationLocal.definitions.js +3 -0
  32. package/dist/services/authenticationLocal/iam.authenticationLocal.definitions.js.map +1 -0
  33. package/dist/services/authenticationLocal/iam.authenticationLocal.service.d.ts +10 -0
  34. package/dist/services/authenticationLocal/iam.authenticationLocal.service.js +60 -0
  35. package/dist/services/authenticationLocal/iam.authenticationLocal.service.js.map +1 -0
  36. package/dist/services/authenticationLocal/index.d.ts +2 -0
  37. package/dist/services/authenticationLocal/index.js +19 -0
  38. package/dist/services/authenticationLocal/index.js.map +1 -0
  39. package/dist/services/authorization/iam.authorization.definitions.d.ts +37 -0
  40. package/dist/services/authorization/iam.authorization.definitions.js +3 -0
  41. package/dist/services/authorization/iam.authorization.definitions.js.map +1 -0
  42. package/dist/services/authorization/iam.authorization.service.d.ts +16 -0
  43. package/dist/services/authorization/iam.authorization.service.js +222 -0
  44. package/dist/services/authorization/iam.authorization.service.js.map +1 -0
  45. package/dist/services/authorization/index.d.ts +2 -0
  46. package/dist/services/authorization/index.js +19 -0
  47. package/dist/services/authorization/index.js.map +1 -0
  48. package/dist/services/index.d.ts +5 -0
  49. package/dist/services/index.js +22 -0
  50. package/dist/services/index.js.map +1 -0
  51. package/dist/services/tokenManager/iam.tokenManager.definitions.d.ts +34 -0
  52. package/dist/services/tokenManager/iam.tokenManager.definitions.js +9 -0
  53. package/dist/services/tokenManager/iam.tokenManager.definitions.js.map +1 -0
  54. package/dist/services/tokenManager/iam.tokenManager.service.d.ts +14 -0
  55. package/dist/services/tokenManager/iam.tokenManager.service.js +202 -0
  56. package/dist/services/tokenManager/iam.tokenManager.service.js.map +1 -0
  57. package/dist/services/tokenManager/index.d.ts +2 -0
  58. package/dist/services/tokenManager/index.js +19 -0
  59. package/dist/services/tokenManager/index.js.map +1 -0
  60. package/dist/services/users/iam.users.definitions.d.ts +36 -0
  61. package/dist/services/users/iam.users.definitions.js +8 -0
  62. package/dist/services/users/iam.users.definitions.js.map +1 -0
  63. package/dist/services/users/iam.users.service.d.ts +14 -0
  64. package/dist/services/users/iam.users.service.js +77 -0
  65. package/dist/services/users/iam.users.service.js.map +1 -0
  66. package/dist/services/users/index.d.ts +2 -0
  67. package/dist/services/users/index.js +19 -0
  68. package/dist/services/users/index.js.map +1 -0
  69. package/package.json +25 -0
  70. package/tsconfig.build.json +9 -0
  71. package/tsconfig.json +9 -0
@@ -0,0 +1,8 @@
1
+ "use strict";
2
+ Object.defineProperty(exports, "__esModule", { value: true });
3
+ exports.UserTokenUserIdentifier = void 0;
4
+ var UserTokenUserIdentifier;
5
+ (function (UserTokenUserIdentifier) {
6
+ UserTokenUserIdentifier["FieldName"] = "userId";
7
+ })(UserTokenUserIdentifier || (exports.UserTokenUserIdentifier = UserTokenUserIdentifier = {}));
8
+ //# sourceMappingURL=iam.users.definitions.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"iam.users.definitions.js","sourceRoot":"","sources":["../../../src/services/users/iam.users.definitions.ts"],"names":[],"mappings":";;;AAsCA,IAAY,uBAGX;AAHD,WAAY,uBAAuB;IAEjC,+CAAoB,CAAA;AACtB,CAAC,EAHW,uBAAuB,uCAAvB,uBAAuB,QAGlC"}
@@ -0,0 +1,14 @@
1
+ import { ConfigProviderService, DomainEntityService, PersistanceEntityService, PersistanceFindOneOptions } from '@node-c/core';
2
+ import { User as BaseUser, CreateAccessTokenOptions, CreateAccessTokenReturnData, GetUserWithPermissionsDataOptions, UserTokenEnityFields } from './iam.users.definitions';
3
+ import { IAMAuthenticationService, UserAuthType } from '../authentication';
4
+ import { IAMTokenManagerService } from '../tokenManager';
5
+ export declare class IAMUsersService<User extends BaseUser<unknown, unknown>> extends DomainEntityService<User, PersistanceEntityService<User>> {
6
+ protected configProvider: ConfigProviderService;
7
+ protected moduleName: string;
8
+ protected persistanceUsersService: PersistanceEntityService<User>;
9
+ protected tokenManager: IAMTokenManagerService<UserTokenEnityFields>;
10
+ protected userAuthServices: Record<UserAuthType, IAMAuthenticationService<User>>;
11
+ constructor(configProvider: ConfigProviderService, moduleName: string, persistanceUsersService: PersistanceEntityService<User>, tokenManager: IAMTokenManagerService<UserTokenEnityFields>, userAuthServices: Record<UserAuthType, IAMAuthenticationService<User>>);
12
+ createAccessToken(options: CreateAccessTokenOptions): Promise<CreateAccessTokenReturnData<User>>;
13
+ getUserWithPermissionsData(_options: PersistanceFindOneOptions, _privateOptions?: GetUserWithPermissionsDataOptions): Promise<User | null>;
14
+ }
@@ -0,0 +1,77 @@
1
+ "use strict";
2
+ var __awaiter = (this && this.__awaiter) || function (thisArg, _arguments, P, generator) {
3
+ function adopt(value) { return value instanceof P ? value : new P(function (resolve) { resolve(value); }); }
4
+ return new (P || (P = Promise))(function (resolve, reject) {
5
+ function fulfilled(value) { try { step(generator.next(value)); } catch (e) { reject(e); } }
6
+ function rejected(value) { try { step(generator["throw"](value)); } catch (e) { reject(e); } }
7
+ function step(result) { result.done ? resolve(result.value) : adopt(result.value).then(fulfilled, rejected); }
8
+ step((generator = generator.apply(thisArg, _arguments || [])).next());
9
+ });
10
+ };
11
+ var __rest = (this && this.__rest) || function (s, e) {
12
+ var t = {};
13
+ for (var p in s) if (Object.prototype.hasOwnProperty.call(s, p) && e.indexOf(p) < 0)
14
+ t[p] = s[p];
15
+ if (s != null && typeof Object.getOwnPropertySymbols === "function")
16
+ for (var i = 0, p = Object.getOwnPropertySymbols(s); i < p.length; i++) {
17
+ if (e.indexOf(p[i]) < 0 && Object.prototype.propertyIsEnumerable.call(s, p[i]))
18
+ t[p[i]] = s[p[i]];
19
+ }
20
+ return t;
21
+ };
22
+ Object.defineProperty(exports, "__esModule", { value: true });
23
+ exports.IAMUsersService = void 0;
24
+ const core_1 = require("@node-c/core");
25
+ const iam_users_definitions_1 = require("./iam.users.definitions");
26
+ const tokenManager_1 = require("../tokenManager");
27
+ class IAMUsersService extends core_1.DomainEntityService {
28
+ constructor(configProvider, moduleName, persistanceUsersService, tokenManager, userAuthServices) {
29
+ super(persistanceUsersService);
30
+ this.configProvider = configProvider;
31
+ this.moduleName = moduleName;
32
+ this.persistanceUsersService = persistanceUsersService;
33
+ this.tokenManager = tokenManager;
34
+ this.userAuthServices = userAuthServices;
35
+ }
36
+ createAccessToken(options) {
37
+ return __awaiter(this, void 0, void 0, function* () {
38
+ const { configProvider, moduleName } = this;
39
+ const { accessTokenExpiryTimeInMinutes, defaultUserIdentifierField, refreshTokenExpiryTimeInMinutes } = configProvider.config.domain[moduleName];
40
+ const _a = options.auth, { type: authType } = _a, authData = __rest(_a, ["type"]), { email, filters, rememberMe } = options;
41
+ console.info(`[Domain.${moduleName}.Users]: Login attempt for email ${email}...`);
42
+ const user = yield this.getUserWithPermissionsData({ filters: Object.assign(Object.assign({}, (filters || {})), { email }) }, { keepPassword: true });
43
+ if (!user) {
44
+ console.info(`[Domain.${moduleName}.Users]: Login attempt failed for email ${email} - user not found.`);
45
+ throw new core_1.ApplicationError('Invalid email or password.');
46
+ }
47
+ const authService = this.userAuthServices[authType];
48
+ if (!authService) {
49
+ throw new core_1.ApplicationError('Invalid auth type.');
50
+ }
51
+ yield authService.authenticateUser(user, Object.assign(Object.assign({}, authData), { userIdentifierField: defaultUserIdentifierField }));
52
+ delete user.password;
53
+ const userIdentifierValue = user[defaultUserIdentifierField];
54
+ const { result: { token: refreshToken } } = yield this.tokenManager.create({ type: tokenManager_1.TokenType.Refresh, [iam_users_definitions_1.UserTokenUserIdentifier.FieldName]: userIdentifierValue }, {
55
+ expiresInMinutes: refreshTokenExpiryTimeInMinutes,
56
+ identifierDataField: iam_users_definitions_1.UserTokenUserIdentifier.FieldName,
57
+ persist: true,
58
+ purgeOldFromPersistance: true
59
+ });
60
+ const { result: { token: accessToken } } = yield this.tokenManager.create({ refreshToken, type: tokenManager_1.TokenType.Access, [iam_users_definitions_1.UserTokenUserIdentifier.FieldName]: userIdentifierValue }, {
61
+ expiresInMinutes: rememberMe ? undefined : accessTokenExpiryTimeInMinutes,
62
+ identifierDataField: iam_users_definitions_1.UserTokenUserIdentifier.FieldName,
63
+ persist: true,
64
+ purgeOldFromPersistance: true
65
+ });
66
+ console.info(`[Domain.${moduleName}.Users]: Login attempt successful for email ${email}.`);
67
+ return { accessToken, refreshToken, user };
68
+ });
69
+ }
70
+ getUserWithPermissionsData(_options, _privateOptions) {
71
+ return __awaiter(this, void 0, void 0, function* () {
72
+ throw new core_1.ApplicationError(`Method ${this.moduleName}.IAMUsersService.getUserWithPermissionsData not implemented.`);
73
+ });
74
+ }
75
+ }
76
+ exports.IAMUsersService = IAMUsersService;
77
+ //# sourceMappingURL=iam.users.service.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"iam.users.service.js","sourceRoot":"","sources":["../../../src/services/users/iam.users.service.ts"],"names":[],"mappings":"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"}
@@ -0,0 +1,2 @@
1
+ export * from './iam.users.definitions';
2
+ export * from './iam.users.service';
@@ -0,0 +1,19 @@
1
+ "use strict";
2
+ var __createBinding = (this && this.__createBinding) || (Object.create ? (function(o, m, k, k2) {
3
+ if (k2 === undefined) k2 = k;
4
+ var desc = Object.getOwnPropertyDescriptor(m, k);
5
+ if (!desc || ("get" in desc ? !m.__esModule : desc.writable || desc.configurable)) {
6
+ desc = { enumerable: true, get: function() { return m[k]; } };
7
+ }
8
+ Object.defineProperty(o, k2, desc);
9
+ }) : (function(o, m, k, k2) {
10
+ if (k2 === undefined) k2 = k;
11
+ o[k2] = m[k];
12
+ }));
13
+ var __exportStar = (this && this.__exportStar) || function(m, exports) {
14
+ for (var p in m) if (p !== "default" && !Object.prototype.hasOwnProperty.call(exports, p)) __createBinding(exports, m, p);
15
+ };
16
+ Object.defineProperty(exports, "__esModule", { value: true });
17
+ __exportStar(require("./iam.users.definitions"), exports);
18
+ __exportStar(require("./iam.users.service"), exports);
19
+ //# sourceMappingURL=index.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"index.js","sourceRoot":"","sources":["../../../src/services/users/index.ts"],"names":[],"mappings":";;;;;;;;;;;;;;;;AAAA,0DAAwC;AACxC,sDAAoC"}
package/package.json ADDED
@@ -0,0 +1,25 @@
1
+ {
2
+ "name": "@node-c/domain-iam",
3
+ "version": "1.0.0-alpha3",
4
+ "license": "MIT",
5
+ "main": "dist/index.js",
6
+ "scripts": {
7
+ "build": "tsc -p tsconfig.build.json",
8
+ "check-types": "tsc -p tsconfig.build.json --noEmit",
9
+ "dev": "tsc -p tsconfig.build.json --watch",
10
+ "publish-package": "rm -rf dist/* && rm -f *.tsbuildinfo && npm run build && npm publish --access public",
11
+ "test": "vitest --config src/vitest.config.ts",
12
+ "test:coverage": "vitest --config src/vitest.config.ts --coverage"
13
+ },
14
+ "dependencies": {
15
+ "@nestjs/common": "^10.4.12",
16
+ "@node-c/core": "^1.0.0-alpha3",
17
+ "@ramster/general-tools": "^2.3.0",
18
+ "immutable": "^5.0.3",
19
+ "jsonwebtoken": "^9.0.2",
20
+ "ramda": "^0.30.1"
21
+ },
22
+ "devDependencies": {
23
+ "@types/jsonwebtoken": "^9.0.8"
24
+ }
25
+ }
@@ -0,0 +1,9 @@
1
+ {
2
+ "extends": "../../tsconfig.base.json",
3
+ "compilerOptions": {
4
+ "outDir": "dist",
5
+ "rootDir": "src"
6
+ },
7
+ "include": ["src"],
8
+ "exclude": ["node_modules", "dist", "src/**/*/*.spec.ts", "src/*.spec.ts", "src/vitest.config.ts"]
9
+ }
package/tsconfig.json ADDED
@@ -0,0 +1,9 @@
1
+ {
2
+ "extends": "../../tsconfig.base.json",
3
+ "compilerOptions": {
4
+ "outDir": "dist",
5
+ "rootDir": "src"
6
+ },
7
+ "include": ["src"],
8
+ "exclude": ["node_modules", "dist"]
9
+ }