1
0
Fork 0
mirror of https://github.com/plankanban/planka.git synced 2025-07-18 20:59:44 +02:00
planka/server/api/hooks/query-methods/models/User.js
Maksim Eltyshev 2ee1166747 feat: Version 2
Closes #627, closes #1047
2025-05-10 02:09:06 +02:00

98 lines
2.3 KiB
JavaScript

/*!
* Copyright (c) 2024 PLANKA Software GmbH
* Licensed under the Fair Use License: https://github.com/plankanban/planka/blob/master/LICENSE.md
*/
const defaultFind = (criteria) => User.find(criteria).sort('id');
/* Query methods */
const createOne = (values) => {
if (sails.config.custom.activeUsersLimit) {
return sails.getDatastore().transaction(async (db) => {
const queryResult = await sails
.sendNativeQuery('SELECT NULL FROM user_account WHERE is_deactivated = $1 FOR UPDATE', [
false,
])
.usingConnection(db);
if (queryResult.rowCount >= sails.config.custom.activeUsersLimit) {
throw 'activeLimitReached';
}
return User.create({ ...values })
.fetch()
.usingConnection(db);
});
}
return User.create({ ...values }).fetch();
};
const getByIds = (ids) => defaultFind(ids);
const getAll = ({ roleOrRoles } = {}) =>
defaultFind({
role: roleOrRoles,
});
const getOneById = (id, { withDeactivated = true } = {}) => {
const criteria = {
id,
};
if (!withDeactivated) {
criteria.isDeactivated = false;
}
return User.findOne(criteria);
};
const getOneByEmail = (email) =>
User.findOne({
email: email.toLowerCase(),
});
const getOneActiveByEmailOrUsername = (emailOrUsername) => {
const fieldName = emailOrUsername.includes('@') ? 'email' : 'username';
return User.findOne({
[fieldName]: emailOrUsername.toLowerCase(),
isDeactivated: false,
});
};
const updateOne = (criteria, values) => {
if (values.isDeactivated === false && sails.config.custom.activeUsersLimit) {
return sails.getDatastore().transaction(async (db) => {
const queryResult = await sails
.sendNativeQuery('SELECT NULL FROM user_account WHERE is_deactivated = $1 FOR UPDATE', [
false,
])
.usingConnection(db);
if (queryResult.rowCount >= sails.config.custom.activeUsersLimit) {
throw 'activeLimitReached';
}
return User.updateOne(criteria)
.set({ ...values })
.usingConnection(db);
});
}
return User.updateOne(criteria).set({ ...values });
};
const deleteOne = (criteria) => User.destroyOne(criteria);
module.exports = {
createOne,
getByIds,
getAll,
getOneById,
getOneByEmail,
getOneActiveByEmailOrUsername,
updateOne,
deleteOne,
};