2024-09-01 12:55:05 +00:00
|
|
|
import { EntityManager } from "typeorm";
|
2024-08-22 09:40:31 +00:00
|
|
|
import { dataSource } from "../data-source";
|
|
|
|
import { user } from "../entity/user";
|
|
|
|
import InternalException from "../exceptions/internalException";
|
2024-11-21 14:58:47 +00:00
|
|
|
import {
|
|
|
|
CreateUserCommand,
|
|
|
|
DeleteUserCommand,
|
|
|
|
TransferUserOwnerCommand,
|
|
|
|
UpdateUserCommand,
|
|
|
|
UpdateUserRolesCommand,
|
2024-11-23 11:11:19 +00:00
|
|
|
UpdateUserSecretCommand,
|
2024-11-21 14:58:47 +00:00
|
|
|
} from "./userCommand";
|
2024-09-01 12:55:05 +00:00
|
|
|
import UserService from "../service/userService";
|
2024-08-22 09:40:31 +00:00
|
|
|
|
|
|
|
export default abstract class UserCommandHandler {
|
|
|
|
/**
|
|
|
|
* @description create user
|
|
|
|
* @param CreateUserCommand
|
2024-08-25 11:36:19 +00:00
|
|
|
* @returns {Promise<number>}
|
2024-08-22 09:40:31 +00:00
|
|
|
*/
|
2024-08-25 11:36:19 +00:00
|
|
|
static async create(createUser: CreateUserCommand): Promise<number> {
|
2024-08-22 09:40:31 +00:00
|
|
|
return await dataSource
|
|
|
|
.createQueryBuilder()
|
|
|
|
.insert()
|
|
|
|
.into(user)
|
|
|
|
.values({
|
|
|
|
username: createUser.username,
|
|
|
|
mail: createUser.mail,
|
2024-08-25 11:36:19 +00:00
|
|
|
firstname: createUser.firstname,
|
|
|
|
lastname: createUser.lastname,
|
2024-08-22 09:40:31 +00:00
|
|
|
secret: createUser.secret,
|
2024-10-07 16:09:27 +00:00
|
|
|
isOwner: createUser.isOwner,
|
2024-08-22 09:40:31 +00:00
|
|
|
})
|
|
|
|
.execute()
|
|
|
|
.then((result) => {
|
|
|
|
return result.identifiers[0].id;
|
|
|
|
})
|
|
|
|
.catch((err) => {
|
2024-09-06 08:08:19 +00:00
|
|
|
throw new InternalException("Failed saving user", err);
|
2024-08-22 09:40:31 +00:00
|
|
|
});
|
|
|
|
}
|
2024-09-01 12:55:05 +00:00
|
|
|
|
|
|
|
/**
|
|
|
|
* @description update user
|
|
|
|
* @param UpdateUserCommand
|
|
|
|
* @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 13:57:13 +00:00
|
|
|
.where("id = :id", { id: updateUser.id })
|
2024-09-01 12:55:05 +00:00
|
|
|
.execute()
|
|
|
|
.then(() => {})
|
|
|
|
.catch((err) => {
|
2024-09-06 08:08:19 +00:00
|
|
|
throw new InternalException("Failed updating user", err);
|
2024-09-01 12:55:05 +00:00
|
|
|
});
|
|
|
|
}
|
|
|
|
|
2024-11-23 11:11:19 +00:00
|
|
|
/**
|
|
|
|
* @description update user
|
|
|
|
* @param UpdateUserSecretCommand
|
|
|
|
* @returns {Promise<void>}
|
|
|
|
*/
|
|
|
|
static async updateSecret(updateUser: UpdateUserSecretCommand): Promise<void> {
|
|
|
|
return await dataSource
|
|
|
|
.createQueryBuilder()
|
|
|
|
.update(user)
|
|
|
|
.set({
|
|
|
|
secret: updateUser.secret,
|
|
|
|
})
|
|
|
|
.where("id = :id", { id: updateUser.id })
|
|
|
|
.execute()
|
|
|
|
.then(() => {})
|
|
|
|
.catch((err) => {
|
|
|
|
throw new InternalException("Failed updating user secret", err);
|
|
|
|
});
|
|
|
|
}
|
|
|
|
|
2024-09-01 12:55:05 +00:00
|
|
|
/**
|
|
|
|
* @description update user roles
|
|
|
|
* @param UpdateUserRolesCommand
|
|
|
|
* @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 13:57:13 +00:00
|
|
|
let newRoles = updateUserRoles.roleIds.filter((r) => !currentRoles.includes(r));
|
|
|
|
let removeRoles = currentRoles.filter((r) => !updateUserRoles.roleIds.includes(r));
|
2024-09-01 12:55:05 +00: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) => {
|
2024-09-06 08:08:19 +00:00
|
|
|
throw new InternalException("Failed saving user roles", err);
|
2024-09-01 12:55:05 +00:00
|
|
|
});
|
|
|
|
}
|
|
|
|
|
|
|
|
private static async updateRolesAdd(manager: EntityManager, userId: number, roleId: number): Promise<void> {
|
|
|
|
return await manager.createQueryBuilder().relation(user, "roles").of(userId).add(roleId);
|
|
|
|
}
|
|
|
|
|
|
|
|
private static async updateRolesRemove(manager: EntityManager, userId: number, roleId: number): Promise<void> {
|
|
|
|
return await manager.createQueryBuilder().relation(user, "roles").of(userId).remove(roleId);
|
|
|
|
}
|
|
|
|
|
2024-11-21 14:58:47 +00:00
|
|
|
/**
|
|
|
|
* @description transfer ownership
|
|
|
|
* @param TransferUserOwnerCommand
|
|
|
|
* @returns {Promise<void>}
|
|
|
|
*/
|
|
|
|
static async transferOwnership(transferOwnership: TransferUserOwnerCommand): Promise<void> {
|
|
|
|
return await dataSource.manager
|
|
|
|
.transaction(async (manager) => {
|
|
|
|
manager
|
|
|
|
.createQueryBuilder()
|
|
|
|
.update(user)
|
|
|
|
.set({
|
|
|
|
isOwner: false,
|
|
|
|
})
|
|
|
|
.where("id = :id", { id: transferOwnership.fromId })
|
|
|
|
.execute();
|
|
|
|
|
|
|
|
manager
|
|
|
|
.createQueryBuilder()
|
|
|
|
.update(user)
|
|
|
|
.set({
|
|
|
|
isOwner: true,
|
|
|
|
})
|
|
|
|
.where("id = :id", { id: transferOwnership.toId })
|
|
|
|
.execute();
|
|
|
|
})
|
|
|
|
.then(() => {})
|
|
|
|
.catch((err) => {
|
|
|
|
throw new InternalException("Failed transfering ownership", err);
|
|
|
|
});
|
|
|
|
}
|
|
|
|
|
2024-09-01 12:55:05 +00: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) => {
|
2024-09-06 08:08:19 +00:00
|
|
|
throw new InternalException("Failed deleting user", err);
|
2024-09-01 12:55:05 +00:00
|
|
|
});
|
|
|
|
}
|
2024-08-22 09:40:31 +00:00
|
|
|
}
|