generate-sitemap.ts 2.5 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101
  1. #!/usr/bin/env bun
  2. import { readdir } from "fs/promises"
  3. import { join } from "path"
  4. import { config } from "../src/config.ts"
  5. const BASE_URL = config.baseUrl
  6. const PUBLIC_DIR = join(import.meta.dir, "../public")
  7. const ROUTES_DIR = join(import.meta.dir, "../src/routes")
  8. const DOCS_DIR = join(import.meta.dir, "../../../web/src/content/docs")
  9. interface SitemapEntry {
  10. url: string
  11. priority: number
  12. changefreq: string
  13. }
  14. async function getMainRoutes(): Promise<SitemapEntry[]> {
  15. const routes: SitemapEntry[] = []
  16. // Add main static routes
  17. const staticRoutes = [
  18. { path: "/", priority: 1.0, changefreq: "daily" },
  19. { path: "/enterprise", priority: 0.8, changefreq: "weekly" },
  20. { path: "/brand", priority: 0.6, changefreq: "monthly" },
  21. { path: "/zen", priority: 0.8, changefreq: "weekly" },
  22. ]
  23. for (const route of staticRoutes) {
  24. routes.push({
  25. url: `${BASE_URL}${route.path}`,
  26. priority: route.priority,
  27. changefreq: route.changefreq,
  28. })
  29. }
  30. return routes
  31. }
  32. async function getDocsRoutes(): Promise<SitemapEntry[]> {
  33. const routes: SitemapEntry[] = []
  34. try {
  35. const files = await readdir(DOCS_DIR)
  36. for (const file of files) {
  37. if (!file.endsWith(".mdx")) continue
  38. const slug = file.replace(".mdx", "")
  39. const path = slug === "index" ? "/docs/" : `/docs/${slug}`
  40. routes.push({
  41. url: `${BASE_URL}${path}`,
  42. priority: slug === "index" ? 0.9 : 0.7,
  43. changefreq: "weekly",
  44. })
  45. }
  46. } catch (error) {
  47. console.error("Error reading docs directory:", error)
  48. }
  49. return routes
  50. }
  51. function generateSitemapXML(entries: SitemapEntry[]): string {
  52. const urls = entries
  53. .map(
  54. (entry) => ` <url>
  55. <loc>${entry.url}</loc>
  56. <changefreq>${entry.changefreq}</changefreq>
  57. <priority>${entry.priority}</priority>
  58. </url>`
  59. )
  60. .join("\n")
  61. return `<?xml version="1.0" encoding="UTF-8"?>
  62. <urlset xmlns="http://www.sitemaps.org/schemas/sitemap/0.9">
  63. ${urls}
  64. </urlset>`
  65. }
  66. async function main() {
  67. console.log("Generating sitemap...")
  68. const mainRoutes = await getMainRoutes()
  69. const docsRoutes = await getDocsRoutes()
  70. const allRoutes = [...mainRoutes, ...docsRoutes]
  71. console.log(`Found ${mainRoutes.length} main routes`)
  72. console.log(`Found ${docsRoutes.length} docs routes`)
  73. console.log(`Total: ${allRoutes.length} routes`)
  74. const xml = generateSitemapXML(allRoutes)
  75. const outputPath = join(PUBLIC_DIR, "sitemap.xml")
  76. await Bun.write(outputPath, xml)
  77. console.log(`✓ Sitemap generated at ${outputPath}`)
  78. }
  79. main()