2022-01-12 16:22:33 +08:00
|
|
|
import { User, UserUpdate, Users } from '@logto/schemas';
|
2021-07-02 21:14:18 +08:00
|
|
|
import { sql } from 'slonik';
|
2021-08-30 11:30:54 +08:00
|
|
|
|
|
|
|
import { buildInsertInto } from '@/database/insert-into';
|
2021-07-02 22:55:14 +08:00
|
|
|
import pool from '@/database/pool';
|
2021-11-18 11:26:34 +08:00
|
|
|
import { buildUpdateWhere } from '@/database/update-where';
|
|
|
|
import { convertToIdentifiers, OmitAutoSetFields } from '@/database/utils';
|
2022-01-14 10:19:43 +08:00
|
|
|
import { DeletionError } from '@/errors/SlonikError';
|
2021-07-02 21:14:18 +08:00
|
|
|
|
|
|
|
const { table, fields } = convertToIdentifiers(Users);
|
|
|
|
|
2021-07-26 22:32:18 +08:00
|
|
|
export const findUserByUsername = async (username: string) =>
|
2021-12-08 11:11:27 +08:00
|
|
|
pool.one<User>(sql`
|
2021-12-20 14:20:23 +08:00
|
|
|
select ${sql.join(Object.values(fields), sql`,`)}
|
|
|
|
from ${table}
|
|
|
|
where ${fields.username}=${username}
|
|
|
|
`);
|
2021-07-26 22:32:18 +08:00
|
|
|
|
2021-07-02 21:14:18 +08:00
|
|
|
export const findUserById = async (id: string) =>
|
2021-12-08 11:11:27 +08:00
|
|
|
pool.one<User>(sql`
|
2021-12-20 14:20:23 +08:00
|
|
|
select ${sql.join(Object.values(fields), sql`,`)}
|
|
|
|
from ${table}
|
|
|
|
where ${fields.id}=${id}
|
|
|
|
`);
|
2021-07-04 17:41:46 +08:00
|
|
|
|
|
|
|
export const hasUser = async (username: string) =>
|
|
|
|
pool.exists(sql`
|
2021-12-20 14:20:23 +08:00
|
|
|
select ${fields.id}
|
|
|
|
from ${table}
|
|
|
|
where ${fields.username}=${username}
|
|
|
|
`);
|
2021-07-04 17:41:46 +08:00
|
|
|
|
|
|
|
export const hasUserWithId = async (id: string) =>
|
|
|
|
pool.exists(sql`
|
2021-12-20 14:20:23 +08:00
|
|
|
select ${fields.id}
|
|
|
|
from ${table}
|
|
|
|
where ${fields.id}=${id}
|
|
|
|
`);
|
2021-07-04 17:41:46 +08:00
|
|
|
|
2022-01-12 16:22:33 +08:00
|
|
|
export const insertUser = buildInsertInto<UserUpdate, User>(pool, Users, { returning: true });
|
2021-11-18 11:26:34 +08:00
|
|
|
|
|
|
|
export const findAllUsers = async () =>
|
2021-12-08 11:11:27 +08:00
|
|
|
pool.many<User>(sql`
|
2021-11-18 11:26:34 +08:00
|
|
|
select ${sql.join(Object.values(fields), sql`, `)}
|
|
|
|
from ${table}
|
|
|
|
`);
|
|
|
|
|
2022-01-12 16:22:33 +08:00
|
|
|
const updateUser = buildUpdateWhere<UserUpdate, User>(pool, Users, true);
|
2021-11-18 11:26:34 +08:00
|
|
|
|
2022-01-12 16:22:33 +08:00
|
|
|
export const updateUserById = async (id: string, set: Partial<OmitAutoSetFields<UserUpdate>>) =>
|
2021-11-18 11:26:34 +08:00
|
|
|
updateUser({ set, where: { id } });
|
|
|
|
|
|
|
|
export const deleteUserById = async (id: string) => {
|
|
|
|
const { rowCount } = await pool.query(sql`
|
2021-12-20 14:20:23 +08:00
|
|
|
delete from ${table}
|
|
|
|
where id=${id}
|
|
|
|
`);
|
2021-11-18 11:26:34 +08:00
|
|
|
if (rowCount < 1) {
|
2022-01-14 10:19:43 +08:00
|
|
|
throw new DeletionError();
|
2021-11-18 11:26:34 +08:00
|
|
|
}
|
|
|
|
};
|