2023-01-12 03:34:36 +01:00
|
|
|
import { UserEntity } from '../entities';
|
|
|
|
import { IUserRepository, UserListFilter } from '@app/domain';
|
|
|
|
import { Injectable, InternalServerErrorException } from '@nestjs/common';
|
2022-07-15 21:30:56 +02:00
|
|
|
import { InjectRepository } from '@nestjs/typeorm';
|
2022-11-15 03:24:25 +01:00
|
|
|
import { Not, Repository } from 'typeorm';
|
2022-07-15 21:30:56 +02:00
|
|
|
|
2023-01-12 03:34:36 +01:00
|
|
|
@Injectable()
|
2022-07-15 21:30:56 +02:00
|
|
|
export class UserRepository implements IUserRepository {
|
|
|
|
constructor(
|
|
|
|
@InjectRepository(UserEntity)
|
|
|
|
private userRepository: Repository<UserEntity>,
|
|
|
|
) {}
|
|
|
|
|
2022-12-23 21:08:50 +01:00
|
|
|
async get(userId: string, withDeleted?: boolean): Promise<UserEntity | null> {
|
2022-11-15 03:24:25 +01:00
|
|
|
return this.userRepository.findOne({ where: { id: userId }, withDeleted: withDeleted });
|
2022-07-15 21:30:56 +02:00
|
|
|
}
|
|
|
|
|
2022-12-23 21:08:50 +01:00
|
|
|
async getAdmin(): Promise<UserEntity | null> {
|
2022-11-15 03:24:25 +01:00
|
|
|
return this.userRepository.findOne({ where: { isAdmin: true } });
|
2022-07-15 21:30:56 +02:00
|
|
|
}
|
|
|
|
|
2022-12-23 21:08:50 +01:00
|
|
|
async getByEmail(email: string, withPassword?: boolean): Promise<UserEntity | null> {
|
2022-11-15 03:24:25 +01:00
|
|
|
let builder = this.userRepository.createQueryBuilder('user').where({ email });
|
|
|
|
|
|
|
|
if (withPassword) {
|
|
|
|
builder = builder.addSelect('user.password');
|
|
|
|
}
|
|
|
|
|
|
|
|
return builder.getOne();
|
2022-07-15 21:30:56 +02:00
|
|
|
}
|
|
|
|
|
2022-12-23 21:08:50 +01:00
|
|
|
async getByOAuthId(oauthId: string): Promise<UserEntity | null> {
|
2022-12-04 04:59:24 +01:00
|
|
|
return this.userRepository.findOne({ where: { oauthId } });
|
|
|
|
}
|
|
|
|
|
2022-12-23 21:08:50 +01:00
|
|
|
async getList({ excludeId }: UserListFilter = {}): Promise<UserEntity[]> {
|
2022-07-15 21:30:56 +02:00
|
|
|
if (!excludeId) {
|
|
|
|
return this.userRepository.find(); // TODO: this should also be ordered the same as below
|
|
|
|
}
|
2022-11-15 03:24:25 +01:00
|
|
|
return this.userRepository.find({
|
2022-07-15 21:30:56 +02:00
|
|
|
where: { id: Not(excludeId) },
|
2022-11-07 22:53:47 +01:00
|
|
|
withDeleted: true,
|
2022-07-15 21:30:56 +02:00
|
|
|
order: {
|
|
|
|
createdAt: 'DESC',
|
|
|
|
},
|
|
|
|
});
|
|
|
|
}
|
|
|
|
|
2022-12-23 21:08:50 +01:00
|
|
|
async create(user: Partial<UserEntity>): Promise<UserEntity> {
|
2022-11-15 03:24:25 +01:00
|
|
|
return this.userRepository.save(user);
|
2022-07-15 21:30:56 +02:00
|
|
|
}
|
|
|
|
|
2022-12-23 21:08:50 +01:00
|
|
|
async update(id: string, user: Partial<UserEntity>): Promise<UserEntity> {
|
2022-11-15 03:24:25 +01:00
|
|
|
user.id = id;
|
2022-07-15 21:30:56 +02:00
|
|
|
|
2022-12-23 21:08:50 +01:00
|
|
|
await this.userRepository.save(user);
|
|
|
|
const updatedUser = await this.get(id);
|
|
|
|
if (!updatedUser) {
|
|
|
|
throw new InternalServerErrorException('Cannot reload user after update');
|
2022-07-15 21:30:56 +02:00
|
|
|
}
|
2022-12-23 21:08:50 +01:00
|
|
|
return updatedUser;
|
2022-07-15 21:30:56 +02:00
|
|
|
}
|
|
|
|
|
2022-12-23 21:08:50 +01:00
|
|
|
async delete(user: UserEntity): Promise<UserEntity> {
|
2022-11-07 22:53:47 +01:00
|
|
|
return this.userRepository.softRemove(user);
|
|
|
|
}
|
|
|
|
|
2022-12-23 21:08:50 +01:00
|
|
|
async restore(user: UserEntity): Promise<UserEntity> {
|
2022-11-07 22:53:47 +01:00
|
|
|
return this.userRepository.recover(user);
|
|
|
|
}
|
2022-10-23 23:54:54 +02:00
|
|
|
}
|