@things-factory/auth-base 5.0.14 → 6.0.0-alpha.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 (313) hide show
  1. package/client/actions/auth.ts +23 -0
  2. package/client/{auth.js → auth.ts} +66 -59
  3. package/client/{bootstrap.js → bootstrap.ts} +5 -4
  4. package/client/index.ts +1 -0
  5. package/client/reducers/{auth.js → auth.ts} +1 -1
  6. package/dist-client/actions/auth.d.ts +8 -0
  7. package/dist-client/actions/auth.js +15 -0
  8. package/dist-client/actions/auth.js.map +1 -0
  9. package/dist-client/auth.d.ts +34 -0
  10. package/dist-client/auth.js +209 -0
  11. package/dist-client/auth.js.map +1 -0
  12. package/dist-client/bootstrap.d.ts +1 -0
  13. package/dist-client/bootstrap.js +34 -0
  14. package/dist-client/bootstrap.js.map +1 -0
  15. package/dist-client/index.d.ts +1 -0
  16. package/dist-client/index.js +2 -0
  17. package/dist-client/index.js.map +1 -0
  18. package/dist-client/reducers/auth.d.ts +14 -0
  19. package/dist-client/reducers/auth.js +19 -0
  20. package/dist-client/reducers/auth.js.map +1 -0
  21. package/dist-client/tsconfig.tsbuildinfo +1 -0
  22. package/dist-server/constants/error-code.d.ts +17 -0
  23. package/dist-server/constants/error-message.d.ts +0 -0
  24. package/dist-server/constants/max-age.d.ts +1 -0
  25. package/dist-server/controllers/auth.d.ts +5 -0
  26. package/dist-server/controllers/auth.js +1 -0
  27. package/dist-server/controllers/auth.js.map +1 -1
  28. package/dist-server/controllers/change-pwd.d.ts +1 -0
  29. package/dist-server/controllers/change-pwd.js +5 -4
  30. package/dist-server/controllers/change-pwd.js.map +1 -1
  31. package/dist-server/controllers/checkin.d.ts +4 -0
  32. package/dist-server/controllers/checkin.js +3 -3
  33. package/dist-server/controllers/checkin.js.map +1 -1
  34. package/dist-server/controllers/delete-user.d.ts +3 -0
  35. package/dist-server/controllers/invitation.d.ts +11 -0
  36. package/dist-server/controllers/invitation.js +11 -12
  37. package/dist-server/controllers/invitation.js.map +1 -1
  38. package/dist-server/controllers/profile.d.ts +26 -0
  39. package/dist-server/controllers/profile.js +4 -4
  40. package/dist-server/controllers/profile.js.map +1 -1
  41. package/dist-server/controllers/reset-password.d.ts +5 -0
  42. package/dist-server/controllers/reset-password.js +7 -7
  43. package/dist-server/controllers/reset-password.js.map +1 -1
  44. package/dist-server/controllers/signin.d.ts +6 -0
  45. package/dist-server/controllers/signin.js +4 -3
  46. package/dist-server/controllers/signin.js.map +1 -1
  47. package/dist-server/controllers/signup.d.ts +8 -0
  48. package/dist-server/controllers/signup.js +13 -9
  49. package/dist-server/controllers/signup.js.map +1 -1
  50. package/dist-server/controllers/unlock-user.d.ts +5 -0
  51. package/dist-server/controllers/unlock-user.js +6 -6
  52. package/dist-server/controllers/unlock-user.js.map +1 -1
  53. package/dist-server/controllers/utils/make-invitation-token.d.ts +1 -0
  54. package/dist-server/controllers/utils/make-verification-token.d.ts +1 -0
  55. package/dist-server/controllers/utils/password-rule.d.ts +14 -0
  56. package/dist-server/controllers/utils/save-invitation-token.d.ts +5 -0
  57. package/dist-server/controllers/utils/save-invitation-token.js +2 -2
  58. package/dist-server/controllers/utils/save-invitation-token.js.map +1 -1
  59. package/dist-server/controllers/utils/save-verification-token.d.ts +6 -0
  60. package/dist-server/controllers/utils/save-verification-token.js +2 -2
  61. package/dist-server/controllers/utils/save-verification-token.js.map +1 -1
  62. package/dist-server/controllers/verification.d.ts +6 -0
  63. package/dist-server/controllers/verification.js +8 -8
  64. package/dist-server/controllers/verification.js.map +1 -1
  65. package/dist-server/errors/auth-error.d.ts +11 -0
  66. package/dist-server/errors/auth-error.js.map +1 -1
  67. package/dist-server/errors/index.d.ts +2 -0
  68. package/dist-server/errors/user-domain-not-match-error.d.ts +9 -0
  69. package/dist-server/errors/user-domain-not-match-error.js.map +1 -1
  70. package/dist-server/index.d.ts +13 -0
  71. package/dist-server/index.js +2 -1
  72. package/dist-server/index.js.map +1 -1
  73. package/dist-server/middlewares/authenticate-401-middleware.d.ts +1 -0
  74. package/dist-server/middlewares/authenticate-401-middleware.js +12 -14
  75. package/dist-server/middlewares/authenticate-401-middleware.js.map +1 -1
  76. package/dist-server/middlewares/domain-authenticate-middleware.d.ts +11 -0
  77. package/dist-server/middlewares/domain-authenticate-middleware.js +7 -4
  78. package/dist-server/middlewares/domain-authenticate-middleware.js.map +1 -1
  79. package/dist-server/middlewares/graphql-authenticate-middleware.d.ts +1 -0
  80. package/dist-server/middlewares/index.d.ts +5 -0
  81. package/dist-server/middlewares/jwt-authenticate-middleware.d.ts +1 -0
  82. package/dist-server/middlewares/signin-middleware.d.ts +1 -0
  83. package/dist-server/migrations/1548206416130-SeedUser.d.ts +5 -0
  84. package/dist-server/migrations/1548206416130-SeedUser.js +4 -5
  85. package/dist-server/migrations/1548206416130-SeedUser.js.map +1 -1
  86. package/dist-server/migrations/1566805283882-SeedPrivilege.d.ts +5 -0
  87. package/dist-server/migrations/1566805283882-SeedPrivilege.js +2 -2
  88. package/dist-server/migrations/1566805283882-SeedPrivilege.js.map +1 -1
  89. package/dist-server/migrations/index.d.ts +1 -0
  90. package/dist-server/router/auth-checkin-router.d.ts +1 -0
  91. package/dist-server/router/auth-checkin-router.js.map +1 -1
  92. package/dist-server/router/auth-private-process-router.d.ts +1 -0
  93. package/dist-server/router/auth-private-process-router.js +2 -2
  94. package/dist-server/router/auth-private-process-router.js.map +1 -1
  95. package/dist-server/router/auth-public-process-router.d.ts +1 -0
  96. package/dist-server/router/auth-public-process-router.js +2 -3
  97. package/dist-server/router/auth-public-process-router.js.map +1 -1
  98. package/dist-server/router/auth-signin-router.d.ts +1 -0
  99. package/dist-server/router/auth-signup-router.d.ts +1 -0
  100. package/dist-server/router/auth-signup-router.js +31 -32
  101. package/dist-server/router/auth-signup-router.js.map +1 -1
  102. package/dist-server/router/index.d.ts +8 -0
  103. package/dist-server/router/oauth2/index.d.ts +2 -0
  104. package/dist-server/router/oauth2/oauth2-authorize-router.d.ts +1 -0
  105. package/dist-server/router/oauth2/oauth2-authorize-router.js +2 -2
  106. package/dist-server/router/oauth2/oauth2-authorize-router.js.map +1 -1
  107. package/dist-server/router/oauth2/oauth2-router.d.ts +9 -0
  108. package/dist-server/router/oauth2/oauth2-router.js +6 -7
  109. package/dist-server/router/oauth2/oauth2-router.js.map +1 -1
  110. package/dist-server/router/oauth2/oauth2-server.d.ts +5 -0
  111. package/dist-server/router/oauth2/oauth2-server.js +23 -21
  112. package/dist-server/router/oauth2/oauth2-server.js.map +1 -1
  113. package/dist-server/router/oauth2/passport-oauth2-client-password.d.ts +7 -0
  114. package/dist-server/router/oauth2/passport-refresh-token.d.ts +7 -0
  115. package/dist-server/router/path-base-domain-router.d.ts +1 -0
  116. package/dist-server/router/site-root-router.d.ts +1 -0
  117. package/dist-server/routes.d.ts +1 -0
  118. package/dist-server/service/app-binding/app-binding-mutation.d.ts +3 -0
  119. package/dist-server/service/app-binding/app-binding-mutation.js +2 -2
  120. package/dist-server/service/app-binding/app-binding-mutation.js.map +1 -1
  121. package/dist-server/service/app-binding/app-binding-query.d.ts +14 -0
  122. package/dist-server/service/app-binding/app-binding-query.js +7 -9
  123. package/dist-server/service/app-binding/app-binding-query.js.map +1 -1
  124. package/dist-server/service/app-binding/app-binding-types.d.ts +5 -0
  125. package/dist-server/service/app-binding/app-binding.d.ts +7 -0
  126. package/dist-server/service/app-binding/index.d.ts +3 -0
  127. package/dist-server/service/appliance/appliance-mutation.d.ts +8 -0
  128. package/dist-server/service/appliance/appliance-mutation.js +13 -12
  129. package/dist-server/service/appliance/appliance-mutation.js.map +1 -1
  130. package/dist-server/service/appliance/appliance-query.d.ts +11 -0
  131. package/dist-server/service/appliance/appliance-query.js +7 -9
  132. package/dist-server/service/appliance/appliance-query.js.map +1 -1
  133. package/dist-server/service/appliance/appliance-types.d.ts +22 -0
  134. package/dist-server/service/appliance/appliance.d.ts +22 -0
  135. package/dist-server/service/appliance/appliance.js +1 -2
  136. package/dist-server/service/appliance/appliance.js.map +1 -1
  137. package/dist-server/service/appliance/index.d.ts +5 -0
  138. package/dist-server/service/application/application-mutation.d.ts +66 -0
  139. package/dist-server/service/application/application-mutation.js +13 -13
  140. package/dist-server/service/application/application-mutation.js.map +1 -1
  141. package/dist-server/service/application/application-query.d.ts +16 -0
  142. package/dist-server/service/application/application-query.js +11 -13
  143. package/dist-server/service/application/application-query.js.map +1 -1
  144. package/dist-server/service/application/application-types.d.ts +27 -0
  145. package/dist-server/service/application/application.d.ts +35 -0
  146. package/dist-server/service/application/application.js +1 -2
  147. package/dist-server/service/application/application.js.map +1 -1
  148. package/dist-server/service/application/index.d.ts +5 -0
  149. package/dist-server/service/domain-generator/domain-generator-mutation.d.ts +6 -0
  150. package/dist-server/service/domain-generator/domain-generator-mutation.js +7 -7
  151. package/dist-server/service/domain-generator/domain-generator-mutation.js.map +1 -1
  152. package/dist-server/service/domain-generator/domain-generator-types.d.ts +19 -0
  153. package/dist-server/service/domain-generator/domain-generator-types.js +1 -2
  154. package/dist-server/service/domain-generator/domain-generator-types.js.map +1 -1
  155. package/dist-server/service/domain-generator/index.d.ts +2 -0
  156. package/dist-server/service/granted-role/granted-role-mutation.d.ts +11 -0
  157. package/dist-server/service/granted-role/granted-role-mutation.js +14 -9
  158. package/dist-server/service/granted-role/granted-role-mutation.js.map +1 -1
  159. package/dist-server/service/granted-role/granted-role-query.d.ts +16 -0
  160. package/dist-server/service/granted-role/granted-role-query.js +8 -9
  161. package/dist-server/service/granted-role/granted-role-query.js.map +1 -1
  162. package/dist-server/service/granted-role/granted-role.d.ts +9 -0
  163. package/dist-server/service/granted-role/granted-role.js +1 -2
  164. package/dist-server/service/granted-role/granted-role.js.map +1 -1
  165. package/dist-server/service/granted-role/index.d.ts +5 -0
  166. package/dist-server/service/index.d.ts +31 -0
  167. package/dist-server/service/invitation/index.d.ts +5 -0
  168. package/dist-server/service/invitation/invitation-mutation.d.ts +17 -0
  169. package/dist-server/service/invitation/invitation-mutation.js +9 -9
  170. package/dist-server/service/invitation/invitation-mutation.js.map +1 -1
  171. package/dist-server/service/invitation/invitation-query.d.ts +8 -0
  172. package/dist-server/service/invitation/invitation-query.js +4 -4
  173. package/dist-server/service/invitation/invitation-query.js.map +1 -1
  174. package/dist-server/service/invitation/invitation-types.d.ts +5 -0
  175. package/dist-server/service/invitation/invitation.d.ts +14 -0
  176. package/dist-server/service/login-history/index.d.ts +4 -0
  177. package/dist-server/service/login-history/login-history-query.d.ts +8 -0
  178. package/dist-server/service/login-history/login-history-query.js +9 -11
  179. package/dist-server/service/login-history/login-history-query.js.map +1 -1
  180. package/dist-server/service/login-history/login-history.d.ts +12 -0
  181. package/dist-server/service/login-history/login-history.js +14 -15
  182. package/dist-server/service/login-history/login-history.js.map +1 -1
  183. package/dist-server/service/partner/index.d.ts +5 -0
  184. package/dist-server/service/partner/partner-mutation.d.ts +4 -0
  185. package/dist-server/service/partner/partner-mutation.js +6 -7
  186. package/dist-server/service/partner/partner-mutation.js.map +1 -1
  187. package/dist-server/service/partner/partner-query.d.ts +14 -0
  188. package/dist-server/service/partner/partner-query.js +11 -13
  189. package/dist-server/service/partner/partner-query.js.map +1 -1
  190. package/dist-server/service/partner/partner-types.d.ts +5 -0
  191. package/dist-server/service/partner/partner.d.ts +15 -0
  192. package/dist-server/service/partner/partner.js +2 -3
  193. package/dist-server/service/partner/partner.js.map +1 -1
  194. package/dist-server/service/password-history/index.d.ts +2 -0
  195. package/dist-server/service/password-history/password-history.d.ts +4 -0
  196. package/dist-server/service/privilege/index.d.ts +5 -0
  197. package/dist-server/service/privilege/privilege-directive.d.ts +3 -0
  198. package/dist-server/service/privilege/privilege-directive.js +2 -2
  199. package/dist-server/service/privilege/privilege-directive.js.map +1 -1
  200. package/dist-server/service/privilege/privilege-mutation.d.ts +7 -0
  201. package/dist-server/service/privilege/privilege-mutation.js +6 -5
  202. package/dist-server/service/privilege/privilege-mutation.js.map +1 -1
  203. package/dist-server/service/privilege/privilege-query.d.ts +13 -0
  204. package/dist-server/service/privilege/privilege-query.js +7 -8
  205. package/dist-server/service/privilege/privilege-query.js.map +1 -1
  206. package/dist-server/service/privilege/privilege-types.d.ts +25 -0
  207. package/dist-server/service/privilege/privilege.d.ts +15 -0
  208. package/dist-server/service/role/index.d.ts +5 -0
  209. package/dist-server/service/role/role-mutation.d.ts +8 -0
  210. package/dist-server/service/role/role-mutation.js +13 -11
  211. package/dist-server/service/role/role-mutation.js.map +1 -1
  212. package/dist-server/service/role/role-query.d.ts +18 -0
  213. package/dist-server/service/role/role-query.js +13 -13
  214. package/dist-server/service/role/role-query.js.map +1 -1
  215. package/dist-server/service/role/role-types.d.ts +33 -0
  216. package/dist-server/service/role/role.d.ts +18 -0
  217. package/dist-server/service/role/role.js +1 -2
  218. package/dist-server/service/role/role.js.map +1 -1
  219. package/dist-server/service/user/index.d.ts +5 -0
  220. package/dist-server/service/user/user-mutation.d.ts +28 -0
  221. package/dist-server/service/user/user-mutation.js +24 -17
  222. package/dist-server/service/user/user-mutation.js.map +1 -1
  223. package/dist-server/service/user/user-query.d.ts +16 -0
  224. package/dist-server/service/user/user-query.js +15 -13
  225. package/dist-server/service/user/user-query.js.map +1 -1
  226. package/dist-server/service/user/user-types.d.ts +26 -0
  227. package/dist-server/service/user/user.d.ts +39 -0
  228. package/dist-server/service/user/user.js +9 -8
  229. package/dist-server/service/user/user.js.map +1 -1
  230. package/dist-server/service/verification-token/index.d.ts +2 -0
  231. package/dist-server/service/verification-token/verification-token.d.ts +14 -0
  232. package/dist-server/templates/account-unlock-email.d.ts +4 -0
  233. package/dist-server/templates/invitation-email.d.ts +4 -0
  234. package/dist-server/templates/reset-password-email.d.ts +4 -0
  235. package/dist-server/templates/verification-email.d.ts +4 -0
  236. package/dist-server/tsconfig.tsbuildinfo +1 -1
  237. package/dist-server/types.d.ts +17 -0
  238. package/dist-server/types.js +3 -0
  239. package/dist-server/types.js.map +1 -0
  240. package/dist-server/utils/accepts.d.ts +1 -0
  241. package/dist-server/utils/access-token-cookie.d.ts +3 -0
  242. package/dist-server/utils/check-user-belongs-domain.d.ts +10 -0
  243. package/dist-server/utils/check-user-belongs-domain.js +2 -2
  244. package/dist-server/utils/check-user-belongs-domain.js.map +1 -1
  245. package/dist-server/utils/get-domain-from-hostname.d.ts +1 -0
  246. package/dist-server/utils/get-domain-users.d.ts +5 -0
  247. package/dist-server/utils/get-domain-users.js +2 -3
  248. package/dist-server/utils/get-domain-users.js.map +1 -1
  249. package/dist-server/utils/get-secret.d.ts +1 -0
  250. package/dist-server/utils/get-user-domains.d.ts +5 -0
  251. package/dist-server/utils/get-user-domains.js +7 -5
  252. package/dist-server/utils/get-user-domains.js.map +1 -1
  253. package/package.json +15 -13
  254. package/server/controllers/auth.ts +1 -0
  255. package/server/controllers/change-pwd.ts +3 -3
  256. package/server/controllers/checkin.ts +3 -3
  257. package/server/controllers/invitation.ts +6 -7
  258. package/server/controllers/profile.ts +4 -3
  259. package/server/controllers/reset-password.ts +3 -3
  260. package/server/controllers/signin.ts +4 -2
  261. package/server/controllers/signup.ts +13 -8
  262. package/server/controllers/unlock-user.ts +5 -3
  263. package/server/controllers/utils/save-invitation-token.ts +2 -1
  264. package/server/controllers/utils/save-verification-token.ts +2 -1
  265. package/server/controllers/verification.ts +6 -4
  266. package/server/errors/auth-error.ts +3 -0
  267. package/server/errors/user-domain-not-match-error.ts +3 -0
  268. package/server/index.ts +3 -1
  269. package/server/middlewares/authenticate-401-middleware.ts +15 -3
  270. package/server/middlewares/domain-authenticate-middleware.ts +9 -6
  271. package/server/migrations/1548206416130-SeedUser.ts +3 -3
  272. package/server/migrations/1566805283882-SeedPrivilege.ts +2 -1
  273. package/server/router/auth-checkin-router.ts +1 -1
  274. package/server/router/auth-private-process-router.ts +1 -2
  275. package/server/router/auth-public-process-router.ts +2 -3
  276. package/server/router/auth-signup-router.ts +38 -38
  277. package/server/router/oauth2/oauth2-authorize-router.ts +3 -2
  278. package/server/router/oauth2/oauth2-router.ts +4 -5
  279. package/server/router/oauth2/oauth2-server.ts +19 -22
  280. package/server/service/app-binding/app-binding-mutation.ts +3 -2
  281. package/server/service/app-binding/app-binding-query.ts +9 -9
  282. package/server/service/appliance/appliance-mutation.ts +14 -8
  283. package/server/service/appliance/appliance-query.ts +11 -10
  284. package/server/service/application/application-mutation.ts +21 -12
  285. package/server/service/application/application-query.ts +20 -17
  286. package/server/service/domain-generator/domain-generator-mutation.ts +15 -10
  287. package/server/service/granted-role/granted-role-mutation.ts +14 -12
  288. package/server/service/granted-role/granted-role-query.ts +12 -10
  289. package/server/service/invitation/invitation-mutation.ts +7 -5
  290. package/server/service/invitation/invitation-query.ts +6 -4
  291. package/server/service/login-history/login-history-query.ts +13 -11
  292. package/server/service/login-history/login-history.ts +5 -4
  293. package/server/service/partner/partner-mutation.ts +10 -9
  294. package/server/service/partner/partner-query.ts +10 -10
  295. package/server/service/privilege/privilege-directive.ts +1 -1
  296. package/server/service/privilege/privilege-mutation.ts +10 -5
  297. package/server/service/privilege/privilege-query.ts +7 -7
  298. package/server/service/role/role-mutation.ts +18 -11
  299. package/server/service/role/role-query.ts +18 -16
  300. package/server/service/user/user-mutation.ts +39 -34
  301. package/server/service/user/user-query.ts +29 -21
  302. package/server/service/user/user.ts +12 -10
  303. package/server/types.ts +21 -0
  304. package/server/utils/check-user-belongs-domain.ts +2 -2
  305. package/server/utils/get-domain-users.ts +4 -2
  306. package/server/utils/get-user-domains.ts +8 -5
  307. package/things-factory.config.js +1 -1
  308. package/translations/en.json +2 -5
  309. package/translations/ko.json +5 -8
  310. package/translations/ms.json +2 -5
  311. package/translations/zh.json +2 -5
  312. package/client/actions/auth.js +0 -16
  313. package/client/index.js +0 -2
@@ -1,16 +1,15 @@
1
1
  "use strict";
2
- var LoginHistory_1, _a;
2
+ var LoginHistory_1;
3
3
  Object.defineProperty(exports, "__esModule", { value: true });
4
4
  exports.LoginHistory = void 0;
5
5
  const tslib_1 = require("tslib");
6
- const shell_1 = require("@things-factory/shell");
7
- const typeorm_1 = require("typeorm");
8
- const typeorm_2 = require("typeorm");
9
6
  const type_graphql_1 = require("type-graphql");
7
+ const typeorm_1 = require("typeorm");
8
+ const shell_1 = require("@things-factory/shell");
10
9
  const user_1 = require("../user/user");
11
10
  let LoginHistory = LoginHistory_1 = class LoginHistory {
12
11
  static async stamp(accessDomain, accessUser, accessorIp) {
13
- await (0, typeorm_1.getRepository)(LoginHistory_1).save({
12
+ await (0, shell_1.getRepository)(LoginHistory_1).save({
14
13
  accessDomain,
15
14
  accessUser,
16
15
  accessorIp
@@ -18,41 +17,41 @@ let LoginHistory = LoginHistory_1 = class LoginHistory {
18
17
  }
19
18
  };
20
19
  tslib_1.__decorate([
21
- (0, typeorm_2.PrimaryGeneratedColumn)('uuid'),
20
+ (0, typeorm_1.PrimaryGeneratedColumn)('uuid'),
22
21
  (0, type_graphql_1.Field)(type => type_graphql_1.ID),
23
22
  tslib_1.__metadata("design:type", String)
24
23
  ], LoginHistory.prototype, "id", void 0);
25
24
  tslib_1.__decorate([
26
- (0, typeorm_2.ManyToOne)(type => shell_1.Domain),
25
+ (0, typeorm_1.ManyToOne)(type => shell_1.Domain),
27
26
  (0, type_graphql_1.Field)(),
28
- tslib_1.__metadata("design:type", typeof (_a = typeof shell_1.Domain !== "undefined" && shell_1.Domain) === "function" ? _a : Object)
27
+ tslib_1.__metadata("design:type", shell_1.Domain)
29
28
  ], LoginHistory.prototype, "accessDomain", void 0);
30
29
  tslib_1.__decorate([
31
- (0, typeorm_2.RelationId)((loginHistory) => loginHistory.accessDomain),
30
+ (0, typeorm_1.RelationId)((loginHistory) => loginHistory.accessDomain),
32
31
  tslib_1.__metadata("design:type", String)
33
32
  ], LoginHistory.prototype, "accessDomainId", void 0);
34
33
  tslib_1.__decorate([
35
- (0, typeorm_2.ManyToOne)(type => user_1.User),
34
+ (0, typeorm_1.ManyToOne)(type => user_1.User),
36
35
  (0, type_graphql_1.Field)(),
37
36
  tslib_1.__metadata("design:type", user_1.User)
38
37
  ], LoginHistory.prototype, "accessUser", void 0);
39
38
  tslib_1.__decorate([
40
- (0, typeorm_2.RelationId)((loginHistory) => loginHistory.accessUser),
39
+ (0, typeorm_1.RelationId)((loginHistory) => loginHistory.accessUser),
41
40
  tslib_1.__metadata("design:type", String)
42
41
  ], LoginHistory.prototype, "accessUserId", void 0);
43
42
  tslib_1.__decorate([
44
- (0, typeorm_2.Column)({ nullable: true }),
43
+ (0, typeorm_1.Column)({ nullable: true }),
45
44
  (0, type_graphql_1.Field)({ nullable: true }),
46
45
  tslib_1.__metadata("design:type", String)
47
46
  ], LoginHistory.prototype, "accessorIp", void 0);
48
47
  tslib_1.__decorate([
49
- (0, typeorm_2.CreateDateColumn)(),
48
+ (0, typeorm_1.CreateDateColumn)(),
50
49
  (0, type_graphql_1.Field)({ nullable: true }),
51
50
  tslib_1.__metadata("design:type", Date)
52
51
  ], LoginHistory.prototype, "accessedAt", void 0);
53
52
  LoginHistory = LoginHistory_1 = tslib_1.__decorate([
54
- (0, typeorm_2.Entity)(),
55
- (0, typeorm_2.Index)('ix_login_history_0', (loginHistory) => [loginHistory.accessDomain, loginHistory.accessUser]),
53
+ (0, typeorm_1.Entity)(),
54
+ (0, typeorm_1.Index)('ix_login_history_0', (loginHistory) => [loginHistory.accessDomain, loginHistory.accessUser]),
56
55
  (0, type_graphql_1.ObjectType)()
57
56
  ], LoginHistory);
58
57
  exports.LoginHistory = LoginHistory;
@@ -1 +1 @@
1
- {"version":3,"file":"login-history.js","sourceRoot":"","sources":["../../../server/service/login-history/login-history.ts"],"names":[],"mappings":";;;;;AAAA,iDAA8C;AAC9C,qCAAuC;AACvC,qCAAgH;AAChH,+CAAoD;AACpD,uCAAmC;AAKnC,IAAa,YAAY,oBAAzB,MAAa,YAAY;IA2BvB,MAAM,CAAC,KAAK,CAAC,KAAK,CAAC,YAAoB,EAAE,UAAgB,EAAE,UAAkB;QAC3E,MAAM,IAAA,uBAAa,EAAC,cAAY,CAAC,CAAC,IAAI,CAAC;YACrC,YAAY;YACZ,UAAU;YACV,UAAU;SACX,CAAC,CAAA;IACJ,CAAC;CACF,CAAA;AA/BC;IAFC,IAAA,gCAAsB,EAAC,MAAM,CAAC;IAC9B,IAAA,oBAAK,EAAC,IAAI,CAAC,EAAE,CAAC,iBAAE,CAAC;;wCACC;AAInB;IAFC,IAAA,mBAAS,EAAC,IAAI,CAAC,EAAE,CAAC,cAAM,CAAC;IACzB,IAAA,oBAAK,GAAE;0DACM,cAAM,oBAAN,cAAM;kDAAA;AAGpB;IADC,IAAA,oBAAU,EAAC,CAAC,YAA0B,EAAE,EAAE,CAAC,YAAY,CAAC,YAAY,CAAC;;oDAChD;AAItB;IAFC,IAAA,mBAAS,EAAC,IAAI,CAAC,EAAE,CAAC,WAAI,CAAC;IACvB,IAAA,oBAAK,GAAE;sCACI,WAAI;gDAAA;AAGhB;IADC,IAAA,oBAAU,EAAC,CAAC,YAA0B,EAAE,EAAE,CAAC,YAAY,CAAC,UAAU,CAAC;;kDAChD;AAIpB;IAFC,IAAA,gBAAM,EAAC,EAAE,QAAQ,EAAE,IAAI,EAAE,CAAC;IAC1B,IAAA,oBAAK,EAAC,EAAE,QAAQ,EAAE,IAAI,EAAE,CAAC;;gDACR;AAIlB;IAFC,IAAA,0BAAgB,GAAE;IAClB,IAAA,oBAAK,EAAC,EAAE,QAAQ,EAAE,IAAI,EAAE,CAAC;sCACd,IAAI;gDAAA;AAzBL,YAAY;IAHxB,IAAA,gBAAM,GAAE;IACR,IAAA,eAAK,EAAC,oBAAoB,EAAE,CAAC,YAA0B,EAAE,EAAE,CAAC,CAAC,YAAY,CAAC,YAAY,EAAE,YAAY,CAAC,UAAU,CAAC,CAAC;IACjH,IAAA,yBAAU,GAAE;GACA,YAAY,CAkCxB;AAlCY,oCAAY","sourcesContent":["import { Domain } from '@things-factory/shell'\nimport { getRepository } from 'typeorm'\nimport { Column, CreateDateColumn, Entity, Index, ManyToOne, RelationId, PrimaryGeneratedColumn } from 'typeorm'\nimport { ObjectType, Field, ID } from 'type-graphql'\nimport { User } from '../user/user'\n\n@Entity()\n@Index('ix_login_history_0', (loginHistory: LoginHistory) => [loginHistory.accessDomain, loginHistory.accessUser])\n@ObjectType()\nexport class LoginHistory {\n @PrimaryGeneratedColumn('uuid')\n @Field(type => ID)\n readonly id: string\n\n @ManyToOne(type => Domain)\n @Field()\n accessDomain: Domain\n\n @RelationId((loginHistory: LoginHistory) => loginHistory.accessDomain)\n accessDomainId: string\n\n @ManyToOne(type => User)\n @Field()\n accessUser: User\n\n @RelationId((loginHistory: LoginHistory) => loginHistory.accessUser)\n accessUserId: string\n\n @Column({ nullable: true })\n @Field({ nullable: true })\n accessorIp: string\n\n @CreateDateColumn()\n @Field({ nullable: true })\n accessedAt: Date\n\n static async stamp(accessDomain: Domain, accessUser: User, accessorIp: string): Promise<void> {\n await getRepository(LoginHistory).save({\n accessDomain,\n accessUser,\n accessorIp\n })\n }\n}\n"]}
1
+ {"version":3,"file":"login-history.js","sourceRoot":"","sources":["../../../server/service/login-history/login-history.ts"],"names":[],"mappings":";;;;;AAAA,+CAAoD;AACpD,qCAAgH;AAEhH,iDAA6D;AAE7D,uCAAmC;AAKnC,IAAa,YAAY,oBAAzB,MAAa,YAAY;IA2BvB,MAAM,CAAC,KAAK,CAAC,KAAK,CAAC,YAAoB,EAAE,UAAgB,EAAE,UAAkB;QAC3E,MAAM,IAAA,qBAAa,EAAC,cAAY,CAAC,CAAC,IAAI,CAAC;YACrC,YAAY;YACZ,UAAU;YACV,UAAU;SACX,CAAC,CAAA;IACJ,CAAC;CACF,CAAA;AA/BC;IAFC,IAAA,gCAAsB,EAAC,MAAM,CAAC;IAC9B,IAAA,oBAAK,EAAC,IAAI,CAAC,EAAE,CAAC,iBAAE,CAAC;;wCACC;AAInB;IAFC,IAAA,mBAAS,EAAC,IAAI,CAAC,EAAE,CAAC,cAAM,CAAC;IACzB,IAAA,oBAAK,GAAE;sCACM,cAAM;kDAAA;AAGpB;IADC,IAAA,oBAAU,EAAC,CAAC,YAA0B,EAAE,EAAE,CAAC,YAAY,CAAC,YAAY,CAAC;;oDAChD;AAItB;IAFC,IAAA,mBAAS,EAAC,IAAI,CAAC,EAAE,CAAC,WAAI,CAAC;IACvB,IAAA,oBAAK,GAAE;sCACI,WAAI;gDAAA;AAGhB;IADC,IAAA,oBAAU,EAAC,CAAC,YAA0B,EAAE,EAAE,CAAC,YAAY,CAAC,UAAU,CAAC;;kDAChD;AAIpB;IAFC,IAAA,gBAAM,EAAC,EAAE,QAAQ,EAAE,IAAI,EAAE,CAAC;IAC1B,IAAA,oBAAK,EAAC,EAAE,QAAQ,EAAE,IAAI,EAAE,CAAC;;gDACR;AAIlB;IAFC,IAAA,0BAAgB,GAAE;IAClB,IAAA,oBAAK,EAAC,EAAE,QAAQ,EAAE,IAAI,EAAE,CAAC;sCACd,IAAI;gDAAA;AAzBL,YAAY;IAHxB,IAAA,gBAAM,GAAE;IACR,IAAA,eAAK,EAAC,oBAAoB,EAAE,CAAC,YAA0B,EAAE,EAAE,CAAC,CAAC,YAAY,CAAC,YAAY,EAAE,YAAY,CAAC,UAAU,CAAC,CAAC;IACjH,IAAA,yBAAU,GAAE;GACA,YAAY,CAkCxB;AAlCY,oCAAY","sourcesContent":["import { Field, ID, ObjectType } from 'type-graphql'\nimport { Column, CreateDateColumn, Entity, Index, ManyToOne, PrimaryGeneratedColumn, RelationId } from 'typeorm'\n\nimport { Domain, getRepository } from '@things-factory/shell'\n\nimport { User } from '../user/user'\n\n@Entity()\n@Index('ix_login_history_0', (loginHistory: LoginHistory) => [loginHistory.accessDomain, loginHistory.accessUser])\n@ObjectType()\nexport class LoginHistory {\n @PrimaryGeneratedColumn('uuid')\n @Field(type => ID)\n readonly id: string\n\n @ManyToOne(type => Domain)\n @Field()\n accessDomain: Domain\n\n @RelationId((loginHistory: LoginHistory) => loginHistory.accessDomain)\n accessDomainId: string\n\n @ManyToOne(type => User)\n @Field()\n accessUser: User\n\n @RelationId((loginHistory: LoginHistory) => loginHistory.accessUser)\n accessUserId: string\n\n @Column({ nullable: true })\n @Field({ nullable: true })\n accessorIp: string\n\n @CreateDateColumn()\n @Field({ nullable: true })\n accessedAt: Date\n\n static async stamp(accessDomain: Domain, accessUser: User, accessorIp: string): Promise<void> {\n await getRepository(LoginHistory).save({\n accessDomain,\n accessUser,\n accessorIp\n })\n }\n}\n"]}
@@ -0,0 +1,5 @@
1
+ import { Partner } from './partner';
2
+ import { PartnerQuery } from './partner-query';
3
+ import { PartnerMutation } from './partner-mutation';
4
+ export declare const entities: (typeof Partner)[];
5
+ export declare const resolvers: (typeof PartnerQuery | typeof PartnerMutation)[];
@@ -0,0 +1,4 @@
1
+ export declare class PartnerMutation {
2
+ inviteCustomer(customerDomainName: string, context: ResolverContext): Promise<boolean>;
3
+ terminateContract(partnerName: string, context: ResolverContext): Promise<boolean>;
4
+ }
@@ -2,24 +2,23 @@
2
2
  Object.defineProperty(exports, "__esModule", { value: true });
3
3
  exports.PartnerMutation = void 0;
4
4
  const tslib_1 = require("tslib");
5
- const partner_1 = require("./partner");
6
5
  const type_graphql_1 = require("type-graphql");
7
6
  const shell_1 = require("@things-factory/shell");
8
- const typeorm_1 = require("typeorm");
9
7
  const granted_role_mutation_1 = require("../granted-role/granted-role-mutation");
8
+ const partner_1 = require("./partner");
10
9
  let PartnerMutation = class PartnerMutation {
11
10
  async inviteCustomer(customerDomainName, context) {
12
11
  // 1. Try to find existing customer
13
12
  const { domain, user } = context.state;
14
- const customerDomain = await (0, typeorm_1.getRepository)(shell_1.Domain).findOne({ where: { name: customerDomainName } });
13
+ const customerDomain = await (0, shell_1.getRepository)(shell_1.Domain).findOne({ where: { name: customerDomainName } });
15
14
  if (!customerDomain)
16
15
  throw new Error(`There's no customer which has ${customerDomainName} as name`);
17
- const isExistingCustomer = Boolean(await (0, typeorm_1.getRepository)(partner_1.Partner).count({
18
- where: { domain, partnerDomain: customerDomain }
16
+ const isExistingCustomer = Boolean(await (0, shell_1.getRepository)(partner_1.Partner).count({
17
+ where: { domain: { id: domain.id }, partnerDomain: customerDomain }
19
18
  }));
20
19
  if (isExistingCustomer)
21
20
  throw new Error('Partner is registered as customer already');
22
- await (0, typeorm_1.getRepository)(partner_1.Partner).save({
21
+ await (0, shell_1.getRepository)(partner_1.Partner).save({
23
22
  domain,
24
23
  partnerDomain: customerDomain,
25
24
  requester: user,
@@ -37,7 +36,7 @@ let PartnerMutation = class PartnerMutation {
37
36
  throw new Error(context.t('error.failed to find x', { x: context.t('label.partner') }));
38
37
  // Find partner
39
38
  const partner = await tx.getRepository(partner_1.Partner).findOne({
40
- where: { domain, partnerDomain }
39
+ where: { domain: { id: domain.id }, partnerDomain }
41
40
  });
42
41
  if (!partner)
43
42
  throw new Error(context.t('error.failed to find x', { x: context.t('label.partner') }));
@@ -1 +1 @@
1
- {"version":3,"file":"partner-mutation.js","sourceRoot":"","sources":["../../../server/service/partner/partner-mutation.ts"],"names":[],"mappings":"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","sourcesContent":["import { Partner } from './partner'\nimport { Resolver, Mutation, Arg, Ctx, Directive } from 'type-graphql'\nimport { Domain } from '@things-factory/shell'\nimport { getRepository, EntityManager } from 'typeorm'\nimport { terminateGrantedRoles } from '../granted-role/granted-role-mutation'\n\n@Resolver(Partner)\nexport class PartnerMutation {\n @Directive('@privilege(category: \"partner\", privilege: \"mutation\")')\n @Mutation(returns => Boolean)\n async inviteCustomer(@Arg('customerDomainName') customerDomainName: string, @Ctx() context: any) {\n // 1. Try to find existing customer\n const { domain, user } = context.state\n const customerDomain: Domain = await getRepository(Domain).findOne({ where: { name: customerDomainName } })\n if (!customerDomain) throw new Error(`There's no customer which has ${customerDomainName} as name`)\n\n const isExistingCustomer: boolean = Boolean(\n await getRepository(Partner).count({\n where: { domain, partnerDomain: customerDomain }\n })\n )\n if (isExistingCustomer) throw new Error('Partner is registered as customer already')\n\n await getRepository(Partner).save({\n domain,\n partnerDomain: customerDomain,\n requester: user,\n approver: user\n })\n\n return true\n }\n\n @Directive('@privilege(category: \"partner\", privilege: \"mutation\")')\n @Directive('@transaction')\n @Mutation(returns => Boolean)\n async terminateContract(@Arg('partnerName') partnerName: string, @Ctx() context: any) {\n const { tx, domain }: { tx: EntityManager; domain: Domain } = context.state\n\n // Find partnerDomain\n const partnerDomain: Domain = await tx.getRepository(Domain).findOne({\n where: { name: partnerName }\n })\n if (!partnerDomain) throw new Error(context.t('error.failed to find x', { x: context.t('label.partner') }))\n\n // Find partner\n const partner: Partner = await tx.getRepository(Partner).findOne({\n where: { domain, partnerDomain }\n })\n if (!partner) throw new Error(context.t('error.failed to find x', { x: context.t('label.partner') }))\n\n // Remove record from partner\n await tx.getRepository(Partner).delete(partner.id)\n\n // Remove granted roles\n await terminateGrantedRoles(domain, partnerDomain, tx)\n\n return true\n }\n}\n"]}
1
+ {"version":3,"file":"partner-mutation.js","sourceRoot":"","sources":["../../../server/service/partner/partner-mutation.ts"],"names":[],"mappings":";;;;AAAA,+CAAsE;AAEtE,iDAA6D;AAE7D,iFAA6E;AAC7E,uCAAmC;AAGnC,IAAa,eAAe,GAA5B,MAAa,eAAe;IAG1B,KAAK,CAAC,cAAc,CAA4B,kBAA0B,EAAS,OAAwB;QACzG,mCAAmC;QACnC,MAAM,EAAE,MAAM,EAAE,IAAI,EAAE,GAAG,OAAO,CAAC,KAAK,CAAA;QACtC,MAAM,cAAc,GAAW,MAAM,IAAA,qBAAa,EAAC,cAAM,CAAC,CAAC,OAAO,CAAC,EAAE,KAAK,EAAE,EAAE,IAAI,EAAE,kBAAkB,EAAE,EAAE,CAAC,CAAA;QAC3G,IAAI,CAAC,cAAc;YAAE,MAAM,IAAI,KAAK,CAAC,iCAAiC,kBAAkB,UAAU,CAAC,CAAA;QAEnG,MAAM,kBAAkB,GAAY,OAAO,CACzC,MAAM,IAAA,qBAAa,EAAC,iBAAO,CAAC,CAAC,KAAK,CAAC;YACjC,KAAK,EAAE,EAAE,MAAM,EAAE,EAAE,EAAE,EAAE,MAAM,CAAC,EAAE,EAAE,EAAE,aAAa,EAAE,cAAc,EAAE;SACpE,CAAC,CACH,CAAA;QACD,IAAI,kBAAkB;YAAE,MAAM,IAAI,KAAK,CAAC,2CAA2C,CAAC,CAAA;QAEpF,MAAM,IAAA,qBAAa,EAAC,iBAAO,CAAC,CAAC,IAAI,CAAC;YAChC,MAAM;YACN,aAAa,EAAE,cAAc;YAC7B,SAAS,EAAE,IAAI;YACf,QAAQ,EAAE,IAAI;SACf,CAAC,CAAA;QAEF,OAAO,IAAI,CAAA;IACb,CAAC;IAKD,KAAK,CAAC,iBAAiB,CAAqB,WAAmB,EAAS,OAAwB;QAC9F,MAAM,EAAE,EAAE,EAAE,MAAM,EAAE,GAAG,OAAO,CAAC,KAAK,CAAA;QAEpC,qBAAqB;QACrB,MAAM,aAAa,GAAW,MAAM,EAAE,CAAC,aAAa,CAAC,cAAM,CAAC,CAAC,OAAO,CAAC;YACnE,KAAK,EAAE,EAAE,IAAI,EAAE,WAAW,EAAE;SAC7B,CAAC,CAAA;QACF,IAAI,CAAC,aAAa;YAAE,MAAM,IAAI,KAAK,CAAC,OAAO,CAAC,CAAC,CAAC,wBAAwB,EAAE,EAAE,CAAC,EAAE,OAAO,CAAC,CAAC,CAAC,eAAe,CAAC,EAAE,CAAC,CAAC,CAAA;QAE3G,eAAe;QACf,MAAM,OAAO,GAAY,MAAM,EAAE,CAAC,aAAa,CAAC,iBAAO,CAAC,CAAC,OAAO,CAAC;YAC/D,KAAK,EAAE,EAAE,MAAM,EAAE,EAAE,EAAE,EAAE,MAAM,CAAC,EAAE,EAAE,EAAE,aAAa,EAAE;SACpD,CAAC,CAAA;QACF,IAAI,CAAC,OAAO;YAAE,MAAM,IAAI,KAAK,CAAC,OAAO,CAAC,CAAC,CAAC,wBAAwB,EAAE,EAAE,CAAC,EAAE,OAAO,CAAC,CAAC,CAAC,eAAe,CAAC,EAAE,CAAC,CAAC,CAAA;QAErG,6BAA6B;QAC7B,MAAM,EAAE,CAAC,aAAa,CAAC,iBAAO,CAAC,CAAC,MAAM,CAAC,OAAO,CAAC,EAAE,CAAC,CAAA;QAElD,uBAAuB;QACvB,MAAM,IAAA,6CAAqB,EAAC,MAAM,EAAE,aAAa,EAAE,EAAE,CAAC,CAAA;QAEtD,OAAO,IAAI,CAAA;IACb,CAAC;CACF,CAAA;AAjDC;IAFC,IAAA,wBAAS,EAAC,wDAAwD,CAAC;IACnE,IAAA,uBAAQ,EAAC,OAAO,CAAC,EAAE,CAAC,OAAO,CAAC;IACP,mBAAA,IAAA,kBAAG,EAAC,oBAAoB,CAAC,CAAA;IAA8B,mBAAA,IAAA,kBAAG,GAAE,CAAA;;;;qDAqBjF;AAKD;IAHC,IAAA,wBAAS,EAAC,wDAAwD,CAAC;IACnE,IAAA,wBAAS,EAAC,cAAc,CAAC;IACzB,IAAA,uBAAQ,EAAC,OAAO,CAAC,EAAE,CAAC,OAAO,CAAC;IACJ,mBAAA,IAAA,kBAAG,EAAC,aAAa,CAAC,CAAA;IAAuB,mBAAA,IAAA,kBAAG,GAAE,CAAA;;;;wDAsBtE;AAnDU,eAAe;IAD3B,IAAA,uBAAQ,EAAC,iBAAO,CAAC;GACL,eAAe,CAoD3B;AApDY,0CAAe","sourcesContent":["import { Arg, Ctx, Directive, Mutation, Resolver } from 'type-graphql'\n\nimport { Domain, getRepository } from '@things-factory/shell'\n\nimport { terminateGrantedRoles } from '../granted-role/granted-role-mutation'\nimport { Partner } from './partner'\n\n@Resolver(Partner)\nexport class PartnerMutation {\n @Directive('@privilege(category: \"partner\", privilege: \"mutation\")')\n @Mutation(returns => Boolean)\n async inviteCustomer(@Arg('customerDomainName') customerDomainName: string, @Ctx() context: ResolverContext) {\n // 1. Try to find existing customer\n const { domain, user } = context.state\n const customerDomain: Domain = await getRepository(Domain).findOne({ where: { name: customerDomainName } })\n if (!customerDomain) throw new Error(`There's no customer which has ${customerDomainName} as name`)\n\n const isExistingCustomer: boolean = Boolean(\n await getRepository(Partner).count({\n where: { domain: { id: domain.id }, partnerDomain: customerDomain }\n })\n )\n if (isExistingCustomer) throw new Error('Partner is registered as customer already')\n\n await getRepository(Partner).save({\n domain,\n partnerDomain: customerDomain,\n requester: user,\n approver: user\n })\n\n return true\n }\n\n @Directive('@privilege(category: \"partner\", privilege: \"mutation\")')\n @Directive('@transaction')\n @Mutation(returns => Boolean)\n async terminateContract(@Arg('partnerName') partnerName: string, @Ctx() context: ResolverContext) {\n const { tx, domain } = context.state\n\n // Find partnerDomain\n const partnerDomain: Domain = await tx.getRepository(Domain).findOne({\n where: { name: partnerName }\n })\n if (!partnerDomain) throw new Error(context.t('error.failed to find x', { x: context.t('label.partner') }))\n\n // Find partner\n const partner: Partner = await tx.getRepository(Partner).findOne({\n where: { domain: { id: domain.id }, partnerDomain }\n })\n if (!partner) throw new Error(context.t('error.failed to find x', { x: context.t('label.partner') }))\n\n // Remove record from partner\n await tx.getRepository(Partner).delete(partner.id)\n\n // Remove granted roles\n await terminateGrantedRoles(domain, partnerDomain, tx)\n\n return true\n }\n}\n"]}
@@ -0,0 +1,14 @@
1
+ import { Domain, DomainList, ListParam } from '@things-factory/shell';
2
+ import { User } from '../user/user';
3
+ import { Partner } from './partner';
4
+ import { PartnerList } from './partner-types';
5
+ export declare class PartnerQuery {
6
+ partners(params: ListParam, context: ResolverContext): Promise<PartnerList>;
7
+ customers(context: ResolverContext): Promise<Domain[]>;
8
+ searchCustomers(params: ListParam, context: ResolverContext): Promise<DomainList>;
9
+ vendors(context: ResolverContext): Promise<Domain[]>;
10
+ domain(partner: Partner): Promise<Domain>;
11
+ partnerDomain(partner: Partner): Promise<Domain>;
12
+ requester(partner: Partner): Promise<User>;
13
+ approver(partner: Partner): Promise<User>;
14
+ }
@@ -1,10 +1,8 @@
1
1
  "use strict";
2
- var _a, _b;
3
2
  Object.defineProperty(exports, "__esModule", { value: true });
4
3
  exports.PartnerQuery = void 0;
5
4
  const tslib_1 = require("tslib");
6
5
  const type_graphql_1 = require("type-graphql");
7
- const typeorm_1 = require("typeorm");
8
6
  const shell_1 = require("@things-factory/shell");
9
7
  const check_user_belongs_domain_1 = require("../../utils/check-user-belongs-domain");
10
8
  const user_1 = require("../user/user");
@@ -13,7 +11,7 @@ const partner_types_1 = require("./partner-types");
13
11
  let PartnerQuery = class PartnerQuery {
14
12
  async partners(params, context) {
15
13
  if (await (0, check_user_belongs_domain_1.checkUserBelongsDomain)(context.state.domain, context.state.user)) {
16
- const qb = (0, typeorm_1.getRepository)(partner_1.Partner).createQueryBuilder('PARTNER');
14
+ const qb = (0, shell_1.getRepository)(partner_1.Partner).createQueryBuilder('PARTNER');
17
15
  (0, shell_1.buildQuery)(qb, params, context);
18
16
  const [items, total] = await qb.getManyAndCount();
19
17
  return { items, total };
@@ -24,7 +22,7 @@ let PartnerQuery = class PartnerQuery {
24
22
  }
25
23
  async customers(context) {
26
24
  const { domain } = context.state;
27
- const partners = await (0, typeorm_1.getRepository)(partner_1.Partner).find({
25
+ const partners = await (0, shell_1.getRepository)(partner_1.Partner).find({
28
26
  where: { domain },
29
27
  relations: ['partnerDomain']
30
28
  });
@@ -32,11 +30,11 @@ let PartnerQuery = class PartnerQuery {
32
30
  }
33
31
  async searchCustomers(params, context) {
34
32
  const { domain } = context.state;
35
- const partners = await (0, typeorm_1.getRepository)(partner_1.Partner).find({
33
+ const partners = await (0, shell_1.getRepository)(partner_1.Partner).find({
36
34
  where: { domain },
37
35
  relations: ['partnerDomain']
38
36
  });
39
- const qb = (0, typeorm_1.getRepository)(shell_1.Domain).createQueryBuilder('DOMAIN');
37
+ const qb = (0, shell_1.getRepository)(shell_1.Domain).createQueryBuilder('DOMAIN');
40
38
  (0, shell_1.buildQuery)(qb, params, context, { domainRef: false });
41
39
  qb.andWhereInIds(partners.map((p) => p.partnerDomain.id));
42
40
  const [items, total] = await qb.getManyAndCount();
@@ -44,7 +42,7 @@ let PartnerQuery = class PartnerQuery {
44
42
  }
45
43
  async vendors(context) {
46
44
  const { domain } = context.state;
47
- const qb = (0, typeorm_1.getRepository)(partner_1.Partner).createQueryBuilder('PARTNER');
45
+ const qb = (0, shell_1.getRepository)(partner_1.Partner).createQueryBuilder('PARTNER');
48
46
  const partners = await qb
49
47
  .leftJoinAndSelect('PARTNER.domain', 'DOMAIN')
50
48
  .leftJoinAndSelect('PARTNER.partnerDomain', 'P_DOMAIN')
@@ -53,16 +51,16 @@ let PartnerQuery = class PartnerQuery {
53
51
  return partners.map((p) => p.domain);
54
52
  }
55
53
  async domain(partner) {
56
- return await (0, typeorm_1.getRepository)(shell_1.Domain).findOne(partner.domainId);
54
+ return await (0, shell_1.getRepository)(shell_1.Domain).findOneBy({ id: partner.domainId });
57
55
  }
58
56
  async partnerDomain(partner) {
59
- return await (0, typeorm_1.getRepository)(shell_1.Domain).findOne(partner.partnerDomainId);
57
+ return await (0, shell_1.getRepository)(shell_1.Domain).findOneBy({ id: partner.partnerDomainId });
60
58
  }
61
59
  async requester(partner) {
62
- return await (0, typeorm_1.getRepository)(user_1.User).findOne(partner.requesterId);
60
+ return await (0, shell_1.getRepository)(user_1.User).findOneBy({ id: partner.requesterId });
63
61
  }
64
62
  async approver(partner) {
65
- return await (0, typeorm_1.getRepository)(user_1.User).findOne(partner.approverId);
63
+ return await (0, shell_1.getRepository)(user_1.User).findOneBy({ id: partner.approverId });
66
64
  }
67
65
  };
68
66
  tslib_1.__decorate([
@@ -71,7 +69,7 @@ tslib_1.__decorate([
71
69
  tslib_1.__param(0, (0, type_graphql_1.Args)()),
72
70
  tslib_1.__param(1, (0, type_graphql_1.Ctx)()),
73
71
  tslib_1.__metadata("design:type", Function),
74
- tslib_1.__metadata("design:paramtypes", [typeof (_a = typeof shell_1.ListParam !== "undefined" && shell_1.ListParam) === "function" ? _a : Object, Object]),
72
+ tslib_1.__metadata("design:paramtypes", [shell_1.ListParam, Object]),
75
73
  tslib_1.__metadata("design:returntype", Promise)
76
74
  ], PartnerQuery.prototype, "partners", null);
77
75
  tslib_1.__decorate([
@@ -88,7 +86,7 @@ tslib_1.__decorate([
88
86
  tslib_1.__param(0, (0, type_graphql_1.Args)()),
89
87
  tslib_1.__param(1, (0, type_graphql_1.Ctx)()),
90
88
  tslib_1.__metadata("design:type", Function),
91
- tslib_1.__metadata("design:paramtypes", [typeof (_b = typeof shell_1.ListParam !== "undefined" && shell_1.ListParam) === "function" ? _b : Object, Object]),
89
+ tslib_1.__metadata("design:paramtypes", [shell_1.ListParam, Object]),
92
90
  tslib_1.__metadata("design:returntype", Promise)
93
91
  ], PartnerQuery.prototype, "searchCustomers", null);
94
92
  tslib_1.__decorate([
@@ -1 +1 @@
1
- {"version":3,"file":"partner-query.js","sourceRoot":"","sources":["../../../server/service/partner/partner-query.ts"],"names":[],"mappings":"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","sourcesContent":["import { Args, Ctx, Directive, FieldResolver, Query, Resolver, Root } from 'type-graphql'\nimport { getRepository, SelectQueryBuilder } from 'typeorm'\n\nimport { buildQuery, Domain, DomainList, ListParam } from '@things-factory/shell'\n\nimport { checkUserBelongsDomain } from '../../utils/check-user-belongs-domain'\nimport { User } from '../user/user'\nimport { Partner } from './partner'\nimport { PartnerList } from './partner-types'\n\n@Resolver(Partner)\nexport class PartnerQuery {\n @Directive('@privilege(category: \"partner\", privilege: \"query\", domainOwnerGranted: true)')\n @Query(returns => PartnerList)\n async partners(@Args() params: ListParam, @Ctx() context: any): Promise<PartnerList> {\n if (await checkUserBelongsDomain(context.state.domain, context.state.user)) {\n const qb: SelectQueryBuilder<Partner> = getRepository(Partner).createQueryBuilder('PARTNER')\n buildQuery(qb, params, context)\n const [items, total] = await qb.getManyAndCount()\n\n return { items, total }\n } else {\n throw new Error(`User doesn't belong in current domain`)\n }\n }\n\n @Directive('@privilege(category: \"partner\", privilege: \"query\", domainOwnerGranted: true)')\n @Query(returns => [Domain])\n async customers(@Ctx() context: any): Promise<Domain[]> {\n const { domain } = context.state\n const partners: Partner[] = await getRepository(Partner).find({\n where: { domain },\n relations: ['partnerDomain']\n })\n\n return partners.map((p: Partner) => p.partnerDomain)\n }\n\n @Directive('@privilege(category: \"partner\", privilege: \"query\")')\n @Query(returns => DomainList)\n async searchCustomers(@Args() params: ListParam, @Ctx() context: any): Promise<DomainList> {\n const { domain } = context.state\n const partners: Partner[] = await getRepository(Partner).find({\n where: { domain },\n relations: ['partnerDomain']\n })\n\n const qb: SelectQueryBuilder<Domain> = getRepository(Domain).createQueryBuilder('DOMAIN')\n buildQuery(qb, params, context, { domainRef: false })\n qb.andWhereInIds(partners.map((p: Partner) => p.partnerDomain.id))\n const [items, total] = await qb.getManyAndCount()\n return { items, total }\n }\n\n @Directive('@privilege(category: \"partner\", privilege: \"query\", domainOwnerGranted: true)')\n @Query(returns => [Domain])\n async vendors(@Ctx() context: any): Promise<Domain[]> {\n const { domain } = context.state\n const qb: SelectQueryBuilder<Partner> = getRepository(Partner).createQueryBuilder('PARTNER')\n const partners: Partner[] = await qb\n .leftJoinAndSelect('PARTNER.domain', 'DOMAIN')\n .leftJoinAndSelect('PARTNER.partnerDomain', 'P_DOMAIN')\n .where('P_DOMAIN.id = :domainId', { domainId: domain.id })\n .getMany()\n\n return partners.map((p: Partner) => p.domain)\n }\n\n @FieldResolver()\n async domain(@Root() partner: Partner) {\n return await getRepository(Domain).findOne(partner.domainId)\n }\n\n @FieldResolver()\n async partnerDomain(@Root() partner: Partner) {\n return await getRepository(Domain).findOne(partner.partnerDomainId)\n }\n\n @FieldResolver()\n async requester(@Root() partner: Partner) {\n return await getRepository(User).findOne(partner.requesterId)\n }\n\n @FieldResolver()\n async approver(@Root() partner: Partner) {\n return await getRepository(User).findOne(partner.approverId)\n }\n}\n"]}
1
+ {"version":3,"file":"partner-query.js","sourceRoot":"","sources":["../../../server/service/partner/partner-query.ts"],"names":[],"mappings":"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","sourcesContent":["import { Args, Ctx, Directive, FieldResolver, Query, Resolver, Root } from 'type-graphql'\nimport { SelectQueryBuilder } from 'typeorm'\n\nimport { buildQuery, Domain, DomainList, getRepository, ListParam } from '@things-factory/shell'\n\nimport { checkUserBelongsDomain } from '../../utils/check-user-belongs-domain'\nimport { User } from '../user/user'\nimport { Partner } from './partner'\nimport { PartnerList } from './partner-types'\n\n@Resolver(Partner)\nexport class PartnerQuery {\n @Directive('@privilege(category: \"partner\", privilege: \"query\", domainOwnerGranted: true)')\n @Query(returns => PartnerList)\n async partners(@Args() params: ListParam, @Ctx() context: ResolverContext): Promise<PartnerList> {\n if (await checkUserBelongsDomain(context.state.domain, context.state.user)) {\n const qb: SelectQueryBuilder<Partner> = getRepository(Partner).createQueryBuilder('PARTNER')\n buildQuery(qb, params, context)\n const [items, total] = await qb.getManyAndCount()\n\n return { items, total }\n } else {\n throw new Error(`User doesn't belong in current domain`)\n }\n }\n\n @Directive('@privilege(category: \"partner\", privilege: \"query\", domainOwnerGranted: true)')\n @Query(returns => [Domain])\n async customers(@Ctx() context: ResolverContext): Promise<Domain[]> {\n const { domain } = context.state\n const partners: Partner[] = await getRepository(Partner).find({\n where: { domain },\n relations: ['partnerDomain']\n })\n\n return partners.map((p: Partner) => p.partnerDomain)\n }\n\n @Directive('@privilege(category: \"partner\", privilege: \"query\")')\n @Query(returns => DomainList)\n async searchCustomers(@Args() params: ListParam, @Ctx() context: ResolverContext): Promise<DomainList> {\n const { domain } = context.state\n const partners: Partner[] = await getRepository(Partner).find({\n where: { domain },\n relations: ['partnerDomain']\n })\n\n const qb: SelectQueryBuilder<Domain> = getRepository(Domain).createQueryBuilder('DOMAIN')\n buildQuery(qb, params, context, { domainRef: false })\n qb.andWhereInIds(partners.map((p: Partner) => p.partnerDomain.id))\n const [items, total] = await qb.getManyAndCount()\n return { items, total }\n }\n\n @Directive('@privilege(category: \"partner\", privilege: \"query\", domainOwnerGranted: true)')\n @Query(returns => [Domain])\n async vendors(@Ctx() context: ResolverContext): Promise<Domain[]> {\n const { domain } = context.state\n const qb: SelectQueryBuilder<Partner> = getRepository(Partner).createQueryBuilder('PARTNER')\n const partners: Partner[] = await qb\n .leftJoinAndSelect('PARTNER.domain', 'DOMAIN')\n .leftJoinAndSelect('PARTNER.partnerDomain', 'P_DOMAIN')\n .where('P_DOMAIN.id = :domainId', { domainId: domain.id })\n .getMany()\n\n return partners.map((p: Partner) => p.domain)\n }\n\n @FieldResolver()\n async domain(@Root() partner: Partner) {\n return await getRepository(Domain).findOneBy({ id: partner.domainId })\n }\n\n @FieldResolver()\n async partnerDomain(@Root() partner: Partner) {\n return await getRepository(Domain).findOneBy({ id: partner.partnerDomainId })\n }\n\n @FieldResolver()\n async requester(@Root() partner: Partner) {\n return await getRepository(User).findOneBy({ id: partner.requesterId })\n }\n\n @FieldResolver()\n async approver(@Root() partner: Partner) {\n return await getRepository(User).findOneBy({ id: partner.approverId })\n }\n}\n"]}
@@ -0,0 +1,5 @@
1
+ import { Partner } from './partner';
2
+ export declare class PartnerList {
3
+ items: Partner[];
4
+ total: number;
5
+ }
@@ -0,0 +1,15 @@
1
+ import { Domain } from '@things-factory/shell';
2
+ import { User } from '../user/user';
3
+ export declare class Partner {
4
+ readonly id: string;
5
+ domain: Domain;
6
+ domainId: string;
7
+ partnerDomain: Domain;
8
+ partnerDomainId: string;
9
+ requestedAt: Date;
10
+ approvedAt: Date;
11
+ requester: User;
12
+ requesterId: string;
13
+ approver: User;
14
+ approverId: string;
15
+ }
@@ -1,5 +1,4 @@
1
1
  "use strict";
2
- var _a, _b;
3
2
  Object.defineProperty(exports, "__esModule", { value: true });
4
3
  exports.Partner = void 0;
5
4
  const tslib_1 = require("tslib");
@@ -17,7 +16,7 @@ tslib_1.__decorate([
17
16
  tslib_1.__decorate([
18
17
  (0, typeorm_1.ManyToOne)(type => shell_1.Domain),
19
18
  (0, type_graphql_1.Field)(),
20
- tslib_1.__metadata("design:type", typeof (_a = typeof shell_1.Domain !== "undefined" && shell_1.Domain) === "function" ? _a : Object)
19
+ tslib_1.__metadata("design:type", shell_1.Domain)
21
20
  ], Partner.prototype, "domain", void 0);
22
21
  tslib_1.__decorate([
23
22
  (0, typeorm_1.RelationId)((partner) => partner.domain),
@@ -26,7 +25,7 @@ tslib_1.__decorate([
26
25
  tslib_1.__decorate([
27
26
  (0, typeorm_1.ManyToOne)(type => shell_1.Domain),
28
27
  (0, type_graphql_1.Field)(),
29
- tslib_1.__metadata("design:type", typeof (_b = typeof shell_1.Domain !== "undefined" && shell_1.Domain) === "function" ? _b : Object)
28
+ tslib_1.__metadata("design:type", shell_1.Domain)
30
29
  ], Partner.prototype, "partnerDomain", void 0);
31
30
  tslib_1.__decorate([
32
31
  (0, typeorm_1.RelationId)((partner) => partner.partnerDomain),
@@ -1 +1 @@
1
- {"version":3,"file":"partner.js","sourceRoot":"","sources":["../../../server/service/partner/partner.ts"],"names":[],"mappings":";;;;;AAAA,iDAA8C;AAC9C,qCAQgB;AAChB,+CAAoD;AACpD,uCAAmC;AAKnC,IAAa,OAAO,GAApB,MAAa,OAAO;CA4CnB,CAAA;AAzCC;IAFC,IAAA,gCAAsB,EAAC,MAAM,CAAC;IAC9B,IAAA,oBAAK,EAAC,IAAI,CAAC,EAAE,CAAC,iBAAE,CAAC;;mCACC;AAInB;IAFC,IAAA,mBAAS,EAAC,IAAI,CAAC,EAAE,CAAC,cAAM,CAAC;IACzB,IAAA,oBAAK,GAAE;0DACA,cAAM,oBAAN,cAAM;uCAAA;AAGd;IADC,IAAA,oBAAU,EAAC,CAAC,OAAgB,EAAE,EAAE,CAAC,OAAO,CAAC,MAAM,CAAC;;yCACjC;AAIhB;IAFC,IAAA,mBAAS,EAAC,IAAI,CAAC,EAAE,CAAC,cAAM,CAAC;IACzB,IAAA,oBAAK,GAAE;0DACO,cAAM,oBAAN,cAAM;8CAAA;AAGrB;IADC,IAAA,oBAAU,EAAC,CAAC,OAAgB,EAAE,EAAE,CAAC,OAAO,CAAC,aAAa,CAAC;;gDACjC;AAIvB;IAFC,IAAA,0BAAgB,GAAE;IAClB,IAAA,oBAAK,GAAE;sCACK,IAAI;4CAAA;AAIjB;IAFC,IAAA,0BAAgB,GAAE;IAClB,IAAA,oBAAK,GAAE;sCACI,IAAI;2CAAA;AAMhB;IAJC,IAAA,mBAAS,EAAC,IAAI,CAAC,EAAE,CAAC,WAAI,EAAE;QACvB,QAAQ,EAAE,IAAI;KACf,CAAC;IACD,IAAA,oBAAK,EAAC,EAAE,QAAQ,EAAE,IAAI,EAAE,CAAC;sCACf,WAAI;0CAAA;AAGf;IADC,IAAA,oBAAU,EAAC,CAAC,OAAgB,EAAE,EAAE,CAAC,OAAO,CAAC,SAAS,CAAC;;4CACjC;AAMnB;IAJC,IAAA,mBAAS,EAAC,IAAI,CAAC,EAAE,CAAC,WAAI,EAAE;QACvB,QAAQ,EAAE,IAAI;KACf,CAAC;IACD,IAAA,oBAAK,EAAC,EAAE,QAAQ,EAAE,IAAI,EAAE,CAAC;sCAChB,WAAI;yCAAA;AAGd;IADC,IAAA,oBAAU,EAAC,CAAC,OAAgB,EAAE,EAAE,CAAC,OAAO,CAAC,QAAQ,CAAC;;2CACjC;AA3CP,OAAO;IAHnB,IAAA,gBAAM,GAAE;IACR,IAAA,eAAK,EAAC,cAAc,EAAE,CAAC,OAAgB,EAAE,EAAE,CAAC,CAAC,OAAO,CAAC,MAAM,EAAE,OAAO,CAAC,aAAa,CAAC,EAAE,EAAE,MAAM,EAAE,IAAI,EAAE,CAAC;IACtG,IAAA,yBAAU,GAAE;GACA,OAAO,CA4CnB;AA5CY,0BAAO","sourcesContent":["import { Domain } from '@things-factory/shell'\nimport {\n CreateDateColumn,\n Entity,\n Index,\n ManyToOne,\n PrimaryGeneratedColumn,\n UpdateDateColumn,\n RelationId\n} from 'typeorm'\nimport { ObjectType, Field, ID } from 'type-graphql'\nimport { User } from '../user/user'\n\n@Entity()\n@Index('ix_partner_0', (partner: Partner) => [partner.domain, partner.partnerDomain], { unique: true })\n@ObjectType()\nexport class Partner {\n @PrimaryGeneratedColumn('uuid')\n @Field(type => ID)\n readonly id: string\n\n @ManyToOne(type => Domain)\n @Field()\n domain: Domain\n\n @RelationId((partner: Partner) => partner.domain)\n domainId: string\n\n @ManyToOne(type => Domain)\n @Field()\n partnerDomain: Domain\n\n @RelationId((partner: Partner) => partner.partnerDomain)\n partnerDomainId: string\n\n @CreateDateColumn()\n @Field()\n requestedAt: Date\n\n @UpdateDateColumn()\n @Field()\n approvedAt: Date\n\n @ManyToOne(type => User, {\n nullable: true\n })\n @Field({ nullable: true })\n requester: User\n\n @RelationId((partner: Partner) => partner.requester)\n requesterId: string\n\n @ManyToOne(type => User, {\n nullable: true\n })\n @Field({ nullable: true })\n approver: User\n\n @RelationId((partner: Partner) => partner.approver)\n approverId: string\n}\n"]}
1
+ {"version":3,"file":"partner.js","sourceRoot":"","sources":["../../../server/service/partner/partner.ts"],"names":[],"mappings":";;;;AAAA,iDAA8C;AAC9C,qCAQgB;AAChB,+CAAoD;AACpD,uCAAmC;AAKnC,IAAa,OAAO,GAApB,MAAa,OAAO;CA4CnB,CAAA;AAzCC;IAFC,IAAA,gCAAsB,EAAC,MAAM,CAAC;IAC9B,IAAA,oBAAK,EAAC,IAAI,CAAC,EAAE,CAAC,iBAAE,CAAC;;mCACC;AAInB;IAFC,IAAA,mBAAS,EAAC,IAAI,CAAC,EAAE,CAAC,cAAM,CAAC;IACzB,IAAA,oBAAK,GAAE;sCACA,cAAM;uCAAA;AAGd;IADC,IAAA,oBAAU,EAAC,CAAC,OAAgB,EAAE,EAAE,CAAC,OAAO,CAAC,MAAM,CAAC;;yCACjC;AAIhB;IAFC,IAAA,mBAAS,EAAC,IAAI,CAAC,EAAE,CAAC,cAAM,CAAC;IACzB,IAAA,oBAAK,GAAE;sCACO,cAAM;8CAAA;AAGrB;IADC,IAAA,oBAAU,EAAC,CAAC,OAAgB,EAAE,EAAE,CAAC,OAAO,CAAC,aAAa,CAAC;;gDACjC;AAIvB;IAFC,IAAA,0BAAgB,GAAE;IAClB,IAAA,oBAAK,GAAE;sCACK,IAAI;4CAAA;AAIjB;IAFC,IAAA,0BAAgB,GAAE;IAClB,IAAA,oBAAK,GAAE;sCACI,IAAI;2CAAA;AAMhB;IAJC,IAAA,mBAAS,EAAC,IAAI,CAAC,EAAE,CAAC,WAAI,EAAE;QACvB,QAAQ,EAAE,IAAI;KACf,CAAC;IACD,IAAA,oBAAK,EAAC,EAAE,QAAQ,EAAE,IAAI,EAAE,CAAC;sCACf,WAAI;0CAAA;AAGf;IADC,IAAA,oBAAU,EAAC,CAAC,OAAgB,EAAE,EAAE,CAAC,OAAO,CAAC,SAAS,CAAC;;4CACjC;AAMnB;IAJC,IAAA,mBAAS,EAAC,IAAI,CAAC,EAAE,CAAC,WAAI,EAAE;QACvB,QAAQ,EAAE,IAAI;KACf,CAAC;IACD,IAAA,oBAAK,EAAC,EAAE,QAAQ,EAAE,IAAI,EAAE,CAAC;sCAChB,WAAI;yCAAA;AAGd;IADC,IAAA,oBAAU,EAAC,CAAC,OAAgB,EAAE,EAAE,CAAC,OAAO,CAAC,QAAQ,CAAC;;2CACjC;AA3CP,OAAO;IAHnB,IAAA,gBAAM,GAAE;IACR,IAAA,eAAK,EAAC,cAAc,EAAE,CAAC,OAAgB,EAAE,EAAE,CAAC,CAAC,OAAO,CAAC,MAAM,EAAE,OAAO,CAAC,aAAa,CAAC,EAAE,EAAE,MAAM,EAAE,IAAI,EAAE,CAAC;IACtG,IAAA,yBAAU,GAAE;GACA,OAAO,CA4CnB;AA5CY,0BAAO","sourcesContent":["import { Domain } from '@things-factory/shell'\nimport {\n CreateDateColumn,\n Entity,\n Index,\n ManyToOne,\n PrimaryGeneratedColumn,\n UpdateDateColumn,\n RelationId\n} from 'typeorm'\nimport { ObjectType, Field, ID } from 'type-graphql'\nimport { User } from '../user/user'\n\n@Entity()\n@Index('ix_partner_0', (partner: Partner) => [partner.domain, partner.partnerDomain], { unique: true })\n@ObjectType()\nexport class Partner {\n @PrimaryGeneratedColumn('uuid')\n @Field(type => ID)\n readonly id: string\n\n @ManyToOne(type => Domain)\n @Field()\n domain: Domain\n\n @RelationId((partner: Partner) => partner.domain)\n domainId: string\n\n @ManyToOne(type => Domain)\n @Field()\n partnerDomain: Domain\n\n @RelationId((partner: Partner) => partner.partnerDomain)\n partnerDomainId: string\n\n @CreateDateColumn()\n @Field()\n requestedAt: Date\n\n @UpdateDateColumn()\n @Field()\n approvedAt: Date\n\n @ManyToOne(type => User, {\n nullable: true\n })\n @Field({ nullable: true })\n requester: User\n\n @RelationId((partner: Partner) => partner.requester)\n requesterId: string\n\n @ManyToOne(type => User, {\n nullable: true\n })\n @Field({ nullable: true })\n approver: User\n\n @RelationId((partner: Partner) => partner.approver)\n approverId: string\n}\n"]}
@@ -0,0 +1,2 @@
1
+ import { PasswordHistory } from './password-history';
2
+ export declare const entities: (typeof PasswordHistory)[];
@@ -0,0 +1,4 @@
1
+ export declare class PasswordHistory {
2
+ userId: string;
3
+ history: string;
4
+ }
@@ -0,0 +1,5 @@
1
+ import { Privilege } from './privilege';
2
+ import { PrivilegeQuery } from './privilege-query';
3
+ import { PrivilegeMutation } from './privilege-mutation';
4
+ export declare const entities: (typeof Privilege)[];
5
+ export declare const resolvers: (typeof PrivilegeQuery | typeof PrivilegeMutation)[];
@@ -0,0 +1,3 @@
1
+ import { GraphQLSchema } from 'graphql';
2
+ export declare const privilegeDirectiveTypeDefs: import("graphql").DocumentNode;
3
+ export declare const privilegeDirectiveResolver: (schema: GraphQLSchema) => GraphQLSchema;
@@ -4,8 +4,8 @@ exports.privilegeDirectiveResolver = exports.privilegeDirectiveTypeDefs = void 0
4
4
  const tslib_1 = require("tslib");
5
5
  const graphql_1 = require("graphql");
6
6
  const graphql_tag_1 = tslib_1.__importDefault(require("graphql-tag"));
7
- const typeorm_1 = require("typeorm");
8
7
  const utils_1 = require("@graphql-tools/utils");
8
+ const shell_1 = require("@things-factory/shell");
9
9
  const user_1 = require("../user/user");
10
10
  process['PRIVILEGES'] = {};
11
11
  const DIRECTIVE = 'privilege';
@@ -40,7 +40,7 @@ const privilegeDirectiveResolver = (schema) => (0, utils_1.mapSchema)(schema, {
40
40
  }
41
41
  if (!category || !privilege)
42
42
  throw new Error(`Unauthorized!`);
43
- const result = await (0, typeorm_1.getRepository)(user_1.User).query(`
43
+ const result = await (0, shell_1.getRepository)(user_1.User).query(`
44
44
  SELECT
45
45
  COUNT(1) AS has_privilege
46
46
  FROM
@@ -1 +1 @@
1
- {"version":3,"file":"privilege-directive.js","sourceRoot":"","sources":["../../../server/service/privilege/privilege-directive.ts"],"names":[],"mappings":";;;;AAAA,qCAA6D;AAC7D,sEAA6B;AAC7B,qCAAuC;AAEvC,gDAA0E;AAE1E,uCAAmC;AAEnC,OAAO,CAAC,YAAY,CAAC,GAAG,EAAE,CAAA;AAE1B,MAAM,SAAS,GAAG,WAAW,CAAA;AAEhB,QAAA,0BAA0B,GAAG,IAAA,qBAAG,EAAA;;;;;;;CAO5C,CAAA;AACM,MAAM,0BAA0B,GAAG,CAAC,MAAqB,EAAE,EAAE,CAClE,IAAA,iBAAS,EAAC,MAAM,EAAE;IAChB,CAAC,kBAAU,CAAC,YAAY,CAAC,EAAE,CAAC,WAAW,EAAE,SAAS,EAAE,QAAQ,EAAE,MAAM,EAAE,EAAE;;QACtE,MAAM,kBAAkB,GAAG,MAAA,IAAA,oBAAY,EAAC,MAAM,EAAE,WAAW,EAAE,SAAS,CAAC,0CAAG,CAAC,CAAC,CAAA;QAC5E,IAAI,kBAAkB,EAAE;YACtB,MAAM,EAAE,OAAO,GAAG,8BAAoB,EAAE,IAAI,EAAE,GAAG,WAAW,CAAA;YAE5D,IAAI,CAAC,IAAI,EAAE;gBACT,MAAM,IAAI,KAAK,CAAC,8EAA8E,SAAS,GAAG,CAAC,CAAA;aAC5G;YAED,MAAM,EAAE,kBAAkB,EAAE,gBAAgB,EAAE,QAAQ,EAAE,SAAS,EAAE,GAAG,kBAAkB,CAAA;YACxF,IAAI,QAAQ,IAAI,SAAS,EAAE;gBACzB,OAAO,CAAC,YAAY,CAAC,CAAC,GAAG,QAAQ,IAAI,SAAS,EAAE,CAAC,GAAG,CAAC,QAAQ,EAAE,SAAS,CAAC,CAAA;aAC1E;YAED,WAAW,CAAC,OAAO,GAAG,KAAK,WAAW,MAAM,EAAE,IAAI,EAAE,OAAO,EAAE,IAAI;gBAC/D,MAAM,EAAE,MAAM,EAAE,IAAI,EAAE,GAAG,OAAO,CAAC,KAAK,CAAA;gBAEtC,IAAI,kBAAkB,IAAI,CAAC,MAAM,OAAO,CAAC,kBAAkB,CAAC,MAAM,EAAE,IAAI,CAAC,CAAC,EAAE;oBAC1E,OAAO,MAAM,OAAO,CAAC,IAAI,CAAC,IAAI,EAAE,MAAM,EAAE,IAAI,EAAE,OAAO,EAAE,IAAI,CAAC,CAAA;iBAC7D;gBAED,IAAI,gBAAgB,IAAI,CAAC,MAAM,OAAO,CAAC,gBAAgB,CAAC,MAAM,EAAE,IAAI,CAAC,CAAC,EAAE;oBACtE,OAAO,MAAM,OAAO,CAAC,IAAI,CAAC,IAAI,EAAE,MAAM,EAAE,IAAI,EAAE,OAAO,EAAE,IAAI,CAAC,CAAA;iBAC7D;gBAED,IAAI,CAAC,QAAQ,IAAI,CAAC,SAAS;oBAAE,MAAM,IAAI,KAAK,CAAC,eAAe,CAAC,CAAA;gBAE7D,MAAM,MAAM,GAAG,MAAM,IAAA,uBAAa,EAAC,WAAI,CAAC,CAAC,KAAK,CAC5C;;;;;;kCAMsB,QAAQ;;8BAEZ,SAAS;;;;;;;;;;;;;;;;;uCAiBA,IAAI,aAAJ,IAAI,uBAAJ,IAAI,CAAE,EAAE;;uCAER,MAAM,aAAN,MAAM,uBAAN,MAAM,CAAE,EAAE;;iBAEhC,CACN,CAAA;gBAED,IAAI,MAAM,CAAC,CAAC,CAAC,CAAC,aAAa,GAAG,CAAC,EAAE;oBAC/B,OAAO,MAAM,OAAO,CAAC,IAAI,CAAC,IAAI,EAAE,MAAM,EAAE,IAAI,EAAE,OAAO,EAAE,IAAI,CAAC,CAAA;iBAC7D;qBAAM;oBACL,MAAM,IAAI,KAAK,CAAC,eAAe,CAAC,CAAA;iBACjC;YACH,CAAC,CAAA;YAED,OAAO,WAAW,CAAA;SACnB;IACH,CAAC;CACF,CAAC,CAAA;AAxES,QAAA,0BAA0B,8BAwEnC","sourcesContent":["import { defaultFieldResolver, GraphQLSchema } from 'graphql'\nimport gql from 'graphql-tag'\nimport { getRepository } from 'typeorm'\n\nimport { getDirective, MapperKind, mapSchema } from '@graphql-tools/utils'\n\nimport { User } from '../user/user'\n\nprocess['PRIVILEGES'] = {}\n\nconst DIRECTIVE = 'privilege'\n\nexport const privilegeDirectiveTypeDefs = gql`\n directive @privilege(\n category: String\n privilege: String\n domainOwnerGranted: Boolean\n superUserGranted: Boolean\n ) on FIELD_DEFINITION\n`\nexport const privilegeDirectiveResolver = (schema: GraphQLSchema) =>\n mapSchema(schema, {\n [MapperKind.OBJECT_FIELD]: (fieldConfig, fieldName, typeName, schema) => {\n const privilegeDirective = getDirective(schema, fieldConfig, DIRECTIVE)?.[0]\n if (privilegeDirective) {\n const { resolve = defaultFieldResolver, args } = fieldConfig\n\n if (!args) {\n throw new Error(`Unexpected Error. args should be defined in @privilige directive for field ${fieldName}.`)\n }\n\n const { domainOwnerGranted, superUserGranted, category, privilege } = privilegeDirective\n if (category && privilege) {\n process['PRIVILEGES'][`${category} ${privilege}`] = [category, privilege]\n }\n\n fieldConfig.resolve = async function (source, args, context, info) {\n const { domain, user } = context.state\n\n if (domainOwnerGranted && (await process.domainOwnerGranted(domain, user))) {\n return await resolve.call(this, source, args, context, info)\n }\n\n if (superUserGranted && (await process.superUserGranted(domain, user))) {\n return await resolve.call(this, source, args, context, info)\n }\n\n if (!category || !privilege) throw new Error(`Unauthorized!`)\n\n const result = await getRepository(User).query(\n `\n SELECT \n COUNT(1) AS has_privilege\n FROM\n privileges\n WHERE\n category = '${category}'\n AND\n name = '${privilege}'\n AND\n id\n IN (\n SELECT\n RP.privileges_id\n FROM\n users_roles UR\n INNER JOIN\n roles_privileges RP\n ON\n UR.roles_id = RP.roles_id\n LEFT JOIN\n roles R\n ON\n R.id = UR.roles_id\n WHERE\n UR.users_id = '${user?.id}'\n AND\n R.domain_id = '${domain?.id}'\n )\n `\n )\n\n if (result[0].has_privilege > 0) {\n return await resolve.call(this, source, args, context, info)\n } else {\n throw new Error(`Unauthorized!`)\n }\n }\n\n return fieldConfig\n }\n }\n })\n"]}
1
+ {"version":3,"file":"privilege-directive.js","sourceRoot":"","sources":["../../../server/service/privilege/privilege-directive.ts"],"names":[],"mappings":";;;;AAAA,qCAA6D;AAC7D,sEAA6B;AAE7B,gDAA0E;AAC1E,iDAAqD;AAErD,uCAAmC;AAEnC,OAAO,CAAC,YAAY,CAAC,GAAG,EAAE,CAAA;AAE1B,MAAM,SAAS,GAAG,WAAW,CAAA;AAEhB,QAAA,0BAA0B,GAAG,IAAA,qBAAG,EAAA;;;;;;;CAO5C,CAAA;AACM,MAAM,0BAA0B,GAAG,CAAC,MAAqB,EAAE,EAAE,CAClE,IAAA,iBAAS,EAAC,MAAM,EAAE;IAChB,CAAC,kBAAU,CAAC,YAAY,CAAC,EAAE,CAAC,WAAW,EAAE,SAAS,EAAE,QAAQ,EAAE,MAAM,EAAE,EAAE;;QACtE,MAAM,kBAAkB,GAAG,MAAA,IAAA,oBAAY,EAAC,MAAM,EAAE,WAAW,EAAE,SAAS,CAAC,0CAAG,CAAC,CAAC,CAAA;QAC5E,IAAI,kBAAkB,EAAE;YACtB,MAAM,EAAE,OAAO,GAAG,8BAAoB,EAAE,IAAI,EAAE,GAAG,WAAW,CAAA;YAE5D,IAAI,CAAC,IAAI,EAAE;gBACT,MAAM,IAAI,KAAK,CAAC,8EAA8E,SAAS,GAAG,CAAC,CAAA;aAC5G;YAED,MAAM,EAAE,kBAAkB,EAAE,gBAAgB,EAAE,QAAQ,EAAE,SAAS,EAAE,GAAG,kBAAkB,CAAA;YACxF,IAAI,QAAQ,IAAI,SAAS,EAAE;gBACzB,OAAO,CAAC,YAAY,CAAC,CAAC,GAAG,QAAQ,IAAI,SAAS,EAAE,CAAC,GAAG,CAAC,QAAQ,EAAE,SAAS,CAAC,CAAA;aAC1E;YAED,WAAW,CAAC,OAAO,GAAG,KAAK,WAAW,MAAM,EAAE,IAAI,EAAE,OAAO,EAAE,IAAI;gBAC/D,MAAM,EAAE,MAAM,EAAE,IAAI,EAAE,GAAG,OAAO,CAAC,KAAK,CAAA;gBAEtC,IAAI,kBAAkB,IAAI,CAAC,MAAM,OAAO,CAAC,kBAAkB,CAAC,MAAM,EAAE,IAAI,CAAC,CAAC,EAAE;oBAC1E,OAAO,MAAM,OAAO,CAAC,IAAI,CAAC,IAAI,EAAE,MAAM,EAAE,IAAI,EAAE,OAAO,EAAE,IAAI,CAAC,CAAA;iBAC7D;gBAED,IAAI,gBAAgB,IAAI,CAAC,MAAM,OAAO,CAAC,gBAAgB,CAAC,MAAM,EAAE,IAAI,CAAC,CAAC,EAAE;oBACtE,OAAO,MAAM,OAAO,CAAC,IAAI,CAAC,IAAI,EAAE,MAAM,EAAE,IAAI,EAAE,OAAO,EAAE,IAAI,CAAC,CAAA;iBAC7D;gBAED,IAAI,CAAC,QAAQ,IAAI,CAAC,SAAS;oBAAE,MAAM,IAAI,KAAK,CAAC,eAAe,CAAC,CAAA;gBAE7D,MAAM,MAAM,GAAG,MAAM,IAAA,qBAAa,EAAC,WAAI,CAAC,CAAC,KAAK,CAC5C;;;;;;kCAMsB,QAAQ;;8BAEZ,SAAS;;;;;;;;;;;;;;;;;uCAiBA,IAAI,aAAJ,IAAI,uBAAJ,IAAI,CAAE,EAAE;;uCAER,MAAM,aAAN,MAAM,uBAAN,MAAM,CAAE,EAAE;;iBAEhC,CACN,CAAA;gBAED,IAAI,MAAM,CAAC,CAAC,CAAC,CAAC,aAAa,GAAG,CAAC,EAAE;oBAC/B,OAAO,MAAM,OAAO,CAAC,IAAI,CAAC,IAAI,EAAE,MAAM,EAAE,IAAI,EAAE,OAAO,EAAE,IAAI,CAAC,CAAA;iBAC7D;qBAAM;oBACL,MAAM,IAAI,KAAK,CAAC,eAAe,CAAC,CAAA;iBACjC;YACH,CAAC,CAAA;YAED,OAAO,WAAW,CAAA;SACnB;IACH,CAAC;CACF,CAAC,CAAA;AAxES,QAAA,0BAA0B,8BAwEnC","sourcesContent":["import { defaultFieldResolver, GraphQLSchema } from 'graphql'\nimport gql from 'graphql-tag'\n\nimport { getDirective, MapperKind, mapSchema } from '@graphql-tools/utils'\nimport { getRepository } from '@things-factory/shell'\n\nimport { User } from '../user/user'\n\nprocess['PRIVILEGES'] = {}\n\nconst DIRECTIVE = 'privilege'\n\nexport const privilegeDirectiveTypeDefs = gql`\n directive @privilege(\n category: String\n privilege: String\n domainOwnerGranted: Boolean\n superUserGranted: Boolean\n ) on FIELD_DEFINITION\n`\nexport const privilegeDirectiveResolver = (schema: GraphQLSchema) =>\n mapSchema(schema, {\n [MapperKind.OBJECT_FIELD]: (fieldConfig, fieldName, typeName, schema) => {\n const privilegeDirective = getDirective(schema, fieldConfig, DIRECTIVE)?.[0]\n if (privilegeDirective) {\n const { resolve = defaultFieldResolver, args } = fieldConfig\n\n if (!args) {\n throw new Error(`Unexpected Error. args should be defined in @privilige directive for field ${fieldName}.`)\n }\n\n const { domainOwnerGranted, superUserGranted, category, privilege } = privilegeDirective\n if (category && privilege) {\n process['PRIVILEGES'][`${category} ${privilege}`] = [category, privilege]\n }\n\n fieldConfig.resolve = async function (source, args, context, info) {\n const { domain, user } = context.state\n\n if (domainOwnerGranted && (await process.domainOwnerGranted(domain, user))) {\n return await resolve.call(this, source, args, context, info)\n }\n\n if (superUserGranted && (await process.superUserGranted(domain, user))) {\n return await resolve.call(this, source, args, context, info)\n }\n\n if (!category || !privilege) throw new Error(`Unauthorized!`)\n\n const result = await getRepository(User).query(\n `\n SELECT \n COUNT(1) AS has_privilege\n FROM\n privileges\n WHERE\n category = '${category}'\n AND\n name = '${privilege}'\n AND\n id\n IN (\n SELECT\n RP.privileges_id\n FROM\n users_roles UR\n INNER JOIN\n roles_privileges RP\n ON\n UR.roles_id = RP.roles_id\n LEFT JOIN\n roles R\n ON\n R.id = UR.roles_id\n WHERE\n UR.users_id = '${user?.id}'\n AND\n R.domain_id = '${domain?.id}'\n )\n `\n )\n\n if (result[0].has_privilege > 0) {\n return await resolve.call(this, source, args, context, info)\n } else {\n throw new Error(`Unauthorized!`)\n }\n }\n\n return fieldConfig\n }\n }\n })\n"]}
@@ -0,0 +1,7 @@
1
+ import { Privilege } from './privilege';
2
+ import { NewPrivilege, PrivilegePatch } from './privilege-types';
3
+ export declare class PrivilegeMutation {
4
+ createPrivilege(privilege: NewPrivilege, context: ResolverContext): Promise<Privilege>;
5
+ updatePrivilege(name: string, category: string, patch: PrivilegePatch, context: ResolverContext): Promise<Privilege>;
6
+ deletePrivilege(name: string, category: string, context: ResolverContext): Promise<boolean>;
7
+ }
@@ -4,18 +4,19 @@ exports.PrivilegeMutation = void 0;
4
4
  const tslib_1 = require("tslib");
5
5
  const type_graphql_1 = require("type-graphql");
6
6
  const typeorm_1 = require("typeorm");
7
+ const shell_1 = require("@things-factory/shell");
7
8
  const role_1 = require("../role/role");
8
9
  const privilege_1 = require("./privilege");
9
10
  const privilege_types_1 = require("./privilege-types");
10
11
  let PrivilegeMutation = class PrivilegeMutation {
11
12
  async createPrivilege(privilege, context) {
12
13
  if (privilege.roles && privilege.roles.length) {
13
- privilege.roles = await (0, typeorm_1.getRepository)(role_1.Role).findByIds(privilege.roles);
14
+ privilege.roles = await (0, shell_1.getRepository)(role_1.Role).findBy({ id: (0, typeorm_1.In)(privilege.roles) });
14
15
  }
15
- return await (0, typeorm_1.getRepository)(privilege_1.Privilege).save(Object.assign({ creator: context.state.user, updater: context.state.user }, privilege));
16
+ return await (0, shell_1.getRepository)(privilege_1.Privilege).save(Object.assign({ creator: context.state.user, updater: context.state.user }, privilege));
16
17
  }
17
18
  async updatePrivilege(name, category, patch, context) {
18
- const repository = (0, typeorm_1.getRepository)(privilege_1.Privilege);
19
+ const repository = (0, shell_1.getRepository)(privilege_1.Privilege);
19
20
  const privilege = await repository.findOne({
20
21
  where: { name, category },
21
22
  relations: ['roles', 'creator', 'updater']
@@ -28,10 +29,10 @@ let PrivilegeMutation = class PrivilegeMutation {
28
29
  }
29
30
  });
30
31
  }
31
- return await repository.save(Object.assign(Object.assign(Object.assign({}, privilege), patch), { roles: await (0, typeorm_1.getRepository)(role_1.Role).findByIds(roleIds), updater: context.state.user }));
32
+ return await repository.save(Object.assign(Object.assign(Object.assign({}, privilege), patch), { roles: await (0, shell_1.getRepository)(role_1.Role).findByIds(roleIds), updater: context.state.user }));
32
33
  }
33
34
  async deletePrivilege(name, category, context) {
34
- await (0, typeorm_1.getRepository)(privilege_1.Privilege).delete({ name, category });
35
+ await (0, shell_1.getRepository)(privilege_1.Privilege).delete({ name, category });
35
36
  return true;
36
37
  }
37
38
  };
@@ -1 +1 @@
1
- {"version":3,"file":"privilege-mutation.js","sourceRoot":"","sources":["../../../server/service/privilege/privilege-mutation.ts"],"names":[],"mappings":"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","sourcesContent":["import { Arg, Ctx, Mutation, Resolver } from 'type-graphql'\nimport { getRepository } from 'typeorm'\n\nimport { Role } from '../role/role'\nimport { Privilege } from './privilege'\nimport { NewPrivilege, PrivilegePatch } from './privilege-types'\n\n@Resolver(Privilege)\nexport class PrivilegeMutation {\n @Mutation(returns => Privilege, { description: 'To create new privilege' })\n async createPrivilege(@Arg('privilege') privilege: NewPrivilege, @Ctx() context: any): Promise<Privilege> {\n if (privilege.roles && privilege.roles.length) {\n privilege.roles = await getRepository(Role).findByIds(privilege.roles)\n }\n\n return await getRepository(Privilege).save({\n creator: context.state.user,\n updater: context.state.user,\n ...privilege\n })\n }\n\n @Mutation(returns => Privilege, { description: 'To modify privilege information' })\n async updatePrivilege(\n @Arg('name') name: string,\n @Arg('category') category: string,\n @Arg('patch') patch: PrivilegePatch,\n @Ctx() context: any\n ): Promise<Privilege> {\n const repository = getRepository(Privilege)\n const privilege = await repository.findOne({\n where: { name, category },\n relations: ['roles', 'creator', 'updater']\n })\n\n const roleIds = privilege.roles.map(role => role.id)\n if (patch.roles && patch.roles.length) {\n patch.roles.forEach(({ id }) => {\n if (!roleIds.includes(id)) {\n roleIds.push(id)\n }\n })\n }\n\n return await repository.save({\n ...privilege,\n ...patch,\n roles: await getRepository(Role).findByIds(roleIds),\n updater: context.state.user\n })\n }\n\n @Mutation(returns => Boolean, { description: 'To delete privilege' })\n async deletePrivilege(\n @Arg('name') name: string,\n @Arg('category') category: string,\n @Ctx() context: any\n ): Promise<boolean> {\n await getRepository(Privilege).delete({ name, category })\n return true\n }\n}\n"]}
1
+ {"version":3,"file":"privilege-mutation.js","sourceRoot":"","sources":["../../../server/service/privilege/privilege-mutation.ts"],"names":[],"mappings":"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","sourcesContent":["import { Arg, Ctx, Mutation, Resolver } from 'type-graphql'\nimport { In } from 'typeorm'\n\nimport { getRepository } from '@things-factory/shell'\n\nimport { Role } from '../role/role'\nimport { Privilege } from './privilege'\nimport { NewPrivilege, PrivilegePatch } from './privilege-types'\n\n@Resolver(Privilege)\nexport class PrivilegeMutation {\n @Mutation(returns => Privilege, { description: 'To create new privilege' })\n async createPrivilege(\n @Arg('privilege') privilege: NewPrivilege,\n @Ctx() context: ResolverContext\n ): Promise<Privilege> {\n if (privilege.roles && privilege.roles.length) {\n privilege.roles = await getRepository(Role).findBy({ id: In(privilege.roles) })\n }\n\n return await getRepository(Privilege).save({\n creator: context.state.user,\n updater: context.state.user,\n ...privilege\n })\n }\n\n @Mutation(returns => Privilege, { description: 'To modify privilege information' })\n async updatePrivilege(\n @Arg('name') name: string,\n @Arg('category') category: string,\n @Arg('patch') patch: PrivilegePatch,\n @Ctx() context: ResolverContext\n ): Promise<Privilege> {\n const repository = getRepository(Privilege)\n const privilege = await repository.findOne({\n where: { name, category },\n relations: ['roles', 'creator', 'updater']\n })\n\n const roleIds = privilege.roles.map(role => role.id)\n if (patch.roles && patch.roles.length) {\n patch.roles.forEach(({ id }) => {\n if (!roleIds.includes(id)) {\n roleIds.push(id)\n }\n })\n }\n\n return await repository.save({\n ...privilege,\n ...patch,\n roles: await getRepository(Role).findByIds(roleIds),\n updater: context.state.user\n })\n }\n\n @Mutation(returns => Boolean, { description: 'To delete privilege' })\n async deletePrivilege(\n @Arg('name') name: string,\n @Arg('category') category: string,\n @Ctx() context: ResolverContext\n ): Promise<boolean> {\n await getRepository(Privilege).delete({ name, category })\n return true\n }\n}\n"]}
@@ -0,0 +1,13 @@
1
+ import { ListParam } from '@things-factory/shell';
2
+ import { Role } from '../role/role';
3
+ import { User } from '../user/user';
4
+ import { Privilege } from './privilege';
5
+ import { PrivilegeList } from './privilege-types';
6
+ export declare class PrivilegeQuery {
7
+ privilege(name: string, category: string): Promise<Privilege>;
8
+ privileges(params: ListParam, context: ResolverContext): Promise<PrivilegeList>;
9
+ description(privilege: Privilege, context: ResolverContext): Promise<string>;
10
+ roles(privilege: Privilege): Promise<Role[]>;
11
+ updater(privilege: Privilege): Promise<User>;
12
+ creator(privilege: Privilege): Promise<User>;
13
+ }
@@ -1,10 +1,8 @@
1
1
  "use strict";
2
- var _a;
3
2
  Object.defineProperty(exports, "__esModule", { value: true });
4
3
  exports.PrivilegeQuery = void 0;
5
4
  const tslib_1 = require("tslib");
6
5
  const type_graphql_1 = require("type-graphql");
7
- const typeorm_1 = require("typeorm");
8
6
  const shell_1 = require("@things-factory/shell");
9
7
  const role_1 = require("../role/role");
10
8
  const user_1 = require("../user/user");
@@ -12,12 +10,12 @@ const privilege_1 = require("./privilege");
12
10
  const privilege_types_1 = require("./privilege-types");
13
11
  let PrivilegeQuery = class PrivilegeQuery {
14
12
  async privilege(name, category) {
15
- return await (0, typeorm_1.getRepository)(privilege_1.Privilege).findOne({
13
+ return await (0, shell_1.getRepository)(privilege_1.Privilege).findOne({
16
14
  where: { name, category }
17
15
  });
18
16
  }
19
17
  async privileges(params, context) {
20
- const queryBuilder = (0, typeorm_1.getRepository)(privilege_1.Privilege).createQueryBuilder();
18
+ const queryBuilder = (0, shell_1.getRepository)(privilege_1.Privilege).createQueryBuilder();
21
19
  (0, shell_1.buildQuery)(queryBuilder, params, context, { domainRef: false });
22
20
  const [items, total] = await queryBuilder.getManyAndCount();
23
21
  return { items, total };
@@ -35,15 +33,16 @@ let PrivilegeQuery = class PrivilegeQuery {
35
33
  });
36
34
  }
37
35
  async roles(privilege) {
38
- return (await (0, typeorm_1.getRepository)(privilege_1.Privilege).findOne(privilege.id, {
36
+ return (await (0, shell_1.getRepository)(privilege_1.Privilege).findOne({
37
+ where: { id: privilege.id },
39
38
  relations: ['roles']
40
39
  })).roles;
41
40
  }
42
41
  async updater(privilege) {
43
- return await (0, typeorm_1.getRepository)(user_1.User).findOne(privilege.updaterId);
42
+ return await (0, shell_1.getRepository)(user_1.User).findOneBy({ id: privilege.updaterId });
44
43
  }
45
44
  async creator(privilege) {
46
- return await (0, typeorm_1.getRepository)(user_1.User).findOne(privilege.creatorId);
45
+ return await (0, shell_1.getRepository)(user_1.User).findOneBy({ id: privilege.creatorId });
47
46
  }
48
47
  };
49
48
  tslib_1.__decorate([
@@ -59,7 +58,7 @@ tslib_1.__decorate([
59
58
  tslib_1.__param(0, (0, type_graphql_1.Args)()),
60
59
  tslib_1.__param(1, (0, type_graphql_1.Ctx)()),
61
60
  tslib_1.__metadata("design:type", Function),
62
- tslib_1.__metadata("design:paramtypes", [typeof (_a = typeof shell_1.ListParam !== "undefined" && shell_1.ListParam) === "function" ? _a : Object, Object]),
61
+ tslib_1.__metadata("design:paramtypes", [shell_1.ListParam, Object]),
63
62
  tslib_1.__metadata("design:returntype", Promise)
64
63
  ], PrivilegeQuery.prototype, "privileges", null);
65
64
  tslib_1.__decorate([