@minimaltech/node-infra 0.5.9-22 → 0.5.9-23

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 (560) hide show
  1. package/dist/base/applications/base.application.js +41 -28
  2. package/dist/base/applications/base.application.js.map +1 -0
  3. package/dist/base/applications/default.application.js +9 -2
  4. package/dist/base/applications/default.application.js.map +1 -0
  5. package/dist/base/applications/index.js +1 -0
  6. package/dist/base/applications/index.js.map +1 -0
  7. package/dist/base/base.component.js +3 -2
  8. package/dist/base/base.component.js.map +1 -0
  9. package/dist/base/base.helper.js +4 -4
  10. package/dist/base/base.helper.js.map +1 -0
  11. package/dist/base/base.provider.js +3 -2
  12. package/dist/base/base.provider.js.map +1 -0
  13. package/dist/base/base.sequence.js +27 -17
  14. package/dist/base/base.sequence.js.map +1 -0
  15. package/dist/base/controllers/common.js +10 -8
  16. package/dist/base/controllers/common.js.map +1 -0
  17. package/dist/base/controllers/crud.controller.js +68 -55
  18. package/dist/base/controllers/crud.controller.js.map +1 -0
  19. package/dist/base/controllers/express-request-handler.js +1 -2
  20. package/dist/base/controllers/express-request-handler.js.map +1 -0
  21. package/dist/base/controllers/index.js +1 -0
  22. package/dist/base/controllers/index.js.map +1 -0
  23. package/dist/base/controllers/kv.controller.js +19 -7
  24. package/dist/base/controllers/kv.controller.js.map +1 -0
  25. package/dist/base/controllers/relational.controller.d.ts +3 -1
  26. package/dist/base/controllers/relational.controller.js +58 -40
  27. package/dist/base/controllers/relational.controller.js.map +1 -0
  28. package/dist/base/controllers/service-crud.controller.js +47 -46
  29. package/dist/base/controllers/service-crud.controller.js.map +1 -0
  30. package/dist/base/datasources/base.datasource.js +1 -1
  31. package/dist/base/datasources/base.datasource.js.map +1 -0
  32. package/dist/base/datasources/index.js +1 -0
  33. package/dist/base/datasources/index.js.map +1 -0
  34. package/dist/base/datasources/types.js +1 -0
  35. package/dist/base/datasources/types.js.map +1 -0
  36. package/dist/base/index.js +1 -0
  37. package/dist/base/index.js.map +1 -0
  38. package/dist/base/loopback/@lb/auth/index.js +1 -0
  39. package/dist/base/loopback/@lb/auth/index.js.map +1 -0
  40. package/dist/base/loopback/@lb/core/index.js +2 -0
  41. package/dist/base/loopback/@lb/core/index.js.map +1 -0
  42. package/dist/base/loopback/@lb/repository/index.js +2 -0
  43. package/dist/base/loopback/@lb/repository/index.js.map +1 -0
  44. package/dist/base/loopback/@lb/rest/index.js +1 -0
  45. package/dist/base/loopback/@lb/rest/index.js.map +1 -0
  46. package/dist/base/loopback/authentication/index.js +3 -0
  47. package/dist/base/loopback/authentication/index.js.map +1 -0
  48. package/dist/base/loopback/authorization/index.js +1 -0
  49. package/dist/base/loopback/authorization/index.js.map +1 -0
  50. package/dist/base/loopback/boot/index.js +1 -0
  51. package/dist/base/loopback/boot/index.js.map +1 -0
  52. package/dist/base/loopback/core/index.js +1 -0
  53. package/dist/base/loopback/core/index.js.map +1 -0
  54. package/dist/base/loopback/filter/index.js +3 -0
  55. package/dist/base/loopback/filter/index.js.map +1 -0
  56. package/dist/base/loopback/health-check/index.js +1 -0
  57. package/dist/base/loopback/health-check/index.js.map +1 -0
  58. package/dist/base/loopback/http-server/index.js +3 -0
  59. package/dist/base/loopback/http-server/index.js.map +1 -0
  60. package/dist/base/loopback/metadata/index.js +1 -0
  61. package/dist/base/loopback/metadata/index.js.map +1 -0
  62. package/dist/base/loopback/repository/index.js +1 -0
  63. package/dist/base/loopback/repository/index.js.map +1 -0
  64. package/dist/base/loopback/rest/index.js +1 -0
  65. package/dist/base/loopback/rest/index.js.map +1 -0
  66. package/dist/base/loopback/security/index.js +1 -0
  67. package/dist/base/loopback/security/index.js.map +1 -0
  68. package/dist/base/loopback/service-proxy/index.js +1 -0
  69. package/dist/base/loopback/service-proxy/index.js.map +1 -0
  70. package/dist/base/models/base.model.d.ts +7 -0
  71. package/dist/base/models/base.model.js +24 -5
  72. package/dist/base/models/base.model.js.map +1 -0
  73. package/dist/base/models/index.js +1 -0
  74. package/dist/base/models/index.js.map +1 -0
  75. package/dist/base/repositories/base.repository.d.ts +3 -0
  76. package/dist/base/repositories/base.repository.js +25 -5
  77. package/dist/base/repositories/base.repository.js.map +1 -0
  78. package/dist/base/repositories/index.js +1 -0
  79. package/dist/base/repositories/index.js.map +1 -0
  80. package/dist/base/repositories/relations/has-many-polymorphic/decorator.d.ts +8 -0
  81. package/dist/base/repositories/relations/has-many-polymorphic/decorator.js +11 -11
  82. package/dist/base/repositories/relations/has-many-polymorphic/decorator.js.map +1 -0
  83. package/dist/base/repositories/relations/has-many-polymorphic/factory.d.ts +9 -0
  84. package/dist/base/repositories/relations/has-many-polymorphic/factory.js +31 -12
  85. package/dist/base/repositories/relations/has-many-polymorphic/factory.js.map +1 -0
  86. package/dist/base/repositories/relations/has-many-polymorphic/index.js +1 -0
  87. package/dist/base/repositories/relations/has-many-polymorphic/index.js.map +1 -0
  88. package/dist/base/repositories/relations/has-many-polymorphic/types.js +1 -0
  89. package/dist/base/repositories/relations/has-many-polymorphic/types.js.map +1 -0
  90. package/dist/base/repositories/relations/index.js +1 -0
  91. package/dist/base/repositories/relations/index.js.map +1 -0
  92. package/dist/base/repositories/searchable-tz-crud.repository.js +161 -129
  93. package/dist/base/repositories/searchable-tz-crud.repository.js.map +1 -0
  94. package/dist/base/repositories/tz-crud.repository.js +59 -23
  95. package/dist/base/repositories/tz-crud.repository.js.map +1 -0
  96. package/dist/base/services/base-crud.service.js +10 -6
  97. package/dist/base/services/base-crud.service.js.map +1 -0
  98. package/dist/base/services/base.service.js +3 -2
  99. package/dist/base/services/base.service.js.map +1 -0
  100. package/dist/base/services/index.js +1 -0
  101. package/dist/base/services/index.js.map +1 -0
  102. package/dist/common/constants.js +90 -81
  103. package/dist/common/constants.js.map +1 -0
  104. package/dist/common/environments.js +26 -25
  105. package/dist/common/environments.js.map +1 -0
  106. package/dist/common/index.js +1 -0
  107. package/dist/common/index.js.map +1 -0
  108. package/dist/common/keys.js +3 -2
  109. package/dist/common/keys.js.map +1 -0
  110. package/dist/common/statuses.js +32 -28
  111. package/dist/common/statuses.js.map +1 -0
  112. package/dist/common/types.d.ts +3 -0
  113. package/dist/common/types.js +1 -0
  114. package/dist/common/types.js.map +1 -0
  115. package/dist/components/authenticate/common/constants.js +14 -11
  116. package/dist/components/authenticate/common/constants.js.map +1 -0
  117. package/dist/components/authenticate/common/index.js +1 -0
  118. package/dist/components/authenticate/common/index.js.map +1 -0
  119. package/dist/components/authenticate/common/keys.js +8 -7
  120. package/dist/components/authenticate/common/keys.js.map +1 -0
  121. package/dist/components/authenticate/common/types.js +4 -11
  122. package/dist/components/authenticate/common/types.js.map +1 -0
  123. package/dist/components/authenticate/component.js +29 -20
  124. package/dist/components/authenticate/component.js.map +1 -0
  125. package/dist/components/authenticate/controllers/auth.controller.js +12 -13
  126. package/dist/components/authenticate/controllers/auth.controller.js.map +1 -0
  127. package/dist/components/authenticate/controllers/index.js +1 -0
  128. package/dist/components/authenticate/controllers/index.js.map +1 -0
  129. package/dist/components/authenticate/controllers/oauth2.controller.js +21 -18
  130. package/dist/components/authenticate/controllers/oauth2.controller.js.map +1 -0
  131. package/dist/components/authenticate/index.js +1 -0
  132. package/dist/components/authenticate/index.js.map +1 -0
  133. package/dist/components/authenticate/middleware.js +36 -25
  134. package/dist/components/authenticate/middleware.js.map +1 -0
  135. package/dist/components/authenticate/models/index.js +1 -0
  136. package/dist/components/authenticate/models/index.js.map +1 -0
  137. package/dist/components/authenticate/models/oauth2-client.model.js +4 -8
  138. package/dist/components/authenticate/models/oauth2-client.model.js.map +1 -0
  139. package/dist/components/authenticate/models/oauth2-scope.model.js +1 -4
  140. package/dist/components/authenticate/models/oauth2-scope.model.js.map +1 -0
  141. package/dist/components/authenticate/models/oauth2-token.model.js +1 -7
  142. package/dist/components/authenticate/models/oauth2-token.model.js.map +1 -0
  143. package/dist/components/authenticate/oauth2-handlers/authorization-code.handler.js +6 -4
  144. package/dist/components/authenticate/oauth2-handlers/authorization-code.handler.js.map +1 -0
  145. package/dist/components/authenticate/oauth2-handlers/base.js +111 -95
  146. package/dist/components/authenticate/oauth2-handlers/base.js.map +1 -0
  147. package/dist/components/authenticate/oauth2-handlers/client-credential.handler.js +4 -2
  148. package/dist/components/authenticate/oauth2-handlers/client-credential.handler.js.map +1 -0
  149. package/dist/components/authenticate/oauth2-handlers/index.js +1 -0
  150. package/dist/components/authenticate/oauth2-handlers/index.js.map +1 -0
  151. package/dist/components/authenticate/oauth2-handlers/oauth2.js +3 -3
  152. package/dist/components/authenticate/oauth2-handlers/oauth2.js.map +1 -0
  153. package/dist/components/authenticate/oauth2-handlers/password.handler.js +1 -0
  154. package/dist/components/authenticate/oauth2-handlers/password.handler.js.map +1 -0
  155. package/dist/components/authenticate/repositories/index.js +1 -0
  156. package/dist/components/authenticate/repositories/index.js.map +1 -0
  157. package/dist/components/authenticate/repositories/oauth2.repository.js +1 -2
  158. package/dist/components/authenticate/repositories/oauth2.repository.js.map +1 -0
  159. package/dist/components/authenticate/services/basic-token.service.js +30 -18
  160. package/dist/components/authenticate/services/basic-token.service.js.map +1 -0
  161. package/dist/components/authenticate/services/basic.strategy.js +18 -7
  162. package/dist/components/authenticate/services/basic.strategy.js.map +1 -0
  163. package/dist/components/authenticate/services/index.js +1 -0
  164. package/dist/components/authenticate/services/index.js.map +1 -0
  165. package/dist/components/authenticate/services/jwt-token.service.js +41 -27
  166. package/dist/components/authenticate/services/jwt-token.service.js.map +1 -0
  167. package/dist/components/authenticate/services/jwt.strategy.js +2 -2
  168. package/dist/components/authenticate/services/jwt.strategy.js.map +1 -0
  169. package/dist/components/authenticate/services/oauth2.service.js +111 -98
  170. package/dist/components/authenticate/services/oauth2.service.js.map +1 -0
  171. package/dist/components/authenticate/services/oauth2.strategy.js +32 -19
  172. package/dist/components/authenticate/services/oauth2.strategy.js.map +1 -0
  173. package/dist/components/authorize/adapters/adapter-builder.js +1 -1
  174. package/dist/components/authorize/adapters/adapter-builder.js.map +1 -0
  175. package/dist/components/authorize/adapters/base.adapter.js +10 -2
  176. package/dist/components/authorize/adapters/base.adapter.js.map +1 -0
  177. package/dist/components/authorize/adapters/casbin-postgres-adapter.helper.js +56 -37
  178. package/dist/components/authorize/adapters/casbin-postgres-adapter.helper.js.map +1 -0
  179. package/dist/components/authorize/adapters/casbin-redis-adapter.helper.js +2 -0
  180. package/dist/components/authorize/adapters/casbin-redis-adapter.helper.js.map +1 -0
  181. package/dist/components/authorize/adapters/index.js +1 -0
  182. package/dist/components/authorize/adapters/index.js.map +1 -0
  183. package/dist/components/authorize/common/constants.js +13 -10
  184. package/dist/components/authorize/common/constants.js.map +1 -0
  185. package/dist/components/authorize/common/index.js +1 -0
  186. package/dist/components/authorize/common/index.js.map +1 -0
  187. package/dist/components/authorize/common/keys.js +16 -15
  188. package/dist/components/authorize/common/keys.js.map +1 -0
  189. package/dist/components/authorize/common/types.js +3 -2
  190. package/dist/components/authorize/common/types.js.map +1 -0
  191. package/dist/components/authorize/component.js +60 -44
  192. package/dist/components/authorize/component.js.map +1 -0
  193. package/dist/components/authorize/decorators/index.d.ts +11 -0
  194. package/dist/components/authorize/decorators/index.js +15 -1
  195. package/dist/components/authorize/decorators/index.js.map +1 -0
  196. package/dist/components/authorize/index.js +1 -0
  197. package/dist/components/authorize/index.js.map +1 -0
  198. package/dist/components/authorize/interceptor.js +81 -76
  199. package/dist/components/authorize/interceptor.js.map +1 -0
  200. package/dist/components/authorize/migrations/0000-create-view-policy.js +15 -3
  201. package/dist/components/authorize/migrations/0000-create-view-policy.js.map +1 -0
  202. package/dist/components/authorize/migrations/index.js +1 -0
  203. package/dist/components/authorize/migrations/index.js.map +1 -0
  204. package/dist/components/authorize/models/defs.js +6 -24
  205. package/dist/components/authorize/models/defs.js.map +1 -0
  206. package/dist/components/authorize/models/index.js +1 -0
  207. package/dist/components/authorize/models/index.js.map +1 -0
  208. package/dist/components/authorize/models/permission-mapping.model.js +1 -0
  209. package/dist/components/authorize/models/permission-mapping.model.js.map +1 -0
  210. package/dist/components/authorize/models/permission.model.js +1 -0
  211. package/dist/components/authorize/models/permission.model.js.map +1 -0
  212. package/dist/components/authorize/models/role.model.js +2 -1
  213. package/dist/components/authorize/models/role.model.js.map +1 -0
  214. package/dist/components/authorize/models/user-role.model.js +2 -0
  215. package/dist/components/authorize/models/user-role.model.js.map +1 -0
  216. package/dist/components/authorize/models/view-authorize-policy.model.js +2 -4
  217. package/dist/components/authorize/models/view-authorize-policy.model.js.map +1 -0
  218. package/dist/components/authorize/provider.js +97 -81
  219. package/dist/components/authorize/provider.js.map +1 -0
  220. package/dist/components/authorize/repositories/authorize.repository.js +7 -3
  221. package/dist/components/authorize/repositories/authorize.repository.js.map +1 -0
  222. package/dist/components/authorize/repositories/index.js +1 -0
  223. package/dist/components/authorize/repositories/index.js.map +1 -0
  224. package/dist/components/authorize/services/enforcer.service.js +28 -20
  225. package/dist/components/authorize/services/enforcer.service.js.map +1 -0
  226. package/dist/components/authorize/services/generator.service.d.ts +20 -0
  227. package/dist/components/authorize/services/generator.service.js +97 -62
  228. package/dist/components/authorize/services/generator.service.js.map +1 -0
  229. package/dist/components/authorize/services/index.js +1 -0
  230. package/dist/components/authorize/services/index.js.map +1 -0
  231. package/dist/components/crash-report/common/constants.js +1 -0
  232. package/dist/components/crash-report/common/constants.js.map +1 -0
  233. package/dist/components/crash-report/common/index.js +1 -0
  234. package/dist/components/crash-report/common/index.js.map +1 -0
  235. package/dist/components/crash-report/common/keys.js +11 -8
  236. package/dist/components/crash-report/common/keys.js.map +1 -0
  237. package/dist/components/crash-report/common/types.js +1 -0
  238. package/dist/components/crash-report/common/types.js.map +1 -0
  239. package/dist/components/crash-report/component.js +45 -31
  240. package/dist/components/crash-report/component.js.map +1 -0
  241. package/dist/components/crash-report/index.js +1 -0
  242. package/dist/components/crash-report/index.js.map +1 -0
  243. package/dist/components/crash-report/providers/index.js +1 -0
  244. package/dist/components/crash-report/providers/index.js.map +1 -0
  245. package/dist/components/crash-report/providers/provider.js +1 -1
  246. package/dist/components/crash-report/providers/provider.js.map +1 -0
  247. package/dist/components/crash-report/providers/third-parties/base.js +3 -2
  248. package/dist/components/crash-report/providers/third-parties/base.js.map +1 -0
  249. package/dist/components/crash-report/providers/third-parties/index.js +1 -0
  250. package/dist/components/crash-report/providers/third-parties/index.js.map +1 -0
  251. package/dist/components/crash-report/services/index.js +1 -0
  252. package/dist/components/crash-report/services/index.js.map +1 -0
  253. package/dist/components/crash-report/services/mt-crash-report.service.js +6 -5
  254. package/dist/components/crash-report/services/mt-crash-report.service.js.map +1 -0
  255. package/dist/components/grpc/common/constants.js +1 -0
  256. package/dist/components/grpc/common/constants.js.map +1 -0
  257. package/dist/components/grpc/common/index.js +1 -0
  258. package/dist/components/grpc/common/index.js.map +1 -0
  259. package/dist/components/grpc/common/keys.js +5 -4
  260. package/dist/components/grpc/common/keys.js.map +1 -0
  261. package/dist/components/grpc/common/types.js +1 -0
  262. package/dist/components/grpc/common/types.js.map +1 -0
  263. package/dist/components/grpc/components/index.js +1 -0
  264. package/dist/components/grpc/components/index.js.map +1 -0
  265. package/dist/components/grpc/components/server.component.js +9 -8
  266. package/dist/components/grpc/components/server.component.js.map +1 -0
  267. package/dist/components/grpc/controllers/base.js +1 -1
  268. package/dist/components/grpc/controllers/base.js.map +1 -0
  269. package/dist/components/grpc/controllers/index.js +1 -0
  270. package/dist/components/grpc/controllers/index.js.map +1 -0
  271. package/dist/components/grpc/decorators/index.js +1 -0
  272. package/dist/components/grpc/decorators/index.js.map +1 -0
  273. package/dist/components/grpc/helpers/grpc-client.js +4 -9
  274. package/dist/components/grpc/helpers/grpc-client.js.map +1 -0
  275. package/dist/components/grpc/helpers/grpc-server.js +18 -14
  276. package/dist/components/grpc/helpers/grpc-server.js.map +1 -0
  277. package/dist/components/grpc/helpers/index.js +1 -0
  278. package/dist/components/grpc/helpers/index.js.map +1 -0
  279. package/dist/components/grpc/index.js +1 -0
  280. package/dist/components/grpc/index.js.map +1 -0
  281. package/dist/components/grpc/persistents/grpc.connector.js +3 -8
  282. package/dist/components/grpc/persistents/grpc.connector.js.map +1 -0
  283. package/dist/components/grpc/persistents/grpc.datasource.js +4 -2
  284. package/dist/components/grpc/persistents/grpc.datasource.js.map +1 -0
  285. package/dist/components/grpc/persistents/grpc.repository.js +3 -3
  286. package/dist/components/grpc/persistents/grpc.repository.js.map +1 -0
  287. package/dist/components/grpc/persistents/index.js +1 -0
  288. package/dist/components/grpc/persistents/index.js.map +1 -0
  289. package/dist/components/health-check/component.js +1 -1
  290. package/dist/components/health-check/component.js.map +1 -0
  291. package/dist/components/health-check/index.js +1 -0
  292. package/dist/components/health-check/index.js.map +1 -0
  293. package/dist/components/index.js +1 -0
  294. package/dist/components/index.js.map +1 -0
  295. package/dist/components/migration/common/index.js +1 -0
  296. package/dist/components/migration/common/index.js.map +1 -0
  297. package/dist/components/migration/common/keys.js +4 -3
  298. package/dist/components/migration/common/keys.js.map +1 -0
  299. package/dist/components/migration/common/types.js +1 -0
  300. package/dist/components/migration/common/types.js.map +1 -0
  301. package/dist/components/migration/component.js +9 -5
  302. package/dist/components/migration/component.js.map +1 -0
  303. package/dist/components/migration/index.js +1 -0
  304. package/dist/components/migration/index.js.map +1 -0
  305. package/dist/components/migration/models/index.js +1 -0
  306. package/dist/components/migration/models/index.js.map +1 -0
  307. package/dist/components/migration/models/migration.model.js +1 -2
  308. package/dist/components/migration/models/migration.model.js.map +1 -0
  309. package/dist/components/migration/repositories/index.js +1 -0
  310. package/dist/components/migration/repositories/index.js.map +1 -0
  311. package/dist/components/migration/repositories/migration.repository.js +1 -0
  312. package/dist/components/migration/repositories/migration.repository.js.map +1 -0
  313. package/dist/components/socket-io/common/constants.js +11 -10
  314. package/dist/components/socket-io/common/constants.js.map +1 -0
  315. package/dist/components/socket-io/common/index.js +1 -0
  316. package/dist/components/socket-io/common/index.js.map +1 -0
  317. package/dist/components/socket-io/common/keys.js +7 -6
  318. package/dist/components/socket-io/common/keys.js.map +1 -0
  319. package/dist/components/socket-io/component.js +9 -9
  320. package/dist/components/socket-io/component.js.map +1 -0
  321. package/dist/components/socket-io/helpers/index.js +1 -0
  322. package/dist/components/socket-io/helpers/index.js.map +1 -0
  323. package/dist/components/socket-io/helpers/socket-io-client.helper.js +12 -7
  324. package/dist/components/socket-io/helpers/socket-io-client.helper.js.map +1 -0
  325. package/dist/components/socket-io/helpers/socket-io-server.helper.js +42 -26
  326. package/dist/components/socket-io/helpers/socket-io-server.helper.js.map +1 -0
  327. package/dist/components/socket-io/index.js +1 -0
  328. package/dist/components/socket-io/index.js.map +1 -0
  329. package/dist/components/static-asset/common/index.js +1 -0
  330. package/dist/components/static-asset/common/index.js.map +1 -0
  331. package/dist/components/static-asset/common/keys.js +5 -4
  332. package/dist/components/static-asset/common/keys.js.map +1 -0
  333. package/dist/components/static-asset/component.js +9 -9
  334. package/dist/components/static-asset/component.js.map +1 -0
  335. package/dist/components/static-asset/controllers/asset.controller.d.ts +8 -0
  336. package/dist/components/static-asset/controllers/asset.controller.js +94 -71
  337. package/dist/components/static-asset/controllers/asset.controller.js.map +1 -0
  338. package/dist/components/static-asset/controllers/index.js +1 -0
  339. package/dist/components/static-asset/controllers/index.js.map +1 -0
  340. package/dist/components/static-asset/controllers/resource.controller.js +10 -8
  341. package/dist/components/static-asset/controllers/resource.controller.js.map +1 -0
  342. package/dist/components/static-asset/index.js +1 -0
  343. package/dist/components/static-asset/index.js.map +1 -0
  344. package/dist/datasources/index.js +1 -0
  345. package/dist/datasources/index.js.map +1 -0
  346. package/dist/datasources/memory/datasource.js +4 -3
  347. package/dist/datasources/memory/datasource.js.map +1 -0
  348. package/dist/datasources/memory/index.js +1 -0
  349. package/dist/datasources/memory/index.js.map +1 -0
  350. package/dist/datasources/postgres/datasource.js +11 -10
  351. package/dist/datasources/postgres/datasource.js.map +1 -0
  352. package/dist/datasources/postgres/index.js +1 -0
  353. package/dist/datasources/postgres/index.js.map +1 -0
  354. package/dist/datasources/postgres/types.js +1 -0
  355. package/dist/datasources/postgres/types.js.map +1 -0
  356. package/dist/datasources/redis/connector.js +8 -18
  357. package/dist/datasources/redis/connector.js.map +1 -0
  358. package/dist/datasources/redis/datasource.js +8 -7
  359. package/dist/datasources/redis/datasource.js.map +1 -0
  360. package/dist/datasources/redis/index.js +1 -0
  361. package/dist/datasources/redis/index.js.map +1 -0
  362. package/dist/datasources/redis/types.js +1 -0
  363. package/dist/datasources/redis/types.js.map +1 -0
  364. package/dist/helpers/application-environment.helper.js +4 -3
  365. package/dist/helpers/application-environment.helper.js.map +1 -0
  366. package/dist/helpers/cron.helper.js +15 -9
  367. package/dist/helpers/cron.helper.js.map +1 -0
  368. package/dist/helpers/crypto/algorithms/aes.algorithm.js +8 -8
  369. package/dist/helpers/crypto/algorithms/aes.algorithm.js.map +1 -0
  370. package/dist/helpers/crypto/algorithms/base.algorithm.js +5 -3
  371. package/dist/helpers/crypto/algorithms/base.algorithm.js.map +1 -0
  372. package/dist/helpers/crypto/algorithms/index.js +1 -0
  373. package/dist/helpers/crypto/algorithms/index.js.map +1 -0
  374. package/dist/helpers/crypto/algorithms/rsa.algorithm.js +6 -4
  375. package/dist/helpers/crypto/algorithms/rsa.algorithm.js.map +1 -0
  376. package/dist/helpers/crypto/common/constants.js +1 -0
  377. package/dist/helpers/crypto/common/constants.js.map +1 -0
  378. package/dist/helpers/crypto/common/index.js +1 -0
  379. package/dist/helpers/crypto/common/index.js.map +1 -0
  380. package/dist/helpers/crypto/common/types.js +1 -0
  381. package/dist/helpers/crypto/common/types.js.map +1 -0
  382. package/dist/helpers/crypto/index.js +1 -0
  383. package/dist/helpers/crypto/index.js.map +1 -0
  384. package/dist/helpers/database/index.js +1 -0
  385. package/dist/helpers/database/index.js.map +1 -0
  386. package/dist/helpers/database/query-builder.helper.js +6 -2
  387. package/dist/helpers/database/query-builder.helper.js.map +1 -0
  388. package/dist/helpers/index.js +1 -0
  389. package/dist/helpers/index.js.map +1 -0
  390. package/dist/helpers/logger/application-logger.js +18 -7
  391. package/dist/helpers/logger/application-logger.js.map +1 -0
  392. package/dist/helpers/logger/common/index.js +1 -0
  393. package/dist/helpers/logger/common/index.js.map +1 -0
  394. package/dist/helpers/logger/common/types.js +23 -20
  395. package/dist/helpers/logger/common/types.js.map +1 -0
  396. package/dist/helpers/logger/default-logger.js +13 -2
  397. package/dist/helpers/logger/default-logger.js.map +1 -0
  398. package/dist/helpers/logger/factory.js +2 -1
  399. package/dist/helpers/logger/factory.js.map +1 -0
  400. package/dist/helpers/logger/index.js +1 -0
  401. package/dist/helpers/logger/index.js.map +1 -0
  402. package/dist/helpers/logger/transports/dgram.transport.js +26 -16
  403. package/dist/helpers/logger/transports/dgram.transport.js.map +1 -0
  404. package/dist/helpers/logger/transports/index.js +1 -0
  405. package/dist/helpers/logger/transports/index.js.map +1 -0
  406. package/dist/helpers/network/http-request/base-network-request.helper.js +35 -36
  407. package/dist/helpers/network/http-request/base-network-request.helper.js.map +1 -0
  408. package/dist/helpers/network/http-request/fetcher/axios-fetcher.js +23 -10
  409. package/dist/helpers/network/http-request/fetcher/axios-fetcher.js.map +1 -0
  410. package/dist/helpers/network/http-request/fetcher/base-fetcher.js +37 -13
  411. package/dist/helpers/network/http-request/fetcher/base-fetcher.js.map +1 -0
  412. package/dist/helpers/network/http-request/fetcher/index.js +1 -0
  413. package/dist/helpers/network/http-request/fetcher/index.js.map +1 -0
  414. package/dist/helpers/network/http-request/fetcher/node-fetcher.js +60 -37
  415. package/dist/helpers/network/http-request/fetcher/node-fetcher.js.map +1 -0
  416. package/dist/helpers/network/http-request/index.js +1 -0
  417. package/dist/helpers/network/http-request/index.js.map +1 -0
  418. package/dist/helpers/network/http-request/types.js +1 -0
  419. package/dist/helpers/network/http-request/types.js.map +1 -0
  420. package/dist/helpers/network/index.js +1 -0
  421. package/dist/helpers/network/index.js.map +1 -0
  422. package/dist/helpers/network/tcp-socket/base-tcp-client.helper.js +28 -30
  423. package/dist/helpers/network/tcp-socket/base-tcp-client.helper.js.map +1 -0
  424. package/dist/helpers/network/tcp-socket/base-tcp-server.helper.js +20 -21
  425. package/dist/helpers/network/tcp-socket/base-tcp-server.helper.js.map +1 -0
  426. package/dist/helpers/network/tcp-socket/index.js +1 -0
  427. package/dist/helpers/network/tcp-socket/index.js.map +1 -0
  428. package/dist/helpers/network/tcp-socket/network-tcp-client.helper.js +2 -5
  429. package/dist/helpers/network/tcp-socket/network-tcp-client.helper.js.map +1 -0
  430. package/dist/helpers/network/tcp-socket/network-tcp-server.helper.js +2 -5
  431. package/dist/helpers/network/tcp-socket/network-tcp-server.helper.js.map +1 -0
  432. package/dist/helpers/network/tcp-socket/network-tls-tcp-client.helper.js +2 -5
  433. package/dist/helpers/network/tcp-socket/network-tls-tcp-client.helper.js.map +1 -0
  434. package/dist/helpers/network/tcp-socket/network-tls-tcp-server.helper.js +2 -5
  435. package/dist/helpers/network/tcp-socket/network-tls-tcp-server.helper.js.map +1 -0
  436. package/dist/helpers/network/udp-socket/index.js +1 -0
  437. package/dist/helpers/network/udp-socket/index.js.map +1 -0
  438. package/dist/helpers/network/udp-socket/network-udp-client.helper.js +19 -21
  439. package/dist/helpers/network/udp-socket/network-udp-client.helper.js.map +1 -0
  440. package/dist/helpers/queue/bullmq.helper.js +23 -21
  441. package/dist/helpers/queue/bullmq.helper.js.map +1 -0
  442. package/dist/helpers/queue/index.js +1 -0
  443. package/dist/helpers/queue/index.js.map +1 -0
  444. package/dist/helpers/queue/mqtt.helper.js +18 -15
  445. package/dist/helpers/queue/mqtt.helper.js.map +1 -0
  446. package/dist/helpers/queue/queue.helper.js +146 -74
  447. package/dist/helpers/queue/queue.helper.js.map +1 -0
  448. package/dist/helpers/redis/default.helper.js +163 -117
  449. package/dist/helpers/redis/default.helper.js.map +1 -0
  450. package/dist/helpers/redis/index.js +1 -0
  451. package/dist/helpers/redis/index.js.map +1 -0
  452. package/dist/helpers/redis/redis-cluster.helper.js +3 -7
  453. package/dist/helpers/redis/redis-cluster.helper.js.map +1 -0
  454. package/dist/helpers/redis/redis.helper.js +6 -8
  455. package/dist/helpers/redis/redis.helper.js.map +1 -0
  456. package/dist/helpers/redis/types.js +1 -0
  457. package/dist/helpers/redis/types.js.map +1 -0
  458. package/dist/helpers/storage/di-container.helper.js +1 -2
  459. package/dist/helpers/storage/di-container.helper.js.map +1 -0
  460. package/dist/helpers/storage/index.js +1 -0
  461. package/dist/helpers/storage/index.js.map +1 -0
  462. package/dist/helpers/storage/minio.helper.js +129 -88
  463. package/dist/helpers/storage/minio.helper.js.map +1 -0
  464. package/dist/helpers/testing/common.js +4 -3
  465. package/dist/helpers/testing/common.js.map +1 -0
  466. package/dist/helpers/testing/describe.js +22 -14
  467. package/dist/helpers/testing/describe.js.map +1 -0
  468. package/dist/helpers/testing/index.js +1 -0
  469. package/dist/helpers/testing/index.js.map +1 -0
  470. package/dist/helpers/testing/test-case.js +1 -5
  471. package/dist/helpers/testing/test-case.js.map +1 -0
  472. package/dist/helpers/testing/test-handler.js +31 -23
  473. package/dist/helpers/testing/test-handler.js.map +1 -0
  474. package/dist/helpers/testing/test-plan/base.js +7 -9
  475. package/dist/helpers/testing/test-plan/base.js.map +1 -0
  476. package/dist/helpers/testing/test-plan/default.js +1 -0
  477. package/dist/helpers/testing/test-plan/default.js.map +1 -0
  478. package/dist/helpers/testing/test-plan/index.js +1 -0
  479. package/dist/helpers/testing/test-plan/index.js.map +1 -0
  480. package/dist/helpers/testing/types.js +1 -0
  481. package/dist/helpers/testing/types.js.map +1 -0
  482. package/dist/helpers/worker-thread/base.js +21 -10
  483. package/dist/helpers/worker-thread/base.js.map +1 -0
  484. package/dist/helpers/worker-thread/index.js +1 -0
  485. package/dist/helpers/worker-thread/index.js.map +1 -0
  486. package/dist/helpers/worker-thread/types.js +1 -0
  487. package/dist/helpers/worker-thread/types.js.map +1 -0
  488. package/dist/helpers/worker-thread/worker-bus.js +13 -11
  489. package/dist/helpers/worker-thread/worker-bus.js.map +1 -0
  490. package/dist/helpers/worker-thread/worker-pool.js +26 -17
  491. package/dist/helpers/worker-thread/worker-pool.js.map +1 -0
  492. package/dist/index.js +1 -0
  493. package/dist/index.js.map +1 -0
  494. package/dist/interceptors/content-range.interceptor.js +133 -115
  495. package/dist/interceptors/content-range.interceptor.js.map +1 -0
  496. package/dist/interceptors/index.js +1 -0
  497. package/dist/interceptors/index.js.map +1 -0
  498. package/dist/middlewares/index.js +1 -0
  499. package/dist/middlewares/index.js.map +1 -0
  500. package/dist/middlewares/request-body-parser.middleware.js +17 -4
  501. package/dist/middlewares/request-body-parser.middleware.js.map +1 -0
  502. package/dist/middlewares/request-spy.middleware.js +6 -4
  503. package/dist/middlewares/request-spy.middleware.js.map +1 -0
  504. package/dist/migrations/base-path.js +1 -0
  505. package/dist/migrations/base-path.js.map +1 -0
  506. package/dist/migrations/handler.js +23 -13
  507. package/dist/migrations/handler.js.map +1 -0
  508. package/dist/migrations/index.js +1 -0
  509. package/dist/migrations/index.js.map +1 -0
  510. package/dist/mixins/data-type.mixin.js +1 -5
  511. package/dist/mixins/data-type.mixin.js.map +1 -0
  512. package/dist/mixins/deprecated/user-audit.mixin.d.ts +3 -0
  513. package/dist/mixins/deprecated/user-audit.mixin.js +6 -2
  514. package/dist/mixins/deprecated/user-audit.mixin.js.map +1 -0
  515. package/dist/mixins/duplicatable.mixin.js +1 -1
  516. package/dist/mixins/duplicatable.mixin.js.map +1 -0
  517. package/dist/mixins/index.js +1 -0
  518. package/dist/mixins/index.js.map +1 -0
  519. package/dist/mixins/object-search.mixin.js +1 -1
  520. package/dist/mixins/object-search.mixin.js.map +1 -0
  521. package/dist/mixins/principal.mixin.js +1 -2
  522. package/dist/mixins/principal.mixin.js.map +1 -0
  523. package/dist/mixins/soft-delete.mixin.js +1 -1
  524. package/dist/mixins/soft-delete.mixin.js.map +1 -0
  525. package/dist/mixins/soft-persistent.mixin.js +1 -1
  526. package/dist/mixins/soft-persistent.mixin.js.map +1 -0
  527. package/dist/mixins/text-search.mixin.js +1 -1
  528. package/dist/mixins/text-search.mixin.js.map +1 -0
  529. package/dist/mixins/tz.mixin.js +1 -2
  530. package/dist/mixins/tz.mixin.js.map +1 -0
  531. package/dist/mixins/user-audit.mixin.js +4 -5
  532. package/dist/mixins/user-audit.mixin.js.map +1 -0
  533. package/dist/mixins/vector.mixin.js +7 -9
  534. package/dist/mixins/vector.mixin.js.map +1 -0
  535. package/dist/tsconfig.base.json +4 -11
  536. package/dist/utilities/crypto.utility.js +1 -0
  537. package/dist/utilities/crypto.utility.js.map +1 -0
  538. package/dist/utilities/date.utility.js +24 -5
  539. package/dist/utilities/date.utility.js.map +1 -0
  540. package/dist/utilities/error.utility.js +1 -2
  541. package/dist/utilities/error.utility.js.map +1 -0
  542. package/dist/utilities/index.js +1 -0
  543. package/dist/utilities/index.js.map +1 -0
  544. package/dist/utilities/model.utility.js +7 -2
  545. package/dist/utilities/model.utility.js.map +1 -0
  546. package/dist/utilities/parse.utility.d.ts +16 -0
  547. package/dist/utilities/parse.utility.js +42 -6
  548. package/dist/utilities/parse.utility.js.map +1 -0
  549. package/dist/utilities/performance.utility.js +3 -1
  550. package/dist/utilities/performance.utility.js.map +1 -0
  551. package/dist/utilities/promise.utility.d.ts +17 -0
  552. package/dist/utilities/promise.utility.js +32 -5
  553. package/dist/utilities/promise.utility.js.map +1 -0
  554. package/dist/utilities/query.utility.js +17 -8
  555. package/dist/utilities/query.utility.js.map +1 -0
  556. package/dist/utilities/request.utility.js +9 -2
  557. package/dist/utilities/request.utility.js.map +1 -0
  558. package/dist/utilities/url.utility.js +1 -0
  559. package/dist/utilities/url.utility.js.map +1 -0
  560. package/package.json +8 -10
@@ -1,4 +1,13 @@
1
1
  "use strict";
2
+ var __awaiter = (this && this.__awaiter) || function (thisArg, _arguments, P, generator) {
3
+ function adopt(value) { return value instanceof P ? value : new P(function (resolve) { resolve(value); }); }
4
+ return new (P || (P = Promise))(function (resolve, reject) {
5
+ function fulfilled(value) { try { step(generator.next(value)); } catch (e) { reject(e); } }
6
+ function rejected(value) { try { step(generator["throw"](value)); } catch (e) { reject(e); } }
7
+ function step(result) { result.done ? resolve(result.value) : adopt(result.value).then(fulfilled, rejected); }
8
+ step((generator = generator.apply(thisArg, _arguments || [])).next());
9
+ });
10
+ };
2
11
  var __importDefault = (this && this.__importDefault) || function (mod) {
3
12
  return (mod && mod.__esModule) ? mod : { "default": mod };
4
13
  };
@@ -11,10 +20,12 @@ const get_1 = __importDefault(require("lodash/get"));
11
20
  const isEmpty_1 = __importDefault(require("lodash/isEmpty"));
12
21
  const common_1 = require("../common");
13
22
  const base_adapter_1 = require("./base.adapter");
23
+ // -----------------------------------------------------------------------------------------
14
24
  class CasbinPostgresAdapter extends base_adapter_1.AbstractCasbinAdapter {
15
25
  constructor(datasource) {
16
26
  super({ scope: CasbinPostgresAdapter.name, datasource });
17
27
  }
28
+ // -----------------------------------------------------------------------------------------
18
29
  generateGroupLine(rule) {
19
30
  const { userId, roleId } = rule;
20
31
  const rs = [
@@ -24,45 +35,53 @@ class CasbinPostgresAdapter extends base_adapter_1.AbstractCasbinAdapter {
24
35
  ];
25
36
  return rs.join(',');
26
37
  }
27
- async loadFilteredPolicy(model, filter) {
28
- if (filter?.principalType?.toLowerCase() === 'role') {
29
- throw (0, utilities_1.getError)({
30
- statusCode: 500,
31
- message: '[loadFilteredPolicy] Only "User" is allowed for filter principal type!',
32
- });
33
- }
34
- const aclQueries = [
35
- this.datasource.execute(`SELECT * FROM public."ViewAuthorizePolicy" WHERE subject=$1`, [
36
- `user_${filter.principalValue}`,
37
- ]),
38
- ];
39
- const userRoles = await this.datasource.execute(`SELECT * FROM public."UserRole" WHERE user_id=$1`, [filter.principalValue]);
40
- for (const userRole of userRoles) {
41
- const execution = this.datasource.execute(`SELECT * FROM public."ViewAuthorizePolicy" WHERE subject=$1`, [`role_${userRole.principal_id}`]);
42
- aclQueries.push(execution);
43
- }
44
- const policyRs = (0, flatten_1.default)(await Promise.all(aclQueries));
45
- this.logger.debug('[loadFilteredPolicy] policyRs: %j | filter: %j', policyRs, filter);
46
- for (const el of policyRs) {
47
- if (!el) {
48
- continue;
38
+ // -----------------------------------------------------------------------------------------
39
+ loadFilteredPolicy(model, filter) {
40
+ return __awaiter(this, void 0, void 0, function* () {
41
+ var _a, _b;
42
+ if (((_a = filter === null || filter === void 0 ? void 0 : filter.principalType) === null || _a === void 0 ? void 0 : _a.toLowerCase()) === 'role') {
43
+ throw (0, utilities_1.getError)({
44
+ statusCode: 500,
45
+ message: '[loadFilteredPolicy] Only "User" is allowed for filter principal type!',
46
+ });
47
+ }
48
+ const aclQueries = [
49
+ this.datasource.execute(`SELECT * FROM public."ViewAuthorizePolicy" WHERE subject=$1`, [
50
+ `user_${filter.principalValue}`,
51
+ ]),
52
+ ];
53
+ // Load role permission policies
54
+ const userRoles = yield this.datasource.execute(`SELECT * FROM public."UserRole" WHERE user_id=$1`, [filter.principalValue]);
55
+ for (const userRole of userRoles) {
56
+ const execution = this.datasource.execute(`SELECT * FROM public."ViewAuthorizePolicy" WHERE subject=$1`, [`role_${userRole.principal_id}`]);
57
+ aclQueries.push(execution);
58
+ }
59
+ // Load policy lines
60
+ const policyRs = (0, flatten_1.default)(yield Promise.all(aclQueries));
61
+ this.logger.debug('[loadFilteredPolicy] policyRs: %j | filter: %j', policyRs, filter);
62
+ for (const el of policyRs) {
63
+ if (!el) {
64
+ continue;
65
+ }
66
+ (_b = el.policies) === null || _b === void 0 ? void 0 : _b.forEach((policyLine) => {
67
+ casbin_1.Helper.loadPolicyLine(policyLine, model);
68
+ this.logger.debug('[loadFilteredPolicy] Load policy: %s', policyLine);
69
+ });
49
70
  }
50
- el.policies?.forEach((policyLine) => {
51
- casbin_1.Helper.loadPolicyLine(policyLine, model);
52
- this.logger.debug('[loadFilteredPolicy] Load policy: %s', policyLine);
53
- });
54
- }
55
- for (const userRole of userRoles) {
56
- const groupLine = this.generateGroupLine({
57
- userId: (0, get_1.default)(userRole, 'user_id'),
58
- roleId: (0, get_1.default)(userRole, 'principal_id'),
59
- });
60
- if (!groupLine || (0, isEmpty_1.default)(groupLine)) {
61
- continue;
71
+ // Load group lines
72
+ for (const userRole of userRoles) {
73
+ const groupLine = this.generateGroupLine({
74
+ userId: (0, get_1.default)(userRole, 'user_id'),
75
+ roleId: (0, get_1.default)(userRole, 'principal_id'),
76
+ });
77
+ if (!groupLine || (0, isEmpty_1.default)(groupLine)) {
78
+ continue;
79
+ }
80
+ casbin_1.Helper.loadPolicyLine(groupLine, model);
81
+ this.logger.debug('[loadFilteredPolicy] Load groupLine: %s', groupLine);
62
82
  }
63
- casbin_1.Helper.loadPolicyLine(groupLine, model);
64
- this.logger.debug('[loadFilteredPolicy] Load groupLine: %s', groupLine);
65
- }
83
+ });
66
84
  }
67
85
  }
68
86
  exports.CasbinPostgresAdapter = CasbinPostgresAdapter;
87
+ //# sourceMappingURL=casbin-postgres-adapter.helper.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"casbin-postgres-adapter.helper.js","sourceRoot":"","sources":["../../../../src/components/authorize/adapters/casbin-postgres-adapter.helper.ts"],"names":[],"mappings":"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"}
@@ -2,6 +2,7 @@
2
2
  Object.defineProperty(exports, "__esModule", { value: true });
3
3
  exports.CasbinRedisAdapter = void 0;
4
4
  const base_adapter_1 = require("./base.adapter");
5
+ // -----------------------------------------------------------------------------------------
5
6
  class CasbinRedisAdapter extends base_adapter_1.AbstractCasbinAdapter {
6
7
  constructor(datasource) {
7
8
  super({ scope: CasbinRedisAdapter.name, datasource });
@@ -11,3 +12,4 @@ class CasbinRedisAdapter extends base_adapter_1.AbstractCasbinAdapter {
11
12
  }
12
13
  }
13
14
  exports.CasbinRedisAdapter = CasbinRedisAdapter;
15
+ //# sourceMappingURL=casbin-redis-adapter.helper.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"casbin-redis-adapter.helper.js","sourceRoot":"","sources":["../../../../src/components/authorize/adapters/casbin-redis-adapter.helper.ts"],"names":[],"mappings":";;;AAGA,iDAAuD;AAEvD,4FAA4F;AAC5F,MAAa,kBAAmB,SAAQ,oCAAqB;IAC3D,YAAY,UAA0B;QACpC,KAAK,CAAC,EAAE,KAAK,EAAE,kBAAkB,CAAC,IAAI,EAAE,UAAU,EAAE,CAAC,CAAC;IACxD,CAAC;IAED,kBAAkB,CAAC,MAAa,EAAE,OAAY;QAC5C,MAAM,IAAI,KAAK,CAAC,yBAAyB,CAAC,CAAC;IAC7C,CAAC;CACF;AARD,gDAQC"}
@@ -18,3 +18,4 @@ __exportStar(require("./adapter-builder"), exports);
18
18
  __exportStar(require("./base.adapter"), exports);
19
19
  __exportStar(require("./casbin-postgres-adapter.helper"), exports);
20
20
  __exportStar(require("./casbin-redis-adapter.helper"), exports);
21
+ //# sourceMappingURL=index.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"index.js","sourceRoot":"","sources":["../../../../src/components/authorize/adapters/index.ts"],"names":[],"mappings":";;;;;;;;;;;;;;;;AAAA,oDAAkC;AAClC,iDAA+B;AAC/B,mEAAiD;AACjD,gEAA8C"}
@@ -1,19 +1,22 @@
1
1
  "use strict";
2
+ var _a;
2
3
  Object.defineProperty(exports, "__esModule", { value: true });
3
4
  exports.EnforcerDefinitions = exports.FixedUserRoles = void 0;
4
5
  class FixedUserRoles {
5
- static SUPER_ADMIN = '999-super-admin';
6
- static ADMIN = '998-admin';
7
- static FULL_AUTHORIZE_ROLES = [this.SUPER_ADMIN, this.ADMIN];
8
6
  }
9
7
  exports.FixedUserRoles = FixedUserRoles;
8
+ _a = FixedUserRoles;
9
+ FixedUserRoles.SUPER_ADMIN = '999-super-admin';
10
+ FixedUserRoles.ADMIN = '998-admin';
11
+ FixedUserRoles.FULL_AUTHORIZE_ROLES = [_a.SUPER_ADMIN, _a.ADMIN];
10
12
  class EnforcerDefinitions {
11
- static ACTION_EXECUTE = 'execute';
12
- static ACTION_READ = 'read';
13
- static ACTION_WRITE = 'write';
14
- static PREFIX_USER = 'user';
15
- static PREFIX_ROLE = 'role';
16
- static PTYPE_POLICY = 'p';
17
- static PTYPE_GROUP = 'g';
18
13
  }
19
14
  exports.EnforcerDefinitions = EnforcerDefinitions;
15
+ EnforcerDefinitions.ACTION_EXECUTE = 'execute';
16
+ EnforcerDefinitions.ACTION_READ = 'read';
17
+ EnforcerDefinitions.ACTION_WRITE = 'write';
18
+ EnforcerDefinitions.PREFIX_USER = 'user';
19
+ EnforcerDefinitions.PREFIX_ROLE = 'role';
20
+ EnforcerDefinitions.PTYPE_POLICY = 'p';
21
+ EnforcerDefinitions.PTYPE_GROUP = 'g';
22
+ //# sourceMappingURL=constants.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"constants.js","sourceRoot":"","sources":["../../../../src/components/authorize/common/constants.ts"],"names":[],"mappings":";;;;AAAA,MAAa,cAAc;;AAA3B,wCAIC;;AAHiB,0BAAW,GAAG,iBAAiB,AAApB,CAAqB;AAChC,oBAAK,GAAG,WAAW,AAAd,CAAe;AACpB,mCAAoB,GAAG,CAAC,EAAI,CAAC,WAAW,EAAE,EAAI,CAAC,KAAK,CAAC,AAAjC,CAAkC;AAGxE,MAAa,mBAAmB;;AAAhC,kDAQC;AAPiB,kCAAc,GAAG,SAAS,CAAC;AAC3B,+BAAW,GAAG,MAAM,CAAC;AACrB,gCAAY,GAAG,OAAO,CAAC;AACvB,+BAAW,GAAG,MAAM,CAAC;AACrB,+BAAW,GAAG,MAAM,CAAC;AACrB,gCAAY,GAAG,GAAG,CAAC;AACnB,+BAAW,GAAG,GAAG,CAAC"}
@@ -17,3 +17,4 @@ Object.defineProperty(exports, "__esModule", { value: true });
17
17
  __exportStar(require("./keys"), exports);
18
18
  __exportStar(require("./types"), exports);
19
19
  __exportStar(require("./constants"), exports);
20
+ //# sourceMappingURL=index.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"index.js","sourceRoot":"","sources":["../../../../src/components/authorize/common/index.ts"],"names":[],"mappings":";;;;;;;;;;;;;;;;AAAA,yCAAuB;AACvB,0CAAwB;AACxB,8CAA4B"}
@@ -2,20 +2,21 @@
2
2
  Object.defineProperty(exports, "__esModule", { value: true });
3
3
  exports.AuthorizerKeys = void 0;
4
4
  class AuthorizerKeys {
5
- static APPLICATION_NAME = '@app/authorize/component/application_name';
6
- static ROLE_MODEL = '@app/authorize/component/models/user';
7
- static PERMISSION_MODEL = '@app/authorize/component/models/permission';
8
- static PERMISSION_MAPPING_MODEL = '@app/authorize/component/models/permission_mapping';
9
- static USER_ROLE_MODEL = '@app/authorize/component/models/user_role';
10
- static ROLE_REPOSITORY = '@app/authorize/component/repositories/user';
11
- static PERMISSION_REPOSITORY = '@app/authorize/component/repositories/permission';
12
- static PERMISSION_MAPPING_REPOSITORY = '@app/authorize/component/repositories/permission_mapping';
13
- static USER_ROLE_REPOSITORY = '@app/authorize/component/repositories/user_role';
14
- static PROVIDER = '@app/authorize/provider';
15
- static ENFORCER = '@app/authorize/enforcer';
16
- static ALWAYS_ALLOW_ROLES = '@app/authorize/always_allow_roles';
17
- static AUTHORIZE_DATASOURCE = '@app/authorize/enforcer/adapter/datasource';
18
- static CONFIGURE_OPTIONS = '@app/authorize/configure_options';
19
- static NORMALIZE_PAYLOAD_FN = '@app/authorize/normalize_payload_fn';
20
5
  }
21
6
  exports.AuthorizerKeys = AuthorizerKeys;
7
+ AuthorizerKeys.APPLICATION_NAME = '@app/authorize/component/application_name';
8
+ AuthorizerKeys.ROLE_MODEL = '@app/authorize/component/models/user';
9
+ AuthorizerKeys.PERMISSION_MODEL = '@app/authorize/component/models/permission';
10
+ AuthorizerKeys.PERMISSION_MAPPING_MODEL = '@app/authorize/component/models/permission_mapping';
11
+ AuthorizerKeys.USER_ROLE_MODEL = '@app/authorize/component/models/user_role';
12
+ AuthorizerKeys.ROLE_REPOSITORY = '@app/authorize/component/repositories/user';
13
+ AuthorizerKeys.PERMISSION_REPOSITORY = '@app/authorize/component/repositories/permission';
14
+ AuthorizerKeys.PERMISSION_MAPPING_REPOSITORY = '@app/authorize/component/repositories/permission_mapping';
15
+ AuthorizerKeys.USER_ROLE_REPOSITORY = '@app/authorize/component/repositories/user_role';
16
+ AuthorizerKeys.PROVIDER = '@app/authorize/provider';
17
+ AuthorizerKeys.ENFORCER = '@app/authorize/enforcer';
18
+ AuthorizerKeys.ALWAYS_ALLOW_ROLES = '@app/authorize/always_allow_roles';
19
+ AuthorizerKeys.AUTHORIZE_DATASOURCE = '@app/authorize/enforcer/adapter/datasource';
20
+ AuthorizerKeys.CONFIGURE_OPTIONS = '@app/authorize/configure_options';
21
+ AuthorizerKeys.NORMALIZE_PAYLOAD_FN = '@app/authorize/normalize_payload_fn';
22
+ //# sourceMappingURL=keys.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"keys.js","sourceRoot":"","sources":["../../../../src/components/authorize/common/keys.ts"],"names":[],"mappings":";;;AAAA,MAAa,cAAc;;AAA3B,wCAoBC;AAnBiB,+BAAgB,GAAG,2CAA2C,CAAC;AAE/D,yBAAU,GAAG,sCAAsC,CAAC;AACpD,+BAAgB,GAAG,4CAA4C,CAAC;AAChE,uCAAwB,GAAG,oDAAoD,CAAC;AAChF,8BAAe,GAAG,2CAA2C,CAAC;AAE9D,8BAAe,GAAG,4CAA4C,CAAC;AAC/D,oCAAqB,GAAG,kDAAkD,CAAC;AAC3E,4CAA6B,GAC3C,0DAA0D,CAAC;AAC7C,mCAAoB,GAAG,iDAAiD,CAAC;AAEzE,uBAAQ,GAAG,yBAAyB,CAAC;AACrC,uBAAQ,GAAG,yBAAyB,CAAC;AACrC,iCAAkB,GAAG,mCAAmC,CAAC;AACzD,mCAAoB,GAAG,4CAA4C,CAAC;AACpE,gCAAiB,GAAG,kCAAkC,CAAC;AACvD,mCAAoB,GAAG,qCAAqC,CAAC"}
@@ -2,7 +2,8 @@
2
2
  Object.defineProperty(exports, "__esModule", { value: true });
3
3
  exports.CasbinAdapterTypes = void 0;
4
4
  class CasbinAdapterTypes {
5
- static POSTGRES = 'casbin-postgres';
6
- static REDIS = 'casbin-redis';
7
5
  }
8
6
  exports.CasbinAdapterTypes = CasbinAdapterTypes;
7
+ CasbinAdapterTypes.POSTGRES = 'casbin-postgres';
8
+ CasbinAdapterTypes.REDIS = 'casbin-redis';
9
+ //# sourceMappingURL=types.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"types.js","sourceRoot":"","sources":["../../../../src/components/authorize/common/types.ts"],"names":[],"mappings":";;;AAQA,MAAa,kBAAkB;;AAA/B,gDAGC;AAFiB,2BAAQ,GAAmB,iBAAiB,CAAC;AAC7C,wBAAK,GAAmB,cAAc,CAAC"}
@@ -11,6 +11,15 @@ var __metadata = (this && this.__metadata) || function (k, v) {
11
11
  var __param = (this && this.__param) || function (paramIndex, decorator) {
12
12
  return function (target, key) { decorator(target, key, paramIndex); }
13
13
  };
14
+ var __awaiter = (this && this.__awaiter) || function (thisArg, _arguments, P, generator) {
15
+ function adopt(value) { return value instanceof P ? value : new P(function (resolve) { resolve(value); }); }
16
+ return new (P || (P = Promise))(function (resolve, reject) {
17
+ function fulfilled(value) { try { step(generator.next(value)); } catch (e) { reject(e); } }
18
+ function rejected(value) { try { step(generator["throw"](value)); } catch (e) { reject(e); } }
19
+ function step(result) { result.done ? resolve(result.value) : adopt(result.value).then(fulfilled, rejected); }
20
+ step((generator = generator.apply(thisArg, _arguments || [])).next());
21
+ });
22
+ };
14
23
  var __importDefault = (this && this.__importDefault) || function (mod) {
15
24
  return (mod && mod.__esModule) ? mod : { "default": mod };
16
25
  };
@@ -32,25 +41,29 @@ const flatten_1 = __importDefault(require("lodash/flatten"));
32
41
  const node_path_1 = __importDefault(require("node:path"));
33
42
  const authorizeConfPath = node_path_1.default.resolve(__dirname, '../../static/security/authorize_model.conf');
34
43
  let AuthorizeComponent = AuthorizeComponent_1 = class AuthorizeComponent extends base_component_1.BaseComponent {
35
- application;
36
- bindings = [
37
- core_1.Binding.bind(common_1.AuthorizerKeys.ROLE_MODEL).toClass(models_1.Role),
38
- core_1.Binding.bind(common_1.AuthorizerKeys.PERMISSION_MODEL).toClass(models_1.Permission),
39
- core_1.Binding.bind(common_1.AuthorizerKeys.PERMISSION_MAPPING_MODEL).toClass(models_1.PermissionMapping),
40
- core_1.Binding.bind(common_1.AuthorizerKeys.USER_ROLE_MODEL).toClass(models_1.UserRole),
41
- core_1.Binding.bind(common_1.AuthorizerKeys.ROLE_REPOSITORY).toClass(repositories_1.RoleRepository),
42
- core_1.Binding.bind(common_1.AuthorizerKeys.PERMISSION_REPOSITORY).toClass(repositories_1.PermissionRepository),
43
- core_1.Binding.bind(common_1.AuthorizerKeys.PERMISSION_MAPPING_REPOSITORY).toClass(repositories_1.PermissionMappingRepository),
44
- core_1.Binding.bind(common_1.AuthorizerKeys.USER_ROLE_REPOSITORY).toClass(repositories_1.UserRoleRepository),
45
- core_1.Binding.bind(common_1.AuthorizerKeys.CONFIGURE_OPTIONS).to({
46
- confPath: authorizeConfPath,
47
- useCache: false,
48
- }),
49
- core_1.Binding.bind(common_1.AuthorizerKeys.NORMALIZE_PAYLOAD_FN).to(null),
50
- ];
51
44
  constructor(application) {
52
45
  super({ scope: AuthorizeComponent_1.name });
53
46
  this.application = application;
47
+ this.bindings = [
48
+ // Model bindings
49
+ core_1.Binding.bind(common_1.AuthorizerKeys.ROLE_MODEL).toClass(models_1.Role),
50
+ core_1.Binding.bind(common_1.AuthorizerKeys.PERMISSION_MODEL).toClass(models_1.Permission),
51
+ core_1.Binding.bind(common_1.AuthorizerKeys.PERMISSION_MAPPING_MODEL).toClass(models_1.PermissionMapping),
52
+ core_1.Binding.bind(common_1.AuthorizerKeys.USER_ROLE_MODEL).toClass(models_1.UserRole),
53
+ // Repository bindings
54
+ core_1.Binding.bind(common_1.AuthorizerKeys.ROLE_REPOSITORY).toClass(repositories_1.RoleRepository),
55
+ core_1.Binding.bind(common_1.AuthorizerKeys.PERMISSION_REPOSITORY).toClass(repositories_1.PermissionRepository),
56
+ core_1.Binding.bind(common_1.AuthorizerKeys.PERMISSION_MAPPING_REPOSITORY).toClass(repositories_1.PermissionMappingRepository),
57
+ core_1.Binding.bind(common_1.AuthorizerKeys.USER_ROLE_REPOSITORY).toClass(repositories_1.UserRoleRepository),
58
+ // Datasource
59
+ // Binding.bind(AuthorizerKeys.AUTHORIZE_DATASOURCE).to(null),
60
+ // Configure path
61
+ core_1.Binding.bind(common_1.AuthorizerKeys.CONFIGURE_OPTIONS).to({
62
+ confPath: authorizeConfPath,
63
+ useCache: false,
64
+ }),
65
+ core_1.Binding.bind(common_1.AuthorizerKeys.NORMALIZE_PAYLOAD_FN).to(null),
66
+ ];
54
67
  this.binding();
55
68
  }
56
69
  defineModels() {
@@ -72,46 +85,48 @@ let AuthorizeComponent = AuthorizeComponent_1 = class AuthorizeComponent extends
72
85
  this.application.repository(repositories_1.UserRoleRepository);
73
86
  this.application.repository(repositories_1.ViewAuthorizePolicyRepository);
74
87
  }
75
- async verify() {
76
- const datasource = this.application.getSync(common_1.AuthorizerKeys.AUTHORIZE_DATASOURCE);
77
- if (!datasource) {
78
- throw (0, utilities_1.getError)({
79
- statusCode: 500,
80
- message: `[verify] Invalid binding datasource to key ${common_1.AuthorizerKeys.AUTHORIZE_DATASOURCE}`,
81
- });
82
- }
83
- const checkTableExecutions = ['Role', 'Permission', 'UserRole', 'PermissionMapping'].map(tableName => {
84
- return datasource.execute(`
88
+ verify() {
89
+ return __awaiter(this, void 0, void 0, function* () {
90
+ const datasource = this.application.getSync(common_1.AuthorizerKeys.AUTHORIZE_DATASOURCE);
91
+ if (!datasource) {
92
+ throw (0, utilities_1.getError)({
93
+ statusCode: 500,
94
+ message: `[verify] Invalid binding datasource to key ${common_1.AuthorizerKeys.AUTHORIZE_DATASOURCE}`,
95
+ });
96
+ }
97
+ const checkTableExecutions = ['Role', 'Permission', 'UserRole', 'PermissionMapping'].map(tableName => {
98
+ return datasource.execute(`
85
99
  SELECT EXISTS (
86
100
  SELECT FROM information_schema.tables
87
101
  WHERE table_schema='public'
88
102
  AND table_name='${tableName}'
89
103
  ) as "isTableExisted"`);
90
- });
91
- const tableRs = await Promise.all(checkTableExecutions);
92
- const checkTableExistRs = (0, flatten_1.default)(tableRs);
93
- for (const rs of checkTableExistRs) {
94
- if (!rs.isTableExisted) {
95
- throw (0, utilities_1.getError)({
96
- statusCode: 500,
97
- message: '[verify] Essential table IS NOT EXISTS | Please check again (Role, Permission, UserRole and PermissionMapping)',
98
- });
104
+ });
105
+ const tableRs = yield Promise.all(checkTableExecutions);
106
+ const checkTableExistRs = (0, flatten_1.default)(tableRs);
107
+ for (const rs of checkTableExistRs) {
108
+ if (!rs.isTableExisted) {
109
+ throw (0, utilities_1.getError)({
110
+ statusCode: 500,
111
+ message: '[verify] Essential table IS NOT EXISTS | Please check again (Role, Permission, UserRole and PermissionMapping)',
112
+ });
113
+ }
99
114
  }
100
- }
101
- const checkAuthorizeViewRs = await datasource.execute(`
115
+ const checkAuthorizeViewRs = yield datasource.execute(`
102
116
  SELECT EXISTS (
103
117
  SELECT FROM information_schema.views
104
118
  WHERE table_schema='public'
105
119
  AND table_name='ViewAuthorizePolicy'
106
120
  ) as "isViewExisted"`);
107
- for (const rs of checkAuthorizeViewRs) {
108
- if (!rs.isViewExisted) {
109
- throw (0, utilities_1.getError)({
110
- statusCode: 500,
111
- message: '[verify] Essential view IS NOT EXISTS | Please check again (ViewAuthorizePolicy)',
112
- });
121
+ for (const rs of checkAuthorizeViewRs) {
122
+ if (!rs.isViewExisted) {
123
+ throw (0, utilities_1.getError)({
124
+ statusCode: 500,
125
+ message: '[verify] Essential view IS NOT EXISTS | Please check again (ViewAuthorizePolicy)',
126
+ });
127
+ }
113
128
  }
114
- }
129
+ });
115
130
  }
116
131
  binding() {
117
132
  this.logger.info('[binding] Binding authorize component for application...');
@@ -143,3 +158,4 @@ exports.AuthorizeComponent = AuthorizeComponent = AuthorizeComponent_1 = __decor
143
158
  __param(0, (0, core_1.inject)(core_1.CoreBindings.APPLICATION_INSTANCE)),
144
159
  __metadata("design:paramtypes", [applications_1.BaseApplication])
145
160
  ], AuthorizeComponent);
161
+ //# sourceMappingURL=component.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"component.js","sourceRoot":"","sources":["../../../src/components/authorize/component.ts"],"names":[],"mappings":"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"}
@@ -4,5 +4,16 @@ export declare class MetadataDecoratorKeys {
4
4
  export interface IPermissionDecorator {
5
5
  idx: number;
6
6
  }
7
+ /**
8
+ * @example
9
+ * ```typescript
10
+ * class MyController {
11
+ * @permission({ idx: 1, allowedRoles: ['admin'], deniedRoles: ['guest'] })
12
+ * myMethod() {
13
+ * // method implementation
14
+ * }
15
+ * }
16
+ * ```
17
+ */
7
18
  export declare function permission(spec: IPermissionDecorator): MethodDecorator;
8
19
  export declare const getDecoratorData: (controllerPrototype: object, keyTargetDecorator: string) => import("@loopback/metadata").MetadataMap<any> | undefined;
@@ -4,13 +4,27 @@ exports.getDecoratorData = exports.MetadataDecoratorKeys = void 0;
4
4
  exports.permission = permission;
5
5
  const metadata_1 = require("@loopback/metadata");
6
6
  class MetadataDecoratorKeys {
7
- static PERMISSION = 'metadata-key-for-permission-decorator';
8
7
  }
9
8
  exports.MetadataDecoratorKeys = MetadataDecoratorKeys;
9
+ MetadataDecoratorKeys.PERMISSION = 'metadata-key-for-permission-decorator';
10
+ // Read more: https://loopback.io/doc/en/lb4/Creating-decorators.html#inspect-metadata-of-a-property
11
+ /**
12
+ * @example
13
+ * ```typescript
14
+ * class MyController {
15
+ * @permission({ idx: 1, allowedRoles: ['admin'], deniedRoles: ['guest'] })
16
+ * myMethod() {
17
+ * // method implementation
18
+ * }
19
+ * }
20
+ * ```
21
+ */
10
22
  function permission(spec) {
11
23
  return metadata_1.MethodDecoratorFactory.createDecorator(MetadataDecoratorKeys.PERMISSION, spec);
12
24
  }
25
+ // Read more: https://loopback.io/doc/en/lb4/Creating-decorators.html#to-create-a-decorator-that-can-be-used-multiple-times-on-a-single-method
13
26
  const getDecoratorData = (controllerPrototype, keyTargetDecorator) => {
14
27
  return metadata_1.MetadataInspector.getAllPropertyMetadata(keyTargetDecorator, controllerPrototype);
15
28
  };
16
29
  exports.getDecoratorData = getDecoratorData;
30
+ //# sourceMappingURL=index.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"index.js","sourceRoot":"","sources":["../../../../src/components/authorize/decorators/index.ts"],"names":[],"mappings":";;;AAsBA,gCAKC;AA3BD,iDAA+E;AAE/E,MAAa,qBAAqB;;AAAlC,sDAEC;AADiB,gCAAU,GAAG,uCAAuC,CAAC;AAOvE,oGAAoG;AACpG;;;;;;;;;;GAUG;AACH,SAAgB,UAAU,CAAC,IAA0B;IACnD,OAAO,iCAAsB,CAAC,eAAe,CAC3C,qBAAqB,CAAC,UAAU,EAChC,IAAI,CACL,CAAC;AACJ,CAAC;AAED,8IAA8I;AACvI,MAAM,gBAAgB,GAAG,CAAC,mBAA2B,EAAE,kBAA0B,EAAE,EAAE;IAC1F,OAAO,4BAAiB,CAAC,sBAAsB,CAAM,kBAAkB,EAAE,mBAAmB,CAAC,CAAC;AAChG,CAAC,CAAC;AAFW,QAAA,gBAAgB,oBAE3B"}
@@ -23,3 +23,4 @@ __exportStar(require("./models"), exports);
23
23
  __exportStar(require("./provider"), exports);
24
24
  __exportStar(require("./repositories"), exports);
25
25
  __exportStar(require("./services"), exports);
26
+ //# sourceMappingURL=index.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"index.js","sourceRoot":"","sources":["../../../src/components/authorize/index.ts"],"names":[],"mappings":";;;;;;;;;;;;;;;;AAAA,6CAA2B;AAC3B,2CAAyB;AACzB,8CAA4B;AAC5B,+CAA6B;AAC7B,+CAA6B;AAC7B,2CAAyB;AACzB,6CAA2B;AAC3B,iDAA+B;AAC/B,6CAA2B"}