Skip to content
New issue

Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.

By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.

Already on GitHub? Sign in to your account

feat: create endpoint to get users #81

Closed
wants to merge 31 commits into from
Closed
Show file tree
Hide file tree
Changes from all commits
Commits
Show all changes
31 commits
Select commit Hold shift + click to select a range
ffceba0
feat: create endpoint to get users
Luana-ns Oct 18, 2023
a918fb2
Update route.ts
ogatalars Oct 18, 2023
4e3ec12
Create user.dao.ts
ogatalars Oct 25, 2023
d171899
Update route.ts
ogatalars Oct 25, 2023
743c01e
ref: add initial fixes
Luana-ns Oct 25, 2023
9fb30ea
ref: merge
Luana-ns Oct 25, 2023
0c972e7
Delete src/app/api/users/user.dao.ts
ogatalars Nov 29, 2023
ff74415
Update route.ts
ogatalars Nov 29, 2023
40f1355
Update user.dao.ts
ogatalars Nov 29, 2023
2e8779c
Update route.ts
ogatalars Nov 29, 2023
9c53c55
fix: route.ts
ogatalars Nov 29, 2023
687e11a
Update route.ts with prisma
ogatalars Nov 29, 2023
978f039
fix: user.dao.ts duplication
ogatalars Nov 29, 2023
773dd48
change the place on route.ts
ogatalars Nov 29, 2023
0518d94
fix user.dao.ts
ogatalars Nov 29, 2023
64b5e28
follow review on user.dao.ts
ogatalars Dec 2, 2023
7c005d2
Update user.dao.ts
ogatalars Jan 25, 2024
450f24b
follow review in route.ts
ogatalars Jan 25, 2024
7cd623e
fix: route.ts
ogatalars Jan 26, 2024
8b8b55c
fix: following Frat's review in user.dao.ts
ogatalars Jan 26, 2024
811d5ae
fix: lint in route.ts
ogatalars Jan 26, 2024
2afd036
Fix: lint in user.dao.ts
ogatalars Jan 26, 2024
5310e4e
fix: lint
Luana-ns Feb 1, 2024
82cf3cd
fix: fetchUsers
Luana-ns Feb 1, 2024
f71d396
fix: users route
Luana-ns Feb 14, 2024
fe176bc
refactor: route.ts
ogatalars Mar 3, 2024
2928419
refactor: follow review on route.ts
ogatalars Mar 4, 2024
2ef45dd
revert: user dao changes
Mar 6, 2024
b6708e4
fix: update user dao for fetch all users
Mar 6, 2024
472b942
feat: create pagination shared zod validation
Mar 8, 2024
85ac528
feat: enhance validation and filter conditions for get users endpoint
Mar 8, 2024
File filter

Filter by extension

Filter by extension

Conversations
Failed to load comments.
Loading
Jump to
Jump to file
Failed to load files.
Loading
Diff view
Diff view
24 changes: 24 additions & 0 deletions src/app/api/users/route.ts
Original file line number Diff line number Diff line change
@@ -0,0 +1,24 @@
import { user } from "@/dao/user.dao";
import { PaginationParamsSchema } from "@/shared/pagination";
import { NextResponse, NextRequest } from "next/server";
import { z } from "zod";

const ListAllUsersParamsSchema = z
.object({
name: z.string().optional(),
username: z.string().optional(),
email: z.string().optional(),
})
.merge(PaginationParamsSchema);

export async function GET(req: NextRequest) {
frattezi marked this conversation as resolved.
Show resolved Hide resolved
const queryParams = ListAllUsersParamsSchema.parse(
Object.fromEntries(req.nextUrl.searchParams)
);

const { page, pageSize, ...filters } = queryParams;

const users = await user.fetchUsers(filters, page, pageSize);

return NextResponse.json(users);
}
39 changes: 39 additions & 0 deletions src/dao/user.dao.ts
Original file line number Diff line number Diff line change
Expand Up @@ -4,6 +4,7 @@ import { z } from "zod";
import { prisma } from "./client";
import { raise } from "@/shared/exceptions";
import { formSchema } from "@/shared/onboarding";
import { GetUsers } from "@/entities/users";

class UserDAO {
async createUser(loginUser: NextUser) {
Expand All @@ -28,6 +29,44 @@ class UserDAO {
});
}

async fetchUsers(filter: GetUsers, page = 1, pageSize = 10) {
const skip = (page - 1) * pageSize;
frattezi marked this conversation as resolved.
Show resolved Hide resolved
const whereCondition: Prisma.Enumerable<Prisma.UserWhereInput> = [];

Object.keys(filter).forEach((key) => {
const property = key as keyof typeof filter;
const value = filter[property];

if (value !== undefined) {
whereCondition.push({
[key]: { contains: value, mode: "insensitive" },
});
}
});

let where: Prisma.UserWhereInput = {};
if (whereCondition.length > 0) {
where = { OR: whereCondition };
}

frattezi marked this conversation as resolved.
Show resolved Hide resolved
const [users, total] = await prisma.$transaction([prisma.user.findMany({
where: where,
skip,
take: pageSize,
}), prisma.user.count({
where: where,
}),]);

return {
total,
data: users,
pagination: {
page,
pageSize,
},
};
}

async isOboardingFinished(username: string) {
const user =
(await this.fetchUserBy({ username })) ??
Expand Down
8 changes: 7 additions & 1 deletion src/entities/users.ts
Original file line number Diff line number Diff line change
@@ -1,11 +1,17 @@
import { Session } from "next-auth";

import { User as UserEntity } from "@prisma/client";
export type User = {
name: string;
email: string;
image: string;
};

export type GetUsers = {
name?: UserEntity["name"];
email?: UserEntity["email"];
username?: UserEntity["username"];
};

export function getUserSession(session: Session | null): User {
if (session?.user == null) {
throw new Error("User session not found");
Expand Down
9 changes: 9 additions & 0 deletions src/shared/pagination.ts
Original file line number Diff line number Diff line change
@@ -0,0 +1,9 @@
import { z } from "zod";

const DEFAULT_PAGE = 1;
const DEFAULT_PAGE_SIZE = 10;

export const PaginationParamsSchema = z.object({
page: z.coerce.number().min(1).default(DEFAULT_PAGE),
pageSize: z.coerce.number().min(10).max(100).default(DEFAULT_PAGE_SIZE),
});
Loading