Skip to content
This repository has been archived by the owner on Jul 26, 2023. It is now read-only.

Commit

Permalink
api is now compatible with ioredis
Browse files Browse the repository at this point in the history
new api using edge runtime need to explictly enable via edge config (`edge_runtime: true`)
  • Loading branch information
aidenlx committed Feb 17, 2023
1 parent 552b9ce commit a10ed00
Show file tree
Hide file tree
Showing 23 changed files with 436 additions and 157 deletions.
2 changes: 2 additions & 0 deletions package.json
Original file line number Diff line number Diff line change
Expand Up @@ -27,13 +27,15 @@
"csstype": "^3.1.1",
"dayjs": "^1.11.7",
"emoji-regex": "^10.2.1",
"encoding": "^0.1.13",
"i18next": "^22.4.9",
"ioredis": "^5.3.0",
"jszip": "^3.10.1",
"mpegts.js": "^1.7.2",
"next": "^13.1.6",
"next-i18next": "^13.0.3",
"nextjs-progressbar": "^0.0.16",
"node-fetch": "^3.3.0",
"path-browserify": "^1.0.1",
"plyr-react": "^5.1.2",
"preview-office-docs": "^1.0.2",
Expand Down
69 changes: 62 additions & 7 deletions pnpm-lock.yaml

Some generated files are not rendered by default. Learn more about how customized files appear on GitHub.

31 changes: 31 additions & 0 deletions src/middleware.ts
Original file line number Diff line number Diff line change
@@ -0,0 +1,31 @@
import { NextResponse } from 'next/server'
import type { NextRequest } from 'next/server'
import { get } from '@vercel/edge-config'

const pattern = /^\/api\/\w+(?=\/|$)/

export async function middleware(request: NextRequest) {
const original = request.nextUrl

let { pathname } = original
if (pathname === '/api/') {
pathname = '/api/index/'
}

const edgeRuntimeEnabled = process.env.EDGE_CONFIG && (await get<boolean>('edge_runtime'))
if (!edgeRuntimeEnabled) {
pathname = pathname.replace(pattern, m => `${m}-v1`)
} else {
pathname = pathname.replace(pattern, m => `${m}-v2`)
}
const rewritten = new URL(pathname, original)
original.searchParams.forEach((value, key) => {
rewritten.searchParams.append(key, value)
})
return NextResponse.rewrite(rewritten)
}

// See "Matching Paths" below to learn more
export const config = {
matcher: '/api/:path*',
}
10 changes: 10 additions & 0 deletions src/pages/api/index-v1.ts
Original file line number Diff line number Diff line change
@@ -0,0 +1,10 @@
import { NodeRequestToWeb } from '@/utils/api/common'
import handle from '@/utils/api/index'
import { kv } from '@/utils/kv/ioredis'
import { NextApiRequest, NextApiResponse } from 'next'
import '@/utils/api/fetch-polyfill'

export default async function handler(req: NextApiRequest, res: NextApiResponse) {
const response = await handle(kv, NodeRequestToWeb(req))
response.toNode(res)
}
11 changes: 11 additions & 0 deletions src/pages/api/index-v2.ts
Original file line number Diff line number Diff line change
@@ -0,0 +1,11 @@
import handle from '@/utils/api/index'
import { kv } from '@/utils/kv/edge'
import { NextRequest } from 'next/server'

export const config = {
runtime: 'edge',
}

export default async function handler(req: NextRequest) {
return (await handle(kv, req)).toWeb()
}
10 changes: 10 additions & 0 deletions src/pages/api/item-v1.ts
Original file line number Diff line number Diff line change
@@ -0,0 +1,10 @@
import { NodeRequestToWeb } from '@/utils/api/common'
import handle from '@/utils/api/item'
import { kv } from '@/utils/kv/ioredis'
import { NextApiRequest, NextApiResponse } from 'next'
import '@/utils/api/fetch-polyfill'

export default async function handler(req: NextApiRequest, res: NextApiResponse) {
const response = await handle(kv, NodeRequestToWeb(req))
response.toNode(res)
}
11 changes: 11 additions & 0 deletions src/pages/api/item-v2.ts
Original file line number Diff line number Diff line change
@@ -0,0 +1,11 @@
import handle from '@/utils/api/item'
import { kv } from '@/utils/kv/edge'
import { NextRequest } from 'next/server'

export const config = {
runtime: 'edge',
}

export default async function handler(req: NextRequest) {
return (await handle(kv, req)).toWeb()
}
7 changes: 7 additions & 0 deletions src/pages/api/name-v1/[name].ts
Original file line number Diff line number Diff line change
@@ -0,0 +1,7 @@
import { NextApiRequest, NextApiResponse } from 'next'
import '@/utils/api/fetch-polyfill'
import handle from '../raw-v1'

export default async function handler(req: NextApiRequest, res: NextApiResponse) {
return handle(req, res)
}
Original file line number Diff line number Diff line change
@@ -1,5 +1,5 @@
import { NextRequest } from 'next/server'
import rawFileHandler from '../raw'
import rawFileHandler from '../raw-v2'

export const config = {
runtime: 'edge',
Expand Down
10 changes: 10 additions & 0 deletions src/pages/api/raw-v1.ts
Original file line number Diff line number Diff line change
@@ -0,0 +1,10 @@
import { NodeRequestToWeb } from '@/utils/api/common'
import handle from '@/utils/api/raw'
import { kv } from '@/utils/kv/ioredis'
import { NextApiRequest, NextApiResponse } from 'next'
import '@/utils/api/fetch-polyfill'

export default async function handler(req: NextApiRequest, res: NextApiResponse) {
const response = await handle(kv, NodeRequestToWeb(req))
response.toNode(res)
}
11 changes: 11 additions & 0 deletions src/pages/api/raw-v2.ts
Original file line number Diff line number Diff line change
@@ -0,0 +1,11 @@
import handle from '@/utils/api/raw'
import { kv } from '@/utils/kv/edge'
import { NextRequest } from 'next/server'

export const config = {
runtime: 'edge',
}

export default async function handler(req: NextRequest) {
return (await handle(kv, req)).toWeb()
}
45 changes: 0 additions & 45 deletions src/pages/api/raw.ts

This file was deleted.

10 changes: 10 additions & 0 deletions src/pages/api/search-v1.ts
Original file line number Diff line number Diff line change
@@ -0,0 +1,10 @@
import { NodeRequestToWeb } from '@/utils/api/common'
import handle from '@/utils/api/search'
import { kv } from '@/utils/kv/ioredis'
import { NextApiRequest, NextApiResponse } from 'next'
import '@/utils/api/fetch-polyfill'

export default async function handler(req: NextApiRequest, res: NextApiResponse) {
const response = await handle(kv, NodeRequestToWeb(req))
response.toNode(res)
}
11 changes: 11 additions & 0 deletions src/pages/api/search-v2.ts
Original file line number Diff line number Diff line change
@@ -0,0 +1,11 @@
import handle from '@/utils/api/search'
import { kv } from '@/utils/kv/edge'
import { NextRequest } from 'next/server'

export const config = {
runtime: 'edge',
}

export default async function handler(req: NextRequest) {
return (await handle(kv, req)).toWeb()
}
10 changes: 10 additions & 0 deletions src/pages/api/thumbnail-v1.ts
Original file line number Diff line number Diff line change
@@ -0,0 +1,10 @@
import { NodeRequestToWeb } from '@/utils/api/common'
import handle from '@/utils/api/thumbnail'
import { kv } from '@/utils/kv/ioredis'
import { NextApiRequest, NextApiResponse } from 'next'
import '@/utils/api/fetch-polyfill'

export default async function handler(req: NextApiRequest, res: NextApiResponse) {
const response = await handle(kv, NodeRequestToWeb(req))
response.toNode(res)
}
Loading

0 comments on commit a10ed00

Please sign in to comment.