Skip to content

Instantly share code, notes, and snippets.

@pcperini
Last active August 8, 2025 12:19
Show Gist options
  • Save pcperini/62fd061d4cc3f6c3bea94e80f4bc3613 to your computer and use it in GitHub Desktop.
Save pcperini/62fd061d4cc3f6c3bea94e80f4bc3613 to your computer and use it in GitHub Desktop.
Notion Site

Make a Notion Site

For when it doesn't really need to be complicated, fancy, or fragile.

CloudFlare

Much like Fruition, you need to configure a CloudFlare worker to catch all traffic at your domain.

Variables

// Base public Notion site. Trailing "/" expected.
const TARGET_HOST = '<YOUR-NOTION-SITE>'
// Optional slug for site root redirect.
const ROOT_PATH = '<YOUR-ROOT-PAGE-SLUG>'
// Injected BEFORE <html> tag opens.
const INJECTED_HTML = `
<style>
</style>
`
async function proxy(request, env, ctx) {
const url = new URL(request.url)
const reqUrlHref = url.href
const reqUrlOrigin = url.origin
const parsedPath = reqUrlHref.substring(reqUrlOrigin.length + 1)
if (parsedPath === '') {
return Response.redirect(reqUrlHref + ROOT_PATH)
} else if (parsedPath.startsWith('api/v3/getPublicPageData')) { // Fix to account for "Continue to external site" error.
return new Response()
}
const proxyUrl = TARGET_HOST + parsedPath
let res = await fetch(proxyUrl, {
headers: {
'redirects': 'follow'
},
...(await request.clone())
})
if (res.headers.get('Content-Type').startsWith('text/html')) {
const html = await res.text()
// Optionally inject additional styling.
res = new Response(`${INJECTED_HTML}${html}`, res)
// Optionally setting CSP to maximum permissiveness helps to maintain flexibility as Notion changes.
// Enable at your own risk.
res.headers.set('Content-Security-Policy', "default-src * 'unsafe-inline' 'unsafe-eval'; script-src * 'unsafe-inline' 'unsafe-eval'; connect-src * 'unsafe-inline'; img-src * data: blob: 'unsafe-inline'; frame-src *; style-src * 'unsafe-inline';")
}
return res;
}
export default {
async fetch(request, env, ctx) {
return proxy(request, env, ctx)
}
}
Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment