ff-admin-server/src/command/management/user/userCommandHandler.ts

172 lines
5.1 KiB
TypeScript
Raw Normal View History

2024-09-01 14:55:05 +02:00
import { EntityManager } from "typeorm";
2025-01-05 14:14:00 +01:00
import { dataSource } from "../../../data-source";
2025-02-15 10:59:54 +01:00
import { user } from "../../../entity/management/user";
2025-01-05 14:14:00 +01:00
import InternalException from "../../../exceptions/internalException";
2024-11-21 15:58:47 +01:00
import {
CreateUserCommand,
DeleteUserCommand,
TransferUserOwnerCommand,
UpdateUserCommand,
UpdateUserRolesCommand,
2024-11-23 12:11:19 +01:00
UpdateUserSecretCommand,
2024-11-21 15:58:47 +01:00
} from "./userCommand";
2025-02-15 10:59:54 +01:00
import UserService from "../../../service/management/userService";
2025-01-29 09:42:22 +01:00
import DatabaseActionException from "../../../exceptions/databaseActionException";
export default abstract class UserCommandHandler {
/**
* @description create user
2025-01-05 14:29:31 +01:00
* @param {CreateUserCommand} createUser
2025-01-29 08:53:49 +01:00
* @returns {Promise<string>}
*/
2025-01-29 08:53:49 +01:00
static async create(createUser: CreateUserCommand): Promise<string> {
return await dataSource
.createQueryBuilder()
.insert()
.into(user)
.values({
username: createUser.username,
mail: createUser.mail,
2024-08-25 13:36:19 +02:00
firstname: createUser.firstname,
lastname: createUser.lastname,
secret: createUser.secret,
2024-10-07 18:09:27 +02:00
isOwner: createUser.isOwner,
})
.execute()
.then((result) => {
return result.identifiers[0].id;
})
.catch((err) => {
2025-01-29 09:42:22 +01:00
throw new DatabaseActionException("CREATE", "user", err);
});
}
2024-09-01 14:55:05 +02:00
/**
* @description update user
2025-01-05 14:29:31 +01:00
* @param {UpdateUserCommand} updateUser
2024-09-01 14:55:05 +02:00
* @returns {Promise<void>}
*/
static async update(updateUser: UpdateUserCommand): Promise<void> {
return await dataSource
.createQueryBuilder()
.update(user)
.set({
mail: updateUser.mail,
firstname: updateUser.firstname,
lastname: updateUser.lastname,
username: updateUser.username,
})
2024-09-02 15:57:13 +02:00
.where("id = :id", { id: updateUser.id })
2024-09-01 14:55:05 +02:00
.execute()
.then(() => {})
.catch((err) => {
2025-01-29 09:42:22 +01:00
throw new DatabaseActionException("UPDATE", "user", err);
2024-09-01 14:55:05 +02:00
});
}
2024-11-23 12:11:19 +01:00
/**
* @description update user
2025-01-05 14:29:31 +01:00
* @param {UpdateUserSecretCommand} updateUser
2024-11-23 12:11:19 +01:00
* @returns {Promise<void>}
*/
static async updateSecret(updateUser: UpdateUserSecretCommand): Promise<void> {
return await dataSource
.createQueryBuilder()
.update(user)
.set({
secret: updateUser.secret,
routine: updateUser.routine,
2024-11-23 12:11:19 +01:00
})
.where("id = :id", { id: updateUser.id })
.execute()
.then(() => {})
.catch((err) => {
2025-01-29 09:42:22 +01:00
throw new DatabaseActionException("UPDATE", "user", err);
2024-11-23 12:11:19 +01:00
});
}
2024-09-01 14:55:05 +02:00
/**
* @description update user roles
2025-01-05 14:29:31 +01:00
* @param {UpdateUserRolesCommand} updateUserRoles
2024-09-01 14:55:05 +02:00
* @returns {Promise<void>}
*/
static async updateRoles(updateUserRoles: UpdateUserRolesCommand): Promise<void> {
let currentRoles = (await UserService.getAssignedRolesByUserId(updateUserRoles.id)).map((r) => r.id);
return await dataSource.manager
.transaction(async (manager) => {
2024-09-02 15:57:13 +02:00
let newRoles = updateUserRoles.roleIds.filter((r) => !currentRoles.includes(r));
let removeRoles = currentRoles.filter((r) => !updateUserRoles.roleIds.includes(r));
2024-09-01 14:55:05 +02:00
for (let role of newRoles) {
await this.updateRolesAdd(manager, updateUserRoles.id, role);
}
for (let role of removeRoles) {
await this.updateRolesRemove(manager, updateUserRoles.id, role);
}
})
.then(() => {})
.catch((err) => {
2025-01-29 09:42:22 +01:00
throw new DatabaseActionException("UPDATE", "userRoles", err);
2024-09-01 14:55:05 +02:00
});
}
2025-01-29 08:53:49 +01:00
private static async updateRolesAdd(manager: EntityManager, userId: string, roleId: number): Promise<void> {
2024-09-01 14:55:05 +02:00
return await manager.createQueryBuilder().relation(user, "roles").of(userId).add(roleId);
}
2025-01-29 08:53:49 +01:00
private static async updateRolesRemove(manager: EntityManager, userId: string, roleId: number): Promise<void> {
2024-09-01 14:55:05 +02:00
return await manager.createQueryBuilder().relation(user, "roles").of(userId).remove(roleId);
}
2024-11-21 15:58:47 +01:00
/**
* @description transfer ownership
2025-01-05 14:29:31 +01:00
* @param {TransferUserOwnerCommand} transferOwnership
2024-11-21 15:58:47 +01:00
* @returns {Promise<void>}
*/
static async transferOwnership(transferOwnership: TransferUserOwnerCommand): Promise<void> {
return await dataSource.manager
.transaction(async (manager) => {
2025-01-05 14:29:31 +01:00
await manager
2024-11-21 15:58:47 +01:00
.createQueryBuilder()
.update(user)
.set({
isOwner: false,
})
.where("id = :id", { id: transferOwnership.fromId })
.execute();
2025-01-05 14:29:31 +01:00
await manager
2024-11-21 15:58:47 +01:00
.createQueryBuilder()
.update(user)
.set({
isOwner: true,
})
.where("id = :id", { id: transferOwnership.toId })
.execute();
})
.then(() => {})
.catch((err) => {
2025-01-29 09:42:22 +01:00
throw new DatabaseActionException("ABORT", "transfer owner", err);
2024-11-21 15:58:47 +01:00
});
}
2024-09-01 14:55:05 +02:00
/**
* @description delete user
* @param DeleteUserCommand
* @returns {Promise<void>}
*/
static async delete(deleteUser: DeleteUserCommand): Promise<void> {
return await dataSource
.createQueryBuilder()
.delete()
.from(user)
.where("id = :id", { id: deleteUser.id })
.execute()
.then(() => {})
.catch((err) => {
2025-01-29 09:42:22 +01:00
throw new DatabaseActionException("DELETE", "user", err);
2024-09-01 14:55:05 +02:00
});
}
}