From 423e8ecbda0394d4c77e2ea659768a8f30c35018 Mon Sep 17 00:00:00 2001 From: Scott Watermasysk Date: Sun, 21 Aug 2011 21:06:21 -0400 Subject: Static Server based on Sinatra Using Sinatra provides better handling of mime types and supports 304's/etc. Also updated the Gemfile to exclude most gem outside of developemnt (default). --- config.ru | 40 +++++++++++++++------------------------- 1 file changed, 15 insertions(+), 25 deletions(-) (limited to 'config.ru') diff --git a/config.ru b/config.ru index 060867f3..b1b746b1 100644 --- a/config.ru +++ b/config.ru @@ -1,35 +1,25 @@ -require 'rubygems' require 'bundler/setup' -require 'rack' +require 'sinatra/base' # The project root directory $root = ::File.dirname(__FILE__) -# Common Rack Middleware -use Rack::ShowStatus # Nice looking 404s and other messages -use Rack::ShowExceptions # Nice looking errors +class SinatraStaticServer < Sinatra::Base -# -# From Rack::DirectoryIndex: -# https://github.com/craigmarksmith/rack-directory-index/ -# -module Rack - class DirectoryIndex - def initialize(app) - @app = app - end - def call(env) - index_path = ::File.join($root, 'public', Rack::Request.new(env).path.split('/'), 'index.html') - if ::File.exists?(index_path) - return [200, {"Content-Type" => "text/html"}, [::File.read(index_path)]] - else - @app.call(env) - end - end + get(/.+/) do + send_sinatra_file(request.path) {404} end -end -use Rack::DirectoryIndex + not_found do + send_sinatra_file('404.html') {"Sorry, I cannot find #{request.path}"} + end -run Rack::Directory.new($root + '/public') + def send_sinatra_file(path, &missing_file_block) + file_path = File.join(File.dirname(__FILE__), 'public', path) + file_path = File.join(file_path, 'index.html') unless file_path =~ /\.[a-z]+$/i + File.exist?(file_path) ? send_file(file_path) : missing_file_block.call + end + +end +run SinatraStaticServer \ No newline at end of file -- cgit v1.2.1