Added different methods to get user websites and teams.

This commit is contained in:
Mike Cao 2023-07-27 11:43:45 -07:00
parent 5189486d6f
commit f4aa8f9661
5 changed files with 58 additions and 12 deletions

15
pages/api/me/teams.ts Normal file
View File

@ -0,0 +1,15 @@
import { useCors } from 'lib/middleware';
import { NextApiRequestQueryBody } from 'lib/types';
import { NextApiResponse } from 'next';
import { methodNotAllowed } from 'next-basics';
import userTeams from 'pages/api/users/[id]/teams';
export default async (req: NextApiRequestQueryBody, res: NextApiResponse) => {
await useCors(req, res);
if (req.method === 'GET') {
return userTeams(req, res);
}
return methodNotAllowed(res);
};

View File

@ -1,21 +1,18 @@
import { useAuth, useCors } from 'lib/middleware';
import { NextApiRequestQueryBody } from 'lib/types';
import { NextApiResponse } from 'next';
import { methodNotAllowed, ok } from 'next-basics';
import { getUserWebsites } from 'queries';
import { methodNotAllowed } from 'next-basics';
import userWebsites from 'pages/api/users/[id]/websites';
export default async (req: NextApiRequestQueryBody, res: NextApiResponse) => {
await useCors(req, res);
await useAuth(req, res);
const {
user: { id: userId },
} = req.auth;
if (req.method === 'GET') {
const websites = await getUserWebsites(userId);
req.query.id = req.auth.user.id;
return ok(res, websites);
return userWebsites(req, res);
}
return methodNotAllowed(res);

View File

@ -0,0 +1,34 @@
import { useAuth, useCors } from 'lib/middleware';
import { NextApiRequestQueryBody } from 'lib/types';
import { NextApiResponse } from 'next';
import { methodNotAllowed, ok, unauthorized } from 'next-basics';
import { getUserTeams } from 'queries';
export interface UserWebsitesRequestBody {
name: string;
domain: string;
shareId: string;
}
export default async (
req: NextApiRequestQueryBody<any, UserWebsitesRequestBody>,
res: NextApiResponse,
) => {
await useCors(req, res);
await useAuth(req, res);
const { user } = req.auth;
const { id: userId } = req.query;
if (req.method === 'GET') {
if (!user.isAdmin && user.id !== userId) {
return unauthorized(res);
}
const teams = await getUserTeams(userId);
return ok(res, teams);
}
return methodNotAllowed(res);
};

View File

@ -16,7 +16,6 @@ export default async (
) => {
await useCors(req, res);
await useAuth(req, res);
const { user } = req.auth;
const { id: userId } = req.query;

View File

@ -4,7 +4,8 @@ import { useAuth, useCors } from 'lib/middleware';
import { NextApiRequestQueryBody } from 'lib/types';
import { NextApiResponse } from 'next';
import { methodNotAllowed, ok, unauthorized } from 'next-basics';
import { createWebsite, getUserWebsites } from 'queries';
import { createWebsite } from 'queries';
import userWebsites from 'pages/api/users/[id]/websites';
export interface WebsitesRequestBody {
name: string;
@ -24,9 +25,9 @@ export default async (
} = req.auth;
if (req.method === 'GET') {
const websites = await getUserWebsites(userId);
req.query.id = userId;
return ok(res, websites);
return userWebsites(req, res);
}
if (req.method === 'POST') {