@tomei/sso 0.60.4 → 0.61.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.
Files changed (677) hide show
  1. package/.commitlintrc.json +22 -22
  2. package/.gitlab-ci.yml +16 -16
  3. package/.husky/commit-msg +15 -15
  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 +5007 -5007
  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/src/components/login-user/user.js +8 -0
  101. package/dist/src/components/login-user/user.js.map +1 -1
  102. package/dist/tsconfig.tsbuildinfo +1 -1
  103. package/eslint.config.mjs +58 -58
  104. package/jest.config.js +14 -14
  105. package/migrations/20240314080602-create-user-table.js +124 -124
  106. package/migrations/20240314080603-create-user-group-table.js +85 -85
  107. package/migrations/20240314080604-create-user-user-group-table.js +55 -55
  108. package/migrations/20240314080605-create-login-history-table.js +53 -53
  109. package/migrations/20240527064925-create-system-table.js +78 -78
  110. package/migrations/20240527064926-create-system-privilege-table.js +71 -71
  111. package/migrations/20240527065342-create-group-table.js +93 -93
  112. package/migrations/20240527065633-create-group-reporting-user-table.js +76 -76
  113. package/migrations/20240528011551-create-group-system-access-table.js +72 -72
  114. package/migrations/20240528023018-user-system-access-table.js +75 -75
  115. package/migrations/20240528032229-user-privilege-table.js +76 -76
  116. package/migrations/20240528063003-create-group-privilege-table.js +76 -76
  117. package/migrations/20240528063051-create-group-object-privilege-table.js +84 -84
  118. package/migrations/20240528063107-create-user-object-privilege-table.js +84 -84
  119. package/migrations/20240528063108-create-api-key-table.js +85 -85
  120. package/migrations/20241104104802-create-building-table.js +95 -95
  121. package/migrations/20250108091132-add-area-manager-user-id-to-building-table.js +14 -14
  122. package/migrations/20250108091133-add-passcode-to-user-table.js +36 -36
  123. package/migrations/20250210115636-create-user-reporting-hierarchy.js +76 -76
  124. package/migrations/20250326043818-crate-user-password-history.js +42 -42
  125. package/package.json +90 -90
  126. package/sampledotenv +7 -7
  127. package/sonar-project.properties +22 -22
  128. package/src/components/api-key/api-key.repository.ts +15 -15
  129. package/src/components/api-key/api-key.ts +448 -448
  130. package/src/components/api-key/index.ts +4 -4
  131. package/src/components/building/building.repository.ts +27 -27
  132. package/src/components/building/index.ts +2 -2
  133. package/src/components/group/group.repository.ts +26 -26
  134. package/src/components/group/group.ts +2284 -2284
  135. package/src/components/group/index.ts +3 -3
  136. package/src/components/group-object-privilege/group-object-privilege.repository.ts +25 -25
  137. package/src/components/group-object-privilege/group-object-privilege.ts +278 -278
  138. package/src/components/group-object-privilege/index.ts +2 -2
  139. package/src/components/group-privilege/group-privilege.repository.ts +29 -29
  140. package/src/components/group-privilege/group-privilege.ts +84 -84
  141. package/src/components/group-privilege/index.ts +2 -2
  142. package/src/components/group-reporting-user/group-reporting-user.repository.ts +23 -23
  143. package/src/components/group-reporting-user/group-reporting-user.ts +506 -506
  144. package/src/components/group-reporting-user/index.ts +3 -3
  145. package/src/components/group-system-access/group-system-access.repository.ts +43 -43
  146. package/src/components/group-system-access/group-system-access.ts +90 -90
  147. package/src/components/group-system-access/index.ts +2 -2
  148. package/src/components/index.ts +20 -20
  149. package/src/components/login-history/index.ts +1 -1
  150. package/src/components/login-history/login-history.repository.ts +11 -11
  151. package/src/components/login-user/index.ts +5 -5
  152. package/src/components/login-user/interfaces/check-user-info-duplicated.interface.ts +7 -7
  153. package/src/components/login-user/interfaces/index.ts +1 -1
  154. package/src/components/login-user/interfaces/system-access.interface.ts +13 -13
  155. package/src/components/login-user/interfaces/user-info.interface.ts +34 -34
  156. package/src/components/login-user/login-user.ts +362 -362
  157. package/src/components/login-user/user.repository.ts +11 -11
  158. package/src/components/login-user/user.ts +3142 -3134
  159. package/src/components/password-hash/index.ts +2 -2
  160. package/src/components/password-hash/interfaces/index.ts +1 -1
  161. package/src/components/password-hash/interfaces/password-hash-service.interface.ts +4 -4
  162. package/src/components/password-hash/password-hash.service.ts +14 -14
  163. package/src/components/staff/index.ts +2 -2
  164. package/src/components/staff/staff.repository.ts +27 -27
  165. package/src/components/system/index.ts +3 -3
  166. package/src/components/system/system.repository.ts +11 -11
  167. package/src/components/system/system.ts +456 -456
  168. package/src/components/system-privilege/index.ts +4 -4
  169. package/src/components/system-privilege/system-privilege.repository.ts +18 -18
  170. package/src/components/system-privilege/system-privilege.ts +541 -541
  171. package/src/components/user-group/index.ts +2 -2
  172. package/src/components/user-group/user-group.repository.ts +19 -19
  173. package/src/components/user-group/user-group.ts +764 -764
  174. package/src/components/user-object-privilege/index.ts +2 -2
  175. package/src/components/user-object-privilege/user-object-privilege.repository.ts +11 -11
  176. package/src/components/user-object-privilege/user-object-privilege.ts +79 -79
  177. package/src/components/user-password-history/index.ts +2 -2
  178. package/src/components/user-password-history/user-password-history.repository.ts +39 -39
  179. package/src/components/user-password-history/user-password-history.ts +187 -187
  180. package/src/components/user-privilege/index.ts +2 -2
  181. package/src/components/user-privilege/user-privilege.repository.ts +25 -25
  182. package/src/components/user-privilege/user-privilege.ts +662 -662
  183. package/src/components/user-reporting-hierarchy/index.ts +2 -2
  184. package/src/components/user-reporting-hierarchy/user-reporting-hierarchy.repository.ts +30 -30
  185. package/src/components/user-reporting-hierarchy/user-reporting-hierarchy.ts +505 -505
  186. package/src/components/user-system-access/index.ts +2 -2
  187. package/src/components/user-system-access/user-system-access.repository.ts +41 -41
  188. package/src/components/user-system-access/user-system-access.ts +717 -717
  189. package/src/database.ts +15 -15
  190. package/src/enum/api-key.enum.ts +5 -5
  191. package/src/enum/building-type.enum.ts +6 -6
  192. package/src/enum/group-type.enum.ts +8 -8
  193. package/src/enum/index.ts +6 -6
  194. package/src/enum/login-status.enum.ts +4 -4
  195. package/src/enum/object-status.enum.ts +4 -4
  196. package/src/enum/user-status.enum.ts +7 -7
  197. package/src/enum/yn.enum.ts +4 -4
  198. package/src/index.ts +8 -8
  199. package/src/interfaces/api-key-attr.interface.ts +16 -16
  200. package/src/interfaces/group-object-privilege.interface.ts +14 -14
  201. package/src/interfaces/group-privilege.interface.ts +10 -10
  202. package/src/interfaces/group-reporting-user.interface.ts +11 -11
  203. package/src/interfaces/group-search-attr.interface.ts +9 -9
  204. package/src/interfaces/group-system-access.interface.ts +10 -10
  205. package/src/interfaces/group.interface.ts +17 -17
  206. package/src/interfaces/index.ts +13 -13
  207. package/src/interfaces/system-login.interface.ts +6 -6
  208. package/src/interfaces/system-privilege-search.interface.ts +5 -5
  209. package/src/interfaces/system-privilege.interface.ts +11 -11
  210. package/src/interfaces/system-search-attr.interface.ts +5 -5
  211. package/src/interfaces/system.interface.ts +15 -15
  212. package/src/interfaces/user-group.interface.ts +12 -12
  213. package/src/interfaces/user-object-privilege.interface.ts +14 -14
  214. package/src/interfaces/user-password-history.interface.ts +6 -6
  215. package/src/interfaces/user-privilege.interface.ts +10 -10
  216. package/src/interfaces/user-reporting-hierarchy.interface.ts +11 -11
  217. package/src/interfaces/user-session.interface.ts +5 -5
  218. package/src/interfaces/user-system-access.interface.ts +10 -10
  219. package/src/models/api-key-entity.ts +101 -101
  220. package/src/models/building.entity.ts +103 -103
  221. package/src/models/group-object-privilege.entity.ts +91 -91
  222. package/src/models/group-privilege.entity.ts +78 -78
  223. package/src/models/group-reporting-user.entity.ts +95 -95
  224. package/src/models/group-system-access.entity.ts +81 -81
  225. package/src/models/group.entity.ts +127 -127
  226. package/src/models/login-history.entity.ts +63 -63
  227. package/src/models/staff.entity.ts +91 -91
  228. package/src/models/system-privilege.entity.ts +90 -90
  229. package/src/models/system.entity.ts +113 -113
  230. package/src/models/user-group.entity.ts +91 -91
  231. package/src/models/user-object-privilege.entity.ts +90 -90
  232. package/src/models/user-password-history.ts +51 -51
  233. package/src/models/user-privilege.entity.ts +78 -78
  234. package/src/models/user-reporting-hierarchy.entity.ts +102 -102
  235. package/src/models/user-system-access.entity.ts +87 -87
  236. package/src/models/user.entity.ts +193 -193
  237. package/src/redis-client/__mocks__/jest-initial-setup.ts +2 -2
  238. package/src/redis-client/__mocks__/redis-mock.ts +28 -28
  239. package/src/redis-client/index.ts +1 -1
  240. package/src/redis-client/redis.service.ts +75 -75
  241. package/src/session/index.ts +2 -2
  242. package/src/session/interfaces/index.ts +1 -1
  243. package/src/session/interfaces/session-service.interface.ts +26 -26
  244. package/src/session/session.service.ts +96 -96
  245. package/src/types/auth-context.ts +10 -10
  246. package/src/types/index.ts +1 -1
  247. package/tsconfig.build.json +5 -5
  248. package/tsconfig.json +23 -23
  249. package/dist/components/api-key/api-key.d.ts +0 -85
  250. package/dist/components/api-key/api-key.d.ts.map +0 -1
  251. package/dist/components/api-key/api-key.js +0 -245
  252. package/dist/components/api-key/api-key.js.map +0 -1
  253. package/dist/components/api-key/api-key.repository.d.ts +0 -7
  254. package/dist/components/api-key/api-key.repository.d.ts.map +0 -1
  255. package/dist/components/api-key/api-key.repository.js +0 -18
  256. package/dist/components/api-key/api-key.repository.js.map +0 -1
  257. package/dist/components/api-key/index.d.ts +0 -4
  258. package/dist/components/api-key/index.d.ts.map +0 -1
  259. package/dist/components/api-key/index.js +0 -8
  260. package/dist/components/api-key/index.js.map +0 -1
  261. package/dist/components/building/building.repository.d.ts +0 -7
  262. package/dist/components/building/building.repository.d.ts.map +0 -1
  263. package/dist/components/building/building.repository.js +0 -30
  264. package/dist/components/building/building.repository.js.map +0 -1
  265. package/dist/components/building/index.d.ts +0 -2
  266. package/dist/components/building/index.d.ts.map +0 -1
  267. package/dist/components/building/index.js +0 -18
  268. package/dist/components/building/index.js.map +0 -1
  269. package/dist/components/group/group.d.ts +0 -129
  270. package/dist/components/group/group.d.ts.map +0 -1
  271. package/dist/components/group/group.js +0 -1337
  272. package/dist/components/group/group.js.map +0 -1
  273. package/dist/components/group/group.repository.d.ts +0 -8
  274. package/dist/components/group/group.repository.d.ts.map +0 -1
  275. package/dist/components/group/group.repository.js +0 -29
  276. package/dist/components/group/group.repository.js.map +0 -1
  277. package/dist/components/group/index.d.ts +0 -3
  278. package/dist/components/group/index.d.ts.map +0 -1
  279. package/dist/components/group/index.js +0 -19
  280. package/dist/components/group/index.js.map +0 -1
  281. package/dist/components/group-object-privilege/group-object-privilege.d.ts +0 -28
  282. package/dist/components/group-object-privilege/group-object-privilege.d.ts.map +0 -1
  283. package/dist/components/group-object-privilege/group-object-privilege.js +0 -163
  284. package/dist/components/group-object-privilege/group-object-privilege.js.map +0 -1
  285. package/dist/components/group-object-privilege/group-object-privilege.repository.d.ts +0 -7
  286. package/dist/components/group-object-privilege/group-object-privilege.repository.d.ts.map +0 -1
  287. package/dist/components/group-object-privilege/group-object-privilege.repository.js +0 -26
  288. package/dist/components/group-object-privilege/group-object-privilege.repository.js.map +0 -1
  289. package/dist/components/group-object-privilege/index.d.ts +0 -3
  290. package/dist/components/group-object-privilege/index.d.ts.map +0 -1
  291. package/dist/components/group-object-privilege/index.js +0 -19
  292. package/dist/components/group-object-privilege/index.js.map +0 -1
  293. package/dist/components/group-privilege/group-privilege.d.ts +0 -25
  294. package/dist/components/group-privilege/group-privilege.d.ts.map +0 -1
  295. package/dist/components/group-privilege/group-privilege.js +0 -67
  296. package/dist/components/group-privilege/group-privilege.js.map +0 -1
  297. package/dist/components/group-privilege/group-privilege.repository.d.ts +0 -7
  298. package/dist/components/group-privilege/group-privilege.repository.d.ts.map +0 -1
  299. package/dist/components/group-privilege/group-privilege.repository.js +0 -28
  300. package/dist/components/group-privilege/group-privilege.repository.js.map +0 -1
  301. package/dist/components/group-privilege/index.d.ts +0 -3
  302. package/dist/components/group-privilege/index.d.ts.map +0 -1
  303. package/dist/components/group-privilege/index.js +0 -19
  304. package/dist/components/group-privilege/index.js.map +0 -1
  305. package/dist/components/group-reporting-user/group-reporting-user.d.ts +0 -30
  306. package/dist/components/group-reporting-user/group-reporting-user.d.ts.map +0 -1
  307. package/dist/components/group-reporting-user/group-reporting-user.js +0 -277
  308. package/dist/components/group-reporting-user/group-reporting-user.js.map +0 -1
  309. package/dist/components/group-reporting-user/group-reporting-user.repository.d.ts +0 -7
  310. package/dist/components/group-reporting-user/group-reporting-user.repository.d.ts.map +0 -1
  311. package/dist/components/group-reporting-user/group-reporting-user.repository.js +0 -23
  312. package/dist/components/group-reporting-user/group-reporting-user.repository.js.map +0 -1
  313. package/dist/components/group-reporting-user/index.d.ts +0 -3
  314. package/dist/components/group-reporting-user/index.d.ts.map +0 -1
  315. package/dist/components/group-reporting-user/index.js +0 -19
  316. package/dist/components/group-reporting-user/index.js.map +0 -1
  317. package/dist/components/group-system-access/group-system-access.d.ts +0 -28
  318. package/dist/components/group-system-access/group-system-access.d.ts.map +0 -1
  319. package/dist/components/group-system-access/group-system-access.js +0 -70
  320. package/dist/components/group-system-access/group-system-access.js.map +0 -1
  321. package/dist/components/group-system-access/group-system-access.repository.d.ts +0 -8
  322. package/dist/components/group-system-access/group-system-access.repository.d.ts.map +0 -1
  323. package/dist/components/group-system-access/group-system-access.repository.js +0 -46
  324. package/dist/components/group-system-access/group-system-access.repository.js.map +0 -1
  325. package/dist/components/group-system-access/index.d.ts +0 -3
  326. package/dist/components/group-system-access/index.d.ts.map +0 -1
  327. package/dist/components/group-system-access/index.js +0 -19
  328. package/dist/components/group-system-access/index.js.map +0 -1
  329. package/dist/components/index.d.ts +0 -18
  330. package/dist/components/index.d.ts.map +0 -1
  331. package/dist/components/index.js +0 -34
  332. package/dist/components/index.js.map +0 -1
  333. package/dist/components/login-history/index.d.ts +0 -2
  334. package/dist/components/login-history/index.d.ts.map +0 -1
  335. package/dist/components/login-history/index.js +0 -18
  336. package/dist/components/login-history/index.js.map +0 -1
  337. package/dist/components/login-history/login-history.repository.d.ts +0 -6
  338. package/dist/components/login-history/login-history.repository.d.ts.map +0 -1
  339. package/dist/components/login-history/login-history.repository.js +0 -15
  340. package/dist/components/login-history/login-history.repository.js.map +0 -1
  341. package/dist/components/login-user/index.d.ts +0 -5
  342. package/dist/components/login-user/index.d.ts.map +0 -1
  343. package/dist/components/login-user/index.js +0 -21
  344. package/dist/components/login-user/index.js.map +0 -1
  345. package/dist/components/login-user/interfaces/check-user-info-duplicated.interface.d.ts +0 -8
  346. package/dist/components/login-user/interfaces/check-user-info-duplicated.interface.d.ts.map +0 -1
  347. package/dist/components/login-user/interfaces/check-user-info-duplicated.interface.js +0 -3
  348. package/dist/components/login-user/interfaces/check-user-info-duplicated.interface.js.map +0 -1
  349. package/dist/components/login-user/interfaces/index.d.ts +0 -2
  350. package/dist/components/login-user/interfaces/index.d.ts.map +0 -1
  351. package/dist/components/login-user/interfaces/index.js +0 -18
  352. package/dist/components/login-user/interfaces/index.js.map +0 -1
  353. package/dist/components/login-user/interfaces/system-access.interface.d.ts +0 -14
  354. package/dist/components/login-user/interfaces/system-access.interface.d.ts.map +0 -1
  355. package/dist/components/login-user/interfaces/system-access.interface.js +0 -3
  356. package/dist/components/login-user/interfaces/system-access.interface.js.map +0 -1
  357. package/dist/components/login-user/interfaces/user-info.interface.d.ts +0 -31
  358. package/dist/components/login-user/interfaces/user-info.interface.d.ts.map +0 -1
  359. package/dist/components/login-user/interfaces/user-info.interface.js +0 -3
  360. package/dist/components/login-user/interfaces/user-info.interface.js.map +0 -1
  361. package/dist/components/login-user/login-user.d.ts +0 -14
  362. package/dist/components/login-user/login-user.d.ts.map +0 -1
  363. package/dist/components/login-user/login-user.js +0 -127
  364. package/dist/components/login-user/login-user.js.map +0 -1
  365. package/dist/components/login-user/user.d.ts +0 -155
  366. package/dist/components/login-user/user.d.ts.map +0 -1
  367. package/dist/components/login-user/user.js +0 -1753
  368. package/dist/components/login-user/user.js.map +0 -1
  369. package/dist/components/login-user/user.repository.d.ts +0 -6
  370. package/dist/components/login-user/user.repository.d.ts.map +0 -1
  371. package/dist/components/login-user/user.repository.js +0 -15
  372. package/dist/components/login-user/user.repository.js.map +0 -1
  373. package/dist/components/password-hash/index.d.ts +0 -3
  374. package/dist/components/password-hash/index.d.ts.map +0 -1
  375. package/dist/components/password-hash/index.js +0 -19
  376. package/dist/components/password-hash/index.js.map +0 -1
  377. package/dist/components/password-hash/interfaces/index.d.ts +0 -2
  378. package/dist/components/password-hash/interfaces/index.d.ts.map +0 -1
  379. package/dist/components/password-hash/interfaces/index.js +0 -18
  380. package/dist/components/password-hash/interfaces/index.js.map +0 -1
  381. package/dist/components/password-hash/interfaces/password-hash-service.interface.d.ts +0 -5
  382. package/dist/components/password-hash/interfaces/password-hash-service.interface.d.ts.map +0 -1
  383. package/dist/components/password-hash/interfaces/password-hash-service.interface.js +0 -3
  384. package/dist/components/password-hash/interfaces/password-hash-service.interface.js.map +0 -1
  385. package/dist/components/password-hash/password-hash.service.d.ts +0 -7
  386. package/dist/components/password-hash/password-hash.service.d.ts.map +0 -1
  387. package/dist/components/password-hash/password-hash.service.js +0 -48
  388. package/dist/components/password-hash/password-hash.service.js.map +0 -1
  389. package/dist/components/staff/index.d.ts +0 -2
  390. package/dist/components/staff/index.d.ts.map +0 -1
  391. package/dist/components/staff/index.js +0 -18
  392. package/dist/components/staff/index.js.map +0 -1
  393. package/dist/components/staff/staff.repository.d.ts +0 -7
  394. package/dist/components/staff/staff.repository.d.ts.map +0 -1
  395. package/dist/components/staff/staff.repository.js +0 -30
  396. package/dist/components/staff/staff.repository.js.map +0 -1
  397. package/dist/components/system/index.d.ts +0 -3
  398. package/dist/components/system/index.d.ts.map +0 -1
  399. package/dist/components/system/index.js +0 -19
  400. package/dist/components/system/index.js.map +0 -1
  401. package/dist/components/system/system.d.ts +0 -40
  402. package/dist/components/system/system.d.ts.map +0 -1
  403. package/dist/components/system/system.js +0 -283
  404. package/dist/components/system/system.js.map +0 -1
  405. package/dist/components/system/system.repository.d.ts +0 -6
  406. package/dist/components/system/system.repository.d.ts.map +0 -1
  407. package/dist/components/system/system.repository.js +0 -15
  408. package/dist/components/system/system.repository.js.map +0 -1
  409. package/dist/components/system-privilege/index.d.ts +0 -4
  410. package/dist/components/system-privilege/index.d.ts.map +0 -1
  411. package/dist/components/system-privilege/index.js +0 -8
  412. package/dist/components/system-privilege/index.js.map +0 -1
  413. package/dist/components/system-privilege/system-privilege.d.ts +0 -53
  414. package/dist/components/system-privilege/system-privilege.d.ts.map +0 -1
  415. package/dist/components/system-privilege/system-privilege.js +0 -315
  416. package/dist/components/system-privilege/system-privilege.js.map +0 -1
  417. package/dist/components/system-privilege/system-privilege.repository.d.ts +0 -7
  418. package/dist/components/system-privilege/system-privilege.repository.d.ts.map +0 -1
  419. package/dist/components/system-privilege/system-privilege.repository.js +0 -21
  420. package/dist/components/system-privilege/system-privilege.repository.js.map +0 -1
  421. package/dist/components/user-group/index.d.ts +0 -3
  422. package/dist/components/user-group/index.d.ts.map +0 -1
  423. package/dist/components/user-group/index.js +0 -19
  424. package/dist/components/user-group/index.js.map +0 -1
  425. package/dist/components/user-group/user-group.d.ts +0 -51
  426. package/dist/components/user-group/user-group.d.ts.map +0 -1
  427. package/dist/components/user-group/user-group.js +0 -335
  428. package/dist/components/user-group/user-group.js.map +0 -1
  429. package/dist/components/user-group/user-group.repository.d.ts +0 -6
  430. package/dist/components/user-group/user-group.repository.d.ts.map +0 -1
  431. package/dist/components/user-group/user-group.repository.js +0 -15
  432. package/dist/components/user-group/user-group.repository.js.map +0 -1
  433. package/dist/components/user-object-privilege/index.d.ts +0 -3
  434. package/dist/components/user-object-privilege/index.d.ts.map +0 -1
  435. package/dist/components/user-object-privilege/index.js +0 -19
  436. package/dist/components/user-object-privilege/index.js.map +0 -1
  437. package/dist/components/user-object-privilege/user-object-privilege.d.ts +0 -24
  438. package/dist/components/user-object-privilege/user-object-privilege.d.ts.map +0 -1
  439. package/dist/components/user-object-privilege/user-object-privilege.js +0 -59
  440. package/dist/components/user-object-privilege/user-object-privilege.js.map +0 -1
  441. package/dist/components/user-object-privilege/user-object-privilege.repository.d.ts +0 -6
  442. package/dist/components/user-object-privilege/user-object-privilege.repository.d.ts.map +0 -1
  443. package/dist/components/user-object-privilege/user-object-privilege.repository.js +0 -15
  444. package/dist/components/user-object-privilege/user-object-privilege.repository.js.map +0 -1
  445. package/dist/components/user-privilege/index.d.ts +0 -3
  446. package/dist/components/user-privilege/index.d.ts.map +0 -1
  447. package/dist/components/user-privilege/index.js +0 -19
  448. package/dist/components/user-privilege/index.js.map +0 -1
  449. package/dist/components/user-privilege/user-privilege.d.ts +0 -71
  450. package/dist/components/user-privilege/user-privilege.d.ts.map +0 -1
  451. package/dist/components/user-privilege/user-privilege.js +0 -388
  452. package/dist/components/user-privilege/user-privilege.js.map +0 -1
  453. package/dist/components/user-privilege/user-privilege.repository.d.ts +0 -7
  454. package/dist/components/user-privilege/user-privilege.repository.d.ts.map +0 -1
  455. package/dist/components/user-privilege/user-privilege.repository.js +0 -29
  456. package/dist/components/user-privilege/user-privilege.repository.js.map +0 -1
  457. package/dist/components/user-system-access/index.d.ts +0 -3
  458. package/dist/components/user-system-access/index.d.ts.map +0 -1
  459. package/dist/components/user-system-access/index.js +0 -19
  460. package/dist/components/user-system-access/index.js.map +0 -1
  461. package/dist/components/user-system-access/user-system-access.d.ts +0 -69
  462. package/dist/components/user-system-access/user-system-access.d.ts.map +0 -1
  463. package/dist/components/user-system-access/user-system-access.js +0 -413
  464. package/dist/components/user-system-access/user-system-access.js.map +0 -1
  465. package/dist/components/user-system-access/user-system-access.repository.d.ts +0 -8
  466. package/dist/components/user-system-access/user-system-access.repository.d.ts.map +0 -1
  467. package/dist/components/user-system-access/user-system-access.repository.js +0 -44
  468. package/dist/components/user-system-access/user-system-access.repository.js.map +0 -1
  469. package/dist/database.d.ts +0 -5
  470. package/dist/database.d.ts.map +0 -1
  471. package/dist/database.js +0 -14
  472. package/dist/database.js.map +0 -1
  473. package/dist/enum/api-key.enum.d.ts +0 -6
  474. package/dist/enum/api-key.enum.d.ts.map +0 -1
  475. package/dist/enum/api-key.enum.js +0 -10
  476. package/dist/enum/api-key.enum.js.map +0 -1
  477. package/dist/enum/group-type.enum.d.ts +0 -9
  478. package/dist/enum/group-type.enum.d.ts.map +0 -1
  479. package/dist/enum/group-type.enum.js +0 -13
  480. package/dist/enum/group-type.enum.js.map +0 -1
  481. package/dist/enum/index.d.ts +0 -7
  482. package/dist/enum/index.d.ts.map +0 -1
  483. package/dist/enum/index.js +0 -23
  484. package/dist/enum/index.js.map +0 -1
  485. package/dist/enum/login-status.enum.d.ts +0 -5
  486. package/dist/enum/login-status.enum.d.ts.map +0 -1
  487. package/dist/enum/login-status.enum.js +0 -9
  488. package/dist/enum/login-status.enum.js.map +0 -1
  489. package/dist/enum/object-status.enum.d.ts +0 -5
  490. package/dist/enum/object-status.enum.d.ts.map +0 -1
  491. package/dist/enum/object-status.enum.js +0 -9
  492. package/dist/enum/object-status.enum.js.map +0 -1
  493. package/dist/enum/user-status.enum.d.ts +0 -8
  494. package/dist/enum/user-status.enum.d.ts.map +0 -1
  495. package/dist/enum/user-status.enum.js +0 -12
  496. package/dist/enum/user-status.enum.js.map +0 -1
  497. package/dist/enum/yn.enum.d.ts +0 -5
  498. package/dist/enum/yn.enum.d.ts.map +0 -1
  499. package/dist/enum/yn.enum.js +0 -9
  500. package/dist/enum/yn.enum.js.map +0 -1
  501. package/dist/index.d.ts.map +0 -1
  502. package/dist/interfaces/api-key-attr.interface.d.ts +0 -16
  503. package/dist/interfaces/api-key-attr.interface.d.ts.map +0 -1
  504. package/dist/interfaces/api-key-attr.interface.js +0 -3
  505. package/dist/interfaces/api-key-attr.interface.js.map +0 -1
  506. package/dist/interfaces/group-object-privilege.interface.d.ts +0 -14
  507. package/dist/interfaces/group-object-privilege.interface.d.ts.map +0 -1
  508. package/dist/interfaces/group-object-privilege.interface.js +0 -3
  509. package/dist/interfaces/group-object-privilege.interface.js.map +0 -1
  510. package/dist/interfaces/group-privilege.interface.d.ts +0 -11
  511. package/dist/interfaces/group-privilege.interface.d.ts.map +0 -1
  512. package/dist/interfaces/group-privilege.interface.js +0 -3
  513. package/dist/interfaces/group-privilege.interface.js.map +0 -1
  514. package/dist/interfaces/group-reporting-user.interface.d.ts +0 -12
  515. package/dist/interfaces/group-reporting-user.interface.d.ts.map +0 -1
  516. package/dist/interfaces/group-reporting-user.interface.js +0 -3
  517. package/dist/interfaces/group-reporting-user.interface.js.map +0 -1
  518. package/dist/interfaces/group-search-attr.interface.d.ts +0 -9
  519. package/dist/interfaces/group-search-attr.interface.d.ts.map +0 -1
  520. package/dist/interfaces/group-search-attr.interface.js +0 -3
  521. package/dist/interfaces/group-search-attr.interface.js.map +0 -1
  522. package/dist/interfaces/group-system-access.interface.d.ts +0 -11
  523. package/dist/interfaces/group-system-access.interface.d.ts.map +0 -1
  524. package/dist/interfaces/group-system-access.interface.js +0 -3
  525. package/dist/interfaces/group-system-access.interface.js.map +0 -1
  526. package/dist/interfaces/group.interface.d.ts +0 -17
  527. package/dist/interfaces/group.interface.d.ts.map +0 -1
  528. package/dist/interfaces/group.interface.js +0 -3
  529. package/dist/interfaces/group.interface.js.map +0 -1
  530. package/dist/interfaces/index.d.ts +0 -14
  531. package/dist/interfaces/index.d.ts.map +0 -1
  532. package/dist/interfaces/index.js +0 -30
  533. package/dist/interfaces/index.js.map +0 -1
  534. package/dist/interfaces/system-login.interface.d.ts +0 -7
  535. package/dist/interfaces/system-login.interface.d.ts.map +0 -1
  536. package/dist/interfaces/system-login.interface.js +0 -3
  537. package/dist/interfaces/system-login.interface.js.map +0 -1
  538. package/dist/interfaces/system-privilege-search.interface.d.ts +0 -6
  539. package/dist/interfaces/system-privilege-search.interface.d.ts.map +0 -1
  540. package/dist/interfaces/system-privilege-search.interface.js +0 -3
  541. package/dist/interfaces/system-privilege-search.interface.js.map +0 -1
  542. package/dist/interfaces/system-privilege.interface.d.ts +0 -12
  543. package/dist/interfaces/system-privilege.interface.d.ts.map +0 -1
  544. package/dist/interfaces/system-privilege.interface.js +0 -3
  545. package/dist/interfaces/system-privilege.interface.js.map +0 -1
  546. package/dist/interfaces/system-search-attr.interface.d.ts +0 -6
  547. package/dist/interfaces/system-search-attr.interface.d.ts.map +0 -1
  548. package/dist/interfaces/system-search-attr.interface.js +0 -3
  549. package/dist/interfaces/system-search-attr.interface.js.map +0 -1
  550. package/dist/interfaces/system.interface.d.ts +0 -16
  551. package/dist/interfaces/system.interface.d.ts.map +0 -1
  552. package/dist/interfaces/system.interface.js +0 -3
  553. package/dist/interfaces/system.interface.js.map +0 -1
  554. package/dist/interfaces/user-group.interface.d.ts +0 -13
  555. package/dist/interfaces/user-group.interface.d.ts.map +0 -1
  556. package/dist/interfaces/user-group.interface.js +0 -3
  557. package/dist/interfaces/user-group.interface.js.map +0 -1
  558. package/dist/interfaces/user-object-privilege.interface.d.ts +0 -14
  559. package/dist/interfaces/user-object-privilege.interface.d.ts.map +0 -1
  560. package/dist/interfaces/user-object-privilege.interface.js +0 -3
  561. package/dist/interfaces/user-object-privilege.interface.js.map +0 -1
  562. package/dist/interfaces/user-privilege.interface.d.ts +0 -11
  563. package/dist/interfaces/user-privilege.interface.d.ts.map +0 -1
  564. package/dist/interfaces/user-privilege.interface.js +0 -3
  565. package/dist/interfaces/user-privilege.interface.js.map +0 -1
  566. package/dist/interfaces/user-session.interface.d.ts +0 -5
  567. package/dist/interfaces/user-session.interface.d.ts.map +0 -1
  568. package/dist/interfaces/user-session.interface.js +0 -3
  569. package/dist/interfaces/user-session.interface.js.map +0 -1
  570. package/dist/interfaces/user-system-access.interface.d.ts +0 -11
  571. package/dist/interfaces/user-system-access.interface.d.ts.map +0 -1
  572. package/dist/interfaces/user-system-access.interface.js +0 -3
  573. package/dist/interfaces/user-system-access.interface.js.map +0 -1
  574. package/dist/models/api-key-entity.d.ts +0 -22
  575. package/dist/models/api-key-entity.d.ts.map +0 -1
  576. package/dist/models/api-key-entity.js +0 -125
  577. package/dist/models/api-key-entity.js.map +0 -1
  578. package/dist/models/building.entity.d.ts +0 -30
  579. package/dist/models/building.entity.d.ts.map +0 -1
  580. package/dist/models/building.entity.js +0 -216
  581. package/dist/models/building.entity.js.map +0 -1
  582. package/dist/models/group-object-privilege.entity.d.ts +0 -22
  583. package/dist/models/group-object-privilege.entity.d.ts.map +0 -1
  584. package/dist/models/group-object-privilege.entity.js +0 -114
  585. package/dist/models/group-object-privilege.entity.js.map +0 -1
  586. package/dist/models/group-privilege.entity.d.ts +0 -19
  587. package/dist/models/group-privilege.entity.d.ts.map +0 -1
  588. package/dist/models/group-privilege.entity.js +0 -99
  589. package/dist/models/group-privilege.entity.js.map +0 -1
  590. package/dist/models/group-reporting-user.entity.d.ts +0 -18
  591. package/dist/models/group-reporting-user.entity.d.ts.map +0 -1
  592. package/dist/models/group-reporting-user.entity.js +0 -117
  593. package/dist/models/group-reporting-user.entity.js.map +0 -1
  594. package/dist/models/group-system-access.entity.d.ts +0 -19
  595. package/dist/models/group-system-access.entity.d.ts.map +0 -1
  596. package/dist/models/group-system-access.entity.js +0 -102
  597. package/dist/models/group-system-access.entity.js.map +0 -1
  598. package/dist/models/group.entity.d.ts +0 -33
  599. package/dist/models/group.entity.d.ts.map +0 -1
  600. package/dist/models/group.entity.js +0 -157
  601. package/dist/models/group.entity.js.map +0 -1
  602. package/dist/models/login-history.entity.d.ts +0 -15
  603. package/dist/models/login-history.entity.d.ts.map +0 -1
  604. package/dist/models/login-history.entity.js +0 -81
  605. package/dist/models/login-history.entity.js.map +0 -1
  606. package/dist/models/staff.entity.d.ts +0 -19
  607. package/dist/models/staff.entity.d.ts.map +0 -1
  608. package/dist/models/staff.entity.js +0 -113
  609. package/dist/models/staff.entity.js.map +0 -1
  610. package/dist/models/system-privilege.entity.d.ts +0 -19
  611. package/dist/models/system-privilege.entity.d.ts.map +0 -1
  612. package/dist/models/system-privilege.entity.js +0 -111
  613. package/dist/models/system-privilege.entity.js.map +0 -1
  614. package/dist/models/system.entity.d.ts +0 -26
  615. package/dist/models/system.entity.d.ts.map +0 -1
  616. package/dist/models/system.entity.js +0 -139
  617. package/dist/models/system.entity.js.map +0 -1
  618. package/dist/models/user-group.entity.d.ts +0 -20
  619. package/dist/models/user-group.entity.d.ts.map +0 -1
  620. package/dist/models/user-group.entity.js +0 -114
  621. package/dist/models/user-group.entity.js.map +0 -1
  622. package/dist/models/user-object-privilege.entity.d.ts +0 -21
  623. package/dist/models/user-object-privilege.entity.d.ts.map +0 -1
  624. package/dist/models/user-object-privilege.entity.js +0 -113
  625. package/dist/models/user-object-privilege.entity.js.map +0 -1
  626. package/dist/models/user-privilege.entity.d.ts +0 -18
  627. package/dist/models/user-privilege.entity.d.ts.map +0 -1
  628. package/dist/models/user-privilege.entity.js +0 -99
  629. package/dist/models/user-privilege.entity.js.map +0 -1
  630. package/dist/models/user-system-access.entity.d.ts +0 -18
  631. package/dist/models/user-system-access.entity.d.ts.map +0 -1
  632. package/dist/models/user-system-access.entity.js +0 -108
  633. package/dist/models/user-system-access.entity.js.map +0 -1
  634. package/dist/models/user.entity.d.ts +0 -41
  635. package/dist/models/user.entity.d.ts.map +0 -1
  636. package/dist/models/user.entity.js +0 -218
  637. package/dist/models/user.entity.js.map +0 -1
  638. package/dist/redis-client/__mocks__/jest-initial-setup.d.ts +0 -2
  639. package/dist/redis-client/__mocks__/jest-initial-setup.d.ts.map +0 -1
  640. package/dist/redis-client/__mocks__/jest-initial-setup.js +0 -8
  641. package/dist/redis-client/__mocks__/jest-initial-setup.js.map +0 -1
  642. package/dist/redis-client/__mocks__/redis-mock.d.ts +0 -3
  643. package/dist/redis-client/__mocks__/redis-mock.d.ts.map +0 -1
  644. package/dist/redis-client/__mocks__/redis-mock.js +0 -56
  645. package/dist/redis-client/__mocks__/redis-mock.js.map +0 -1
  646. package/dist/redis-client/index.d.ts +0 -2
  647. package/dist/redis-client/index.d.ts.map +0 -1
  648. package/dist/redis-client/index.js +0 -18
  649. package/dist/redis-client/index.js.map +0 -1
  650. package/dist/redis-client/redis.service.d.ts +0 -10
  651. package/dist/redis-client/redis.service.d.ts.map +0 -1
  652. package/dist/redis-client/redis.service.js +0 -69
  653. package/dist/redis-client/redis.service.js.map +0 -1
  654. package/dist/session/index.d.ts +0 -3
  655. package/dist/session/index.d.ts.map +0 -1
  656. package/dist/session/index.js +0 -19
  657. package/dist/session/index.js.map +0 -1
  658. package/dist/session/interfaces/index.d.ts +0 -2
  659. package/dist/session/interfaces/index.d.ts.map +0 -1
  660. package/dist/session/interfaces/index.js +0 -18
  661. package/dist/session/interfaces/index.js.map +0 -1
  662. package/dist/session/interfaces/session-service.interface.d.ts +0 -10
  663. package/dist/session/interfaces/session-service.interface.d.ts.map +0 -1
  664. package/dist/session/interfaces/session-service.interface.js +0 -3
  665. package/dist/session/interfaces/session-service.interface.js.map +0 -1
  666. package/dist/session/session.service.d.ts +0 -14
  667. package/dist/session/session.service.d.ts.map +0 -1
  668. package/dist/session/session.service.js +0 -73
  669. package/dist/session/session.service.js.map +0 -1
  670. package/dist/types/auth-context.d.ts +0 -7
  671. package/dist/types/auth-context.d.ts.map +0 -1
  672. package/dist/types/auth-context.js +0 -3
  673. package/dist/types/auth-context.js.map +0 -1
  674. package/dist/types/index.d.ts +0 -2
  675. package/dist/types/index.d.ts.map +0 -1
  676. package/dist/types/index.js +0 -18
  677. package/dist/types/index.js.map +0 -1
@@ -1,456 +1,456 @@
1
- import { ClassError, HashTable, ObjectBase } from '@tomei/general';
2
- import { SystemRepository } from './system.repository';
3
- import { ISystemAttr } from '../../interfaces/system.interface';
4
- import { LoginUser } from '../login-user/login-user';
5
- import { ApplicationConfig, ComponentConfig } from '@tomei/config';
6
- import { ActionEnum, Activity } from '@tomei/activity-history';
7
- import { ISystemSearchAttr } from '../../interfaces/system-search-attr.interface';
8
- import { Op } from 'sequelize';
9
- import { v4 as uuidv4 } from 'uuid';
10
-
11
- export class System extends ObjectBase {
12
- ObjectId: string;
13
- ObjectName: string;
14
- TableName = 'sso_System';
15
- ObjectType = 'System';
16
- private static _htSystem: HashTable;
17
-
18
- SystemCode: string;
19
- Name: string;
20
- Description: string;
21
- AccessURL: string;
22
- GooglePlayURL: string;
23
- AppleStoreURL: string;
24
- APIKey: string;
25
- APISecret: string;
26
- Status: string;
27
- private _CreatedById: number;
28
- private _CreatedAt: Date;
29
- private _UpdatedById: number;
30
- private _UpdatedAt: Date;
31
- private static _Repo = new SystemRepository();
32
-
33
- get CreatedById(): number {
34
- return this._CreatedById;
35
- }
36
-
37
- get CreatedAt(): Date {
38
- return this._CreatedAt;
39
- }
40
-
41
- get UpdatedById(): number {
42
- return this._UpdatedById;
43
- }
44
-
45
- get UpdatedAt(): Date {
46
- return this._UpdatedAt;
47
- }
48
-
49
- private constructor(systemAttr?: ISystemAttr) {
50
- super();
51
- if (systemAttr) {
52
- this.SystemCode = systemAttr.SystemCode;
53
- this.Name = systemAttr.Name;
54
- this.Description = systemAttr?.Description;
55
- this.AccessURL = systemAttr?.AccessURL;
56
- this.GooglePlayURL = systemAttr?.GooglePlayURL;
57
- this.AppleStoreURL = systemAttr?.AppleStoreURL;
58
- this.APIKey = systemAttr?.APIKey;
59
- this.APISecret = systemAttr?.APISecret;
60
- this.Status = systemAttr?.Status;
61
- this._CreatedById = systemAttr.CreatedById;
62
- this._CreatedAt = systemAttr.CreatedAt;
63
- this._UpdatedById = systemAttr.UpdatedById;
64
- this._UpdatedAt = systemAttr.UpdatedAt;
65
- }
66
- }
67
-
68
- public static async init(dbTransaction: any, SystemCode?: string) {
69
- try {
70
- if (SystemCode) {
71
- const system = await System._Repo.findByPk(SystemCode, {
72
- transaction: dbTransaction,
73
- });
74
- if (system) {
75
- return new System(system);
76
- } else {
77
- throw new ClassError('System', 'SystemErrMsg00', 'System Not Found');
78
- }
79
- }
80
- return new System();
81
- } catch (error) {
82
- throw new ClassError(
83
- 'System',
84
- 'SystemErrMsg01',
85
- 'Failed To Initialize System',
86
- );
87
- }
88
- }
89
-
90
- public async createSystem(
91
- loginUser: LoginUser,
92
- dbTransaction: any,
93
- ): Promise<void> {
94
- try {
95
- //Creates a new system in the database.
96
- //Part 1: Check Privilege
97
- //Call loginUser.checkPrivilege() method to check if the user has the privilege to create a system.
98
- const systemCode =
99
- ApplicationConfig.getComponentConfigValue('system-code');
100
- const isPrivileged = await loginUser.checkPrivileges(
101
- systemCode,
102
- 'System - Create',
103
- );
104
- if (!isPrivileged) {
105
- throw new Error('You do not have permission to list UserGroup.');
106
- }
107
-
108
- //Part 2: Validate Input Params
109
- //If this._SystemCode is missing, throw ClassError
110
- if (!this.SystemCode) {
111
- throw new ClassError(
112
- 'System',
113
- 'SystemErrMsg02',
114
- 'SystemCode must have value.',
115
- );
116
- }
117
-
118
- //If this._Name missing, throw ClassError
119
- if (!this.Name) {
120
- throw new ClassError(
121
- 'System',
122
- 'SystemErrMsg03',
123
- 'Name must have value.',
124
- );
125
- }
126
-
127
- //If this._Description missing, throw ClassError
128
- if (!this.Description) {
129
- throw new ClassError(
130
- 'System',
131
- 'SystemErrMsg04',
132
- 'Description must have value.',
133
- );
134
- }
135
-
136
- //Part 3: Prepare to Insert Data
137
- //Set private properties
138
- this._CreatedById = loginUser.UserId;
139
- this._CreatedAt = new Date();
140
- this._UpdatedById = loginUser.UserId;
141
- this._UpdatedAt = new Date();
142
-
143
- //Call System._Repo create method
144
- await System._Repo.create(
145
- {
146
- SystemCode: this.SystemCode,
147
- Name: this.Name,
148
- Description: this.Description,
149
- AccessURL: this.AccessURL,
150
- GooglePlayURL: this.GooglePlayURL,
151
- AppleStoreURL: this.AppleStoreURL,
152
- APIKey: this.APIKey,
153
- APISecret: this.APISecret,
154
- Status: this.Status,
155
- CreatedById: this._CreatedById,
156
- CreatedAt: this._CreatedAt,
157
- UpdatedById: this._UpdatedById,
158
- UpdatedAt: this._UpdatedAt,
159
- },
160
- {
161
- transaction: dbTransaction,
162
- },
163
- );
164
-
165
- //Part 4: Record Create System Activity
166
- //Initialise EntityValueAfter variable and set to this class.
167
- const entityValueAfter = {
168
- SystemCode: this.SystemCode,
169
- Name: this.Name,
170
- Description: this.Description,
171
- AccessURL: this.AccessURL,
172
- GooglePlayURL: this.GooglePlayURL,
173
- AppleStoreURL: this.AppleStoreURL,
174
- APIKey: this.APIKey,
175
- APISecret: this.APISecret,
176
- Status: this.Status,
177
- };
178
-
179
- //Instantiate new activity from Activity class, call createId() method, then set the properties.
180
- const activity = new Activity();
181
- activity.ActivityId = activity.createId();
182
- activity.Action = ActionEnum.CREATE;
183
- activity.Description = 'Add System';
184
- activity.EntityType = 'System';
185
- activity.EntityId = this.SystemCode;
186
- activity.EntityValueBefore = JSON.stringify({});
187
- activity.EntityValueAfter = JSON.stringify(entityValueAfter);
188
- } catch (error) {
189
- throw error;
190
- }
191
- }
192
-
193
- protected static async checkDuplicateSystemCode(
194
- dbTransaction: any,
195
- systemCode: string,
196
- ): Promise<void> {
197
- //This method will make sure there is no duplicate system code.
198
- try {
199
- //Call System._Repo findOne() method by passing Params.SystemCode and dbTransaction, if SystemCode already exists, throw ClassError.
200
- const system = await System._Repo.findOne({
201
- where: {
202
- SystemCode: systemCode,
203
- },
204
- transaction: dbTransaction,
205
- });
206
-
207
- if (system) {
208
- throw new ClassError(
209
- 'System',
210
- 'SystemErrMsg05',
211
- 'System Code already exists.',
212
- );
213
- }
214
- } catch (error) {
215
- throw error;
216
- }
217
- }
218
-
219
- public async setSystemCode(
220
- dbTransaction: any,
221
- systemCode: string,
222
- ): Promise<void> {
223
- //Custom setter method for SystemCode
224
- try {
225
- //Call checkDuplicateSystemCode() method to make sure there is no duplicate system code.
226
- await System.checkDuplicateSystemCode(dbTransaction, systemCode);
227
- //Set this._SystemCode to Params.SystemCode
228
- this.SystemCode = systemCode;
229
- } catch (error) {
230
- throw error;
231
- }
232
- }
233
-
234
- public static async findAll(
235
- dbTransaction: any,
236
- loginUser: LoginUser,
237
- page?: number,
238
- rows?: number,
239
- search?: ISystemSearchAttr,
240
- ): Promise<{ count: number; systems: System[] }> {
241
- //This method list all system records based on filter.
242
- try {
243
- //Part 1: Retrieve listing
244
- const queryObj: any = {};
245
- const whereObj: any = {};
246
- if (search) {
247
- Object.entries(search).forEach(([key, value]) => {
248
- if (value) {
249
- queryObj[key] = {
250
- [Op.substring]: value,
251
- };
252
- }
253
- });
254
- }
255
-
256
- if (page && rows) {
257
- whereObj.offset = (page - 1) * rows;
258
- whereObj.limit = rows;
259
- }
260
-
261
- //Call System._Repo findAll() method by passing queryObj and whereObj
262
- const result = await System._Repo.findAllWithPagination({
263
- distinct: true,
264
- where: queryObj,
265
- ...whereObj,
266
- order: [['CreatedAt', 'DESC']],
267
- transaction: dbTransaction,
268
- });
269
-
270
- //Return result
271
- const systems = result.rows.map((system) => new System(system));
272
- return { count: result.count, systems };
273
- } catch (error) {
274
- throw error;
275
- }
276
- }
277
-
278
- public static async renewApiKeyAndSecret(
279
- loginUser: LoginUser,
280
- dbTransaction: any,
281
- systemCode: string,
282
- ) {
283
- try {
284
- //Part 1: Privilege Checking
285
- //Call loginUser.checkPrivilege() method to check if the user has the privilege to renew API Key and Secret.
286
- const sc = ApplicationConfig.getComponentConfigValue('system-code');
287
- const isPrivileged = await loginUser.checkPrivileges(sc, 'SYSTEM_UPDATE');
288
-
289
- if (!isPrivileged) {
290
- throw new ClassError(
291
- 'System',
292
- 'SystemErrMsg06',
293
- 'You do not have permission to renew API Key and Secret.',
294
- );
295
- }
296
-
297
- //Part 2: Validation
298
- //Instantiate existing System
299
- const system = await System.init(dbTransaction, systemCode);
300
-
301
- //Check if system.AccessURL got value. If not, throw new ClassError
302
- if (!system.AccessURL) {
303
- throw new ClassError(
304
- 'System',
305
- 'SystemErrMsg07',
306
- 'AccessURL is required for callback',
307
- );
308
- }
309
-
310
- //Check if system.Status is "Active". If not, throw new ClassError
311
- if (system.Status !== 'Active') {
312
- throw new ClassError(
313
- 'System',
314
- 'SystemErrMsg08',
315
- 'Cannot do this operation on inactive system.',
316
- );
317
- }
318
-
319
- //Set EntityValueBefore to system instance.
320
- const entityValueBefore = {
321
- SystemCode: system.SystemCode,
322
- Name: system.Name,
323
- Description: system.Description,
324
- AccessURL: system.AccessURL,
325
- GooglePlayURL: system.GooglePlayURL,
326
- AppleStoreURL: system.AppleStoreURL,
327
- APIKey: system.APIKey,
328
- APISecret: system.APISecret,
329
- Status: system.Status,
330
- };
331
-
332
- //Part 3: Generate API key and secret
333
- //Use https://www.npmjs.com/package/uuid package to generate both the api key and api secret.
334
- const apiKey = uuidv4();
335
- const apiSecret = uuidv4();
336
-
337
- //Update the system instance with new API key and secret.
338
- system.APIKey = apiKey;
339
- system.APISecret = apiSecret;
340
- system._UpdatedById = loginUser.UserId;
341
- system._UpdatedAt = new Date();
342
- //Call System._Repo update() method to update the system record.
343
- await System._Repo.update(
344
- {
345
- APIKey: apiKey,
346
- APISecret: apiSecret,
347
- UpdatedById: system._UpdatedById,
348
- UpdatedAt: system._UpdatedAt,
349
- },
350
- {
351
- where: {
352
- SystemCode: systemCode,
353
- },
354
- transaction: dbTransaction,
355
- },
356
- );
357
-
358
- //Part 4: Record Renew API Key and Secret Activity
359
- //Set EntityValueAfter to system instance.
360
- const entityValueAfter = {
361
- SystemCode: system.SystemCode,
362
- Name: system.Name,
363
- Description: system.Description,
364
- AccessURL: system.AccessURL,
365
- GooglePlayURL: system.GooglePlayURL,
366
- AppleStoreURL: system.AppleStoreURL,
367
- APIKey: system.APIKey,
368
- APISecret: system.APISecret,
369
- Status: system.Status,
370
- };
371
-
372
- //Instantiate new activity from Activity class, call createId() method, then set the properties.
373
- const activity = new Activity();
374
- activity.ActivityId = activity.createId();
375
- activity.Action = ActionEnum.UPDATE;
376
- activity.Description = 'Renew API key and secret for a system';
377
- activity.EntityType = 'System';
378
- activity.EntityId = system.SystemCode;
379
- activity.EntityValueBefore = JSON.stringify(entityValueBefore);
380
- activity.EntityValueAfter = JSON.stringify(entityValueAfter);
381
-
382
- await activity.create(loginUser.ObjectId, dbTransaction);
383
- //Return the updated system instance.
384
- return system;
385
- } catch (error) {
386
- throw error;
387
- }
388
- }
389
-
390
- public static async loadSystem(dbTransaction): Promise<string> {
391
- try {
392
- // Part 1: Retrieve System Info
393
- // Load sso component config.loadComponentConfig Call Config. by passing:
394
- // filepath: '/component-config/sso-config.json'
395
- ComponentConfig.loadComponentConfig('./component-config/sso-config.json');
396
-
397
- const config: {
398
- name: string;
399
- code: string;
400
- description: string;
401
- userId: string;
402
- } = ComponentConfig.getComponentConfigValue('@tomei/sso', 'system');
403
-
404
- // Make sure all required fields are provided in the config file.
405
- if (
406
- !config.name ||
407
- !config.code ||
408
- !config.description ||
409
- !config.userId
410
- ) {
411
- throw new Error('Missing required fields in the config file.');
412
- }
413
-
414
- // Retrieve existing System. Call System._Repo findByPk method by passing:
415
- // SystemCode: system.code
416
- // dbTransaction
417
- const system = await System._Repo.findByPk(config.code, {
418
- transaction: dbTransaction,
419
- });
420
-
421
- // If system already exists, skip all steps below and return "System loaded."
422
- if (system) {
423
- return 'System loaded.';
424
- }
425
-
426
- //if system not exists. Call System._Repo create method by passing:
427
- // SystemCode: system.code,
428
- // Name: system.name
429
- // Description: system.description,
430
- // Status: 'Active',
431
- // CreatedById: system.userId
432
- // CreatedAt: current date & time
433
- // UpdatedById: system.userId
434
- // UpdatedAt: current date & time
435
- await System._Repo.create(
436
- {
437
- SystemCode: config.code,
438
- Name: config.name,
439
- Description: config.description,
440
- Status: 'Active',
441
- CreatedById: config.userId,
442
- CreatedAt: new Date(),
443
- UpdatedById: config.userId,
444
- UpdatedAt: new Date(),
445
- },
446
- {
447
- transaction: dbTransaction,
448
- },
449
- );
450
- // Return "System loaded."
451
- return 'System loaded.';
452
- } catch (error) {
453
- throw error;
454
- }
455
- }
456
- }
1
+ import { ClassError, HashTable, ObjectBase } from '@tomei/general';
2
+ import { SystemRepository } from './system.repository';
3
+ import { ISystemAttr } from '../../interfaces/system.interface';
4
+ import { LoginUser } from '../login-user/login-user';
5
+ import { ApplicationConfig, ComponentConfig } from '@tomei/config';
6
+ import { ActionEnum, Activity } from '@tomei/activity-history';
7
+ import { ISystemSearchAttr } from '../../interfaces/system-search-attr.interface';
8
+ import { Op } from 'sequelize';
9
+ import { v4 as uuidv4 } from 'uuid';
10
+
11
+ export class System extends ObjectBase {
12
+ ObjectId: string;
13
+ ObjectName: string;
14
+ TableName = 'sso_System';
15
+ ObjectType = 'System';
16
+ private static _htSystem: HashTable;
17
+
18
+ SystemCode: string;
19
+ Name: string;
20
+ Description: string;
21
+ AccessURL: string;
22
+ GooglePlayURL: string;
23
+ AppleStoreURL: string;
24
+ APIKey: string;
25
+ APISecret: string;
26
+ Status: string;
27
+ private _CreatedById: number;
28
+ private _CreatedAt: Date;
29
+ private _UpdatedById: number;
30
+ private _UpdatedAt: Date;
31
+ private static _Repo = new SystemRepository();
32
+
33
+ get CreatedById(): number {
34
+ return this._CreatedById;
35
+ }
36
+
37
+ get CreatedAt(): Date {
38
+ return this._CreatedAt;
39
+ }
40
+
41
+ get UpdatedById(): number {
42
+ return this._UpdatedById;
43
+ }
44
+
45
+ get UpdatedAt(): Date {
46
+ return this._UpdatedAt;
47
+ }
48
+
49
+ private constructor(systemAttr?: ISystemAttr) {
50
+ super();
51
+ if (systemAttr) {
52
+ this.SystemCode = systemAttr.SystemCode;
53
+ this.Name = systemAttr.Name;
54
+ this.Description = systemAttr?.Description;
55
+ this.AccessURL = systemAttr?.AccessURL;
56
+ this.GooglePlayURL = systemAttr?.GooglePlayURL;
57
+ this.AppleStoreURL = systemAttr?.AppleStoreURL;
58
+ this.APIKey = systemAttr?.APIKey;
59
+ this.APISecret = systemAttr?.APISecret;
60
+ this.Status = systemAttr?.Status;
61
+ this._CreatedById = systemAttr.CreatedById;
62
+ this._CreatedAt = systemAttr.CreatedAt;
63
+ this._UpdatedById = systemAttr.UpdatedById;
64
+ this._UpdatedAt = systemAttr.UpdatedAt;
65
+ }
66
+ }
67
+
68
+ public static async init(dbTransaction: any, SystemCode?: string) {
69
+ try {
70
+ if (SystemCode) {
71
+ const system = await System._Repo.findByPk(SystemCode, {
72
+ transaction: dbTransaction,
73
+ });
74
+ if (system) {
75
+ return new System(system);
76
+ } else {
77
+ throw new ClassError('System', 'SystemErrMsg00', 'System Not Found');
78
+ }
79
+ }
80
+ return new System();
81
+ } catch (error) {
82
+ throw new ClassError(
83
+ 'System',
84
+ 'SystemErrMsg01',
85
+ 'Failed To Initialize System',
86
+ );
87
+ }
88
+ }
89
+
90
+ public async createSystem(
91
+ loginUser: LoginUser,
92
+ dbTransaction: any,
93
+ ): Promise<void> {
94
+ try {
95
+ //Creates a new system in the database.
96
+ //Part 1: Check Privilege
97
+ //Call loginUser.checkPrivilege() method to check if the user has the privilege to create a system.
98
+ const systemCode =
99
+ ApplicationConfig.getComponentConfigValue('system-code');
100
+ const isPrivileged = await loginUser.checkPrivileges(
101
+ systemCode,
102
+ 'System - Create',
103
+ );
104
+ if (!isPrivileged) {
105
+ throw new Error('You do not have permission to list UserGroup.');
106
+ }
107
+
108
+ //Part 2: Validate Input Params
109
+ //If this._SystemCode is missing, throw ClassError
110
+ if (!this.SystemCode) {
111
+ throw new ClassError(
112
+ 'System',
113
+ 'SystemErrMsg02',
114
+ 'SystemCode must have value.',
115
+ );
116
+ }
117
+
118
+ //If this._Name missing, throw ClassError
119
+ if (!this.Name) {
120
+ throw new ClassError(
121
+ 'System',
122
+ 'SystemErrMsg03',
123
+ 'Name must have value.',
124
+ );
125
+ }
126
+
127
+ //If this._Description missing, throw ClassError
128
+ if (!this.Description) {
129
+ throw new ClassError(
130
+ 'System',
131
+ 'SystemErrMsg04',
132
+ 'Description must have value.',
133
+ );
134
+ }
135
+
136
+ //Part 3: Prepare to Insert Data
137
+ //Set private properties
138
+ this._CreatedById = loginUser.UserId;
139
+ this._CreatedAt = new Date();
140
+ this._UpdatedById = loginUser.UserId;
141
+ this._UpdatedAt = new Date();
142
+
143
+ //Call System._Repo create method
144
+ await System._Repo.create(
145
+ {
146
+ SystemCode: this.SystemCode,
147
+ Name: this.Name,
148
+ Description: this.Description,
149
+ AccessURL: this.AccessURL,
150
+ GooglePlayURL: this.GooglePlayURL,
151
+ AppleStoreURL: this.AppleStoreURL,
152
+ APIKey: this.APIKey,
153
+ APISecret: this.APISecret,
154
+ Status: this.Status,
155
+ CreatedById: this._CreatedById,
156
+ CreatedAt: this._CreatedAt,
157
+ UpdatedById: this._UpdatedById,
158
+ UpdatedAt: this._UpdatedAt,
159
+ },
160
+ {
161
+ transaction: dbTransaction,
162
+ },
163
+ );
164
+
165
+ //Part 4: Record Create System Activity
166
+ //Initialise EntityValueAfter variable and set to this class.
167
+ const entityValueAfter = {
168
+ SystemCode: this.SystemCode,
169
+ Name: this.Name,
170
+ Description: this.Description,
171
+ AccessURL: this.AccessURL,
172
+ GooglePlayURL: this.GooglePlayURL,
173
+ AppleStoreURL: this.AppleStoreURL,
174
+ APIKey: this.APIKey,
175
+ APISecret: this.APISecret,
176
+ Status: this.Status,
177
+ };
178
+
179
+ //Instantiate new activity from Activity class, call createId() method, then set the properties.
180
+ const activity = new Activity();
181
+ activity.ActivityId = activity.createId();
182
+ activity.Action = ActionEnum.CREATE;
183
+ activity.Description = 'Add System';
184
+ activity.EntityType = 'System';
185
+ activity.EntityId = this.SystemCode;
186
+ activity.EntityValueBefore = JSON.stringify({});
187
+ activity.EntityValueAfter = JSON.stringify(entityValueAfter);
188
+ } catch (error) {
189
+ throw error;
190
+ }
191
+ }
192
+
193
+ protected static async checkDuplicateSystemCode(
194
+ dbTransaction: any,
195
+ systemCode: string,
196
+ ): Promise<void> {
197
+ //This method will make sure there is no duplicate system code.
198
+ try {
199
+ //Call System._Repo findOne() method by passing Params.SystemCode and dbTransaction, if SystemCode already exists, throw ClassError.
200
+ const system = await System._Repo.findOne({
201
+ where: {
202
+ SystemCode: systemCode,
203
+ },
204
+ transaction: dbTransaction,
205
+ });
206
+
207
+ if (system) {
208
+ throw new ClassError(
209
+ 'System',
210
+ 'SystemErrMsg05',
211
+ 'System Code already exists.',
212
+ );
213
+ }
214
+ } catch (error) {
215
+ throw error;
216
+ }
217
+ }
218
+
219
+ public async setSystemCode(
220
+ dbTransaction: any,
221
+ systemCode: string,
222
+ ): Promise<void> {
223
+ //Custom setter method for SystemCode
224
+ try {
225
+ //Call checkDuplicateSystemCode() method to make sure there is no duplicate system code.
226
+ await System.checkDuplicateSystemCode(dbTransaction, systemCode);
227
+ //Set this._SystemCode to Params.SystemCode
228
+ this.SystemCode = systemCode;
229
+ } catch (error) {
230
+ throw error;
231
+ }
232
+ }
233
+
234
+ public static async findAll(
235
+ dbTransaction: any,
236
+ loginUser: LoginUser,
237
+ page?: number,
238
+ rows?: number,
239
+ search?: ISystemSearchAttr,
240
+ ): Promise<{ count: number; systems: System[] }> {
241
+ //This method list all system records based on filter.
242
+ try {
243
+ //Part 1: Retrieve listing
244
+ const queryObj: any = {};
245
+ const whereObj: any = {};
246
+ if (search) {
247
+ Object.entries(search).forEach(([key, value]) => {
248
+ if (value) {
249
+ queryObj[key] = {
250
+ [Op.substring]: value,
251
+ };
252
+ }
253
+ });
254
+ }
255
+
256
+ if (page && rows) {
257
+ whereObj.offset = (page - 1) * rows;
258
+ whereObj.limit = rows;
259
+ }
260
+
261
+ //Call System._Repo findAll() method by passing queryObj and whereObj
262
+ const result = await System._Repo.findAllWithPagination({
263
+ distinct: true,
264
+ where: queryObj,
265
+ ...whereObj,
266
+ order: [['CreatedAt', 'DESC']],
267
+ transaction: dbTransaction,
268
+ });
269
+
270
+ //Return result
271
+ const systems = result.rows.map((system) => new System(system));
272
+ return { count: result.count, systems };
273
+ } catch (error) {
274
+ throw error;
275
+ }
276
+ }
277
+
278
+ public static async renewApiKeyAndSecret(
279
+ loginUser: LoginUser,
280
+ dbTransaction: any,
281
+ systemCode: string,
282
+ ) {
283
+ try {
284
+ //Part 1: Privilege Checking
285
+ //Call loginUser.checkPrivilege() method to check if the user has the privilege to renew API Key and Secret.
286
+ const sc = ApplicationConfig.getComponentConfigValue('system-code');
287
+ const isPrivileged = await loginUser.checkPrivileges(sc, 'SYSTEM_UPDATE');
288
+
289
+ if (!isPrivileged) {
290
+ throw new ClassError(
291
+ 'System',
292
+ 'SystemErrMsg06',
293
+ 'You do not have permission to renew API Key and Secret.',
294
+ );
295
+ }
296
+
297
+ //Part 2: Validation
298
+ //Instantiate existing System
299
+ const system = await System.init(dbTransaction, systemCode);
300
+
301
+ //Check if system.AccessURL got value. If not, throw new ClassError
302
+ if (!system.AccessURL) {
303
+ throw new ClassError(
304
+ 'System',
305
+ 'SystemErrMsg07',
306
+ 'AccessURL is required for callback',
307
+ );
308
+ }
309
+
310
+ //Check if system.Status is "Active". If not, throw new ClassError
311
+ if (system.Status !== 'Active') {
312
+ throw new ClassError(
313
+ 'System',
314
+ 'SystemErrMsg08',
315
+ 'Cannot do this operation on inactive system.',
316
+ );
317
+ }
318
+
319
+ //Set EntityValueBefore to system instance.
320
+ const entityValueBefore = {
321
+ SystemCode: system.SystemCode,
322
+ Name: system.Name,
323
+ Description: system.Description,
324
+ AccessURL: system.AccessURL,
325
+ GooglePlayURL: system.GooglePlayURL,
326
+ AppleStoreURL: system.AppleStoreURL,
327
+ APIKey: system.APIKey,
328
+ APISecret: system.APISecret,
329
+ Status: system.Status,
330
+ };
331
+
332
+ //Part 3: Generate API key and secret
333
+ //Use https://www.npmjs.com/package/uuid package to generate both the api key and api secret.
334
+ const apiKey = uuidv4();
335
+ const apiSecret = uuidv4();
336
+
337
+ //Update the system instance with new API key and secret.
338
+ system.APIKey = apiKey;
339
+ system.APISecret = apiSecret;
340
+ system._UpdatedById = loginUser.UserId;
341
+ system._UpdatedAt = new Date();
342
+ //Call System._Repo update() method to update the system record.
343
+ await System._Repo.update(
344
+ {
345
+ APIKey: apiKey,
346
+ APISecret: apiSecret,
347
+ UpdatedById: system._UpdatedById,
348
+ UpdatedAt: system._UpdatedAt,
349
+ },
350
+ {
351
+ where: {
352
+ SystemCode: systemCode,
353
+ },
354
+ transaction: dbTransaction,
355
+ },
356
+ );
357
+
358
+ //Part 4: Record Renew API Key and Secret Activity
359
+ //Set EntityValueAfter to system instance.
360
+ const entityValueAfter = {
361
+ SystemCode: system.SystemCode,
362
+ Name: system.Name,
363
+ Description: system.Description,
364
+ AccessURL: system.AccessURL,
365
+ GooglePlayURL: system.GooglePlayURL,
366
+ AppleStoreURL: system.AppleStoreURL,
367
+ APIKey: system.APIKey,
368
+ APISecret: system.APISecret,
369
+ Status: system.Status,
370
+ };
371
+
372
+ //Instantiate new activity from Activity class, call createId() method, then set the properties.
373
+ const activity = new Activity();
374
+ activity.ActivityId = activity.createId();
375
+ activity.Action = ActionEnum.UPDATE;
376
+ activity.Description = 'Renew API key and secret for a system';
377
+ activity.EntityType = 'System';
378
+ activity.EntityId = system.SystemCode;
379
+ activity.EntityValueBefore = JSON.stringify(entityValueBefore);
380
+ activity.EntityValueAfter = JSON.stringify(entityValueAfter);
381
+
382
+ await activity.create(loginUser.ObjectId, dbTransaction);
383
+ //Return the updated system instance.
384
+ return system;
385
+ } catch (error) {
386
+ throw error;
387
+ }
388
+ }
389
+
390
+ public static async loadSystem(dbTransaction): Promise<string> {
391
+ try {
392
+ // Part 1: Retrieve System Info
393
+ // Load sso component config.loadComponentConfig Call Config. by passing:
394
+ // filepath: '/component-config/sso-config.json'
395
+ ComponentConfig.loadComponentConfig('./component-config/sso-config.json');
396
+
397
+ const config: {
398
+ name: string;
399
+ code: string;
400
+ description: string;
401
+ userId: string;
402
+ } = ComponentConfig.getComponentConfigValue('@tomei/sso', 'system');
403
+
404
+ // Make sure all required fields are provided in the config file.
405
+ if (
406
+ !config.name ||
407
+ !config.code ||
408
+ !config.description ||
409
+ !config.userId
410
+ ) {
411
+ throw new Error('Missing required fields in the config file.');
412
+ }
413
+
414
+ // Retrieve existing System. Call System._Repo findByPk method by passing:
415
+ // SystemCode: system.code
416
+ // dbTransaction
417
+ const system = await System._Repo.findByPk(config.code, {
418
+ transaction: dbTransaction,
419
+ });
420
+
421
+ // If system already exists, skip all steps below and return "System loaded."
422
+ if (system) {
423
+ return 'System loaded.';
424
+ }
425
+
426
+ //if system not exists. Call System._Repo create method by passing:
427
+ // SystemCode: system.code,
428
+ // Name: system.name
429
+ // Description: system.description,
430
+ // Status: 'Active',
431
+ // CreatedById: system.userId
432
+ // CreatedAt: current date & time
433
+ // UpdatedById: system.userId
434
+ // UpdatedAt: current date & time
435
+ await System._Repo.create(
436
+ {
437
+ SystemCode: config.code,
438
+ Name: config.name,
439
+ Description: config.description,
440
+ Status: 'Active',
441
+ CreatedById: config.userId,
442
+ CreatedAt: new Date(),
443
+ UpdatedById: config.userId,
444
+ UpdatedAt: new Date(),
445
+ },
446
+ {
447
+ transaction: dbTransaction,
448
+ },
449
+ );
450
+ // Return "System loaded."
451
+ return 'System loaded.';
452
+ } catch (error) {
453
+ throw error;
454
+ }
455
+ }
456
+ }