@tomei/sso 0.60.4-dev.1 → 0.60.4-dev.11

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 (173) hide show
  1. package/.commitlintrc.json +22 -22
  2. package/.gitlab-ci.yml +16 -16
  3. package/.husky/commit-msg +9 -9
  4. package/.husky/pre-commit +7 -7
  5. package/.prettierrc +4 -4
  6. package/Jenkinsfile +57 -57
  7. package/README.md +23 -23
  8. package/__tests__/unit/components/group/group.spec.ts +79 -79
  9. package/__tests__/unit/components/group-object-privilege/group-object-privilege.spec.ts +88 -88
  10. package/__tests__/unit/components/group-privilege/group-privilege.spec.ts +68 -68
  11. package/__tests__/unit/components/group-reporting-user/group-reporting-user.spec.ts +66 -66
  12. package/__tests__/unit/components/group-system-access/group-system-access.spec.ts +83 -83
  13. package/__tests__/unit/components/login-user/l.spec.ts +746 -746
  14. package/__tests__/unit/components/login-user/login.spec.ts +1164 -1164
  15. package/__tests__/unit/components/password-hash/password-hash.service.spec.ts +31 -31
  16. package/__tests__/unit/components/system/system.spec.ts +254 -254
  17. package/__tests__/unit/components/system-privilege/system-privilege.spec.ts +83 -83
  18. package/__tests__/unit/components/user-group/user-group.spec.ts +86 -86
  19. package/__tests__/unit/components/user-object-privilege/user-object-privilege.spec.ts +78 -78
  20. package/__tests__/unit/components/user-privilege/user-privilege.spec.ts +72 -72
  21. package/__tests__/unit/components/user-system-access/user-system-access.spec.ts +89 -89
  22. package/__tests__/unit/redis-client/redis.service.spec.ts +23 -23
  23. package/__tests__/unit/session/session.service.spec.ts +47 -47
  24. package/__tests__/unit/system-privilege/system-privilage.spec.ts +91 -91
  25. package/coverage/clover.xml +1452 -1452
  26. package/coverage/coverage-final.json +47 -47
  27. package/coverage/lcov-report/base.css +224 -224
  28. package/coverage/lcov-report/block-navigation.js +87 -87
  29. package/coverage/lcov-report/components/group/group.repository.ts.html +117 -117
  30. package/coverage/lcov-report/components/group/group.ts.html +327 -327
  31. package/coverage/lcov-report/components/group/index.html +130 -130
  32. package/coverage/lcov-report/components/group-object-privilege/group-object-privilege.repository.ts.html +117 -117
  33. package/coverage/lcov-report/components/group-object-privilege/group-object-privilege.ts.html +321 -321
  34. package/coverage/lcov-report/components/group-object-privilege/index.html +130 -130
  35. package/coverage/lcov-report/components/group-privilege/group-privilege.repository.ts.html +117 -117
  36. package/coverage/lcov-report/components/group-privilege/group-privilege.ts.html +303 -303
  37. package/coverage/lcov-report/components/group-privilege/index.html +130 -130
  38. package/coverage/lcov-report/components/group-reporting-user/group-reporting-user.repository.ts.html +117 -117
  39. package/coverage/lcov-report/components/group-reporting-user/group-reporting-user.ts.html +327 -327
  40. package/coverage/lcov-report/components/group-reporting-user/index.html +130 -130
  41. package/coverage/lcov-report/components/group-system-access/group-system-access.repository.ts.html +117 -117
  42. package/coverage/lcov-report/components/group-system-access/group-system-access.ts.html +309 -309
  43. package/coverage/lcov-report/components/group-system-access/index.html +130 -130
  44. package/coverage/lcov-report/components/login-history/index.html +115 -115
  45. package/coverage/lcov-report/components/login-history/login-history.repository.ts.html +117 -117
  46. package/coverage/lcov-report/components/login-user/index.html +130 -130
  47. package/coverage/lcov-report/components/login-user/login-user.ts.html +5015 -5008
  48. package/coverage/lcov-report/components/login-user/user.repository.ts.html +117 -117
  49. package/coverage/lcov-report/components/password-hash/index.html +115 -115
  50. package/coverage/lcov-report/components/password-hash/password-hash.service.ts.html +126 -126
  51. package/coverage/lcov-report/components/system/index.html +130 -130
  52. package/coverage/lcov-report/components/system/system.repository.ts.html +117 -117
  53. package/coverage/lcov-report/components/system/system.ts.html +909 -909
  54. package/coverage/lcov-report/components/system-privilege/index.html +130 -130
  55. package/coverage/lcov-report/components/system-privilege/system-privilege.repository.ts.html +120 -120
  56. package/coverage/lcov-report/components/system-privilege/system-privilege.ts.html +390 -390
  57. package/coverage/lcov-report/components/user-group/index.html +130 -130
  58. package/coverage/lcov-report/components/user-group/user-group.repository.ts.html +117 -117
  59. package/coverage/lcov-report/components/user-group/user-group.ts.html +354 -354
  60. package/coverage/lcov-report/components/user-object-privilege/index.html +130 -130
  61. package/coverage/lcov-report/components/user-object-privilege/user-object-privilege.repository.ts.html +117 -117
  62. package/coverage/lcov-report/components/user-object-privilege/user-object-privilege.ts.html +312 -312
  63. package/coverage/lcov-report/components/user-privilege/index.html +130 -130
  64. package/coverage/lcov-report/components/user-privilege/user-privilege.repository.ts.html +117 -117
  65. package/coverage/lcov-report/components/user-privilege/user-privilege.ts.html +306 -306
  66. package/coverage/lcov-report/components/user-system-access/index.html +130 -130
  67. package/coverage/lcov-report/components/user-system-access/user-system-access.repository.ts.html +117 -117
  68. package/coverage/lcov-report/components/user-system-access/user-system-access.ts.html +312 -312
  69. package/coverage/lcov-report/enum/group-type.enum.ts.html +108 -108
  70. package/coverage/lcov-report/enum/index.html +160 -160
  71. package/coverage/lcov-report/enum/index.ts.html +93 -93
  72. package/coverage/lcov-report/enum/user-status.enum.ts.html +105 -105
  73. package/coverage/lcov-report/enum/yn.enum.ts.html +96 -96
  74. package/coverage/lcov-report/index.html +370 -370
  75. package/coverage/lcov-report/models/group-object-privilege.entity.ts.html +333 -333
  76. package/coverage/lcov-report/models/group-privilege.entity.ts.html +315 -315
  77. package/coverage/lcov-report/models/group-reporting-user.entity.ts.html +339 -339
  78. package/coverage/lcov-report/models/group-system-access.entity.ts.html +324 -324
  79. package/coverage/lcov-report/models/group.entity.ts.html +435 -435
  80. package/coverage/lcov-report/models/index.html +310 -310
  81. package/coverage/lcov-report/models/login-history.entity.ts.html +252 -252
  82. package/coverage/lcov-report/models/staff.entity.ts.html +411 -411
  83. package/coverage/lcov-report/models/system-privilege.entity.ts.html +354 -354
  84. package/coverage/lcov-report/models/system.entity.ts.html +423 -423
  85. package/coverage/lcov-report/models/user-group.entity.ts.html +354 -354
  86. package/coverage/lcov-report/models/user-object-privilege.entity.ts.html +330 -330
  87. package/coverage/lcov-report/models/user-privilege.entity.ts.html +315 -315
  88. package/coverage/lcov-report/models/user-system-access.entity.ts.html +315 -315
  89. package/coverage/lcov-report/models/user.entity.ts.html +522 -522
  90. package/coverage/lcov-report/prettify.css +1 -1
  91. package/coverage/lcov-report/prettify.js +2 -2
  92. package/coverage/lcov-report/redis-client/index.html +115 -115
  93. package/coverage/lcov-report/redis-client/redis.service.ts.html +240 -240
  94. package/coverage/lcov-report/session/index.html +115 -115
  95. package/coverage/lcov-report/session/session.service.ts.html +246 -246
  96. package/coverage/lcov-report/sorter.js +196 -196
  97. package/coverage/lcov.info +2490 -2490
  98. package/coverage/test-report.xml +128 -128
  99. package/create-sso-user.sql +39 -39
  100. package/dist/__tests__/unit/components/group-privilege/group-privilege.test.d.ts +1 -0
  101. package/dist/__tests__/unit/components/group-privilege/group-privilege.test.js +71 -0
  102. package/dist/__tests__/unit/components/group-privilege/group-privilege.test.js.map +1 -0
  103. package/dist/__tests__/unit/components/login-user/login-user.spec.d.ts +0 -0
  104. package/dist/__tests__/unit/components/login-user/login-user.spec.js +6 -0
  105. package/dist/__tests__/unit/components/login-user/login-user.spec.js.map +1 -0
  106. package/dist/src/components/login-history/index.d.ts +1 -0
  107. package/dist/src/components/login-history/index.js +1 -0
  108. package/dist/src/components/login-history/index.js.map +1 -1
  109. package/dist/src/components/login-history/login-history.d.ts +23 -0
  110. package/dist/src/components/login-history/login-history.js +88 -0
  111. package/dist/src/components/login-history/login-history.js.map +1 -0
  112. package/dist/src/components/login-history/login-history.repository.d.ts +2 -2
  113. package/dist/src/components/login-history/login-history.repository.js.map +1 -1
  114. package/dist/src/components/login-user/interfaces/user-info.interface.d.ts +1 -0
  115. package/dist/src/components/login-user/login-user.js +1 -0
  116. package/dist/src/components/login-user/login-user.js.map +1 -1
  117. package/dist/src/components/login-user/user.d.ts +28 -3
  118. package/dist/src/components/login-user/user.js +357 -14
  119. package/dist/src/components/login-user/user.js.map +1 -1
  120. package/dist/src/components/user-system-access/user-system-access.js +1 -1
  121. package/dist/src/components/user-system-access/user-system-access.js.map +1 -1
  122. package/dist/src/interfaces/login-history-search-attr.interface.d.ts +8 -0
  123. package/dist/src/interfaces/login-history-search-attr.interface.js +3 -0
  124. package/dist/src/interfaces/login-history-search-attr.interface.js.map +1 -0
  125. package/dist/src/interfaces/login-history.interface.d.ts +11 -0
  126. package/dist/src/interfaces/login-history.interface.js +3 -0
  127. package/dist/src/interfaces/login-history.interface.js.map +1 -0
  128. package/dist/src/models/login-history.entity.d.ts +2 -2
  129. package/dist/src/models/login-history.entity.js +13 -13
  130. package/dist/src/models/login-history.entity.js.map +1 -1
  131. package/dist/src/models/user.entity.d.ts +1 -0
  132. package/dist/src/models/user.entity.js +8 -0
  133. package/dist/src/models/user.entity.js.map +1 -1
  134. package/dist/tsconfig.tsbuildinfo +1 -1
  135. package/eslint.config.mjs +58 -58
  136. package/jest.config.js +14 -14
  137. package/migrations/20240314080602-create-user-table.js +124 -124
  138. package/migrations/20240314080603-create-user-group-table.js +85 -85
  139. package/migrations/20240314080604-create-user-user-group-table.js +55 -55
  140. package/migrations/20240314080605-create-login-history-table.js +53 -53
  141. package/migrations/20240527064925-create-system-table.js +78 -78
  142. package/migrations/20240527064926-create-system-privilege-table.js +71 -71
  143. package/migrations/20240527065342-create-group-table.js +93 -93
  144. package/migrations/20240527065633-create-group-reporting-user-table.js +76 -76
  145. package/migrations/20240528011551-create-group-system-access-table.js +72 -72
  146. package/migrations/20240528023018-user-system-access-table.js +75 -75
  147. package/migrations/20240528032229-user-privilege-table.js +76 -76
  148. package/migrations/20240528063003-create-group-privilege-table.js +76 -76
  149. package/migrations/20240528063051-create-group-object-privilege-table.js +84 -84
  150. package/migrations/20240528063107-create-user-object-privilege-table.js +84 -84
  151. package/migrations/20240528063108-create-api-key-table.js +85 -85
  152. package/migrations/20241104104802-create-building-table.js +95 -95
  153. package/migrations/20250108091132-add-area-manager-user-id-to-building-table.js +14 -14
  154. package/migrations/20250108091133-add-passcode-to-user-table.js +36 -36
  155. package/migrations/20250210115636-create-user-reporting-hierarchy.js +76 -76
  156. package/migrations/20250326043818-crate-user-password-history.js +42 -42
  157. package/migrations/20250610070720-added-MFBypassYN-to-sso-user.js +30 -0
  158. package/package.json +90 -90
  159. package/sampledotenv +7 -7
  160. package/src/components/login-history/index.ts +1 -0
  161. package/src/components/login-history/login-history.repository.ts +4 -4
  162. package/src/components/login-history/login-history.ts +124 -0
  163. package/src/components/login-user/interfaces/user-info.interface.ts +1 -0
  164. package/src/components/login-user/login-user.ts +1 -0
  165. package/src/components/login-user/user.ts +435 -16
  166. package/src/components/user-system-access/user-system-access.ts +1 -1
  167. package/src/interfaces/login-history-search-attr.interface.ts +8 -0
  168. package/src/interfaces/login-history.interface.ts +11 -0
  169. package/src/models/login-history.entity.ts +2 -2
  170. package/src/models/user.entity.ts +7 -0
  171. package/tsconfig.build.json +5 -5
  172. package/tsconfig.json +23 -23
  173. package/sonar-project.properties +0 -23
@@ -1,90 +1,90 @@
1
- import { UserSystemAccess } from '../../../../src/components/user-system-access/user-system-access';
2
- import { UserSystemAccessRepository } from '../../../../src/components/user-system-access/user-system-access.repository';
3
- import { ClassError } from '@tomei/general';
4
-
5
- describe('UserSystemAccess', () => {
6
- let userSystemAccess: UserSystemAccess;
7
- const userSystemAccessAttr = {
8
- UserSystemAccessId: 1,
9
- UserId: 1,
10
- SystemCode: 'system1',
11
- Status: 'active',
12
- CreatedById: 1,
13
- CreatedAt: new Date(),
14
- UpdatedById: 1,
15
- UpdatedAt: new Date(),
16
- };
17
-
18
- beforeEach(() => {
19
- userSystemAccess = new (UserSystemAccess as any)(userSystemAccessAttr);
20
- });
21
-
22
- afterEach(() => {
23
- jest.clearAllMocks();
24
- });
25
-
26
- describe('constructor', () => {
27
- it('should create a new UserSystemAccess instance', () => {
28
- expect(userSystemAccess).toBeDefined();
29
- expect(userSystemAccess).toBeInstanceOf(UserSystemAccess);
30
- expect(userSystemAccess.UserSystemAccessId).toBe(
31
- userSystemAccessAttr.UserSystemAccessId
32
- );
33
- expect(userSystemAccess.UserId).toBe(userSystemAccessAttr.UserId);
34
- expect(userSystemAccess.SystemCode).toBe(userSystemAccessAttr.SystemCode);
35
- expect(userSystemAccess.Status).toBe(userSystemAccessAttr.Status);
36
- expect(userSystemAccess.CreatedById).toBe(
37
- userSystemAccessAttr.CreatedById
38
- );
39
- expect(userSystemAccess.CreatedAt).toBe(userSystemAccessAttr.CreatedAt);
40
- expect(userSystemAccess.UpdatedById).toBe(
41
- userSystemAccessAttr.UpdatedById
42
- );
43
- expect(userSystemAccess.UpdatedAt).toBe(userSystemAccessAttr.UpdatedAt);
44
- });
45
- });
46
-
47
- describe('init', () => {
48
- it('should initialize UserSystemAccess with valid UserSystemAccessId', async () => {
49
- const findOneMock = jest
50
- .spyOn(UserSystemAccessRepository.prototype, 'findOne')
51
- .mockResolvedValueOnce({
52
- ...userSystemAccessAttr,
53
- get: () => userSystemAccessAttr,
54
- } as any);
55
-
56
- const result = await UserSystemAccess.init(null, 1);
57
-
58
- expect(findOneMock).toHaveBeenCalledTimes(1);
59
- expect(findOneMock).toHaveBeenCalledWith({
60
- where: { UserSystemAccessId: 1 },
61
- transaction: null,
62
- });
63
- expect(result).toBeInstanceOf(UserSystemAccess);
64
- expect(result.UserSystemAccessId).toBe(
65
- userSystemAccessAttr.UserSystemAccessId
66
- );
67
- expect(result.UserId).toBe(userSystemAccessAttr.UserId);
68
- expect(result.SystemCode).toBe(userSystemAccessAttr.SystemCode);
69
- expect(result.Status).toBe(userSystemAccessAttr.Status);
70
- expect(result.CreatedById).toBe(userSystemAccessAttr.CreatedById);
71
- expect(result.CreatedAt).toBe(userSystemAccessAttr.CreatedAt);
72
- expect(result.UpdatedById).toBe(userSystemAccessAttr.UpdatedById);
73
- expect(result.UpdatedAt).toBe(userSystemAccessAttr.UpdatedAt);
74
- });
75
-
76
- it('should throw ClassError when UserSystemAccessId is not found', async () => {
77
- jest
78
- .spyOn(UserSystemAccessRepository.prototype, 'findOne')
79
- .mockResolvedValueOnce(null);
80
-
81
- try {
82
- await UserSystemAccess.init(null, 1)
83
- expect(false).toBe(true);
84
- } catch (error) {
85
- expect(error).toBeInstanceOf(ClassError);
86
- expect(error.message).toBe('UserSystemAccess not found');
87
- }
88
- });
89
- });
1
+ import { UserSystemAccess } from '../../../../src/components/user-system-access/user-system-access';
2
+ import { UserSystemAccessRepository } from '../../../../src/components/user-system-access/user-system-access.repository';
3
+ import { ClassError } from '@tomei/general';
4
+
5
+ describe('UserSystemAccess', () => {
6
+ let userSystemAccess: UserSystemAccess;
7
+ const userSystemAccessAttr = {
8
+ UserSystemAccessId: 1,
9
+ UserId: 1,
10
+ SystemCode: 'system1',
11
+ Status: 'active',
12
+ CreatedById: 1,
13
+ CreatedAt: new Date(),
14
+ UpdatedById: 1,
15
+ UpdatedAt: new Date(),
16
+ };
17
+
18
+ beforeEach(() => {
19
+ userSystemAccess = new (UserSystemAccess as any)(userSystemAccessAttr);
20
+ });
21
+
22
+ afterEach(() => {
23
+ jest.clearAllMocks();
24
+ });
25
+
26
+ describe('constructor', () => {
27
+ it('should create a new UserSystemAccess instance', () => {
28
+ expect(userSystemAccess).toBeDefined();
29
+ expect(userSystemAccess).toBeInstanceOf(UserSystemAccess);
30
+ expect(userSystemAccess.UserSystemAccessId).toBe(
31
+ userSystemAccessAttr.UserSystemAccessId
32
+ );
33
+ expect(userSystemAccess.UserId).toBe(userSystemAccessAttr.UserId);
34
+ expect(userSystemAccess.SystemCode).toBe(userSystemAccessAttr.SystemCode);
35
+ expect(userSystemAccess.Status).toBe(userSystemAccessAttr.Status);
36
+ expect(userSystemAccess.CreatedById).toBe(
37
+ userSystemAccessAttr.CreatedById
38
+ );
39
+ expect(userSystemAccess.CreatedAt).toBe(userSystemAccessAttr.CreatedAt);
40
+ expect(userSystemAccess.UpdatedById).toBe(
41
+ userSystemAccessAttr.UpdatedById
42
+ );
43
+ expect(userSystemAccess.UpdatedAt).toBe(userSystemAccessAttr.UpdatedAt);
44
+ });
45
+ });
46
+
47
+ describe('init', () => {
48
+ it('should initialize UserSystemAccess with valid UserSystemAccessId', async () => {
49
+ const findOneMock = jest
50
+ .spyOn(UserSystemAccessRepository.prototype, 'findOne')
51
+ .mockResolvedValueOnce({
52
+ ...userSystemAccessAttr,
53
+ get: () => userSystemAccessAttr,
54
+ } as any);
55
+
56
+ const result = await UserSystemAccess.init(null, 1);
57
+
58
+ expect(findOneMock).toHaveBeenCalledTimes(1);
59
+ expect(findOneMock).toHaveBeenCalledWith({
60
+ where: { UserSystemAccessId: 1 },
61
+ transaction: null,
62
+ });
63
+ expect(result).toBeInstanceOf(UserSystemAccess);
64
+ expect(result.UserSystemAccessId).toBe(
65
+ userSystemAccessAttr.UserSystemAccessId
66
+ );
67
+ expect(result.UserId).toBe(userSystemAccessAttr.UserId);
68
+ expect(result.SystemCode).toBe(userSystemAccessAttr.SystemCode);
69
+ expect(result.Status).toBe(userSystemAccessAttr.Status);
70
+ expect(result.CreatedById).toBe(userSystemAccessAttr.CreatedById);
71
+ expect(result.CreatedAt).toBe(userSystemAccessAttr.CreatedAt);
72
+ expect(result.UpdatedById).toBe(userSystemAccessAttr.UpdatedById);
73
+ expect(result.UpdatedAt).toBe(userSystemAccessAttr.UpdatedAt);
74
+ });
75
+
76
+ it('should throw ClassError when UserSystemAccessId is not found', async () => {
77
+ jest
78
+ .spyOn(UserSystemAccessRepository.prototype, 'findOne')
79
+ .mockResolvedValueOnce(null);
80
+
81
+ try {
82
+ await UserSystemAccess.init(null, 1)
83
+ expect(false).toBe(true);
84
+ } catch (error) {
85
+ expect(error).toBeInstanceOf(ClassError);
86
+ expect(error.message).toBe('UserSystemAccess not found');
87
+ }
88
+ });
89
+ });
90
90
  });
@@ -1,24 +1,24 @@
1
- import { RedisService } from "../../../src/redis-client/redis.service";
2
- require('dotenv').config()
3
- // nneed to figure out how to mock redis
4
- describe('redis.service', () => {
5
-
6
- afterEach(() => {
7
- jest.restoreAllMocks()
8
- })
9
-
10
- it('should return redis service when instansiated', async () => {
11
- const redisService = await RedisService.init();
12
- expect(redisService).toBeDefined();
13
- });
14
-
15
- it('should able to write and read redis', async () => {
16
- const data = {
17
- test: 'test'
18
- }
19
- const redisService = await RedisService.init();
20
- await redisService.set("test", data, 60 * 60 * 24 * 1)
21
- const result = await redisService.get("test");
22
- expect(result).toEqual(JSON.stringify(data));
23
- });
1
+ import { RedisService } from "../../../src/redis-client/redis.service";
2
+ require('dotenv').config()
3
+ // nneed to figure out how to mock redis
4
+ describe('redis.service', () => {
5
+
6
+ afterEach(() => {
7
+ jest.restoreAllMocks()
8
+ })
9
+
10
+ it('should return redis service when instansiated', async () => {
11
+ const redisService = await RedisService.init();
12
+ expect(redisService).toBeDefined();
13
+ });
14
+
15
+ it('should able to write and read redis', async () => {
16
+ const data = {
17
+ test: 'test'
18
+ }
19
+ const redisService = await RedisService.init();
20
+ await redisService.set("test", data, 60 * 60 * 24 * 1)
21
+ const result = await redisService.get("test");
22
+ expect(result).toEqual(JSON.stringify(data));
23
+ });
24
24
  });
@@ -1,47 +1,47 @@
1
- import { IUserSession } from '../../../src/interfaces/user-session.interface';
2
- import { SessionService } from '../../../src/session/session.service';
3
- require('dotenv').config()
4
-
5
- describe('session.service', () => {
6
- it('should return session service when instansiated', async () => {
7
- const sessionService = await SessionService.init();
8
- expect(sessionService).toBeDefined();
9
- });
10
-
11
- it('should able to write session data', async () => {
12
- const data: IUserSession = {
13
- systemLogins: [
14
- {
15
- id: '1',
16
- code: 'EZC',
17
- sessionId: 'test1',
18
- privileges: ['PRIVILEGE1', 'PRIVILEGE2'],
19
- },
20
- ],
21
- };
22
- const sessionService = await SessionService.init();
23
- await sessionService.setUserSession("1", data)
24
- const result = await sessionService.retrieveUserSession("1");
25
- expect(result).toEqual(data);
26
- });
27
-
28
- it('should able to refresh session data', async () => {
29
- const setUserSession = jest.spyOn(SessionService.prototype, 'setUserSession');
30
- const retrieveUserSession = jest.spyOn(SessionService.prototype, 'retrieveUserSession');
31
- const data: IUserSession = {
32
- systemLogins: [
33
- {
34
- id: '1',
35
- code: 'EZC',
36
- sessionId: 'test1',
37
- privileges: ['PRIVILEGE1', 'PRIVILEGE2'],
38
- },
39
- ],
40
- };
41
- const sessionService = await SessionService.init();
42
- await sessionService.setUserSession("1", data)
43
- await sessionService.refreshDuration("1");
44
- expect(setUserSession).toBeCalledTimes(2);
45
- expect(retrieveUserSession).toBeCalledTimes(1);
46
- });
47
- });
1
+ import { IUserSession } from '../../../src/interfaces/user-session.interface';
2
+ import { SessionService } from '../../../src/session/session.service';
3
+ require('dotenv').config()
4
+
5
+ describe('session.service', () => {
6
+ it('should return session service when instansiated', async () => {
7
+ const sessionService = await SessionService.init();
8
+ expect(sessionService).toBeDefined();
9
+ });
10
+
11
+ it('should able to write session data', async () => {
12
+ const data: IUserSession = {
13
+ systemLogins: [
14
+ {
15
+ id: '1',
16
+ code: 'EZC',
17
+ sessionId: 'test1',
18
+ privileges: ['PRIVILEGE1', 'PRIVILEGE2'],
19
+ },
20
+ ],
21
+ };
22
+ const sessionService = await SessionService.init();
23
+ await sessionService.setUserSession("1", data)
24
+ const result = await sessionService.retrieveUserSession("1");
25
+ expect(result).toEqual(data);
26
+ });
27
+
28
+ it('should able to refresh session data', async () => {
29
+ const setUserSession = jest.spyOn(SessionService.prototype, 'setUserSession');
30
+ const retrieveUserSession = jest.spyOn(SessionService.prototype, 'retrieveUserSession');
31
+ const data: IUserSession = {
32
+ systemLogins: [
33
+ {
34
+ id: '1',
35
+ code: 'EZC',
36
+ sessionId: 'test1',
37
+ privileges: ['PRIVILEGE1', 'PRIVILEGE2'],
38
+ },
39
+ ],
40
+ };
41
+ const sessionService = await SessionService.init();
42
+ await sessionService.setUserSession("1", data)
43
+ await sessionService.refreshDuration("1");
44
+ expect(setUserSession).toBeCalledTimes(2);
45
+ expect(retrieveUserSession).toBeCalledTimes(1);
46
+ });
47
+ });
@@ -1,91 +1,91 @@
1
- // import { Privilege } from '../../../src/components/system-privilege/privilege';
2
- // import { SystemPrivilegeRepository } from '../../../src/components/system-privilege/system-privilege.repository';
3
- // import { SystemRepository } from '../../../src/components/system/system.repository';
4
- // describe('SystemPrivilege', () => {
5
- // afterEach(async () => {
6
- // jest.restoreAllMocks();
7
- // });
8
- // it('should be able to load single package privileges', async () => {
9
- // let privilegeCalled = 0;
10
- // const findOrCreateMock = jest
11
- // .spyOn(SystemPrivilegeRepository.prototype, 'findOrCreate')
12
- // .mockResolvedValueOnce([{}, true] as any);
13
-
14
- // const systemRepositoryMock = jest
15
- // .spyOn(SystemRepository.prototype, 'findOne')
16
- // .mockResolvedValueOnce({
17
- // id: 175,
18
- // } as any);
19
-
20
- // jest.mock('@tomei/mailer/privileges.json', () => {
21
- // privilegeCalled++;
22
- // return {
23
- // Privileges: [
24
- // {
25
- // Code: 'Privilege1',
26
- // Description: 'This is Privilege1',
27
- // },
28
- // ],
29
- // };
30
- // });
31
-
32
- // await Privilege.loadPrivileges('mailer', 'EZC');
33
- // expect(findOrCreateMock).toBeCalledTimes(1);
34
- // expect(systemRepositoryMock).toBeCalledTimes(1);
35
- // expect(privilegeCalled).toEqual(1);
36
- // });
37
-
38
- // it('should be able to load multiple package privileges', async () => {
39
- // let privilegeCalled = 0;
40
- // const findOrCreateMock = jest
41
- // .spyOn(SystemPrivilegeRepository.prototype, 'findOrCreate')
42
- // .mockResolvedValueOnce([{}, true] as any);
43
-
44
- // const systemRepositoryMock = jest
45
- // .spyOn(SystemRepository.prototype, 'findOne')
46
- // .mockResolvedValueOnce({
47
- // id: 175,
48
- // } as any);
49
-
50
- // jest.mock(
51
- // '@tomei/mailer/privileges.json',
52
- // () => {
53
- // privilegeCalled++;
54
- // return {
55
- // Privileges: [
56
- // {
57
- // Code: 'Privilege1',
58
- // Description: 'This is Privilege1',
59
- // },
60
- // ],
61
- // };
62
- // },
63
- // );
64
-
65
- // jest.mock(
66
- // '@tomei/config/privileges.json',
67
- // () => {
68
- // privilegeCalled++;
69
- // return {
70
- // Privileges: [
71
- // {
72
- // Code: 'Privilege2',
73
- // Description: 'This is Privilege2',
74
- // },
75
- // ],
76
- // };
77
- // },
78
- // );
79
-
80
- // await Privilege.loadPrivileges(['mailer', 'config'], 'EZC');
81
- // expect(findOrCreateMock).toBeCalledTimes(2);
82
- // expect(systemRepositoryMock).toBeCalledTimes(1);
83
- // expect(privilegeCalled).toEqual(2);
84
- // });
85
- // });
86
-
87
- describe('SystemPrivilege', () => {
88
- it('should be true', () => {
89
- expect(true).toBe(true);
90
- });
91
- });
1
+ // import { Privilege } from '../../../src/components/system-privilege/privilege';
2
+ // import { SystemPrivilegeRepository } from '../../../src/components/system-privilege/system-privilege.repository';
3
+ // import { SystemRepository } from '../../../src/components/system/system.repository';
4
+ // describe('SystemPrivilege', () => {
5
+ // afterEach(async () => {
6
+ // jest.restoreAllMocks();
7
+ // });
8
+ // it('should be able to load single package privileges', async () => {
9
+ // let privilegeCalled = 0;
10
+ // const findOrCreateMock = jest
11
+ // .spyOn(SystemPrivilegeRepository.prototype, 'findOrCreate')
12
+ // .mockResolvedValueOnce([{}, true] as any);
13
+
14
+ // const systemRepositoryMock = jest
15
+ // .spyOn(SystemRepository.prototype, 'findOne')
16
+ // .mockResolvedValueOnce({
17
+ // id: 175,
18
+ // } as any);
19
+
20
+ // jest.mock('@tomei/mailer/privileges.json', () => {
21
+ // privilegeCalled++;
22
+ // return {
23
+ // Privileges: [
24
+ // {
25
+ // Code: 'Privilege1',
26
+ // Description: 'This is Privilege1',
27
+ // },
28
+ // ],
29
+ // };
30
+ // });
31
+
32
+ // await Privilege.loadPrivileges('mailer', 'EZC');
33
+ // expect(findOrCreateMock).toBeCalledTimes(1);
34
+ // expect(systemRepositoryMock).toBeCalledTimes(1);
35
+ // expect(privilegeCalled).toEqual(1);
36
+ // });
37
+
38
+ // it('should be able to load multiple package privileges', async () => {
39
+ // let privilegeCalled = 0;
40
+ // const findOrCreateMock = jest
41
+ // .spyOn(SystemPrivilegeRepository.prototype, 'findOrCreate')
42
+ // .mockResolvedValueOnce([{}, true] as any);
43
+
44
+ // const systemRepositoryMock = jest
45
+ // .spyOn(SystemRepository.prototype, 'findOne')
46
+ // .mockResolvedValueOnce({
47
+ // id: 175,
48
+ // } as any);
49
+
50
+ // jest.mock(
51
+ // '@tomei/mailer/privileges.json',
52
+ // () => {
53
+ // privilegeCalled++;
54
+ // return {
55
+ // Privileges: [
56
+ // {
57
+ // Code: 'Privilege1',
58
+ // Description: 'This is Privilege1',
59
+ // },
60
+ // ],
61
+ // };
62
+ // },
63
+ // );
64
+
65
+ // jest.mock(
66
+ // '@tomei/config/privileges.json',
67
+ // () => {
68
+ // privilegeCalled++;
69
+ // return {
70
+ // Privileges: [
71
+ // {
72
+ // Code: 'Privilege2',
73
+ // Description: 'This is Privilege2',
74
+ // },
75
+ // ],
76
+ // };
77
+ // },
78
+ // );
79
+
80
+ // await Privilege.loadPrivileges(['mailer', 'config'], 'EZC');
81
+ // expect(findOrCreateMock).toBeCalledTimes(2);
82
+ // expect(systemRepositoryMock).toBeCalledTimes(1);
83
+ // expect(privilegeCalled).toEqual(2);
84
+ // });
85
+ // });
86
+
87
+ describe('SystemPrivilege', () => {
88
+ it('should be true', () => {
89
+ expect(true).toBe(true);
90
+ });
91
+ });