You can serve static files with Sinatra by placing them in public/
(by default) -- I have an index.html
in there at the moment, but how can I make the root point to that file without having to parse it as a template?
To be clear, I can access /index.html
successfully, and I'd like to route /
to be the same static file, but without redirecting. Any idea how to do this?
Just set
enable :static
inside of your app class. Like so:There is a gem "sinatra-index" to solve this problem.
https://github.com/elitheeli/sinatra-index
using passenger this seems to work right out of the box. having an index.html file in the public directory and no routing brings up the index.html when accessing the root url.
As described at Serving static files with Sinatra
I think this is only an issue because Sinatra/Rack doesn't have the concept of a default file to serve if you just go to
/
. In a webserver like Apache or Nginx this is taken care of for you and usually defaults toindex.html index.htm
(if either exists it will get served when going to a directory with no actual filename on the end).When everyone says this is built into Passenger, I think they really mean that it's built into Apache/Nginx. Apache/Nginx will check if the static file exists and serve it if it does, the request will never get to Rack, which is awesome for performance.
I wouldn't want to set up a redirect to the 404 page as this sort of violates the whole idea of HTTP: there should be one endpoint for everything that end point should return the true state of that endpoint. Meaning that if you go to
/asdf
you want the webserver to report a 404 because that's what is actually going on. If you do a redirect, now your site is saying "I used to have something here, but it moved" and then the page it redirects you to, even though it says 404 in the text on the page, is actually reported by the web server as a 200, meaning "everything is fine with this page!"Probably a better answer will eventually come, until then this is my shot at it.
If this is not what you want:
You might do something like this:
I'd go with the first one though, Not sure why you want to avoid that redirect