68 lines
1.3 KiB
JavaScript
68 lines
1.3 KiB
JavaScript
// @flow
|
|
import { ValidationError } from "../errors";
|
|
import { Event, User } from "../models";
|
|
import { Op, sequelize } from "../sequelize";
|
|
|
|
export default async function userDestroyer({
|
|
user,
|
|
actor,
|
|
ip,
|
|
}: {
|
|
user: User,
|
|
actor: User,
|
|
ip: string,
|
|
}) {
|
|
const { teamId } = user;
|
|
|
|
const usersCount = await User.count({
|
|
where: {
|
|
teamId,
|
|
},
|
|
});
|
|
|
|
if (usersCount === 1) {
|
|
throw new ValidationError("Cannot delete last user on the team.");
|
|
}
|
|
|
|
if (user.isAdmin) {
|
|
const otherAdminsCount = await User.count({
|
|
where: {
|
|
isAdmin: true,
|
|
teamId,
|
|
id: { [Op.ne]: user.id },
|
|
},
|
|
});
|
|
|
|
if (otherAdminsCount === 0) {
|
|
throw new ValidationError(
|
|
"Cannot delete account as only admin. Please make another user admin and try again."
|
|
);
|
|
}
|
|
}
|
|
|
|
let transaction = await sequelize.transaction();
|
|
let response;
|
|
|
|
try {
|
|
response = await user.destroy({ transaction });
|
|
await Event.create(
|
|
{
|
|
name: "users.delete",
|
|
actorId: actor.id,
|
|
userId: user.id,
|
|
teamId,
|
|
data: { name: user.name },
|
|
ip,
|
|
},
|
|
{ transaction }
|
|
);
|
|
|
|
await transaction.commit();
|
|
} catch (err) {
|
|
await transaction.rollback();
|
|
throw err;
|
|
}
|
|
|
|
return response;
|
|
}
|