-
Notifications
You must be signed in to change notification settings - Fork 746
New issue
Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.
By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.
Already on GitHub? Sign in to your account
middleware based auth for pages, robots.txt, sitemap.xml #164
base: main
Are you sure you want to change the base?
Changes from 8 commits
d972a2c
aa0cd25
7e47955
c5b4256
8d33552
a62802f
c937e79
83f4b24
3b5812c
36b17ac
File filter
Filter by extension
Conversations
Jump to
Diff view
Diff view
There are no files selected for viewing
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,13 @@ | ||
import { type MetadataRoute } from 'next' | ||
import { routeGroups, routeTypes } from '@/routes' | ||
|
||
export default function robots(): MetadataRoute.Robots { | ||
return { | ||
rules: { | ||
userAgent: '*', | ||
allow: [...routeGroups.landing], | ||
disallow: [...routeTypes.authed], | ||
}, | ||
sitemap: 'https://supermemory.ai/sitemap.xml', | ||
} | ||
} |
Original file line number | Diff line number | Diff line change | ||||||||||||||||||||||||||||||||||||||||||||
---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|
@@ -0,0 +1,12 @@ | ||||||||||||||||||||||||||||||||||||||||||||||
import { type MetadataRoute } from 'next' | ||||||||||||||||||||||||||||||||||||||||||||||
|
||||||||||||||||||||||||||||||||||||||||||||||
export default function sitemap(): MetadataRoute.Sitemap { | ||||||||||||||||||||||||||||||||||||||||||||||
return [ | ||||||||||||||||||||||||||||||||||||||||||||||
{ | ||||||||||||||||||||||||||||||||||||||||||||||
url: 'https://supermemory.ai/', | ||||||||||||||||||||||||||||||||||||||||||||||
lastModified: new Date(), | ||||||||||||||||||||||||||||||||||||||||||||||
changeFrequency: 'yearly', | ||||||||||||||||||||||||||||||||||||||||||||||
priority: 1, | ||||||||||||||||||||||||||||||||||||||||||||||
} | ||||||||||||||||||||||||||||||||||||||||||||||
] | ||||||||||||||||||||||||||||||||||||||||||||||
Comment on lines
+4
to
+11
There was a problem hiding this comment. Choose a reason for hiding this commentThe reason will be displayed to describe this comment to others. Learn more. Comment: The Solution: Add URLs for authenticated pages to the Reason For Comment: The current implementation only includes the root URL, which is insufficient for SEO purposes. Authenticated pages should be included in the sitemap to improve discoverability by search engines.
Suggested change
|
||||||||||||||||||||||||||||||||||||||||||||||
} |
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -1,24 +1,35 @@ | ||
import { NextRequest, NextResponse } from "next/server"; | ||
import { type NextRequest, NextResponse } from "next/server"; | ||
import { auth } from "./server/auth"; | ||
import { routeTypes } from "@/routes"; | ||
|
||
const corsHeaders = { | ||
"Access-Control-Allow-Origin": "*", | ||
"Access-Control-Allow-Methods": "GET, POST, PUT, DELETE, OPTIONS", | ||
"Access-Control-Allow-Headers": "Content-Type, Authorization", | ||
}; | ||
|
||
export function middleware(request: NextRequest) { | ||
if (request.method === "OPTIONS") { | ||
return new NextResponse(null, { headers: corsHeaders }); | ||
} | ||
export async function middleware(request: NextRequest) { | ||
if (request.nextUrl.pathname.startsWith("/api")) { | ||
if (request.method === "OPTIONS") { | ||
return new NextResponse(null, { headers: corsHeaders }); | ||
} | ||
|
||
const response = NextResponse.next(); | ||
Object.entries(corsHeaders).forEach(([key, value]) => { | ||
response.headers.set(key, value); | ||
}); | ||
const response = NextResponse.next(); | ||
Object.entries(corsHeaders).forEach(([key, value]) => { | ||
response.headers.set(key, value); | ||
}); | ||
|
||
return response; | ||
return response; | ||
} | ||
const info = await auth(); | ||
if (routeTypes.authed.some((route) => request.nextUrl.pathname.startsWith(route))) { | ||
if (!info) { | ||
NextResponse.redirect(new URL("/signin", request.nextUrl)); | ||
} | ||
} else { | ||
if (info) { | ||
NextResponse.redirect(new URL("/home", request.nextUrl)); | ||
} | ||
} | ||
return NextResponse.next(); | ||
} | ||
|
||
export const config = { | ||
matcher: "/api/:path*", | ||
}; |
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,12 @@ | ||
export const routeGroups = { | ||
auth: ["/privacy", "/signin", "/tos"], | ||
canvas: ["/canvas"], | ||
dash: ["/memories", "/space", "/chat", "/home", "/note"], | ||
landing: ["/"], | ||
other: ["/ref", "/onboarding"], | ||
}; | ||
|
||
export const routeTypes = { | ||
authed: [...routeGroups.canvas, ...routeGroups.dash, ...routeGroups.other], | ||
unauthed: [...routeGroups.auth, ...routeGroups.landing], | ||
} |
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
Comment: The redirect logic in the Page function does not handle errors properly.
Solution: Change the condition to explicitly check for both success and data.
Reason For Comment: Using a nullish coalescing operator (??) in the condition might lead to unexpected behavior. It should explicitly check for both success and data.