@things-factory/auth-base 4.3.671 → 4.3.672

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 (229) hide show
  1. package/dist-server/constants/error-code.js +21 -0
  2. package/dist-server/constants/error-code.js.map +1 -0
  3. package/dist-server/constants/error-message.js +1 -0
  4. package/dist-server/constants/error-message.js.map +1 -0
  5. package/dist-server/constants/max-age.js +5 -0
  6. package/dist-server/constants/max-age.js.map +1 -0
  7. package/dist-server/controllers/auth.js +21 -0
  8. package/dist-server/controllers/auth.js.map +1 -0
  9. package/dist-server/controllers/change-pwd.js +80 -0
  10. package/dist-server/controllers/change-pwd.js.map +1 -0
  11. package/dist-server/controllers/checkin.js +21 -0
  12. package/dist-server/controllers/checkin.js.map +1 -0
  13. package/dist-server/controllers/delete-user.js +61 -0
  14. package/dist-server/controllers/delete-user.js.map +1 -0
  15. package/dist-server/controllers/invitation.js +119 -0
  16. package/dist-server/controllers/invitation.js.map +1 -0
  17. package/dist-server/controllers/profile.js +26 -0
  18. package/dist-server/controllers/profile.js.map +1 -0
  19. package/dist-server/controllers/reset-password.js +110 -0
  20. package/dist-server/controllers/reset-password.js.map +1 -0
  21. package/dist-server/controllers/signin.js +76 -0
  22. package/dist-server/controllers/signin.js.map +1 -0
  23. package/dist-server/controllers/signup.js +105 -0
  24. package/dist-server/controllers/signup.js.map +1 -0
  25. package/dist-server/controllers/unlock-user.js +60 -0
  26. package/dist-server/controllers/unlock-user.js.map +1 -0
  27. package/dist-server/controllers/utils/make-invitation-token.js +12 -0
  28. package/dist-server/controllers/utils/make-invitation-token.js.map +1 -0
  29. package/dist-server/controllers/utils/make-verification-token.js +12 -0
  30. package/dist-server/controllers/utils/make-verification-token.js.map +1 -0
  31. package/dist-server/controllers/utils/password-rule.js +90 -0
  32. package/dist-server/controllers/utils/password-rule.js.map +1 -0
  33. package/dist-server/controllers/utils/save-invitation-token.js +13 -0
  34. package/dist-server/controllers/utils/save-invitation-token.js.map +1 -0
  35. package/dist-server/controllers/utils/save-verification-token.js +15 -0
  36. package/dist-server/controllers/utils/save-verification-token.js.map +1 -0
  37. package/dist-server/controllers/verification.js +78 -0
  38. package/dist-server/controllers/verification.js.map +1 -0
  39. package/dist-server/errors/auth-error.js +40 -0
  40. package/dist-server/errors/auth-error.js.map +1 -0
  41. package/dist-server/errors/index.js +19 -0
  42. package/dist-server/errors/index.js.map +1 -0
  43. package/dist-server/errors/user-domain-not-match-error.js +24 -0
  44. package/dist-server/errors/user-domain-not-match-error.js.map +1 -0
  45. package/dist-server/index.js +29 -0
  46. package/dist-server/index.js.map +1 -0
  47. package/dist-server/middlewares/authenticate-401-middleware.js +84 -0
  48. package/dist-server/middlewares/authenticate-401-middleware.js.map +1 -0
  49. package/dist-server/middlewares/domain-authenticate-middleware.js +58 -0
  50. package/dist-server/middlewares/domain-authenticate-middleware.js.map +1 -0
  51. package/dist-server/middlewares/graphql-authenticate-middleware.js +17 -0
  52. package/dist-server/middlewares/graphql-authenticate-middleware.js.map +1 -0
  53. package/dist-server/middlewares/index.js +57 -0
  54. package/dist-server/middlewares/index.js.map +1 -0
  55. package/dist-server/middlewares/jwt-authenticate-middleware.js +77 -0
  56. package/dist-server/middlewares/jwt-authenticate-middleware.js.map +1 -0
  57. package/dist-server/middlewares/signin-middleware.js +47 -0
  58. package/dist-server/middlewares/signin-middleware.js.map +1 -0
  59. package/dist-server/migrations/1548206416130-SeedUser.js +46 -0
  60. package/dist-server/migrations/1548206416130-SeedUser.js.map +1 -0
  61. package/dist-server/migrations/1566805283882-SeedPrivilege.js +26 -0
  62. package/dist-server/migrations/1566805283882-SeedPrivilege.js.map +1 -0
  63. package/dist-server/migrations/index.js +12 -0
  64. package/dist-server/migrations/index.js.map +1 -0
  65. package/dist-server/router/auth-checkin-router.js +96 -0
  66. package/dist-server/router/auth-checkin-router.js.map +1 -0
  67. package/dist-server/router/auth-private-process-router.js +91 -0
  68. package/dist-server/router/auth-private-process-router.js.map +1 -0
  69. package/dist-server/router/auth-public-process-router.js +243 -0
  70. package/dist-server/router/auth-public-process-router.js.map +1 -0
  71. package/dist-server/router/auth-signin-router.js +38 -0
  72. package/dist-server/router/auth-signin-router.js.map +1 -0
  73. package/dist-server/router/auth-signup-router.js +76 -0
  74. package/dist-server/router/auth-signup-router.js.map +1 -0
  75. package/dist-server/router/index.js +25 -0
  76. package/dist-server/router/index.js.map +1 -0
  77. package/dist-server/router/oauth2/index.js +19 -0
  78. package/dist-server/router/oauth2/index.js.map +1 -0
  79. package/dist-server/router/oauth2/oauth2-authorize-router.js +72 -0
  80. package/dist-server/router/oauth2/oauth2-authorize-router.js.map +1 -0
  81. package/dist-server/router/oauth2/oauth2-router.js +137 -0
  82. package/dist-server/router/oauth2/oauth2-router.js.map +1 -0
  83. package/dist-server/router/oauth2/oauth2-server.js +201 -0
  84. package/dist-server/router/oauth2/oauth2-server.js.map +1 -0
  85. package/dist-server/router/oauth2/passport-oauth2-client-password.js +84 -0
  86. package/dist-server/router/oauth2/passport-oauth2-client-password.js.map +1 -0
  87. package/dist-server/router/oauth2/passport-refresh-token.js +84 -0
  88. package/dist-server/router/oauth2/passport-refresh-token.js.map +1 -0
  89. package/dist-server/router/path-base-domain-router.js +15 -0
  90. package/dist-server/router/path-base-domain-router.js.map +1 -0
  91. package/dist-server/router/site-root-router.js +48 -0
  92. package/dist-server/router/site-root-router.js.map +1 -0
  93. package/dist-server/routes.js +58 -0
  94. package/dist-server/routes.js.map +1 -0
  95. package/dist-server/service/app-binding/app-binding-mutation.js +45 -0
  96. package/dist-server/service/app-binding/app-binding-mutation.js.map +1 -0
  97. package/dist-server/service/app-binding/app-binding-query.js +135 -0
  98. package/dist-server/service/app-binding/app-binding-query.js.map +1 -0
  99. package/dist-server/service/app-binding/app-binding-types.js +29 -0
  100. package/dist-server/service/app-binding/app-binding-types.js.map +1 -0
  101. package/dist-server/service/app-binding/app-binding.js +34 -0
  102. package/dist-server/service/app-binding/app-binding.js.map +1 -0
  103. package/dist-server/service/app-binding/index.js +7 -0
  104. package/dist-server/service/app-binding/index.js.map +1 -0
  105. package/dist-server/service/appliance/appliance-mutation.js +117 -0
  106. package/dist-server/service/appliance/appliance-mutation.js.map +1 -0
  107. package/dist-server/service/appliance/appliance-query.js +85 -0
  108. package/dist-server/service/appliance/appliance-query.js.map +1 -0
  109. package/dist-server/service/appliance/appliance-types.js +93 -0
  110. package/dist-server/service/appliance/appliance-types.js.map +1 -0
  111. package/dist-server/service/appliance/appliance.js +155 -0
  112. package/dist-server/service/appliance/appliance.js.map +1 -0
  113. package/dist-server/service/appliance/index.js +9 -0
  114. package/dist-server/service/appliance/index.js.map +1 -0
  115. package/dist-server/service/application/application-mutation.js +121 -0
  116. package/dist-server/service/application/application-mutation.js.map +1 -0
  117. package/dist-server/service/application/application-query.js +128 -0
  118. package/dist-server/service/application/application-query.js.map +1 -0
  119. package/dist-server/service/application/application-types.js +119 -0
  120. package/dist-server/service/application/application-types.js.map +1 -0
  121. package/dist-server/service/application/application.js +236 -0
  122. package/dist-server/service/application/application.js.map +1 -0
  123. package/dist-server/service/application/index.js +9 -0
  124. package/dist-server/service/application/index.js.map +1 -0
  125. package/dist-server/service/domain-generator/domain-generator-mutation.js +117 -0
  126. package/dist-server/service/domain-generator/domain-generator-mutation.js.map +1 -0
  127. package/dist-server/service/domain-generator/domain-generator-types.js +79 -0
  128. package/dist-server/service/domain-generator/domain-generator-types.js.map +1 -0
  129. package/dist-server/service/domain-generator/index.js +6 -0
  130. package/dist-server/service/domain-generator/index.js.map +1 -0
  131. package/dist-server/service/granted-role/granted-role-mutation.js +144 -0
  132. package/dist-server/service/granted-role/granted-role-mutation.js.map +1 -0
  133. package/dist-server/service/granted-role/granted-role-query.js +93 -0
  134. package/dist-server/service/granted-role/granted-role-query.js.map +1 -0
  135. package/dist-server/service/granted-role/granted-role.js +49 -0
  136. package/dist-server/service/granted-role/granted-role.js.map +1 -0
  137. package/dist-server/service/granted-role/index.js +9 -0
  138. package/dist-server/service/granted-role/index.js.map +1 -0
  139. package/dist-server/service/index.js +94 -0
  140. package/dist-server/service/index.js.map +1 -0
  141. package/dist-server/service/invitation/index.js +9 -0
  142. package/dist-server/service/invitation/index.js.map +1 -0
  143. package/dist-server/service/invitation/invitation-mutation.js +76 -0
  144. package/dist-server/service/invitation/invitation-mutation.js.map +1 -0
  145. package/dist-server/service/invitation/invitation-query.js +57 -0
  146. package/dist-server/service/invitation/invitation-query.js.map +1 -0
  147. package/dist-server/service/invitation/invitation-types.js +29 -0
  148. package/dist-server/service/invitation/invitation-types.js.map +1 -0
  149. package/dist-server/service/invitation/invitation.js +84 -0
  150. package/dist-server/service/invitation/invitation.js.map +1 -0
  151. package/dist-server/service/login-history/index.js +8 -0
  152. package/dist-server/service/login-history/index.js.map +1 -0
  153. package/dist-server/service/login-history/login-history-query.js +67 -0
  154. package/dist-server/service/login-history/login-history-query.js.map +1 -0
  155. package/dist-server/service/login-history/login-history.js +68 -0
  156. package/dist-server/service/login-history/login-history.js.map +1 -0
  157. package/dist-server/service/partner/index.js +9 -0
  158. package/dist-server/service/partner/index.js.map +1 -0
  159. package/dist-server/service/partner/partner-mutation.js +134 -0
  160. package/dist-server/service/partner/partner-mutation.js.map +1 -0
  161. package/dist-server/service/partner/partner-query.js +193 -0
  162. package/dist-server/service/partner/partner-query.js.map +1 -0
  163. package/dist-server/service/partner/partner-types.js +57 -0
  164. package/dist-server/service/partner/partner-types.js.map +1 -0
  165. package/dist-server/service/partner/partner.js +86 -0
  166. package/dist-server/service/partner/partner.js.map +1 -0
  167. package/dist-server/service/password-history/index.js +6 -0
  168. package/dist-server/service/password-history/index.js.map +1 -0
  169. package/dist-server/service/password-history/password-history.js +34 -0
  170. package/dist-server/service/password-history/password-history.js.map +1 -0
  171. package/dist-server/service/privilege/index.js +9 -0
  172. package/dist-server/service/privilege/index.js.map +1 -0
  173. package/dist-server/service/privilege/privilege-directive.js +85 -0
  174. package/dist-server/service/privilege/privilege-directive.js.map +1 -0
  175. package/dist-server/service/privilege/privilege-mutation.js +80 -0
  176. package/dist-server/service/privilege/privilege-mutation.js.map +1 -0
  177. package/dist-server/service/privilege/privilege-query.js +109 -0
  178. package/dist-server/service/privilege/privilege-query.js.map +1 -0
  179. package/dist-server/service/privilege/privilege-types.js +100 -0
  180. package/dist-server/service/privilege/privilege-types.js.map +1 -0
  181. package/dist-server/service/privilege/privilege.js +92 -0
  182. package/dist-server/service/privilege/privilege.js.map +1 -0
  183. package/dist-server/service/role/index.js +9 -0
  184. package/dist-server/service/role/index.js.map +1 -0
  185. package/dist-server/service/role/role-mutation.js +121 -0
  186. package/dist-server/service/role/role-mutation.js.map +1 -0
  187. package/dist-server/service/role/role-query.js +207 -0
  188. package/dist-server/service/role/role-query.js.map +1 -0
  189. package/dist-server/service/role/role-types.js +130 -0
  190. package/dist-server/service/role/role-types.js.map +1 -0
  191. package/dist-server/service/role/role.js +94 -0
  192. package/dist-server/service/role/role.js.map +1 -0
  193. package/dist-server/service/user/index.js +9 -0
  194. package/dist-server/service/user/index.js.map +1 -0
  195. package/dist-server/service/user/user-mutation.js +307 -0
  196. package/dist-server/service/user/user-mutation.js.map +1 -0
  197. package/dist-server/service/user/user-query.js +194 -0
  198. package/dist-server/service/user/user-query.js.map +1 -0
  199. package/dist-server/service/user/user-types.js +106 -0
  200. package/dist-server/service/user/user-types.js.map +1 -0
  201. package/dist-server/service/user/user.js +274 -0
  202. package/dist-server/service/user/user.js.map +1 -0
  203. package/dist-server/service/verification-token/index.js +6 -0
  204. package/dist-server/service/verification-token/index.js.map +1 -0
  205. package/dist-server/service/verification-token/verification-token.js +75 -0
  206. package/dist-server/service/verification-token/verification-token.js.map +1 -0
  207. package/dist-server/templates/account-unlock-email.js +69 -0
  208. package/dist-server/templates/account-unlock-email.js.map +1 -0
  209. package/dist-server/templates/invitation-email.js +70 -0
  210. package/dist-server/templates/invitation-email.js.map +1 -0
  211. package/dist-server/templates/reset-password-email.js +66 -0
  212. package/dist-server/templates/reset-password-email.js.map +1 -0
  213. package/dist-server/templates/verification-email.js +70 -0
  214. package/dist-server/templates/verification-email.js.map +1 -0
  215. package/dist-server/utils/accepts.js +14 -0
  216. package/dist-server/utils/accepts.js.map +1 -0
  217. package/dist-server/utils/access-token-cookie.js +45 -0
  218. package/dist-server/utils/access-token-cookie.js.map +1 -0
  219. package/dist-server/utils/check-user-belongs-domain.js +22 -0
  220. package/dist-server/utils/check-user-belongs-domain.js.map +1 -0
  221. package/dist-server/utils/get-domain-from-hostname.js +10 -0
  222. package/dist-server/utils/get-domain-from-hostname.js.map +1 -0
  223. package/dist-server/utils/get-domain-users.js +31 -0
  224. package/dist-server/utils/get-domain-users.js.map +1 -0
  225. package/dist-server/utils/get-secret.js +15 -0
  226. package/dist-server/utils/get-secret.js.map +1 -0
  227. package/dist-server/utils/get-user-domains.js +40 -0
  228. package/dist-server/utils/get-user-domains.js.map +1 -0
  229. package/package.json +5 -5
@@ -0,0 +1,9 @@
1
+ "use strict";
2
+ Object.defineProperty(exports, "__esModule", { value: true });
3
+ exports.resolvers = exports.entities = void 0;
4
+ const privilege_1 = require("./privilege");
5
+ const privilege_query_1 = require("./privilege-query");
6
+ const privilege_mutation_1 = require("./privilege-mutation");
7
+ exports.entities = [privilege_1.Privilege];
8
+ exports.resolvers = [privilege_query_1.PrivilegeQuery, privilege_mutation_1.PrivilegeMutation];
9
+ //# sourceMappingURL=index.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"index.js","sourceRoot":"","sources":["../../../server/service/privilege/index.ts"],"names":[],"mappings":";;;AAAA,2CAAuC;AACvC,uDAAkD;AAClD,6DAAwD;AAE3C,QAAA,QAAQ,GAAG,CAAC,qBAAS,CAAC,CAAA;AACtB,QAAA,SAAS,GAAG,CAAC,gCAAc,EAAE,sCAAiB,CAAC,CAAA"}
@@ -0,0 +1,85 @@
1
+ "use strict";
2
+ Object.defineProperty(exports, "__esModule", { value: true });
3
+ exports.privilegeDirectiveResolver = exports.privilegeDirectiveTypeDefs = void 0;
4
+ const graphql_1 = require("graphql");
5
+ const graphql_tag_1 = require("graphql-tag");
6
+ const utils_1 = require("@graphql-tools/utils");
7
+ const typeorm_1 = require("typeorm");
8
+ const user_1 = require("../user/user");
9
+ const debug = require('debug')('things-factory:shell:directive-privilege');
10
+ process['PRIVILEGES'] = {};
11
+ const DIRECTIVE = 'privilege';
12
+ exports.privilegeDirectiveTypeDefs = (0, graphql_tag_1.gql) `
13
+ directive @privilege(
14
+ category: String
15
+ privilege: String
16
+ domainOwnerGranted: Boolean
17
+ superUserGranted: Boolean
18
+ ) on FIELD_DEFINITION
19
+ `;
20
+ const privilegeDirectiveResolver = (schema) => (0, utils_1.mapSchema)(schema, {
21
+ [utils_1.MapperKind.OBJECT_FIELD]: (fieldConfig, fieldName, typeName, schema) => {
22
+ var _a;
23
+ const privilegeDirective = (_a = (0, utils_1.getDirective)(schema, fieldConfig, DIRECTIVE)) === null || _a === void 0 ? void 0 : _a[0];
24
+ if (privilegeDirective) {
25
+ const { resolve = graphql_1.defaultFieldResolver, args } = fieldConfig;
26
+ if (!args) {
27
+ throw new Error(`Unexpected Error. args should be defined in @privilige directive for field ${fieldName}.`);
28
+ }
29
+ const { domainOwnerGranted, superUserGranted, category, privilege } = privilegeDirective;
30
+ if (category && privilege) {
31
+ process['PRIVILEGES'][`${category} ${privilege}`] = [category, privilege];
32
+ }
33
+ fieldConfig.resolve = async function (source, args, context, info) {
34
+ const { domain, user } = context.state;
35
+ if (domainOwnerGranted && (await process.domainOwnerGranted(domain, user))) {
36
+ return await resolve.call(this, source, args, context, info);
37
+ }
38
+ if (superUserGranted && (await process.superUserGranted(domain, user))) {
39
+ return await resolve.call(this, source, args, context, info);
40
+ }
41
+ if (!category || !privilege)
42
+ throw new Error(`Unauthorized!`);
43
+ const result = await (0, typeorm_1.getRepository)(user_1.User).query(`
44
+ SELECT
45
+ COUNT(1) AS has_privilege
46
+ FROM
47
+ privileges
48
+ WHERE
49
+ category = '${category}'
50
+ AND
51
+ name = '${privilege}'
52
+ AND
53
+ id
54
+ IN (
55
+ SELECT
56
+ RP.privileges_id
57
+ FROM
58
+ users_roles UR
59
+ INNER JOIN
60
+ roles_privileges RP
61
+ ON
62
+ UR.roles_id = RP.roles_id
63
+ LEFT JOIN
64
+ roles R
65
+ ON
66
+ R.id = UR.roles_id
67
+ WHERE
68
+ UR.users_id = '${user === null || user === void 0 ? void 0 : user.id}'
69
+ AND
70
+ R.domain_id = '${domain === null || domain === void 0 ? void 0 : domain.id}'
71
+ )
72
+ `);
73
+ if (result[0].has_privilege > 0) {
74
+ return await resolve.call(this, source, args, context, info);
75
+ }
76
+ else {
77
+ throw new Error(`Unauthorized!`);
78
+ }
79
+ };
80
+ return fieldConfig;
81
+ }
82
+ }
83
+ });
84
+ exports.privilegeDirectiveResolver = privilegeDirectiveResolver;
85
+ //# sourceMappingURL=privilege-directive.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"privilege-directive.js","sourceRoot":"","sources":["../../../server/service/privilege/privilege-directive.ts"],"names":[],"mappings":";;;AAAA,qCAA6D;AAC7D,6CAAiC;AACjC,gDAA0E;AAC1E,qCAAuC;AACvC,uCAAmC;AAEnC,MAAM,KAAK,GAAG,OAAO,CAAC,OAAO,CAAC,CAAC,0CAA0C,CAAC,CAAA;AAE1E,OAAO,CAAC,YAAY,CAAC,GAAG,EAAE,CAAA;AAE1B,MAAM,SAAS,GAAG,WAAW,CAAA;AAEhB,QAAA,0BAA0B,GAAG,IAAA,iBAAG,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"}
@@ -0,0 +1,80 @@
1
+ "use strict";
2
+ var __decorate = (this && this.__decorate) || function (decorators, target, key, desc) {
3
+ var c = arguments.length, r = c < 3 ? target : desc === null ? desc = Object.getOwnPropertyDescriptor(target, key) : desc, d;
4
+ if (typeof Reflect === "object" && typeof Reflect.decorate === "function") r = Reflect.decorate(decorators, target, key, desc);
5
+ else for (var i = decorators.length - 1; i >= 0; i--) if (d = decorators[i]) r = (c < 3 ? d(r) : c > 3 ? d(target, key, r) : d(target, key)) || r;
6
+ return c > 3 && r && Object.defineProperty(target, key, r), r;
7
+ };
8
+ var __metadata = (this && this.__metadata) || function (k, v) {
9
+ if (typeof Reflect === "object" && typeof Reflect.metadata === "function") return Reflect.metadata(k, v);
10
+ };
11
+ var __param = (this && this.__param) || function (paramIndex, decorator) {
12
+ return function (target, key) { decorator(target, key, paramIndex); }
13
+ };
14
+ Object.defineProperty(exports, "__esModule", { value: true });
15
+ exports.PrivilegeMutation = void 0;
16
+ const type_graphql_1 = require("type-graphql");
17
+ const typeorm_1 = require("typeorm");
18
+ const role_1 = require("../role/role");
19
+ const privilege_1 = require("./privilege");
20
+ const privilege_types_1 = require("./privilege-types");
21
+ let PrivilegeMutation = class PrivilegeMutation {
22
+ async createPrivilege(privilege, context) {
23
+ if (privilege.roles && privilege.roles.length) {
24
+ privilege.roles = await (0, typeorm_1.getRepository)(role_1.Role).findByIds(privilege.roles);
25
+ }
26
+ return await (0, typeorm_1.getRepository)(privilege_1.Privilege).save(Object.assign({ creator: context.state.user, updater: context.state.user }, privilege));
27
+ }
28
+ async updatePrivilege(name, category, patch, context) {
29
+ const repository = (0, typeorm_1.getRepository)(privilege_1.Privilege);
30
+ const privilege = await repository.findOne({
31
+ where: { name, category },
32
+ relations: ['roles', 'creator', 'updater']
33
+ });
34
+ const roleIds = privilege.roles.map(role => role.id);
35
+ if (patch.roles && patch.roles.length) {
36
+ patch.roles.forEach((roleId) => {
37
+ if (!roleIds.includes(roleId)) {
38
+ roleIds.push(roleId);
39
+ }
40
+ });
41
+ }
42
+ 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 }));
43
+ }
44
+ async deletePrivilege(name, category, context) {
45
+ await (0, typeorm_1.getRepository)(privilege_1.Privilege).delete({ name, category });
46
+ return true;
47
+ }
48
+ };
49
+ __decorate([
50
+ (0, type_graphql_1.Mutation)(returns => privilege_1.Privilege, { description: 'To create new privilege' }),
51
+ __param(0, (0, type_graphql_1.Arg)('privilege')),
52
+ __param(1, (0, type_graphql_1.Ctx)()),
53
+ __metadata("design:type", Function),
54
+ __metadata("design:paramtypes", [privilege_types_1.NewPrivilege, Object]),
55
+ __metadata("design:returntype", Promise)
56
+ ], PrivilegeMutation.prototype, "createPrivilege", null);
57
+ __decorate([
58
+ (0, type_graphql_1.Mutation)(returns => privilege_1.Privilege, { description: 'To modify privilege information' }),
59
+ __param(0, (0, type_graphql_1.Arg)('name')),
60
+ __param(1, (0, type_graphql_1.Arg)('category')),
61
+ __param(2, (0, type_graphql_1.Arg)('patch')),
62
+ __param(3, (0, type_graphql_1.Ctx)()),
63
+ __metadata("design:type", Function),
64
+ __metadata("design:paramtypes", [String, String, privilege_types_1.PrivilegePatch, Object]),
65
+ __metadata("design:returntype", Promise)
66
+ ], PrivilegeMutation.prototype, "updatePrivilege", null);
67
+ __decorate([
68
+ (0, type_graphql_1.Mutation)(returns => Boolean, { description: 'To delete privilege' }),
69
+ __param(0, (0, type_graphql_1.Arg)('name')),
70
+ __param(1, (0, type_graphql_1.Arg)('category')),
71
+ __param(2, (0, type_graphql_1.Ctx)()),
72
+ __metadata("design:type", Function),
73
+ __metadata("design:paramtypes", [String, String, Object]),
74
+ __metadata("design:returntype", Promise)
75
+ ], PrivilegeMutation.prototype, "deletePrivilege", null);
76
+ PrivilegeMutation = __decorate([
77
+ (0, type_graphql_1.Resolver)(privilege_1.Privilege)
78
+ ], PrivilegeMutation);
79
+ exports.PrivilegeMutation = PrivilegeMutation;
80
+ //# sourceMappingURL=privilege-mutation.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"privilege-mutation.js","sourceRoot":"","sources":["../../../server/service/privilege/privilege-mutation.ts"],"names":[],"mappings":"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"}
@@ -0,0 +1,109 @@
1
+ "use strict";
2
+ var __decorate = (this && this.__decorate) || function (decorators, target, key, desc) {
3
+ var c = arguments.length, r = c < 3 ? target : desc === null ? desc = Object.getOwnPropertyDescriptor(target, key) : desc, d;
4
+ if (typeof Reflect === "object" && typeof Reflect.decorate === "function") r = Reflect.decorate(decorators, target, key, desc);
5
+ else for (var i = decorators.length - 1; i >= 0; i--) if (d = decorators[i]) r = (c < 3 ? d(r) : c > 3 ? d(target, key, r) : d(target, key)) || r;
6
+ return c > 3 && r && Object.defineProperty(target, key, r), r;
7
+ };
8
+ var __metadata = (this && this.__metadata) || function (k, v) {
9
+ if (typeof Reflect === "object" && typeof Reflect.metadata === "function") return Reflect.metadata(k, v);
10
+ };
11
+ var __param = (this && this.__param) || function (paramIndex, decorator) {
12
+ return function (target, key) { decorator(target, key, paramIndex); }
13
+ };
14
+ var _a;
15
+ Object.defineProperty(exports, "__esModule", { value: true });
16
+ exports.PrivilegeQuery = void 0;
17
+ const type_graphql_1 = require("type-graphql");
18
+ const typeorm_1 = require("typeorm");
19
+ const shell_1 = require("@things-factory/shell");
20
+ const user_1 = require("../user/user");
21
+ const role_1 = require("../role/role");
22
+ const privilege_1 = require("./privilege");
23
+ const privilege_types_1 = require("./privilege-types");
24
+ let PrivilegeQuery = class PrivilegeQuery {
25
+ async privilege(name, category) {
26
+ return await (0, typeorm_1.getRepository)(privilege_1.Privilege).findOne({
27
+ where: { name, category }
28
+ });
29
+ }
30
+ async privileges(params, context) {
31
+ const queryBuilder = (0, typeorm_1.getRepository)(privilege_1.Privilege).createQueryBuilder();
32
+ (0, shell_1.buildQuery)(queryBuilder, params, context, false);
33
+ const [items, total] = await queryBuilder.getManyAndCount();
34
+ return { items, total };
35
+ }
36
+ async description(privilege, context) {
37
+ const { t } = context;
38
+ const { name, category } = privilege;
39
+ const keyname = `privilege.name.${name}`;
40
+ const keycategory = `privilege.category.${category}`;
41
+ const tname = t(keyname);
42
+ const tcategory = t(keycategory);
43
+ return t('privilege.description', {
44
+ name: tname === keyname ? name : tname,
45
+ category: tcategory === keycategory ? category : tcategory
46
+ });
47
+ }
48
+ async roles(privilege) {
49
+ return (await (0, typeorm_1.getRepository)(privilege_1.Privilege).findOne(privilege.id, {
50
+ relations: ['roles']
51
+ })).roles;
52
+ }
53
+ async updater(privilege) {
54
+ return await (0, typeorm_1.getRepository)(user_1.User).findOne(privilege.updaterId);
55
+ }
56
+ async creator(privilege) {
57
+ return await (0, typeorm_1.getRepository)(user_1.User).findOne(privilege.creatorId);
58
+ }
59
+ };
60
+ __decorate([
61
+ (0, type_graphql_1.Query)(returns => privilege_1.Privilege, { description: 'To fetch privilege' }),
62
+ __param(0, (0, type_graphql_1.Arg)('name')),
63
+ __param(1, (0, type_graphql_1.Arg)('category')),
64
+ __metadata("design:type", Function),
65
+ __metadata("design:paramtypes", [String, String]),
66
+ __metadata("design:returntype", Promise)
67
+ ], PrivilegeQuery.prototype, "privilege", null);
68
+ __decorate([
69
+ (0, type_graphql_1.Query)(returns => privilege_types_1.PrivilegeList, { description: 'To fetch multiple privileges' }),
70
+ __param(0, (0, type_graphql_1.Args)()),
71
+ __param(1, (0, type_graphql_1.Ctx)()),
72
+ __metadata("design:type", Function),
73
+ __metadata("design:paramtypes", [typeof (_a = typeof shell_1.ListParam !== "undefined" && shell_1.ListParam) === "function" ? _a : Object, Object]),
74
+ __metadata("design:returntype", Promise)
75
+ ], PrivilegeQuery.prototype, "privileges", null);
76
+ __decorate([
77
+ (0, type_graphql_1.FieldResolver)(type => String),
78
+ __param(0, (0, type_graphql_1.Root)()),
79
+ __param(1, (0, type_graphql_1.Ctx)()),
80
+ __metadata("design:type", Function),
81
+ __metadata("design:paramtypes", [privilege_1.Privilege, Object]),
82
+ __metadata("design:returntype", Promise)
83
+ ], PrivilegeQuery.prototype, "description", null);
84
+ __decorate([
85
+ (0, type_graphql_1.FieldResolver)(type => [role_1.Role]),
86
+ __param(0, (0, type_graphql_1.Root)()),
87
+ __metadata("design:type", Function),
88
+ __metadata("design:paramtypes", [privilege_1.Privilege]),
89
+ __metadata("design:returntype", Promise)
90
+ ], PrivilegeQuery.prototype, "roles", null);
91
+ __decorate([
92
+ (0, type_graphql_1.FieldResolver)(type => user_1.User),
93
+ __param(0, (0, type_graphql_1.Root)()),
94
+ __metadata("design:type", Function),
95
+ __metadata("design:paramtypes", [privilege_1.Privilege]),
96
+ __metadata("design:returntype", Promise)
97
+ ], PrivilegeQuery.prototype, "updater", null);
98
+ __decorate([
99
+ (0, type_graphql_1.FieldResolver)(type => user_1.User),
100
+ __param(0, (0, type_graphql_1.Root)()),
101
+ __metadata("design:type", Function),
102
+ __metadata("design:paramtypes", [privilege_1.Privilege]),
103
+ __metadata("design:returntype", Promise)
104
+ ], PrivilegeQuery.prototype, "creator", null);
105
+ PrivilegeQuery = __decorate([
106
+ (0, type_graphql_1.Resolver)(privilege_1.Privilege)
107
+ ], PrivilegeQuery);
108
+ exports.PrivilegeQuery = PrivilegeQuery;
109
+ //# sourceMappingURL=privilege-query.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"privilege-query.js","sourceRoot":"","sources":["../../../server/service/privilege/privilege-query.ts"],"names":[],"mappings":"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"}
@@ -0,0 +1,100 @@
1
+ "use strict";
2
+ var __decorate = (this && this.__decorate) || function (decorators, target, key, desc) {
3
+ var c = arguments.length, r = c < 3 ? target : desc === null ? desc = Object.getOwnPropertyDescriptor(target, key) : desc, d;
4
+ if (typeof Reflect === "object" && typeof Reflect.decorate === "function") r = Reflect.decorate(decorators, target, key, desc);
5
+ else for (var i = decorators.length - 1; i >= 0; i--) if (d = decorators[i]) r = (c < 3 ? d(r) : c > 3 ? d(target, key, r) : d(target, key)) || r;
6
+ return c > 3 && r && Object.defineProperty(target, key, r), r;
7
+ };
8
+ var __metadata = (this && this.__metadata) || function (k, v) {
9
+ if (typeof Reflect === "object" && typeof Reflect.metadata === "function") return Reflect.metadata(k, v);
10
+ };
11
+ Object.defineProperty(exports, "__esModule", { value: true });
12
+ exports.UserPrivilege = exports.PrivilegeList = exports.PrivilegePatch = exports.NewPrivilege = void 0;
13
+ const type_graphql_1 = require("type-graphql");
14
+ const shell_1 = require("@things-factory/shell");
15
+ const privilege_1 = require("./privilege");
16
+ let NewPrivilege = class NewPrivilege {
17
+ };
18
+ __decorate([
19
+ (0, type_graphql_1.Field)(),
20
+ __metadata("design:type", String)
21
+ ], NewPrivilege.prototype, "name", void 0);
22
+ __decorate([
23
+ (0, type_graphql_1.Field)(),
24
+ __metadata("design:type", String)
25
+ ], NewPrivilege.prototype, "category", void 0);
26
+ __decorate([
27
+ (0, type_graphql_1.Field)({ nullable: true }),
28
+ __metadata("design:type", String)
29
+ ], NewPrivilege.prototype, "description", void 0);
30
+ __decorate([
31
+ (0, type_graphql_1.Field)(type => [shell_1.ObjectRef], { nullable: true }),
32
+ __metadata("design:type", Array)
33
+ ], NewPrivilege.prototype, "roles", void 0);
34
+ NewPrivilege = __decorate([
35
+ (0, type_graphql_1.InputType)()
36
+ ], NewPrivilege);
37
+ exports.NewPrivilege = NewPrivilege;
38
+ let PrivilegePatch = class PrivilegePatch {
39
+ };
40
+ __decorate([
41
+ (0, type_graphql_1.Field)({ nullable: true }),
42
+ __metadata("design:type", String)
43
+ ], PrivilegePatch.prototype, "id", void 0);
44
+ __decorate([
45
+ (0, type_graphql_1.Field)({ nullable: true }),
46
+ __metadata("design:type", String)
47
+ ], PrivilegePatch.prototype, "name", void 0);
48
+ __decorate([
49
+ (0, type_graphql_1.Field)({ nullable: true }),
50
+ __metadata("design:type", String)
51
+ ], PrivilegePatch.prototype, "category", void 0);
52
+ __decorate([
53
+ (0, type_graphql_1.Field)({ nullable: true }),
54
+ __metadata("design:type", String)
55
+ ], PrivilegePatch.prototype, "description", void 0);
56
+ __decorate([
57
+ (0, type_graphql_1.Field)(type => [shell_1.ObjectRef], { nullable: true }),
58
+ __metadata("design:type", Array)
59
+ ], PrivilegePatch.prototype, "roles", void 0);
60
+ PrivilegePatch = __decorate([
61
+ (0, type_graphql_1.InputType)()
62
+ ], PrivilegePatch);
63
+ exports.PrivilegePatch = PrivilegePatch;
64
+ let PrivilegeList = class PrivilegeList {
65
+ };
66
+ __decorate([
67
+ (0, type_graphql_1.Field)(type => [privilege_1.Privilege], { nullable: true }),
68
+ __metadata("design:type", Array)
69
+ ], PrivilegeList.prototype, "items", void 0);
70
+ __decorate([
71
+ (0, type_graphql_1.Field)(type => type_graphql_1.Int, { nullable: true }),
72
+ __metadata("design:type", Number)
73
+ ], PrivilegeList.prototype, "total", void 0);
74
+ PrivilegeList = __decorate([
75
+ (0, type_graphql_1.ObjectType)()
76
+ ], PrivilegeList);
77
+ exports.PrivilegeList = PrivilegeList;
78
+ let UserPrivilege = class UserPrivilege {
79
+ };
80
+ __decorate([
81
+ (0, type_graphql_1.Field)({ nullable: true }),
82
+ __metadata("design:type", String)
83
+ ], UserPrivilege.prototype, "id", void 0);
84
+ __decorate([
85
+ (0, type_graphql_1.Field)({ nullable: true }),
86
+ __metadata("design:type", String)
87
+ ], UserPrivilege.prototype, "name", void 0);
88
+ __decorate([
89
+ (0, type_graphql_1.Field)({ nullable: true }),
90
+ __metadata("design:type", String)
91
+ ], UserPrivilege.prototype, "description", void 0);
92
+ __decorate([
93
+ (0, type_graphql_1.Field)({ nullable: true }),
94
+ __metadata("design:type", Boolean)
95
+ ], UserPrivilege.prototype, "assigned", void 0);
96
+ UserPrivilege = __decorate([
97
+ (0, type_graphql_1.ObjectType)()
98
+ ], UserPrivilege);
99
+ exports.UserPrivilege = UserPrivilege;
100
+ //# sourceMappingURL=privilege-types.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"privilege-types.js","sourceRoot":"","sources":["../../../server/service/privilege/privilege-types.ts"],"names":[],"mappings":";;;;;;;;;;;;AAAA,+CAAgE;AAChE,iDAAiD;AACjD,2CAAuC;AAGhC,IAAM,YAAY,GAAlB,MAAM,YAAY;CAYxB,CAAA;AAXC;IAAC,IAAA,oBAAK,GAAE;;0CACI;AAEZ;IAAC,IAAA,oBAAK,GAAE;;8CACQ;AAEhB;IAAC,IAAA,oBAAK,EAAC,EAAE,QAAQ,EAAE,IAAI,EAAE,CAAC;;iDACN;AAEpB;IAAC,IAAA,oBAAK,EAAC,IAAI,CAAC,EAAE,CAAC,CAAC,iBAAS,CAAC,EAAE,EAAE,QAAQ,EAAE,IAAI,EAAE,CAAC;;2CAC7B;AAXP,YAAY;IADxB,IAAA,wBAAS,GAAE;GACC,YAAY,CAYxB;AAZY,oCAAY;AAelB,IAAM,cAAc,GAApB,MAAM,cAAc;CAe1B,CAAA;AAdC;IAAC,IAAA,oBAAK,EAAC,EAAE,QAAQ,EAAE,IAAI,EAAE,CAAC;;0CACf;AAEX;IAAC,IAAA,oBAAK,EAAC,EAAE,QAAQ,EAAE,IAAI,EAAE,CAAC;;4CACb;AAEb;IAAC,IAAA,oBAAK,EAAC,EAAE,QAAQ,EAAE,IAAI,EAAE,CAAC;;gDACT;AAEjB;IAAC,IAAA,oBAAK,EAAC,EAAE,QAAQ,EAAE,IAAI,EAAE,CAAC;;mDACN;AAEpB;IAAC,IAAA,oBAAK,EAAC,IAAI,CAAC,EAAE,CAAC,CAAC,iBAAS,CAAC,EAAE,EAAE,QAAQ,EAAE,IAAI,EAAE,CAAC;;6CAC5B;AAdR,cAAc;IAD1B,IAAA,wBAAS,GAAE;GACC,cAAc,CAe1B;AAfY,wCAAc;AAkBpB,IAAM,aAAa,GAAnB,MAAM,aAAa;CAMzB,CAAA;AALC;IAAC,IAAA,oBAAK,EAAC,IAAI,CAAC,EAAE,CAAC,CAAC,qBAAS,CAAC,EAAE,EAAE,QAAQ,EAAE,IAAI,EAAE,CAAC;;4CAC7B;AAElB;IAAC,IAAA,oBAAK,EAAC,IAAI,CAAC,EAAE,CAAC,kBAAG,EAAE,EAAE,QAAQ,EAAE,IAAI,EAAE,CAAC;;4CAC1B;AALF,aAAa;IADzB,IAAA,yBAAU,GAAE;GACA,aAAa,CAMzB;AANY,sCAAa;AASnB,IAAM,aAAa,GAAnB,MAAM,aAAa;CAYzB,CAAA;AAXC;IAAC,IAAA,oBAAK,EAAC,EAAE,QAAQ,EAAE,IAAI,EAAE,CAAC;8BACtB,MAAM;yCAAA;AAEV;IAAC,IAAA,oBAAK,EAAC,EAAE,QAAQ,EAAE,IAAI,EAAE,CAAC;8BACpB,MAAM;2CAAA;AAEZ;IAAC,IAAA,oBAAK,EAAC,EAAE,QAAQ,EAAE,IAAI,EAAE,CAAC;8BACb,MAAM;kDAAA;AAEnB;IAAC,IAAA,oBAAK,EAAC,EAAE,QAAQ,EAAE,IAAI,EAAE,CAAC;8BAChB,OAAO;+CAAA;AAXN,aAAa;IADzB,IAAA,yBAAU,GAAE;GACA,aAAa,CAYzB;AAZY,sCAAa"}
@@ -0,0 +1,92 @@
1
+ "use strict";
2
+ var __decorate = (this && this.__decorate) || function (decorators, target, key, desc) {
3
+ var c = arguments.length, r = c < 3 ? target : desc === null ? desc = Object.getOwnPropertyDescriptor(target, key) : desc, d;
4
+ if (typeof Reflect === "object" && typeof Reflect.decorate === "function") r = Reflect.decorate(decorators, target, key, desc);
5
+ else for (var i = decorators.length - 1; i >= 0; i--) if (d = decorators[i]) r = (c < 3 ? d(r) : c > 3 ? d(target, key, r) : d(target, key)) || r;
6
+ return c > 3 && r && Object.defineProperty(target, key, r), r;
7
+ };
8
+ var __metadata = (this && this.__metadata) || function (k, v) {
9
+ if (typeof Reflect === "object" && typeof Reflect.metadata === "function") return Reflect.metadata(k, v);
10
+ };
11
+ Object.defineProperty(exports, "__esModule", { value: true });
12
+ exports.Privilege = void 0;
13
+ const typeorm_1 = require("typeorm");
14
+ const type_graphql_1 = require("type-graphql");
15
+ const role_1 = require("../role/role");
16
+ const user_1 = require("../user/user");
17
+ let Privilege = class Privilege {
18
+ };
19
+ __decorate([
20
+ (0, typeorm_1.PrimaryGeneratedColumn)('uuid'),
21
+ (0, type_graphql_1.Field)(type => type_graphql_1.ID),
22
+ __metadata("design:type", String)
23
+ ], Privilege.prototype, "id", void 0);
24
+ __decorate([
25
+ (0, typeorm_1.Column)(),
26
+ (0, type_graphql_1.Field)(),
27
+ __metadata("design:type", String)
28
+ ], Privilege.prototype, "name", void 0);
29
+ __decorate([
30
+ (0, typeorm_1.Column)(),
31
+ (0, type_graphql_1.Field)({ nullable: true }),
32
+ __metadata("design:type", String)
33
+ ], Privilege.prototype, "category", void 0);
34
+ __decorate([
35
+ (0, typeorm_1.Column)({
36
+ nullable: true
37
+ }),
38
+ (0, type_graphql_1.Field)({ nullable: true }),
39
+ __metadata("design:type", String)
40
+ ], Privilege.prototype, "description", void 0);
41
+ __decorate([
42
+ (0, typeorm_1.ManyToMany)(type => role_1.Role, role => role.privileges),
43
+ (0, typeorm_1.JoinTable)({
44
+ /* case M2M, JoinTable setting should be defined only one side (never set both side) */
45
+ name: 'roles_privileges',
46
+ joinColumns: [{ name: 'privileges_id', referencedColumnName: 'id' }],
47
+ inverseJoinColumns: [{ name: 'roles_id', referencedColumnName: 'id' }]
48
+ }),
49
+ (0, type_graphql_1.Field)(type => [role_1.Role], { nullable: true }),
50
+ __metadata("design:type", Array)
51
+ ], Privilege.prototype, "roles", void 0);
52
+ __decorate([
53
+ (0, typeorm_1.ManyToOne)(type => user_1.User, {
54
+ nullable: true
55
+ }),
56
+ (0, type_graphql_1.Field)(type => user_1.User, { nullable: true }),
57
+ __metadata("design:type", user_1.User)
58
+ ], Privilege.prototype, "creator", void 0);
59
+ __decorate([
60
+ (0, typeorm_1.RelationId)((privilege) => privilege.creator),
61
+ __metadata("design:type", String)
62
+ ], Privilege.prototype, "creatorId", void 0);
63
+ __decorate([
64
+ (0, typeorm_1.ManyToOne)(type => user_1.User, {
65
+ nullable: true
66
+ }),
67
+ (0, type_graphql_1.Field)(type => user_1.User, { nullable: true }),
68
+ __metadata("design:type", user_1.User)
69
+ ], Privilege.prototype, "updater", void 0);
70
+ __decorate([
71
+ (0, typeorm_1.RelationId)((privilege) => privilege.updater),
72
+ __metadata("design:type", String)
73
+ ], Privilege.prototype, "updaterId", void 0);
74
+ __decorate([
75
+ (0, typeorm_1.CreateDateColumn)(),
76
+ (0, type_graphql_1.Field)({ nullable: true }),
77
+ __metadata("design:type", Date)
78
+ ], Privilege.prototype, "createdAt", void 0);
79
+ __decorate([
80
+ (0, typeorm_1.UpdateDateColumn)(),
81
+ (0, type_graphql_1.Field)({ nullable: true }),
82
+ __metadata("design:type", Date)
83
+ ], Privilege.prototype, "updatedAt", void 0);
84
+ Privilege = __decorate([
85
+ (0, typeorm_1.Entity)(),
86
+ (0, typeorm_1.Index)('ix_privilege_0', (privilege) => [privilege.name, privilege.category], {
87
+ unique: false
88
+ }),
89
+ (0, type_graphql_1.ObjectType)()
90
+ ], Privilege);
91
+ exports.Privilege = Privilege;
92
+ //# sourceMappingURL=privilege.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"privilege.js","sourceRoot":"","sources":["../../../server/service/privilege/privilege.ts"],"names":[],"mappings":";;;;;;;;;;;;AAAA,qCAWgB;AAChB,+CAAoD;AACpD,uCAAmC;AACnC,uCAAmC;AAO5B,IAAM,SAAS,GAAf,MAAM,SAAS;CAsDrB,CAAA;AArDC;IAAC,IAAA,gCAAsB,EAAC,MAAM,CAAC;IAC9B,IAAA,oBAAK,EAAC,IAAI,CAAC,EAAE,CAAC,iBAAE,CAAC;;qCACR;AAEV;IAAC,IAAA,gBAAM,GAAE;IACR,IAAA,oBAAK,GAAE;;uCACI;AAEZ;IAAC,IAAA,gBAAM,GAAE;IACR,IAAA,oBAAK,EAAC,EAAE,QAAQ,EAAE,IAAI,EAAE,CAAC;;2CACV;AAEhB;IAAC,IAAA,gBAAM,EAAC;QACN,QAAQ,EAAE,IAAI;KACf,CAAC;IACD,IAAA,oBAAK,EAAC,EAAE,QAAQ,EAAE,IAAI,EAAE,CAAC;;8CACP;AAEnB;IAAC,IAAA,oBAAU,EAAC,IAAI,CAAC,EAAE,CAAC,WAAI,EAAE,IAAI,CAAC,EAAE,CAAC,IAAI,CAAC,UAAU,CAAC;IACjD,IAAA,mBAAS,EAAC;QACT,uFAAuF;QACvF,IAAI,EAAE,kBAAkB;QACxB,WAAW,EAAE,CAAC,EAAE,IAAI,EAAE,eAAe,EAAE,oBAAoB,EAAE,IAAI,EAAE,CAAC;QACpE,kBAAkB,EAAE,CAAC,EAAE,IAAI,EAAE,UAAU,EAAE,oBAAoB,EAAE,IAAI,EAAE,CAAC;KACvE,CAAC;IACD,IAAA,oBAAK,EAAC,IAAI,CAAC,EAAE,CAAC,CAAC,WAAI,CAAC,EAAE,EAAE,QAAQ,EAAE,IAAI,EAAE,CAAC;;wCAC7B;AAEb;IAAC,IAAA,mBAAS,EAAC,IAAI,CAAC,EAAE,CAAC,WAAI,EAAE;QACvB,QAAQ,EAAE,IAAI;KACf,CAAC;IACD,IAAA,oBAAK,EAAC,IAAI,CAAC,EAAE,CAAC,WAAI,EAAE,EAAE,QAAQ,EAAE,IAAI,EAAE,CAAC;8BAC/B,WAAI;0CAAA;AAEb;IAAC,IAAA,oBAAU,EAAC,CAAC,SAAoB,EAAE,EAAE,CAAC,SAAS,CAAC,OAAO,CAAC;;4CACvC;AAEjB;IAAC,IAAA,mBAAS,EAAC,IAAI,CAAC,EAAE,CAAC,WAAI,EAAE;QACvB,QAAQ,EAAE,IAAI;KACf,CAAC;IACD,IAAA,oBAAK,EAAC,IAAI,CAAC,EAAE,CAAC,WAAI,EAAE,EAAE,QAAQ,EAAE,IAAI,EAAE,CAAC;8BAC/B,WAAI;0CAAA;AAEb;IAAC,IAAA,oBAAU,EAAC,CAAC,SAAoB,EAAE,EAAE,CAAC,SAAS,CAAC,OAAO,CAAC;;4CACvC;AAEjB;IAAC,IAAA,0BAAgB,GAAE;IAClB,IAAA,oBAAK,EAAC,EAAE,QAAQ,EAAE,IAAI,EAAE,CAAC;8BACf,IAAI;4CAAA;AAEf;IAAC,IAAA,0BAAgB,GAAE;IAClB,IAAA,oBAAK,EAAC,EAAE,QAAQ,EAAE,IAAI,EAAE,CAAC;8BACf,IAAI;4CAAA;AArDJ,SAAS;IALrB,IAAA,gBAAM,GAAE;IACR,IAAA,eAAK,EAAC,gBAAgB,EAAE,CAAC,SAAoB,EAAE,EAAE,CAAC,CAAC,SAAS,CAAC,IAAI,EAAE,SAAS,CAAC,QAAQ,CAAC,EAAE;QACvF,MAAM,EAAE,KAAK;KACd,CAAC;IACD,IAAA,yBAAU,GAAE;GACA,SAAS,CAsDrB;AAtDY,8BAAS"}
@@ -0,0 +1,9 @@
1
+ "use strict";
2
+ Object.defineProperty(exports, "__esModule", { value: true });
3
+ exports.resolvers = exports.entities = void 0;
4
+ const role_1 = require("./role");
5
+ const role_query_1 = require("./role-query");
6
+ const role_mutation_1 = require("./role-mutation");
7
+ exports.entities = [role_1.Role];
8
+ exports.resolvers = [role_query_1.RoleQuery, role_mutation_1.RoleMutation];
9
+ //# sourceMappingURL=index.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"index.js","sourceRoot":"","sources":["../../../server/service/role/index.ts"],"names":[],"mappings":";;;AAAA,iCAA6B;AAC7B,6CAAwC;AACxC,mDAA8C;AAEjC,QAAA,QAAQ,GAAG,CAAC,WAAI,CAAC,CAAA;AACjB,QAAA,SAAS,GAAG,CAAC,sBAAS,EAAE,4BAAY,CAAC,CAAA"}
@@ -0,0 +1,121 @@
1
+ "use strict";
2
+ var __decorate = (this && this.__decorate) || function (decorators, target, key, desc) {
3
+ var c = arguments.length, r = c < 3 ? target : desc === null ? desc = Object.getOwnPropertyDescriptor(target, key) : desc, d;
4
+ if (typeof Reflect === "object" && typeof Reflect.decorate === "function") r = Reflect.decorate(decorators, target, key, desc);
5
+ else for (var i = decorators.length - 1; i >= 0; i--) if (d = decorators[i]) r = (c < 3 ? d(r) : c > 3 ? d(target, key, r) : d(target, key)) || r;
6
+ return c > 3 && r && Object.defineProperty(target, key, r), r;
7
+ };
8
+ var __metadata = (this && this.__metadata) || function (k, v) {
9
+ if (typeof Reflect === "object" && typeof Reflect.metadata === "function") return Reflect.metadata(k, v);
10
+ };
11
+ var __param = (this && this.__param) || function (paramIndex, decorator) {
12
+ return function (target, key) { decorator(target, key, paramIndex); }
13
+ };
14
+ Object.defineProperty(exports, "__esModule", { value: true });
15
+ exports.RoleMutation = void 0;
16
+ const type_graphql_1 = require("type-graphql");
17
+ const typeorm_1 = require("typeorm");
18
+ const user_1 = require("../user/user");
19
+ const privilege_1 = require("../privilege/privilege");
20
+ const role_1 = require("./role");
21
+ const role_types_1 = require("./role-types");
22
+ let RoleMutation = class RoleMutation {
23
+ async createRole(role, context) {
24
+ const { domain, user } = context.state;
25
+ const roleName = role.name.trim();
26
+ const existsRole = await (0, typeorm_1.getRepository)(role_1.Role).findOne({ where: { name: roleName, domain } });
27
+ if (existsRole) {
28
+ throw new Error('role name is duplicated');
29
+ }
30
+ if (role.privileges && role.privileges.length) {
31
+ role.privileges = await (0, typeorm_1.getRepository)(privilege_1.Privilege).findByIds(role.privileges.map(privilege => privilege.id));
32
+ }
33
+ if (role.users && role.users.length) {
34
+ role.users = await (0, typeorm_1.getRepository)(user_1.User).findByIds(role.users.map(user => user.id));
35
+ }
36
+ return await (0, typeorm_1.getRepository)(role_1.Role).save(Object.assign({ domain, updater: user, creator: user }, role));
37
+ }
38
+ async updateRole(id, patch, context) {
39
+ const { domain, user } = context.state;
40
+ const { name, description, privileges } = patch;
41
+ const roleRepository = (0, typeorm_1.getRepository)(role_1.Role);
42
+ const role = await roleRepository.findOne({
43
+ where: { domain, id },
44
+ relations: ['privileges', 'creator', 'updater']
45
+ });
46
+ if (name && role.name !== name) {
47
+ const roleName = name.trim();
48
+ const existsRole = await roleRepository.findOne({ where: { name: roleName, domain } });
49
+ if (existsRole) {
50
+ throw new Error('role name is duplicated');
51
+ }
52
+ role.name = roleName;
53
+ }
54
+ if (description) {
55
+ role.description = description;
56
+ }
57
+ return await roleRepository.save(Object.assign(Object.assign(Object.assign({}, role), patch), { privileges: await (0, typeorm_1.getRepository)(privilege_1.Privilege).findByIds(patch.privileges.map((privilege) => privilege.id)), updater: user }));
58
+ }
59
+ async deleteRole(id, context) {
60
+ const { tx, domain } = context.state;
61
+ let role = await tx.getRepository(role_1.Role).findOne({ where: { domain, id }, relations: ['users', 'privileges'] });
62
+ try {
63
+ if (role.users.length)
64
+ throw new Error('cannot delete role because it is currently in use');
65
+ role.privileges = [];
66
+ role = await tx.getRepository(role_1.Role).save(role);
67
+ await tx.getRepository(role_1.Role).delete(role.id);
68
+ return true;
69
+ }
70
+ catch (e) {
71
+ context.throw(401, 'cannot delete role because it is currently in use');
72
+ }
73
+ }
74
+ async deleteRoles(ids, _context) {
75
+ await (0, typeorm_1.getRepository)(role_1.Role).delete(ids);
76
+ return true;
77
+ }
78
+ };
79
+ __decorate([
80
+ (0, type_graphql_1.Directive)('@privilege(category: "user", privilege: "mutation", domainOwnerGranted: true)'),
81
+ (0, type_graphql_1.Mutation)(returns => user_1.User, { description: 'To create new user' }),
82
+ __param(0, (0, type_graphql_1.Arg)('role')),
83
+ __param(1, (0, type_graphql_1.Ctx)()),
84
+ __metadata("design:type", Function),
85
+ __metadata("design:paramtypes", [role_types_1.NewRole, Object]),
86
+ __metadata("design:returntype", Promise)
87
+ ], RoleMutation.prototype, "createRole", null);
88
+ __decorate([
89
+ (0, type_graphql_1.Directive)('@privilege(category: "user", privilege: "mutation", domainOwnerGranted: true)'),
90
+ (0, type_graphql_1.Mutation)(returns => role_1.Role, { description: 'To modify role information' }),
91
+ __param(0, (0, type_graphql_1.Arg)('id')),
92
+ __param(1, (0, type_graphql_1.Arg)('patch')),
93
+ __param(2, (0, type_graphql_1.Ctx)()),
94
+ __metadata("design:type", Function),
95
+ __metadata("design:paramtypes", [String, role_types_1.RolePatch, Object]),
96
+ __metadata("design:returntype", Promise)
97
+ ], RoleMutation.prototype, "updateRole", null);
98
+ __decorate([
99
+ (0, type_graphql_1.Directive)('@privilege(category: "user", privilege: "mutation")'),
100
+ (0, type_graphql_1.Directive)('@transaction'),
101
+ (0, type_graphql_1.Mutation)(returns => Boolean, { description: 'To delete role' }),
102
+ __param(0, (0, type_graphql_1.Arg)('id')),
103
+ __param(1, (0, type_graphql_1.Ctx)()),
104
+ __metadata("design:type", Function),
105
+ __metadata("design:paramtypes", [String, Object]),
106
+ __metadata("design:returntype", Promise)
107
+ ], RoleMutation.prototype, "deleteRole", null);
108
+ __decorate([
109
+ (0, type_graphql_1.Directive)('@privilege(category: "user", privilege: "mutation", domainOwnerGranted: true)'),
110
+ (0, type_graphql_1.Mutation)(returns => Boolean, { description: 'To delete multiple roles' }),
111
+ __param(0, (0, type_graphql_1.Arg)('ids', type => [String])),
112
+ __param(1, (0, type_graphql_1.Ctx)()),
113
+ __metadata("design:type", Function),
114
+ __metadata("design:paramtypes", [Array, Object]),
115
+ __metadata("design:returntype", Promise)
116
+ ], RoleMutation.prototype, "deleteRoles", null);
117
+ RoleMutation = __decorate([
118
+ (0, type_graphql_1.Resolver)(role_1.Role)
119
+ ], RoleMutation);
120
+ exports.RoleMutation = RoleMutation;
121
+ //# sourceMappingURL=role-mutation.js.map