@node-c/domain-iam 1.0.0-alpha10

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 +70 -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 +18 -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 +35 -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 +203 -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 +30 -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 +16 -0
  64. package/dist/services/users/iam.users.service.js +93 -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 @@
1
+ {"version":3,"file":"iam.users.definitions.js","sourceRoot":"","sources":["../../../src/services/users/iam.users.definitions.ts"],"names":[],"mappings":";;;AAkCA,IAAY,uBAGX;AAHD,WAAY,uBAAuB;IAEjC,+CAAoB,CAAA;AACtB,CAAC,EAHW,uBAAuB,uCAAvB,uBAAuB,QAGlC"}
@@ -0,0 +1,16 @@
1
+ import { ConfigProviderService, DomainEntityService, DomainEntityServiceDefaultData, PersistanceEntityService, PersistanceFindOneOptions } from '@node-c/core';
2
+ import { CreateAccessTokenOptions, CreateAccessTokenReturnData, GetUserWithPermissionsDataOptions, UserTokenEnityFields, UserWithPermissionsData } from './iam.users.definitions';
3
+ import { IAMAuthenticationService, UserAuthType } from '../authentication';
4
+ import { IAMTokenManagerService } from '../tokenManager';
5
+ export declare class IAMUsersService<User extends object, Data extends DomainEntityServiceDefaultData<Partial<User>> = DomainEntityServiceDefaultData<Partial<User>>> extends DomainEntityService<User, PersistanceEntityService<User>, Data, Record<string, PersistanceEntityService<Partial<User>>> | undefined> {
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
+ protected defaultMethods: string[];
12
+ protected additionalPersistanceEntityServices?: Record<string, PersistanceEntityService<Partial<User>>> | undefined;
13
+ constructor(configProvider: ConfigProviderService, moduleName: string, persistanceUsersService: PersistanceEntityService<User>, tokenManager: IAMTokenManagerService<UserTokenEnityFields>, userAuthServices: Record<UserAuthType, IAMAuthenticationService<User>>, defaultMethods?: string[], additionalPersistanceEntityServices?: Record<string, PersistanceEntityService<Partial<User>>> | undefined);
14
+ createAccessToken(options: CreateAccessTokenOptions): Promise<CreateAccessTokenReturnData<User>>;
15
+ getUserWithPermissionsData(_options: PersistanceFindOneOptions, _privateOptions?: GetUserWithPermissionsDataOptions): Promise<UserWithPermissionsData<User, unknown> | null>;
16
+ }
@@ -0,0 +1,93 @@
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, defaultMethods = [
29
+ core_1.DomainMethod.BulkCreate,
30
+ core_1.DomainMethod.Create,
31
+ core_1.DomainMethod.Delete,
32
+ core_1.DomainMethod.Find,
33
+ core_1.DomainMethod.FindOne,
34
+ core_1.DomainMethod.Update
35
+ ], additionalPersistanceEntityServices) {
36
+ super(persistanceUsersService, defaultMethods, additionalPersistanceEntityServices);
37
+ this.configProvider = configProvider;
38
+ this.moduleName = moduleName;
39
+ this.persistanceUsersService = persistanceUsersService;
40
+ this.tokenManager = tokenManager;
41
+ this.userAuthServices = userAuthServices;
42
+ this.defaultMethods = defaultMethods;
43
+ this.additionalPersistanceEntityServices = additionalPersistanceEntityServices;
44
+ }
45
+ createAccessToken(options) {
46
+ return __awaiter(this, void 0, void 0, function* () {
47
+ const { configProvider, moduleName } = this;
48
+ const { accessTokenExpiryTimeInMinutes, defaultUserIdentifierField, refreshTokenExpiryTimeInMinutes } = configProvider.config.domain[moduleName];
49
+ const _a = options.auth, { type: authType } = _a, authData = __rest(_a, ["type"]), { filters, mainFilterField, rememberUser } = options;
50
+ const mainFilterValue = filters[mainFilterField];
51
+ console.info(`[Domain.${moduleName}.Users]: Login attempt for ${mainFilterField} ${mainFilterValue}...`);
52
+ if (!Object.keys(filters).length) {
53
+ console.info(`[Domain.${moduleName}.Users]: No filters provided.`);
54
+ throw new core_1.ApplicationError('Invalid user identifier or password.');
55
+ }
56
+ const user = yield this.getUserWithPermissionsData({ filters }, { keepPassword: true });
57
+ if (!user) {
58
+ console.info(`[Domain.${moduleName}.Users]: Login attempt failed for ${mainFilterField} ${mainFilterValue} - user not found.`);
59
+ throw new core_1.ApplicationError('Invalid user identifier or password.');
60
+ }
61
+ const authService = this.userAuthServices[authType];
62
+ if (!authService) {
63
+ throw new core_1.ApplicationError('Invalid auth type.');
64
+ }
65
+ yield authService.authenticateUser(user, Object.assign(Object.assign({}, authData), { userIdentifierField: defaultUserIdentifierField }));
66
+ if ('password' in user) {
67
+ delete user.password;
68
+ }
69
+ const userIdentifierValue = user[defaultUserIdentifierField];
70
+ const { result: { token: refreshToken } } = yield this.tokenManager.create({ type: tokenManager_1.TokenType.Refresh, [iam_users_definitions_1.UserTokenUserIdentifier.FieldName]: userIdentifierValue }, {
71
+ expiresInMinutes: rememberUser ? undefined : refreshTokenExpiryTimeInMinutes,
72
+ identifierDataField: iam_users_definitions_1.UserTokenUserIdentifier.FieldName,
73
+ persist: true,
74
+ purgeOldFromPersistance: true
75
+ });
76
+ const { result: { token: accessToken } } = yield this.tokenManager.create({ refreshToken, type: tokenManager_1.TokenType.Access, [iam_users_definitions_1.UserTokenUserIdentifier.FieldName]: userIdentifierValue }, {
77
+ expiresInMinutes: accessTokenExpiryTimeInMinutes,
78
+ identifierDataField: iam_users_definitions_1.UserTokenUserIdentifier.FieldName,
79
+ persist: true,
80
+ purgeOldFromPersistance: true
81
+ });
82
+ console.info(`[Domain.${moduleName}.Users]: Login attempt successful for ${mainFilterField} ${mainFilterValue}.`);
83
+ return { accessToken, refreshToken, user };
84
+ });
85
+ }
86
+ getUserWithPermissionsData(_options, _privateOptions) {
87
+ return __awaiter(this, void 0, void 0, function* () {
88
+ throw new core_1.ApplicationError(`Method ${this.moduleName}.IAMUsersService.getUserWithPermissionsData not implemented.`);
89
+ });
90
+ }
91
+ }
92
+ exports.IAMUsersService = IAMUsersService;
93
+ //# 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-alpha10",
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-alpha10",
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
+ }