summaryrefslogtreecommitdiff
path: root/src/app/(main)/api
diff options
context:
space:
mode:
authorBertrand Yuan <bert.yuan@outlook.com>2025-12-16 00:25:04 +0800
committerGitHub <noreply@github.com>2025-12-16 00:25:04 +0800
commit39c83fbb69ef06d2d56790d75abc254ba7e34394 (patch)
treedd006593448c3500bdcb414af3b4656f7a7683d4 /src/app/(main)/api
parent48b07bc308a35734a6a7a305c8fdccbfa47de7d8 (diff)
parent785371bb3eccca455e5ce5fccbe9b6e3752a03f6 (diff)
Merge pull request #1 from bertyuan/feat-introduce-payloadv1.0
Feat: introduce payload
Diffstat (limited to 'src/app/(main)/api')
-rw-r--r--src/app/(main)/api/auth/[...all]/route.ts4
-rw-r--r--src/app/(main)/api/comments/[...comment]/route.ts9
-rw-r--r--src/app/(main)/api/search/route.ts20
3 files changed, 33 insertions, 0 deletions
diff --git a/src/app/(main)/api/auth/[...all]/route.ts b/src/app/(main)/api/auth/[...all]/route.ts
new file mode 100644
index 0000000..677b24c
--- /dev/null
+++ b/src/app/(main)/api/auth/[...all]/route.ts
@@ -0,0 +1,4 @@
+import { auth } from '@/server/auth';
+import { toNextJsHandler } from 'better-auth/next-js';
+
+export const { POST, GET } = toNextJsHandler(auth);
diff --git a/src/app/(main)/api/comments/[...comment]/route.ts b/src/app/(main)/api/comments/[...comment]/route.ts
new file mode 100644
index 0000000..1da87db
--- /dev/null
+++ b/src/app/(main)/api/comments/[...comment]/route.ts
@@ -0,0 +1,9 @@
+import { auth, storage } from '@/server/comments/config';
+import { NextComment } from '@fuma-comment/server/next';
+
+export const { GET, DELETE, PATCH, POST } = NextComment({
+ // role: 'database', todo use role in auth
+ mention: { enabled: true },
+ auth: auth,
+ storage: storage,
+});
diff --git a/src/app/(main)/api/search/route.ts b/src/app/(main)/api/search/route.ts
new file mode 100644
index 0000000..cc2a1c8
--- /dev/null
+++ b/src/app/(main)/api/search/route.ts
@@ -0,0 +1,20 @@
+import { getPublishedPosts } from '@/lib/payload-posts';
+import { createSearchAPI } from 'fumadocs-core/search/server';
+
+// 动态生成搜索索引
+export async function GET(request: Request) {
+ const { posts } = await getPublishedPosts({ limit: 1000 });
+
+ const indexes = posts.map((post) => ({
+ title: post.title,
+ description: post.description,
+ id: post.url,
+ url: post.url,
+ }));
+
+ const searchAPI = createSearchAPI('advanced', {
+ indexes,
+ });
+
+ return searchAPI.GET(request);
+}