data:image/s3,"s3://crabby-images/d62f4/d62f4e2fd9424bb022ecd40ff2c0000fc5c9cf14" alt="How to configure Sub-folders with Cloudflare on Feather".png?table=block&id=0073c15e-0226-4270-b490-cfd90b590031&cache=v2)
Do not index
Do not index
This is the most robust and easiest way to add Sub-folders. Any type of website can be configured to use sub-folders when your DNS records are hosted on Cloudflare. If you are not using Cloudflare as your DNS, I suggest you to use it. Around 20% of the website are powered by Cloudflare.
Let’s get started with the setup,
1. Open Workers Dashboard
data:image/s3,"s3://crabby-images/55dec/55dec7ccef187a3e8315dd79e531d9e95df33b7f" alt="notion image"
2. Create a service
data:image/s3,"s3://crabby-images/c4dd6/c4dd6e96a2404f072a5faa9a7bac568cfcb35244" alt="notion image"
You can name this whatever you want.
data:image/s3,"s3://crabby-images/d5ece/d5ece7fdc8407c3069f79715e783b3d0de4e024e" alt="notion image"
You cannot edit the worker code yet so simply press finish.
data:image/s3,"s3://crabby-images/78417/784171100007211e581d295f78717ef0f0d8f296" alt="notion image"
You should now see your worker in the workers overview page.
data:image/s3,"s3://crabby-images/3611d/3611dc7ea260d88f2a9ca4555d125cb6dfc11e56" alt="notion image"
3. Edit your worker
Click on your worker and press edit code.
data:image/s3,"s3://crabby-images/bfe65/bfe651eb8da2a65c08f65973ce1c1aac9b890923" alt="notion image"
Remove all the existing code and paste the following code into the worker.
addEventListener("fetch", event => {
event.respondWith(handleRequest(event.request))
})
async function handleRequest(request) {
const urlObject = new URL(request.url)
if (urlObject.pathname.endsWith('/') && urlObject.pathname !== '/') {
urlObject.pathname = urlObject.pathname.slice(0, -1)
return Response.redirect(urlObject.toString(), 301)
}
const host = urlObject.host
try {
const blogHost = "mydomain.feather.blog" // change this to your feather blog url
// I'm hosting on 'mydomain.com/blog' that's why I have ["blog", "_feather"] in below code
// if you're hosting on 'mydomain.com/help' then below code should be ["help", "_feather"]
const paths = ["blog", "_feather"]
let url = new URL(request.url)
const prevUrl = new URL(url)
if (
paths.some((path) => urlObject.pathname === `/${path}` ||
urlObject.pathname.startsWith(`/${path}/`))
) {
url.hostname = blogHost
}
let proxyRequest = new Request(url.toString(), request)
proxyRequest.headers.set("X-Forwarded-Host", host)
return fetch(proxyRequest)
} catch (e) {
return await fetch(request);
}
}
Please make sure to update line 16 & line 20 accordingly.
Once you paste it, your worker should look like this. Make the changes as required and then press deploy.
data:image/s3,"s3://crabby-images/d0a4b/d0a4b924e016b3bce56e72a96de1fce3628b9e60" alt="notion image"
4. Set trigger routes
data:image/s3,"s3://crabby-images/5450c/5450c10f3c0d8343db424efb9b154e601a47d81d" alt="notion image"
We need 2 routes
- /blog* (if you are hosting on
mydomain/help
, you will need to write/help*
instead)
- /_feather*
Let’s consider here that you’re trying to host Sub-folder at
/blog
for ecomreco.com
domain. For that, you would have to select ecomreco.com
zone and add the required routes as shown in the below screenshots.data:image/s3,"s3://crabby-images/a8d08/a8d08039e93a271a55b391c628a87f69a6483f7d" alt="notion image"
data:image/s3,"s3://crabby-images/775f9/775f92e0d083e15af06eec575db487513b8ad97c" alt="notion image"
5. Setup Sub-folder in Feather Dashboard
In Feather, navigate to Settings > Features and switch on “Enable Subdirectory” feature and after that go to Settings > Sub-folder management and enter the following values,
data:image/s3,"s3://crabby-images/1ae01/1ae01f2b12d6ad5671c3ca7dcb4a49646e3d3af3" alt="notion image"
Make sure to replace
www.mydomain.com
with the domain you are using and blog
with whatever sub-route you plan to use.Important Note: Under the Domains section make sure that you are using Subdomain settings. If you have added a custom domain there, please remove it. Sub-folders does not require the Custom Domain configurations and if you have it, then the sub-folder will not work.
Once you do these, your sub-folder should be live. You should be able to access your feather site on
www.mydomain.com/blog
. If it’s not reach out to us at support@feather.so.