50 lines
1.6 KiB
TypeScript
50 lines
1.6 KiB
TypeScript
import { db } from "@/lib/db"
|
|
import fetchUserWithImpersonation from "@/lib/fetch-user-impersonation";
|
|
import { NextResponse } from "next/server";
|
|
|
|
export async function GET(req: Request, { params } : { params: { id: string } }) {
|
|
try {
|
|
const user = await fetchUserWithImpersonation(req)
|
|
if (!user) {
|
|
return NextResponse.json({ message: 'Unauthorized.', error: null, value: null }, { status: 401 });
|
|
}
|
|
|
|
let id = req.headers?.get('x-api-key')
|
|
if (id == null) {
|
|
return NextResponse.json(null);
|
|
}
|
|
|
|
const tokens = await db.apiKey.findFirst({
|
|
where: {
|
|
id: id
|
|
}
|
|
});
|
|
|
|
return NextResponse.json(tokens);
|
|
} catch (error) {
|
|
console.log("[TOKEN/GET]", error);
|
|
return NextResponse.json({ message: 'Something went wrong', error: error, value: null }, { status: 500 })
|
|
}
|
|
}
|
|
|
|
export async function DELETE(req: Request, { params } : { params: { id: string } }) {
|
|
try {
|
|
const user = await fetchUserWithImpersonation(req)
|
|
if (!user) {
|
|
return NextResponse.json({ message: 'Unauthorized.', error: null, value: null }, { status: 401 });
|
|
}
|
|
|
|
const { id } = params
|
|
const token = await db.apiKey.delete({
|
|
where: {
|
|
id,
|
|
userId: user?.id
|
|
}
|
|
});
|
|
|
|
return NextResponse.json(token);
|
|
} catch (error) {
|
|
console.log("[TOKEN/DELETE]", error);
|
|
return NextResponse.json({ message: 'Something went wrong', error: error, value: null }, { status: 500 })
|
|
}
|
|
} |