40 lines
1.4 KiB
TypeScript
40 lines
1.4 KiB
TypeScript
import type { NextApiRequest, NextApiResponse } from "next";
|
|
import { getServerSession } from "next-auth/next";
|
|
import { authOptions } from "@/pages/api/auth/[...nextauth]";
|
|
import getUsers from "@/lib/api/controllers/users/getUsers";
|
|
import updateUser from "@/lib/api/controllers/users/updateUser";
|
|
|
|
export default async function users(req: NextApiRequest, res: NextApiResponse) {
|
|
const session = await getServerSession(req, res, authOptions);
|
|
|
|
if (!session?.user.id) {
|
|
return res.status(401).json({ response: "You must be logged in." });
|
|
} else if (session?.user?.isSubscriber === false)
|
|
res.status(401).json({
|
|
response:
|
|
"You are not a subscriber, feel free to reach out to us at hello@linkwarden.app in case of any issues.",
|
|
});
|
|
|
|
const lookupUsername = (req.query.username as string) || undefined;
|
|
const lookupId = Number(req.query.id) || undefined;
|
|
const isSelf =
|
|
session.user.username === lookupUsername || session.user.id === lookupId
|
|
? true
|
|
: false;
|
|
|
|
if (req.method === "GET") {
|
|
const users = await getUsers({
|
|
params: {
|
|
lookupUsername,
|
|
lookupId,
|
|
},
|
|
isSelf,
|
|
username: session.user.username,
|
|
});
|
|
return res.status(users.status).json({ response: users.response });
|
|
} else if (req.method === "PUT") {
|
|
const updated = await updateUser(req.body, session.user);
|
|
return res.status(updated.status).json({ response: updated.response });
|
|
}
|
|
}
|