mirror of
https://github.com/d0zingcat/nextjs-notion-starter-kit.git
synced 2026-05-24 23:16:45 +00:00
feat: Change sitemap.xml, robots.xml end-point
This commit is contained in:
@@ -1,23 +0,0 @@
|
||||
import { NextApiRequest, NextApiResponse } from 'next'
|
||||
|
||||
import { host } from '../lib/config'
|
||||
|
||||
export default async (
|
||||
req: NextApiRequest,
|
||||
res: NextApiResponse
|
||||
): Promise<void> => {
|
||||
if (req.method !== 'GET') {
|
||||
return res.status(405).send({ error: 'method not allowed' })
|
||||
}
|
||||
|
||||
// cache robots.txt for up to 60 seconds
|
||||
res.setHeader(
|
||||
'Cache-Control',
|
||||
'public, s-maxage=60, max-age=60, stale-while-revalidate=60'
|
||||
)
|
||||
res.setHeader('Content-Type', 'text/plain')
|
||||
res.write(`User-agent: *
|
||||
Sitemap: ${host}/api/sitemap.xml
|
||||
`)
|
||||
res.end()
|
||||
}
|
||||
@@ -1,49 +0,0 @@
|
||||
import { NextApiRequest, NextApiResponse } from 'next'
|
||||
|
||||
import { SiteMap } from '../lib/types'
|
||||
import { host } from '../lib/config'
|
||||
import { getSiteMaps } from '../lib/get-site-maps'
|
||||
|
||||
export default async (
|
||||
req: NextApiRequest,
|
||||
res: NextApiResponse
|
||||
): Promise<void> => {
|
||||
if (req.method !== 'GET') {
|
||||
return res.status(405).send({ error: 'method not allowed' })
|
||||
}
|
||||
|
||||
const siteMaps = await getSiteMaps()
|
||||
|
||||
// cache sitemap for up to one hour
|
||||
res.setHeader(
|
||||
'Cache-Control',
|
||||
'public, s-maxage=3600, max-age=3600, stale-while-revalidate=3600'
|
||||
)
|
||||
res.setHeader('Content-Type', 'text/xml')
|
||||
res.write(createSitemap(siteMaps[0]))
|
||||
res.end()
|
||||
}
|
||||
|
||||
const createSitemap = (
|
||||
siteMap: SiteMap
|
||||
) => `<?xml version="1.0" encoding="UTF-8"?>
|
||||
<urlset xmlns="http://www.sitemaps.org/schemas/sitemap/0.9">
|
||||
<url>
|
||||
<loc>${host}</loc>
|
||||
</url>
|
||||
|
||||
<url>
|
||||
<loc>${host}/</loc>
|
||||
</url>
|
||||
|
||||
${Object.keys(siteMap.canonicalPageMap)
|
||||
.map((canonicalPagePath) =>
|
||||
`
|
||||
<url>
|
||||
<loc>${host}/${canonicalPagePath}</loc>
|
||||
</url>
|
||||
`.trim()
|
||||
)
|
||||
.join('')}
|
||||
</urlset>
|
||||
`
|
||||
Reference in New Issue
Block a user