Added base repository, updated char. hair repo and user repo
This commit is contained in:
@ -1,19 +1,13 @@
|
||||
import { appLogger } from '#utilities/logger'
|
||||
import { Database } from '#utilities/database'
|
||||
import { User } from '../entities/user'
|
||||
import { BaseRepository } from './baseRepository'
|
||||
import { User } from '#entities/user'
|
||||
|
||||
class UserRepository {
|
||||
class UserRepository extends BaseRepository {
|
||||
async getById(id: number) {
|
||||
try {
|
||||
const orm = await Database.getInstance()
|
||||
const em = orm.em.fork()
|
||||
const repository = em.getRepository(User)
|
||||
|
||||
return await repository.findOne({
|
||||
id
|
||||
})
|
||||
const repository = this.em.getRepository(User)
|
||||
return await repository.findOne({ id })
|
||||
} catch (error: any) {
|
||||
// Handle error
|
||||
appLogger.error(`Failed to get user by ID: ${error instanceof Error ? error.message : String(error)}`)
|
||||
return null
|
||||
}
|
||||
@ -21,15 +15,9 @@ class UserRepository {
|
||||
|
||||
async getByUsername(username: string) {
|
||||
try {
|
||||
const orm = await Database.getInstance()
|
||||
const em = orm.em.fork()
|
||||
const repository = em.getRepository(User)
|
||||
|
||||
return await repository.findOne({
|
||||
username
|
||||
})
|
||||
const repository = this.em.getRepository(User)
|
||||
return await repository.findOne({ username })
|
||||
} catch (error: any) {
|
||||
// Handle error
|
||||
appLogger.error(`Failed to get user by username: ${error instanceof Error ? error.message : String(error)}`)
|
||||
return null
|
||||
}
|
||||
@ -37,19 +25,13 @@ class UserRepository {
|
||||
|
||||
async getByEmail(email: string) {
|
||||
try {
|
||||
const orm = await Database.getInstance()
|
||||
const em = orm.em.fork()
|
||||
const repository = em.getRepository(User)
|
||||
|
||||
return await repository.findOne({
|
||||
email
|
||||
})
|
||||
const repository = this.em.getRepository(User)
|
||||
return await repository.findOne({ email })
|
||||
} catch (error: any) {
|
||||
// Handle error
|
||||
appLogger.error(`Failed to get user by email: ${error instanceof Error ? error.message : String(error)}`)
|
||||
return null
|
||||
}
|
||||
}
|
||||
}
|
||||
|
||||
export default new UserRepository()
|
||||
export default new UserRepository()
|
Reference in New Issue
Block a user