@inobeta/api 0.5.0 → 0.6.0
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/dist/users/users.gql.d.ts +4 -11
- package/dist/users/users.gql.d.ts.map +1 -1
- package/dist/users/users.gql.js +6 -5
- package/dist/users/users.gql.js.map +1 -1
- package/dist/users/users.plugin.d.ts.map +1 -1
- package/dist/users/users.plugin.js +14 -14
- package/dist/users/users.plugin.js.map +1 -1
- package/dist/users/users.service.d.ts +45 -42
- package/dist/users/users.service.d.ts.map +1 -1
- package/dist/users/users.service.js +171 -166
- package/dist/users/users.service.js.map +1 -1
- package/dist/users/users.types.d.ts +6 -62
- package/dist/users/users.types.d.ts.map +1 -1
- package/package.json +1 -1
|
@@ -1,14 +1,7 @@
|
|
|
1
1
|
import type { FastifyInstance } from "fastify";
|
|
2
|
-
|
|
3
|
-
|
|
4
|
-
|
|
5
|
-
getUsers(authHeader?: string): Promise<User[]>;
|
|
6
|
-
getUserByEmail(email: string, authHeader?: string): Promise<unknown>;
|
|
7
|
-
getUserById(id: string, authHeader?: string): Promise<unknown>;
|
|
8
|
-
};
|
|
9
|
-
path: string;
|
|
10
|
-
graphiql: boolean;
|
|
2
|
+
export interface RegisterUserGraphQLOptions {
|
|
3
|
+
path?: string;
|
|
4
|
+
graphiql?: boolean;
|
|
11
5
|
}
|
|
12
|
-
export declare function registerUserGraphQL(server: FastifyInstance, options
|
|
13
|
-
export {};
|
|
6
|
+
export declare function registerUserGraphQL(server: FastifyInstance, options?: RegisterUserGraphQLOptions): Promise<void>;
|
|
14
7
|
//# sourceMappingURL=users.gql.d.ts.map
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"users.gql.d.ts","sourceRoot":"","sources":["../../src/users/users.gql.ts"],"names":[],"mappings":"AACA,OAAO,KAAK,EAAE,eAAe,EAAE,MAAM,SAAS,CAAC;
|
|
1
|
+
{"version":3,"file":"users.gql.d.ts","sourceRoot":"","sources":["../../src/users/users.gql.ts"],"names":[],"mappings":"AACA,OAAO,KAAK,EAAE,eAAe,EAAE,MAAM,SAAS,CAAC;AAK/C,MAAM,WAAW,0BAA0B;IACvC,IAAI,CAAC,EAAE,MAAM,CAAC;IACd,QAAQ,CAAC,EAAE,OAAO,CAAC;CACtB;AAED,wBAAsB,mBAAmB,CACrC,MAAM,EAAE,eAAe,EACvB,OAAO,CAAC,EAAE,0BAA0B,iBA2DvC"}
|
package/dist/users/users.gql.js
CHANGED
|
@@ -5,27 +5,28 @@ var __importDefault = (this && this.__importDefault) || function (mod) {
|
|
|
5
5
|
Object.defineProperty(exports, "__esModule", { value: true });
|
|
6
6
|
exports.registerUserGraphQL = void 0;
|
|
7
7
|
const mercurius_1 = __importDefault(require("mercurius"));
|
|
8
|
+
const users_service_1 = require("./users.service");
|
|
8
9
|
const users_schema_1 = require("./users.schema");
|
|
9
10
|
async function registerUserGraphQL(server, options) {
|
|
10
11
|
const resolvers = {
|
|
11
12
|
Query: {
|
|
12
13
|
users: async (_, args, context) => {
|
|
13
|
-
let users = (await
|
|
14
|
+
let users = (await (0, users_service_1.getUsers)(server, context.reply.request.headers.authorization)).filter((user) => (args.enabled === undefined || user.enabled === args.enabled) &&
|
|
14
15
|
(args.email === undefined || user.email === args.email));
|
|
15
16
|
if (args.orderBy?.length) {
|
|
16
17
|
users = [...users].sort(buildUserComparator(args.orderBy));
|
|
17
18
|
}
|
|
18
19
|
return users;
|
|
19
20
|
},
|
|
20
|
-
userByEmail: async (_, args, context) =>
|
|
21
|
-
user: async (_, args, context) =>
|
|
21
|
+
userByEmail: async (_, args, context) => (0, users_service_1.getUserByEmail)(server, args.email, context.reply.request.headers.authorization),
|
|
22
|
+
user: async (_, args, context) => (0, users_service_1.getUserById)(server, args.params.id, context.reply.request.headers.authorization)
|
|
22
23
|
}
|
|
23
24
|
};
|
|
24
25
|
await server.register(mercurius_1.default, {
|
|
25
26
|
schema: users_schema_1.userGraphqlSchema,
|
|
26
27
|
resolvers,
|
|
27
|
-
path: options
|
|
28
|
-
graphiql: options
|
|
28
|
+
path: options?.path ?? "/graphql",
|
|
29
|
+
graphiql: options?.graphiql ?? true
|
|
29
30
|
});
|
|
30
31
|
}
|
|
31
32
|
exports.registerUserGraphQL = registerUserGraphQL;
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"users.gql.js","sourceRoot":"","sources":["../../src/users/users.gql.ts"],"names":[],"mappings":";;;;;;AAAA,0DAAkC;
|
|
1
|
+
{"version":3,"file":"users.gql.js","sourceRoot":"","sources":["../../src/users/users.gql.ts"],"names":[],"mappings":"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"}
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"users.plugin.d.ts","sourceRoot":"","sources":["../../src/users/users.plugin.ts"],"names":[],"mappings":"AAAA,OAAO,KAAK,EAAE,kBAAkB,EAAE,MAAM,SAAS,CAAC;
|
|
1
|
+
{"version":3,"file":"users.plugin.d.ts","sourceRoot":"","sources":["../../src/users/users.plugin.ts"],"names":[],"mappings":"AAAA,OAAO,KAAK,EAAE,kBAAkB,EAAE,MAAM,SAAS,CAAC;AAUlD,OAAO,KAAK,EAKR,kBAAkB,EACrB,MAAM,eAAe,CAAC;AAEvB,wBAAgB,iBAAiB,CAC7B,OAAO,EAAE,kBAAkB,GAC5B,kBAAkB,CAoGpB"}
|
|
@@ -5,11 +5,6 @@ const users_service_1 = require("./users.service");
|
|
|
5
5
|
const users_gql_1 = require("./users.gql");
|
|
6
6
|
function createUsersPlugin(options) {
|
|
7
7
|
const plugin = async (server) => {
|
|
8
|
-
const service = (0, users_service_1.createUsersService)({
|
|
9
|
-
keycloak: options.keycloak,
|
|
10
|
-
auth: options.auth,
|
|
11
|
-
authConfig: options.authConfig
|
|
12
|
-
});
|
|
13
8
|
const prefix = options.prefix ?? "/v1";
|
|
14
9
|
server.route({
|
|
15
10
|
method: "GET",
|
|
@@ -17,7 +12,7 @@ function createUsersPlugin(options) {
|
|
|
17
12
|
config: {
|
|
18
13
|
capabilityRequested: "users.db_select"
|
|
19
14
|
},
|
|
20
|
-
handler: async (request) =>
|
|
15
|
+
handler: async (request) => (0, users_service_1.getUsers)(server, request.headers.authorization)
|
|
21
16
|
});
|
|
22
17
|
server.route({
|
|
23
18
|
method: "GET",
|
|
@@ -25,7 +20,7 @@ function createUsersPlugin(options) {
|
|
|
25
20
|
config: {
|
|
26
21
|
capabilityRequested: "users.db_select"
|
|
27
22
|
},
|
|
28
|
-
handler: async (request) =>
|
|
23
|
+
handler: async (request) => (0, users_service_1.getUserById)(server, request.params.id, request.headers.authorization)
|
|
29
24
|
});
|
|
30
25
|
server.route({
|
|
31
26
|
method: "PUT",
|
|
@@ -33,7 +28,7 @@ function createUsersPlugin(options) {
|
|
|
33
28
|
config: {
|
|
34
29
|
capabilityRequested: "users.db_update"
|
|
35
30
|
},
|
|
36
|
-
handler:
|
|
31
|
+
handler: (0, users_service_1.updateUser)(server)
|
|
37
32
|
});
|
|
38
33
|
server.route({
|
|
39
34
|
method: "DELETE",
|
|
@@ -41,7 +36,7 @@ function createUsersPlugin(options) {
|
|
|
41
36
|
config: {
|
|
42
37
|
capabilityRequested: "users.db_update"
|
|
43
38
|
},
|
|
44
|
-
handler:
|
|
39
|
+
handler: (0, users_service_1.deleteUser)(server)
|
|
45
40
|
});
|
|
46
41
|
server.route({
|
|
47
42
|
method: "POST",
|
|
@@ -50,7 +45,10 @@ function createUsersPlugin(options) {
|
|
|
50
45
|
capabilityRequested: "me.password-change"
|
|
51
46
|
},
|
|
52
47
|
handler: async (request, reply) => {
|
|
53
|
-
const result = await
|
|
48
|
+
const result = await (0, users_service_1.changeOwnPassword)(server, options.authConfig)({
|
|
49
|
+
headers: request.headers,
|
|
50
|
+
body: request.body
|
|
51
|
+
});
|
|
54
52
|
if (!result.ok) {
|
|
55
53
|
return options.httpResponse(reply, result.statusCode, result.message);
|
|
56
54
|
}
|
|
@@ -67,7 +65,10 @@ function createUsersPlugin(options) {
|
|
|
67
65
|
capabilityRequested: "users.password-change"
|
|
68
66
|
},
|
|
69
67
|
handler: async (request, reply) => {
|
|
70
|
-
const result = await
|
|
68
|
+
const result = await (0, users_service_1.changeUserPassword)(server)({
|
|
69
|
+
params: request.params,
|
|
70
|
+
body: request.body
|
|
71
|
+
});
|
|
71
72
|
if (!result.ok) {
|
|
72
73
|
return options.httpResponse(reply, result.statusCode, result.message);
|
|
73
74
|
}
|
|
@@ -79,9 +80,8 @@ function createUsersPlugin(options) {
|
|
|
79
80
|
});
|
|
80
81
|
if (options.graphql?.enabled) {
|
|
81
82
|
await (0, users_gql_1.registerUserGraphQL)(server, {
|
|
82
|
-
|
|
83
|
-
|
|
84
|
-
graphiql: options.graphql.graphiql ?? true
|
|
83
|
+
path: options.graphql.path,
|
|
84
|
+
graphiql: options.graphql.graphiql
|
|
85
85
|
});
|
|
86
86
|
}
|
|
87
87
|
};
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"users.plugin.js","sourceRoot":"","sources":["../../src/users/users.plugin.ts"],"names":[],"mappings":";;;
|
|
1
|
+
{"version":3,"file":"users.plugin.js","sourceRoot":"","sources":["../../src/users/users.plugin.ts"],"names":[],"mappings":"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"}
|
|
@@ -1,44 +1,47 @@
|
|
|
1
|
-
import type {
|
|
2
|
-
|
|
3
|
-
|
|
4
|
-
|
|
5
|
-
|
|
6
|
-
|
|
7
|
-
|
|
8
|
-
|
|
1
|
+
import type { FastifyInstance } from "fastify";
|
|
2
|
+
import type { ChangeOwnPasswordRoute, ChangeUserPasswordRoute, UpdateUserRoute, User, UserDetailed, UsersAuthConfig } from "./users.types";
|
|
3
|
+
export declare const getUsers: (server: FastifyInstance, authHeader?: string) => Promise<User[]>;
|
|
4
|
+
export declare const getUserById: (server: FastifyInstance, id: string, authHeader?: string) => Promise<UserDetailed | null>;
|
|
5
|
+
export declare const getUserByEmail: (server: FastifyInstance, email: string, authHeader?: string) => Promise<UserDetailed | null>;
|
|
6
|
+
export declare const updateUser: (server: FastifyInstance) => (request: {
|
|
7
|
+
params: UpdateUserRoute["Params"];
|
|
8
|
+
body: UpdateUserRoute["Body"];
|
|
9
|
+
}) => Promise<{
|
|
10
|
+
errors: boolean;
|
|
11
|
+
message: string;
|
|
12
|
+
}>;
|
|
13
|
+
export declare const deleteUser: (server: FastifyInstance) => (request: {
|
|
14
|
+
params: {
|
|
15
|
+
id: string;
|
|
9
16
|
};
|
|
10
|
-
}
|
|
11
|
-
|
|
12
|
-
|
|
13
|
-
|
|
14
|
-
|
|
15
|
-
|
|
16
|
-
|
|
17
|
-
|
|
18
|
-
|
|
19
|
-
|
|
20
|
-
|
|
21
|
-
|
|
22
|
-
|
|
23
|
-
|
|
24
|
-
|
|
25
|
-
|
|
26
|
-
|
|
27
|
-
|
|
28
|
-
|
|
29
|
-
|
|
30
|
-
|
|
31
|
-
|
|
32
|
-
|
|
33
|
-
|
|
34
|
-
|
|
35
|
-
|
|
36
|
-
|
|
37
|
-
|
|
38
|
-
|
|
39
|
-
|
|
40
|
-
statusCode: number;
|
|
41
|
-
message: string;
|
|
42
|
-
}>;
|
|
43
|
-
};
|
|
17
|
+
}) => Promise<{
|
|
18
|
+
errors: boolean;
|
|
19
|
+
message: string;
|
|
20
|
+
}>;
|
|
21
|
+
export declare const changeOwnPassword: (server: FastifyInstance, authConfig: UsersAuthConfig) => (request: {
|
|
22
|
+
headers: {
|
|
23
|
+
authorization?: string;
|
|
24
|
+
};
|
|
25
|
+
body: ChangeOwnPasswordRoute["Body"];
|
|
26
|
+
}) => Promise<{
|
|
27
|
+
ok: false;
|
|
28
|
+
statusCode: number;
|
|
29
|
+
message: string;
|
|
30
|
+
} | {
|
|
31
|
+
ok: true;
|
|
32
|
+
statusCode?: undefined;
|
|
33
|
+
message?: undefined;
|
|
34
|
+
}>;
|
|
35
|
+
export declare const changeUserPassword: (server: FastifyInstance) => (request: {
|
|
36
|
+
params: ChangeUserPasswordRoute["Params"];
|
|
37
|
+
body: ChangeUserPasswordRoute["Body"];
|
|
38
|
+
}) => Promise<{
|
|
39
|
+
ok: true;
|
|
40
|
+
statusCode?: undefined;
|
|
41
|
+
message?: undefined;
|
|
42
|
+
} | {
|
|
43
|
+
ok: false;
|
|
44
|
+
statusCode: number;
|
|
45
|
+
message: string;
|
|
46
|
+
}>;
|
|
44
47
|
//# sourceMappingURL=users.service.d.ts.map
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"users.service.d.ts","sourceRoot":"","sources":["../../src/users/users.service.ts"],"names":[],"mappings":"AAAA,OAAO,KAAK,
|
|
1
|
+
{"version":3,"file":"users.service.d.ts","sourceRoot":"","sources":["../../src/users/users.service.ts"],"names":[],"mappings":"AAAA,OAAO,KAAK,EAAE,eAAe,EAAE,MAAM,SAAS,CAAC;AAG/C,OAAO,KAAK,EACR,sBAAsB,EACtB,uBAAuB,EACvB,eAAe,EACf,IAAI,EACJ,YAAY,EACZ,eAAe,EAClB,MAAM,eAAe,CAAC;AAEvB,eAAO,MAAM,QAAQ,WACT,eAAe,eACV,MAAM,KACpB,QAAQ,IAAI,EAAE,CAQhB,CAAC;AAEF,eAAO,MAAM,WAAW,WACZ,eAAe,MACnB,MAAM,eACG,MAAM,KACpB,QAAQ,YAAY,GAAG,IAAI,CAqB7B,CAAC;AAEF,eAAO,MAAM,cAAc,WACf,eAAe,SAChB,MAAM,eACA,MAAM,KACpB,QAAQ,YAAY,GAAG,IAAI,CAsB7B,CAAC;AAEF,eAAO,MAAM,UAAU,WACV,eAAe,eAEP;IACL,MAAM,EAAE,eAAe,CAAC,QAAQ,CAAC,CAAC;IAClC,IAAI,EAAE,eAAe,CAAC,MAAM,CAAC,CAAC;CACjC;;;EA2DJ,CAAC;AAEV,eAAO,MAAM,UAAU,WACV,eAAe,eACJ;IAAE,MAAM,EAAE;QAAE,EAAE,EAAE,MAAM,CAAA;KAAE,CAAA;CAAE;;;EAgBzC,CAAC;AAEV,eAAO,MAAM,iBAAiB,WACjB,eAAe,cAAc,eAAe,eACjC;IACZ,OAAO,EAAE;QAAE,aAAa,CAAC,EAAE,MAAM,CAAA;KAAE,CAAC;IACpC,IAAI,EAAE,sBAAsB,CAAC,MAAM,CAAC,CAAC;CACxC;;;;;;;;EAiDA,CAAC;AAEV,eAAO,MAAM,kBAAkB,WAClB,eAAe,eACJ;IACZ,MAAM,EAAE,uBAAuB,CAAC,QAAQ,CAAC,CAAC;IAC1C,IAAI,EAAE,uBAAuB,CAAC,MAAM,CAAC,CAAC;CACzC;;;;;;;;EA2BA,CAAC"}
|
|
@@ -1,187 +1,192 @@
|
|
|
1
1
|
"use strict";
|
|
2
2
|
Object.defineProperty(exports, "__esModule", { value: true });
|
|
3
|
-
exports.
|
|
3
|
+
exports.changeUserPassword = exports.changeOwnPassword = exports.deleteUser = exports.updateUser = exports.getUserByEmail = exports.getUserById = exports.getUsers = void 0;
|
|
4
4
|
const auth_service_1 = require("../auth/auth.service");
|
|
5
|
-
|
|
6
|
-
const
|
|
7
|
-
|
|
8
|
-
|
|
9
|
-
return [];
|
|
10
|
-
}
|
|
11
|
-
return (await keycloak.users.find());
|
|
5
|
+
const getUsers = async (server, authHeader) => {
|
|
6
|
+
const allowed = await server.auth.hasCapability("users.db_select", authHeader);
|
|
7
|
+
if (!allowed) {
|
|
8
|
+
return [];
|
|
12
9
|
}
|
|
13
|
-
|
|
14
|
-
|
|
15
|
-
|
|
16
|
-
|
|
17
|
-
|
|
18
|
-
|
|
19
|
-
|
|
20
|
-
}
|
|
21
|
-
const rm = await keycloak.users.listRealmRoleMappings({
|
|
22
|
-
id,
|
|
23
|
-
realm: keycloak.realmName
|
|
24
|
-
});
|
|
25
|
-
user.realmRoles = rm.map((r) => r.name).filter(Boolean);
|
|
26
|
-
return user;
|
|
10
|
+
return (await server.kc.users.find());
|
|
11
|
+
};
|
|
12
|
+
exports.getUsers = getUsers;
|
|
13
|
+
const getUserById = async (server, id, authHeader) => {
|
|
14
|
+
const allowed = await server.auth.hasCapability("users.db_select", authHeader);
|
|
15
|
+
if (!allowed) {
|
|
16
|
+
return null;
|
|
27
17
|
}
|
|
28
|
-
|
|
29
|
-
|
|
30
|
-
|
|
31
|
-
}
|
|
32
|
-
const users = (await keycloak.users.find());
|
|
33
|
-
const user = users.find((u) => u.email?.toLowerCase() === email.toLowerCase());
|
|
34
|
-
if (!user?.id) {
|
|
35
|
-
return null;
|
|
36
|
-
}
|
|
37
|
-
const rm = await keycloak.users.listRealmRoleMappings({
|
|
38
|
-
id: user.id,
|
|
39
|
-
realm: keycloak.realmName
|
|
40
|
-
});
|
|
41
|
-
user.realmRoles = rm.map((r) => r.name).filter(Boolean);
|
|
42
|
-
return user;
|
|
18
|
+
const user = (await server.kc.users.findOne({ id }));
|
|
19
|
+
if (!user?.id) {
|
|
20
|
+
return null;
|
|
43
21
|
}
|
|
44
|
-
|
|
45
|
-
|
|
46
|
-
|
|
47
|
-
|
|
48
|
-
|
|
49
|
-
|
|
50
|
-
|
|
51
|
-
|
|
52
|
-
|
|
53
|
-
|
|
54
|
-
|
|
55
|
-
|
|
56
|
-
{
|
|
57
|
-
type: "password",
|
|
58
|
-
value: body.password,
|
|
59
|
-
temporary: false
|
|
60
|
-
}
|
|
61
|
-
];
|
|
62
|
-
const created = await keycloak.users.create({
|
|
63
|
-
...userData,
|
|
64
|
-
realm: keycloak.realmName
|
|
65
|
-
});
|
|
66
|
-
const allRoles = await keycloak.roles.find();
|
|
67
|
-
const hasuraRole = allRoles.find((role) => role.name === "authenticated-user");
|
|
68
|
-
const userRole = allRoles.find((role) => role.name === "user");
|
|
69
|
-
if (userRole && hasuraRole) {
|
|
70
|
-
await keycloak.users.addRealmRoleMappings({
|
|
71
|
-
id: created.id,
|
|
72
|
-
roles: [
|
|
73
|
-
{ id: hasuraRole.id, name: hasuraRole.name },
|
|
74
|
-
{ id: userRole.id, name: userRole.name }
|
|
75
|
-
],
|
|
76
|
-
realm: keycloak.realmName
|
|
77
|
-
});
|
|
78
|
-
}
|
|
79
|
-
}
|
|
80
|
-
else {
|
|
81
|
-
await keycloak.users.update({ id }, userData);
|
|
82
|
-
}
|
|
83
|
-
return {
|
|
84
|
-
errors: false,
|
|
85
|
-
message: "User updated successfully"
|
|
86
|
-
};
|
|
87
|
-
}
|
|
88
|
-
catch (e) {
|
|
89
|
-
return {
|
|
90
|
-
errors: true,
|
|
91
|
-
message: e instanceof Error ? e.message : "Internal server error"
|
|
92
|
-
};
|
|
93
|
-
}
|
|
22
|
+
const roleMappings = await server.kc.users.listRealmRoleMappings({
|
|
23
|
+
id,
|
|
24
|
+
realm: server.kc.realmName
|
|
25
|
+
});
|
|
26
|
+
user.realmRoles = roleMappings.map((r) => r.name).filter(Boolean);
|
|
27
|
+
return user;
|
|
28
|
+
};
|
|
29
|
+
exports.getUserById = getUserById;
|
|
30
|
+
const getUserByEmail = async (server, email, authHeader) => {
|
|
31
|
+
const allowed = await server.auth.hasCapability("users.db_select", authHeader);
|
|
32
|
+
if (!allowed) {
|
|
33
|
+
return null;
|
|
94
34
|
}
|
|
95
|
-
|
|
96
|
-
|
|
97
|
-
|
|
98
|
-
|
|
99
|
-
errors: false,
|
|
100
|
-
message: "User deleted successfully"
|
|
101
|
-
};
|
|
102
|
-
}
|
|
103
|
-
catch (e) {
|
|
104
|
-
return {
|
|
105
|
-
errors: true,
|
|
106
|
-
message: e instanceof Error ? e.message : "Internal server error"
|
|
107
|
-
};
|
|
108
|
-
}
|
|
35
|
+
const users = (await server.kc.users.find());
|
|
36
|
+
const user = users.find((u) => u.email?.toLowerCase() === email.toLowerCase());
|
|
37
|
+
if (!user?.id) {
|
|
38
|
+
return null;
|
|
109
39
|
}
|
|
110
|
-
|
|
111
|
-
|
|
112
|
-
|
|
113
|
-
|
|
114
|
-
|
|
115
|
-
|
|
116
|
-
|
|
117
|
-
|
|
118
|
-
|
|
119
|
-
|
|
120
|
-
|
|
121
|
-
|
|
122
|
-
|
|
123
|
-
|
|
124
|
-
|
|
125
|
-
|
|
126
|
-
|
|
127
|
-
|
|
128
|
-
|
|
129
|
-
|
|
130
|
-
|
|
131
|
-
|
|
132
|
-
|
|
133
|
-
message: "Current password is incorrect"
|
|
134
|
-
};
|
|
135
|
-
}
|
|
136
|
-
await keycloak.users.resetPassword({
|
|
137
|
-
id: userId,
|
|
138
|
-
realm: keycloak.realmName,
|
|
139
|
-
credential: {
|
|
40
|
+
const roleMappings = await server.kc.users.listRealmRoleMappings({
|
|
41
|
+
id: user.id,
|
|
42
|
+
realm: server.kc.realmName
|
|
43
|
+
});
|
|
44
|
+
user.realmRoles = roleMappings.map((r) => r.name).filter(Boolean);
|
|
45
|
+
return user;
|
|
46
|
+
};
|
|
47
|
+
exports.getUserByEmail = getUserByEmail;
|
|
48
|
+
const updateUser = (server) => async (request) => {
|
|
49
|
+
try {
|
|
50
|
+
const { id } = request.params;
|
|
51
|
+
const body = request.body;
|
|
52
|
+
const userData = {
|
|
53
|
+
firstName: body.firstName,
|
|
54
|
+
lastName: body.lastName,
|
|
55
|
+
email: body.email,
|
|
56
|
+
username: body.email,
|
|
57
|
+
enabled: body.enabled,
|
|
58
|
+
emailVerified: true
|
|
59
|
+
};
|
|
60
|
+
if (id === "new") {
|
|
61
|
+
userData.credentials = [
|
|
62
|
+
{
|
|
140
63
|
type: "password",
|
|
141
|
-
value:
|
|
64
|
+
value: body.password,
|
|
142
65
|
temporary: false
|
|
143
66
|
}
|
|
67
|
+
];
|
|
68
|
+
const created = await server.kc.users.create({
|
|
69
|
+
...userData,
|
|
70
|
+
realm: server.kc.realmName
|
|
144
71
|
});
|
|
145
|
-
|
|
72
|
+
const allRoles = await server.kc.roles.find();
|
|
73
|
+
const hasuraRole = allRoles.find((role) => role.name === "authenticated-user");
|
|
74
|
+
const userRole = allRoles.find((role) => role.name === "user");
|
|
75
|
+
if (userRole && hasuraRole) {
|
|
76
|
+
await server.kc.users.addRealmRoleMappings({
|
|
77
|
+
id: created.id,
|
|
78
|
+
roles: [
|
|
79
|
+
{ id: hasuraRole.id, name: hasuraRole.name },
|
|
80
|
+
{ id: userRole.id, name: userRole.name }
|
|
81
|
+
],
|
|
82
|
+
realm: server.kc.realmName
|
|
83
|
+
});
|
|
84
|
+
}
|
|
146
85
|
}
|
|
147
|
-
|
|
148
|
-
|
|
149
|
-
ok: false,
|
|
150
|
-
statusCode: 500,
|
|
151
|
-
message: "Internal server error"
|
|
152
|
-
};
|
|
86
|
+
else {
|
|
87
|
+
await server.kc.users.update({ id }, userData);
|
|
153
88
|
}
|
|
89
|
+
return {
|
|
90
|
+
errors: false,
|
|
91
|
+
message: "User updated successfully"
|
|
92
|
+
};
|
|
154
93
|
}
|
|
155
|
-
|
|
156
|
-
|
|
157
|
-
|
|
158
|
-
|
|
159
|
-
|
|
160
|
-
|
|
161
|
-
|
|
162
|
-
|
|
163
|
-
|
|
164
|
-
|
|
165
|
-
|
|
166
|
-
|
|
167
|
-
|
|
168
|
-
|
|
94
|
+
catch (e) {
|
|
95
|
+
return {
|
|
96
|
+
errors: true,
|
|
97
|
+
message: e instanceof Error ? e.message : "Internal server error"
|
|
98
|
+
};
|
|
99
|
+
}
|
|
100
|
+
};
|
|
101
|
+
exports.updateUser = updateUser;
|
|
102
|
+
const deleteUser = (server) => async (request) => {
|
|
103
|
+
try {
|
|
104
|
+
const { id } = request.params;
|
|
105
|
+
await server.kc.users.del({ id });
|
|
106
|
+
return {
|
|
107
|
+
errors: false,
|
|
108
|
+
message: "User deleted successfully"
|
|
109
|
+
};
|
|
110
|
+
}
|
|
111
|
+
catch (e) {
|
|
112
|
+
return {
|
|
113
|
+
errors: true,
|
|
114
|
+
message: e instanceof Error ? e.message : "Internal server error"
|
|
115
|
+
};
|
|
116
|
+
}
|
|
117
|
+
};
|
|
118
|
+
exports.deleteUser = deleteUser;
|
|
119
|
+
const changeOwnPassword = (server, authConfig) => async (request) => {
|
|
120
|
+
try {
|
|
121
|
+
const decoded = server.auth.getDecodedToken(request.headers.authorization);
|
|
122
|
+
const userId = decoded?.sub ?? "";
|
|
123
|
+
const { currentPassword, newPassword } = request.body;
|
|
124
|
+
const tokens = await (0, auth_service_1.kcTokenHandle)({
|
|
125
|
+
authUrl: authConfig.authUrl,
|
|
126
|
+
formData: new URLSearchParams({
|
|
127
|
+
client_id: authConfig.clientId,
|
|
128
|
+
client_secret: authConfig.clientSecret,
|
|
129
|
+
grant_type: "password",
|
|
130
|
+
username: decoded?.preferred_username ?? "",
|
|
131
|
+
password: currentPassword
|
|
132
|
+
}),
|
|
133
|
+
withSessionStorage: false
|
|
134
|
+
});
|
|
135
|
+
if (!tokens) {
|
|
169
136
|
return {
|
|
170
137
|
ok: false,
|
|
171
|
-
statusCode:
|
|
172
|
-
message: "
|
|
138
|
+
statusCode: 400,
|
|
139
|
+
message: "Current password is incorrect"
|
|
173
140
|
};
|
|
174
141
|
}
|
|
142
|
+
await server.kc.users.resetPassword({
|
|
143
|
+
id: userId,
|
|
144
|
+
realm: server.kc.realmName,
|
|
145
|
+
credential: {
|
|
146
|
+
type: "password",
|
|
147
|
+
value: newPassword,
|
|
148
|
+
temporary: false
|
|
149
|
+
}
|
|
150
|
+
});
|
|
151
|
+
return {
|
|
152
|
+
ok: true
|
|
153
|
+
};
|
|
154
|
+
}
|
|
155
|
+
catch (e) {
|
|
156
|
+
console.error("Password change error", e);
|
|
157
|
+
return {
|
|
158
|
+
ok: false,
|
|
159
|
+
statusCode: 500,
|
|
160
|
+
message: "Internal server error"
|
|
161
|
+
};
|
|
162
|
+
}
|
|
163
|
+
};
|
|
164
|
+
exports.changeOwnPassword = changeOwnPassword;
|
|
165
|
+
const changeUserPassword = (server) => async (request) => {
|
|
166
|
+
try {
|
|
167
|
+
const { id: userId } = request.params;
|
|
168
|
+
const { password } = request.body;
|
|
169
|
+
await server.kc.users.resetPassword({
|
|
170
|
+
id: userId,
|
|
171
|
+
realm: server.kc.realmName,
|
|
172
|
+
credential: {
|
|
173
|
+
type: "password",
|
|
174
|
+
value: password,
|
|
175
|
+
temporary: false
|
|
176
|
+
}
|
|
177
|
+
});
|
|
178
|
+
return {
|
|
179
|
+
ok: true
|
|
180
|
+
};
|
|
181
|
+
}
|
|
182
|
+
catch (e) {
|
|
183
|
+
console.error("Password change error", e);
|
|
184
|
+
return {
|
|
185
|
+
ok: false,
|
|
186
|
+
statusCode: 500,
|
|
187
|
+
message: "Internal server error"
|
|
188
|
+
};
|
|
175
189
|
}
|
|
176
|
-
|
|
177
|
-
|
|
178
|
-
getUserById,
|
|
179
|
-
getUserByEmail,
|
|
180
|
-
saveUser,
|
|
181
|
-
deleteUser,
|
|
182
|
-
changeOwnPassword,
|
|
183
|
-
changeUserPassword
|
|
184
|
-
};
|
|
185
|
-
}
|
|
186
|
-
exports.createUsersService = createUsersService;
|
|
190
|
+
};
|
|
191
|
+
exports.changeUserPassword = changeUserPassword;
|
|
187
192
|
//# sourceMappingURL=users.service.js.map
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"users.service.js","sourceRoot":"","sources":["../../src/users/users.service.ts"],"names":[],"mappings":";;;
|
|
1
|
+
{"version":3,"file":"users.service.js","sourceRoot":"","sources":["../../src/users/users.service.ts"],"names":[],"mappings":"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"}
|
|
@@ -42,70 +42,14 @@ export type UserOrderByInput = {
|
|
|
42
42
|
key: UserOrderField;
|
|
43
43
|
direction?: SortDirection;
|
|
44
44
|
};
|
|
45
|
-
export interface
|
|
46
|
-
|
|
47
|
-
|
|
48
|
-
|
|
45
|
+
export interface UsersAuthConfig {
|
|
46
|
+
authUrl: string;
|
|
47
|
+
clientId: string;
|
|
48
|
+
clientSecret: string;
|
|
49
49
|
}
|
|
50
|
-
export interface AuthAdapter {
|
|
51
|
-
hasCapability(capability: string, authHeader?: string): boolean;
|
|
52
|
-
getDecodedToken(authHeader?: string): DecodedToken | null;
|
|
53
|
-
}
|
|
54
|
-
export interface KeycloakRole {
|
|
55
|
-
id?: string;
|
|
56
|
-
name?: string;
|
|
57
|
-
}
|
|
58
|
-
export interface KeycloakUserApi {
|
|
59
|
-
find(): Promise<unknown[]>;
|
|
60
|
-
findOne(params: {
|
|
61
|
-
id: string;
|
|
62
|
-
}): Promise<unknown | null>;
|
|
63
|
-
create(data: Record<string, unknown>): Promise<{
|
|
64
|
-
id: string;
|
|
65
|
-
}>;
|
|
66
|
-
update(params: {
|
|
67
|
-
id: string;
|
|
68
|
-
}, data: Record<string, unknown>): Promise<void>;
|
|
69
|
-
del(params: {
|
|
70
|
-
id: string;
|
|
71
|
-
}): Promise<void>;
|
|
72
|
-
resetPassword(params: {
|
|
73
|
-
id: string;
|
|
74
|
-
realm: string;
|
|
75
|
-
credential: {
|
|
76
|
-
type: string;
|
|
77
|
-
value: string;
|
|
78
|
-
temporary: boolean;
|
|
79
|
-
};
|
|
80
|
-
}): Promise<void>;
|
|
81
|
-
listRealmRoleMappings(params: {
|
|
82
|
-
id: string;
|
|
83
|
-
realm: string;
|
|
84
|
-
}): Promise<KeycloakRole[]>;
|
|
85
|
-
addRealmRoleMappings(params: {
|
|
86
|
-
id: string;
|
|
87
|
-
realm: string;
|
|
88
|
-
roles: KeycloakRole[];
|
|
89
|
-
}): Promise<void>;
|
|
90
|
-
}
|
|
91
|
-
export interface KeycloakRolesApi {
|
|
92
|
-
find(): Promise<KeycloakRole[]>;
|
|
93
|
-
}
|
|
94
|
-
export interface KeycloakAdapter {
|
|
95
|
-
realmName: string;
|
|
96
|
-
users: KeycloakUserApi;
|
|
97
|
-
roles: KeycloakRolesApi;
|
|
98
|
-
}
|
|
99
|
-
export type HttpResponseHandler = (reply: FastifyReply, statusCode: number, message: string) => unknown;
|
|
100
50
|
export interface UsersPluginOptions {
|
|
101
|
-
|
|
102
|
-
|
|
103
|
-
httpResponse: HttpResponseHandler;
|
|
104
|
-
authConfig: {
|
|
105
|
-
authUrl: string;
|
|
106
|
-
clientId: string;
|
|
107
|
-
clientSecret: string;
|
|
108
|
-
};
|
|
51
|
+
httpResponse: (reply: FastifyReply, statusCode: number, message: string) => unknown;
|
|
52
|
+
authConfig: UsersAuthConfig;
|
|
109
53
|
graphql?: {
|
|
110
54
|
enabled?: boolean;
|
|
111
55
|
path?: string;
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"users.types.d.ts","sourceRoot":"","sources":["../../src/users/users.types.ts"],"names":[],"mappings":"AAAA,OAAO,KAAK,EAAE,YAAY,EAAE,MAAM,SAAS,CAAC;AAE5C,MAAM,MAAM,gBAAgB,GAAG;IAC3B,MAAM,EAAE;QAAE,EAAE,EAAE,MAAM,CAAA;KAAE,CAAC;CAC1B,CAAC;AAEF,MAAM,MAAM,uBAAuB,GAAG,gBAAgB,GAAG;IACrD,IAAI,EAAE;QACF,QAAQ,EAAE,MAAM,CAAC;KACpB,CAAC;CACL,CAAC;AAEF,MAAM,MAAM,sBAAsB,GAAG;IACjC,IAAI,EAAE;QACF,eAAe,EAAE,MAAM,CAAC;QACxB,WAAW,EAAE,MAAM,CAAC;KACvB,CAAC;CACL,CAAC;AAEF,MAAM,MAAM,eAAe,GAAG,gBAAgB,GAAG;IAC7C,IAAI,EAAE;QACF,SAAS,CAAC,EAAE,MAAM,CAAC;QACnB,QAAQ,CAAC,EAAE,MAAM,CAAC;QAClB,KAAK,CAAC,EAAE,MAAM,CAAC;QACf,OAAO,CAAC,EAAE,OAAO,CAAC;QAClB,QAAQ,CAAC,EAAE,MAAM,CAAC;KACrB,CAAC;CACL,CAAC;AAEF,MAAM,MAAM,IAAI,GAAG;IACf,EAAE,EAAE,MAAM,CAAC;IACX,QAAQ,EAAE,MAAM,CAAC;IACjB,KAAK,EAAE,MAAM,CAAC;IACd,OAAO,EAAE,OAAO,CAAC;IACjB,SAAS,EAAE,MAAM,CAAC;IAClB,QAAQ,EAAE,MAAM,CAAC;IACjB,UAAU,EAAE,MAAM,EAAE,CAAC;CACxB,CAAC;AAEF,MAAM,MAAM,YAAY,GAAG,IAAI,GAAG;IAC9B,UAAU,EAAE,MAAM,EAAE,CAAC;CACxB,CAAC;AAEF,MAAM,MAAM,cAAc,GAAG,OAAO,GAAG,WAAW,GAAG,UAAU,CAAC;AAChE,MAAM,MAAM,aAAa,GAAG,KAAK,GAAG,MAAM,CAAC;AAE3C,MAAM,MAAM,gBAAgB,GAAG;IAC3B,GAAG,EAAE,cAAc,CAAC;IACpB,SAAS,CAAC,EAAE,aAAa,CAAC;CAC7B,CAAC;AAEF,MAAM,WAAW,
|
|
1
|
+
{"version":3,"file":"users.types.d.ts","sourceRoot":"","sources":["../../src/users/users.types.ts"],"names":[],"mappings":"AAAA,OAAO,KAAK,EAAE,YAAY,EAAE,MAAM,SAAS,CAAC;AAE5C,MAAM,MAAM,gBAAgB,GAAG;IAC3B,MAAM,EAAE;QAAE,EAAE,EAAE,MAAM,CAAA;KAAE,CAAC;CAC1B,CAAC;AAEF,MAAM,MAAM,uBAAuB,GAAG,gBAAgB,GAAG;IACrD,IAAI,EAAE;QACF,QAAQ,EAAE,MAAM,CAAC;KACpB,CAAC;CACL,CAAC;AAEF,MAAM,MAAM,sBAAsB,GAAG;IACjC,IAAI,EAAE;QACF,eAAe,EAAE,MAAM,CAAC;QACxB,WAAW,EAAE,MAAM,CAAC;KACvB,CAAC;CACL,CAAC;AAEF,MAAM,MAAM,eAAe,GAAG,gBAAgB,GAAG;IAC7C,IAAI,EAAE;QACF,SAAS,CAAC,EAAE,MAAM,CAAC;QACnB,QAAQ,CAAC,EAAE,MAAM,CAAC;QAClB,KAAK,CAAC,EAAE,MAAM,CAAC;QACf,OAAO,CAAC,EAAE,OAAO,CAAC;QAClB,QAAQ,CAAC,EAAE,MAAM,CAAC;KACrB,CAAC;CACL,CAAC;AAEF,MAAM,MAAM,IAAI,GAAG;IACf,EAAE,EAAE,MAAM,CAAC;IACX,QAAQ,EAAE,MAAM,CAAC;IACjB,KAAK,EAAE,MAAM,CAAC;IACd,OAAO,EAAE,OAAO,CAAC;IACjB,SAAS,EAAE,MAAM,CAAC;IAClB,QAAQ,EAAE,MAAM,CAAC;IACjB,UAAU,EAAE,MAAM,EAAE,CAAC;CACxB,CAAC;AAEF,MAAM,MAAM,YAAY,GAAG,IAAI,GAAG;IAC9B,UAAU,EAAE,MAAM,EAAE,CAAC;CACxB,CAAC;AAEF,MAAM,MAAM,cAAc,GAAG,OAAO,GAAG,WAAW,GAAG,UAAU,CAAC;AAChE,MAAM,MAAM,aAAa,GAAG,KAAK,GAAG,MAAM,CAAC;AAE3C,MAAM,MAAM,gBAAgB,GAAG;IAC3B,GAAG,EAAE,cAAc,CAAC;IACpB,SAAS,CAAC,EAAE,aAAa,CAAC;CAC7B,CAAC;AAEF,MAAM,WAAW,eAAe;IAC5B,OAAO,EAAE,MAAM,CAAC;IAChB,QAAQ,EAAE,MAAM,CAAC;IACjB,YAAY,EAAE,MAAM,CAAC;CACxB;AAED,MAAM,WAAW,kBAAkB;IAC/B,YAAY,EAAE,CACV,KAAK,EAAE,YAAY,EACnB,UAAU,EAAE,MAAM,EAClB,OAAO,EAAE,MAAM,KACd,OAAO,CAAC;IACb,UAAU,EAAE,eAAe,CAAC;IAC5B,OAAO,CAAC,EAAE;QACN,OAAO,CAAC,EAAE,OAAO,CAAC;QAClB,IAAI,CAAC,EAAE,MAAM,CAAC;QACd,QAAQ,CAAC,EAAE,OAAO,CAAC;KACtB,CAAC;IACF,MAAM,CAAC,EAAE,MAAM,CAAC;CACnB"}
|