mirror of
https://github.com/crocofied/CoreControl.git
synced 2025-12-17 15:36:50 +00:00
Servers add & get_all api route | networks api route
This commit is contained in:
parent
2e73acdeba
commit
ed4a607373
33
app/api/servers/add/route.ts
Normal file
33
app/api/servers/add/route.ts
Normal file
@ -0,0 +1,33 @@
|
|||||||
|
import { NextRequest, NextResponse } from "next/server";
|
||||||
|
import prisma from "@/app/prisma";
|
||||||
|
import { z } from "zod/v4";
|
||||||
|
|
||||||
|
const schema = z.object({
|
||||||
|
networkId: z.number(),
|
||||||
|
name: z.string().min(3, "Server name must be at least 3 characters long").max(30, "Server name must be less than 30 characters long"),
|
||||||
|
description: z.string().optional(),
|
||||||
|
icon: z.string().optional(),
|
||||||
|
});
|
||||||
|
|
||||||
|
export async function POST(request: NextRequest) {
|
||||||
|
try {
|
||||||
|
const body = schema.parse(await request.json());
|
||||||
|
|
||||||
|
const server = await prisma.server.create({
|
||||||
|
data: {
|
||||||
|
networkId: body.networkId,
|
||||||
|
name: body.name,
|
||||||
|
description: body.description,
|
||||||
|
icon: body.icon,
|
||||||
|
},
|
||||||
|
});
|
||||||
|
|
||||||
|
return NextResponse.json({ server }, { status: 201 });
|
||||||
|
} catch (error: any) {
|
||||||
|
if(error instanceof z.ZodError) {
|
||||||
|
return NextResponse.json({ error: error.issues[0].message }, { status: 400 });
|
||||||
|
}
|
||||||
|
return NextResponse.json({ error: "Internal Server Error" }, { status: 500 });
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
65
app/api/servers/get_all/route.ts
Normal file
65
app/api/servers/get_all/route.ts
Normal file
@ -0,0 +1,65 @@
|
|||||||
|
import { NextRequest, NextResponse } from "next/server";
|
||||||
|
import prisma from "@/app/prisma";
|
||||||
|
import Fuse from 'fuse.js';
|
||||||
|
import { z } from "zod/v4";
|
||||||
|
|
||||||
|
const schema = z.object({
|
||||||
|
currentPage: z.string().optional(),
|
||||||
|
itemPerPage: z.string().optional(),
|
||||||
|
search: z.string().optional(),
|
||||||
|
});
|
||||||
|
|
||||||
|
export async function GET(request: NextRequest) {
|
||||||
|
const { searchParams } = request.nextUrl;
|
||||||
|
const currentPage = Number(schema.parse({ currentPage: searchParams.get("currentPage") }).currentPage) || 1;
|
||||||
|
const itemPerPage = Number(schema.parse({ itemPerPage: searchParams.get("itemPerPage") }).itemPerPage) || 10;
|
||||||
|
const search = schema.parse({ search: searchParams.get("search") }).search || "";
|
||||||
|
|
||||||
|
try {
|
||||||
|
if (!search) {
|
||||||
|
const skip = (currentPage - 1) * itemPerPage;
|
||||||
|
const take = itemPerPage;
|
||||||
|
|
||||||
|
const servers = await prisma.server.findMany({
|
||||||
|
skip,
|
||||||
|
take,
|
||||||
|
orderBy: {
|
||||||
|
name: 'asc',
|
||||||
|
},
|
||||||
|
});
|
||||||
|
|
||||||
|
const total = await prisma.server.count();
|
||||||
|
return NextResponse.json({ servers, total, currentPage, itemPerPage }, { status: 200 });
|
||||||
|
}
|
||||||
|
|
||||||
|
const allServers = await prisma.server.findMany({
|
||||||
|
orderBy: {
|
||||||
|
name: 'asc',
|
||||||
|
},
|
||||||
|
});
|
||||||
|
|
||||||
|
const fuseOptions = {
|
||||||
|
includeScore: true,
|
||||||
|
threshold: 0.4,
|
||||||
|
keys: ['name', 'description', 'networks.name']
|
||||||
|
};
|
||||||
|
|
||||||
|
const fuse = new Fuse(allServers, fuseOptions);
|
||||||
|
const searchResults = fuse.search(search);
|
||||||
|
|
||||||
|
const servers = searchResults.map((result) => result.item);
|
||||||
|
|
||||||
|
const total = searchResults.length;
|
||||||
|
const skip = (currentPage - 1) * itemPerPage;
|
||||||
|
const take = itemPerPage;
|
||||||
|
|
||||||
|
const paginatedServers = servers.slice(skip, skip + take);
|
||||||
|
|
||||||
|
return NextResponse.json({ servers: paginatedServers, total, currentPage, itemPerPage }, { status: 200 });
|
||||||
|
} catch (error: any) {
|
||||||
|
if(error instanceof z.ZodError) {
|
||||||
|
return NextResponse.json({ error: error.issues[0].message }, { status: 400 });
|
||||||
|
}
|
||||||
|
return NextResponse.json({ error: "Internal Server Error" }, { status: 500 });
|
||||||
|
}
|
||||||
|
}
|
||||||
19
app/api/sites/networks/get_all/route.ts
Normal file
19
app/api/sites/networks/get_all/route.ts
Normal file
@ -0,0 +1,19 @@
|
|||||||
|
import { NextRequest, NextResponse } from "next/server";
|
||||||
|
import prisma from "@/app/prisma";
|
||||||
|
|
||||||
|
export async function GET(request: NextRequest) {
|
||||||
|
try {
|
||||||
|
const networks = await prisma.network.findMany({
|
||||||
|
orderBy: {
|
||||||
|
name: 'asc',
|
||||||
|
},
|
||||||
|
});
|
||||||
|
|
||||||
|
return NextResponse.json({ networks }, { status: 200 });
|
||||||
|
} catch (error: any) {
|
||||||
|
return NextResponse.json({ error: "Internal Server Error" }, { status: 500 });
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
Loading…
x
Reference in New Issue
Block a user