@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.
- package/dist-server/constants/error-code.js +21 -0
- package/dist-server/constants/error-code.js.map +1 -0
- package/dist-server/constants/error-message.js +1 -0
- package/dist-server/constants/error-message.js.map +1 -0
- package/dist-server/constants/max-age.js +5 -0
- package/dist-server/constants/max-age.js.map +1 -0
- package/dist-server/controllers/auth.js +21 -0
- package/dist-server/controllers/auth.js.map +1 -0
- package/dist-server/controllers/change-pwd.js +80 -0
- package/dist-server/controllers/change-pwd.js.map +1 -0
- package/dist-server/controllers/checkin.js +21 -0
- package/dist-server/controllers/checkin.js.map +1 -0
- package/dist-server/controllers/delete-user.js +61 -0
- package/dist-server/controllers/delete-user.js.map +1 -0
- package/dist-server/controllers/invitation.js +119 -0
- package/dist-server/controllers/invitation.js.map +1 -0
- package/dist-server/controllers/profile.js +26 -0
- package/dist-server/controllers/profile.js.map +1 -0
- package/dist-server/controllers/reset-password.js +110 -0
- package/dist-server/controllers/reset-password.js.map +1 -0
- package/dist-server/controllers/signin.js +76 -0
- package/dist-server/controllers/signin.js.map +1 -0
- package/dist-server/controllers/signup.js +105 -0
- package/dist-server/controllers/signup.js.map +1 -0
- package/dist-server/controllers/unlock-user.js +60 -0
- package/dist-server/controllers/unlock-user.js.map +1 -0
- package/dist-server/controllers/utils/make-invitation-token.js +12 -0
- package/dist-server/controllers/utils/make-invitation-token.js.map +1 -0
- package/dist-server/controllers/utils/make-verification-token.js +12 -0
- package/dist-server/controllers/utils/make-verification-token.js.map +1 -0
- package/dist-server/controllers/utils/password-rule.js +90 -0
- package/dist-server/controllers/utils/password-rule.js.map +1 -0
- package/dist-server/controllers/utils/save-invitation-token.js +13 -0
- package/dist-server/controllers/utils/save-invitation-token.js.map +1 -0
- package/dist-server/controllers/utils/save-verification-token.js +15 -0
- package/dist-server/controllers/utils/save-verification-token.js.map +1 -0
- package/dist-server/controllers/verification.js +78 -0
- package/dist-server/controllers/verification.js.map +1 -0
- package/dist-server/errors/auth-error.js +40 -0
- package/dist-server/errors/auth-error.js.map +1 -0
- package/dist-server/errors/index.js +19 -0
- package/dist-server/errors/index.js.map +1 -0
- package/dist-server/errors/user-domain-not-match-error.js +24 -0
- package/dist-server/errors/user-domain-not-match-error.js.map +1 -0
- package/dist-server/index.js +29 -0
- package/dist-server/index.js.map +1 -0
- package/dist-server/middlewares/authenticate-401-middleware.js +84 -0
- package/dist-server/middlewares/authenticate-401-middleware.js.map +1 -0
- package/dist-server/middlewares/domain-authenticate-middleware.js +58 -0
- package/dist-server/middlewares/domain-authenticate-middleware.js.map +1 -0
- package/dist-server/middlewares/graphql-authenticate-middleware.js +17 -0
- package/dist-server/middlewares/graphql-authenticate-middleware.js.map +1 -0
- package/dist-server/middlewares/index.js +57 -0
- package/dist-server/middlewares/index.js.map +1 -0
- package/dist-server/middlewares/jwt-authenticate-middleware.js +77 -0
- package/dist-server/middlewares/jwt-authenticate-middleware.js.map +1 -0
- package/dist-server/middlewares/signin-middleware.js +47 -0
- package/dist-server/middlewares/signin-middleware.js.map +1 -0
- package/dist-server/migrations/1548206416130-SeedUser.js +46 -0
- package/dist-server/migrations/1548206416130-SeedUser.js.map +1 -0
- package/dist-server/migrations/1566805283882-SeedPrivilege.js +26 -0
- package/dist-server/migrations/1566805283882-SeedPrivilege.js.map +1 -0
- package/dist-server/migrations/index.js +12 -0
- package/dist-server/migrations/index.js.map +1 -0
- package/dist-server/router/auth-checkin-router.js +96 -0
- package/dist-server/router/auth-checkin-router.js.map +1 -0
- package/dist-server/router/auth-private-process-router.js +91 -0
- package/dist-server/router/auth-private-process-router.js.map +1 -0
- package/dist-server/router/auth-public-process-router.js +243 -0
- package/dist-server/router/auth-public-process-router.js.map +1 -0
- package/dist-server/router/auth-signin-router.js +38 -0
- package/dist-server/router/auth-signin-router.js.map +1 -0
- package/dist-server/router/auth-signup-router.js +76 -0
- package/dist-server/router/auth-signup-router.js.map +1 -0
- package/dist-server/router/index.js +25 -0
- package/dist-server/router/index.js.map +1 -0
- package/dist-server/router/oauth2/index.js +19 -0
- package/dist-server/router/oauth2/index.js.map +1 -0
- package/dist-server/router/oauth2/oauth2-authorize-router.js +72 -0
- package/dist-server/router/oauth2/oauth2-authorize-router.js.map +1 -0
- package/dist-server/router/oauth2/oauth2-router.js +137 -0
- package/dist-server/router/oauth2/oauth2-router.js.map +1 -0
- package/dist-server/router/oauth2/oauth2-server.js +201 -0
- package/dist-server/router/oauth2/oauth2-server.js.map +1 -0
- package/dist-server/router/oauth2/passport-oauth2-client-password.js +84 -0
- package/dist-server/router/oauth2/passport-oauth2-client-password.js.map +1 -0
- package/dist-server/router/oauth2/passport-refresh-token.js +84 -0
- package/dist-server/router/oauth2/passport-refresh-token.js.map +1 -0
- package/dist-server/router/path-base-domain-router.js +15 -0
- package/dist-server/router/path-base-domain-router.js.map +1 -0
- package/dist-server/router/site-root-router.js +48 -0
- package/dist-server/router/site-root-router.js.map +1 -0
- package/dist-server/routes.js +58 -0
- package/dist-server/routes.js.map +1 -0
- package/dist-server/service/app-binding/app-binding-mutation.js +45 -0
- package/dist-server/service/app-binding/app-binding-mutation.js.map +1 -0
- package/dist-server/service/app-binding/app-binding-query.js +135 -0
- package/dist-server/service/app-binding/app-binding-query.js.map +1 -0
- package/dist-server/service/app-binding/app-binding-types.js +29 -0
- package/dist-server/service/app-binding/app-binding-types.js.map +1 -0
- package/dist-server/service/app-binding/app-binding.js +34 -0
- package/dist-server/service/app-binding/app-binding.js.map +1 -0
- package/dist-server/service/app-binding/index.js +7 -0
- package/dist-server/service/app-binding/index.js.map +1 -0
- package/dist-server/service/appliance/appliance-mutation.js +117 -0
- package/dist-server/service/appliance/appliance-mutation.js.map +1 -0
- package/dist-server/service/appliance/appliance-query.js +85 -0
- package/dist-server/service/appliance/appliance-query.js.map +1 -0
- package/dist-server/service/appliance/appliance-types.js +93 -0
- package/dist-server/service/appliance/appliance-types.js.map +1 -0
- package/dist-server/service/appliance/appliance.js +155 -0
- package/dist-server/service/appliance/appliance.js.map +1 -0
- package/dist-server/service/appliance/index.js +9 -0
- package/dist-server/service/appliance/index.js.map +1 -0
- package/dist-server/service/application/application-mutation.js +121 -0
- package/dist-server/service/application/application-mutation.js.map +1 -0
- package/dist-server/service/application/application-query.js +128 -0
- package/dist-server/service/application/application-query.js.map +1 -0
- package/dist-server/service/application/application-types.js +119 -0
- package/dist-server/service/application/application-types.js.map +1 -0
- package/dist-server/service/application/application.js +236 -0
- package/dist-server/service/application/application.js.map +1 -0
- package/dist-server/service/application/index.js +9 -0
- package/dist-server/service/application/index.js.map +1 -0
- package/dist-server/service/domain-generator/domain-generator-mutation.js +117 -0
- package/dist-server/service/domain-generator/domain-generator-mutation.js.map +1 -0
- package/dist-server/service/domain-generator/domain-generator-types.js +79 -0
- package/dist-server/service/domain-generator/domain-generator-types.js.map +1 -0
- package/dist-server/service/domain-generator/index.js +6 -0
- package/dist-server/service/domain-generator/index.js.map +1 -0
- package/dist-server/service/granted-role/granted-role-mutation.js +144 -0
- package/dist-server/service/granted-role/granted-role-mutation.js.map +1 -0
- package/dist-server/service/granted-role/granted-role-query.js +93 -0
- package/dist-server/service/granted-role/granted-role-query.js.map +1 -0
- package/dist-server/service/granted-role/granted-role.js +49 -0
- package/dist-server/service/granted-role/granted-role.js.map +1 -0
- package/dist-server/service/granted-role/index.js +9 -0
- package/dist-server/service/granted-role/index.js.map +1 -0
- package/dist-server/service/index.js +94 -0
- package/dist-server/service/index.js.map +1 -0
- package/dist-server/service/invitation/index.js +9 -0
- package/dist-server/service/invitation/index.js.map +1 -0
- package/dist-server/service/invitation/invitation-mutation.js +76 -0
- package/dist-server/service/invitation/invitation-mutation.js.map +1 -0
- package/dist-server/service/invitation/invitation-query.js +57 -0
- package/dist-server/service/invitation/invitation-query.js.map +1 -0
- package/dist-server/service/invitation/invitation-types.js +29 -0
- package/dist-server/service/invitation/invitation-types.js.map +1 -0
- package/dist-server/service/invitation/invitation.js +84 -0
- package/dist-server/service/invitation/invitation.js.map +1 -0
- package/dist-server/service/login-history/index.js +8 -0
- package/dist-server/service/login-history/index.js.map +1 -0
- package/dist-server/service/login-history/login-history-query.js +67 -0
- package/dist-server/service/login-history/login-history-query.js.map +1 -0
- package/dist-server/service/login-history/login-history.js +68 -0
- package/dist-server/service/login-history/login-history.js.map +1 -0
- package/dist-server/service/partner/index.js +9 -0
- package/dist-server/service/partner/index.js.map +1 -0
- package/dist-server/service/partner/partner-mutation.js +134 -0
- package/dist-server/service/partner/partner-mutation.js.map +1 -0
- package/dist-server/service/partner/partner-query.js +193 -0
- package/dist-server/service/partner/partner-query.js.map +1 -0
- package/dist-server/service/partner/partner-types.js +57 -0
- package/dist-server/service/partner/partner-types.js.map +1 -0
- package/dist-server/service/partner/partner.js +86 -0
- package/dist-server/service/partner/partner.js.map +1 -0
- package/dist-server/service/password-history/index.js +6 -0
- package/dist-server/service/password-history/index.js.map +1 -0
- package/dist-server/service/password-history/password-history.js +34 -0
- package/dist-server/service/password-history/password-history.js.map +1 -0
- package/dist-server/service/privilege/index.js +9 -0
- package/dist-server/service/privilege/index.js.map +1 -0
- package/dist-server/service/privilege/privilege-directive.js +85 -0
- package/dist-server/service/privilege/privilege-directive.js.map +1 -0
- package/dist-server/service/privilege/privilege-mutation.js +80 -0
- package/dist-server/service/privilege/privilege-mutation.js.map +1 -0
- package/dist-server/service/privilege/privilege-query.js +109 -0
- package/dist-server/service/privilege/privilege-query.js.map +1 -0
- package/dist-server/service/privilege/privilege-types.js +100 -0
- package/dist-server/service/privilege/privilege-types.js.map +1 -0
- package/dist-server/service/privilege/privilege.js +92 -0
- package/dist-server/service/privilege/privilege.js.map +1 -0
- package/dist-server/service/role/index.js +9 -0
- package/dist-server/service/role/index.js.map +1 -0
- package/dist-server/service/role/role-mutation.js +121 -0
- package/dist-server/service/role/role-mutation.js.map +1 -0
- package/dist-server/service/role/role-query.js +207 -0
- package/dist-server/service/role/role-query.js.map +1 -0
- package/dist-server/service/role/role-types.js +130 -0
- package/dist-server/service/role/role-types.js.map +1 -0
- package/dist-server/service/role/role.js +94 -0
- package/dist-server/service/role/role.js.map +1 -0
- package/dist-server/service/user/index.js +9 -0
- package/dist-server/service/user/index.js.map +1 -0
- package/dist-server/service/user/user-mutation.js +307 -0
- package/dist-server/service/user/user-mutation.js.map +1 -0
- package/dist-server/service/user/user-query.js +194 -0
- package/dist-server/service/user/user-query.js.map +1 -0
- package/dist-server/service/user/user-types.js +106 -0
- package/dist-server/service/user/user-types.js.map +1 -0
- package/dist-server/service/user/user.js +274 -0
- package/dist-server/service/user/user.js.map +1 -0
- package/dist-server/service/verification-token/index.js +6 -0
- package/dist-server/service/verification-token/index.js.map +1 -0
- package/dist-server/service/verification-token/verification-token.js +75 -0
- package/dist-server/service/verification-token/verification-token.js.map +1 -0
- package/dist-server/templates/account-unlock-email.js +69 -0
- package/dist-server/templates/account-unlock-email.js.map +1 -0
- package/dist-server/templates/invitation-email.js +70 -0
- package/dist-server/templates/invitation-email.js.map +1 -0
- package/dist-server/templates/reset-password-email.js +66 -0
- package/dist-server/templates/reset-password-email.js.map +1 -0
- package/dist-server/templates/verification-email.js +70 -0
- package/dist-server/templates/verification-email.js.map +1 -0
- package/dist-server/utils/accepts.js +14 -0
- package/dist-server/utils/accepts.js.map +1 -0
- package/dist-server/utils/access-token-cookie.js +45 -0
- package/dist-server/utils/access-token-cookie.js.map +1 -0
- package/dist-server/utils/check-user-belongs-domain.js +22 -0
- package/dist-server/utils/check-user-belongs-domain.js.map +1 -0
- package/dist-server/utils/get-domain-from-hostname.js +10 -0
- package/dist-server/utils/get-domain-from-hostname.js.map +1 -0
- package/dist-server/utils/get-domain-users.js +31 -0
- package/dist-server/utils/get-domain-users.js.map +1 -0
- package/dist-server/utils/get-secret.js +15 -0
- package/dist-server/utils/get-secret.js.map +1 -0
- package/dist-server/utils/get-user-domains.js +40 -0
- package/dist-server/utils/get-user-domains.js.map +1 -0
- 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
|