All files / src/modules/shared/database/repositories User.repository.ts

30.76% Statements 4/13
100% Branches 0/0
16.66% Functions 1/6
25% Lines 3/12

Press n or j to go to the next uncovered block, b, p or k for the previous block.

1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31 32 33 34 35 36 37 38 39 40 41 42 43 44 45 46 47 48 49 50 51 52 53 54 55 56 57 58 59 60 61 62 63 64 65 66 67 68 69 70 71 72 73 74 75 76                3x 8x   8x                                                                                                                                
import { Services } from "@/types/Constants";
import { Inject, Logger } from "@nestjs/common";
import { User } from "discord.js";
import { UserEntity } from "../entities";
import { PrismaService } from "../prisma/Prisma.service";
import { DatabaseStatus } from "../types";
import type { IUserRepository } from "./interfaces";
 
export class UserRepository implements IUserRepository {
	public constructor(@Inject(Services.Prisma) private readonly prisma: PrismaService) {}
 
	private readonly logger = new Logger(UserRepository.name);
 
	public async get(userId: string): Promise<UserEntity> {
		return await this.prisma.user.findUnique({
			where: { id: userId },
			include: {
				Settings: true,
				APIUser: true,
			},
		});
	}
 
	public async create(user: User): Promise<{ callback: UserEntity | void; status: DatabaseStatus }> {
		let status = DatabaseStatus.Created;
		const callback = await this.prisma.user
			.create({
				data: {
					id: user.id,
					Settings: {
						create: {},
					},
					APIUser: {
						create: {
							accessToken: "",
							email: "",
						},
					},
				},
				include: {
					Settings: true,
				},
			})
			.catch((err) => {
				this.logger.error(err);
				status = DatabaseStatus.Error;
			});
		this.logger.log(`${user.username} Configuration Created on Database`);
		return {
			callback,
			status,
		};
	}
 
	public async update(user: User): Promise<UserEntity> {
		return await this.prisma.user.update({
			where: { id: user.id },
			data: {},
			include: {
				Settings: true,
				APIUser: true,
			},
		});
	}
 
	public async delete(user: User): Promise<UserEntity> {
		return await this.prisma.user.delete({
			where: { id: user.id },
			include: {
				Settings: true,
				APIUser: true,
			},
		});
	}
}