2006-03-25 22:29:09 -05:00
|
|
|
require 'fileutils'
|
2008-11-22 15:48:32 -05:00
|
|
|
require 'optparse'
|
2009-11-23 20:06:10 -05:00
|
|
|
require 'action_dispatch'
|
2013-10-12 14:27:13 -04:00
|
|
|
require 'rails'
|
2005-11-07 05:25:36 -05:00
|
|
|
|
2009-11-23 20:06:10 -05:00
|
|
|
module Rails
|
|
|
|
class Server < ::Rack::Server
|
|
|
|
class Options
|
|
|
|
def parse!(args)
|
2010-02-09 16:21:11 -05:00
|
|
|
args, options = args.dup, {}
|
|
|
|
|
2014-07-11 15:26:33 -04:00
|
|
|
option_parser(options).parse! args
|
|
|
|
|
|
|
|
options[:log_stdout] = options[:daemonize].blank? && (options[:environment] || Rails.env) == "development"
|
|
|
|
options[:server] = args.shift
|
|
|
|
options
|
|
|
|
end
|
|
|
|
|
|
|
|
private
|
|
|
|
|
|
|
|
def option_parser(options)
|
|
|
|
OptionParser.new do |opts|
|
2014-08-22 00:13:45 -04:00
|
|
|
opts.banner = "Usage: rails server [mongrel, thin etc] [options]"
|
2009-11-23 20:06:10 -05:00
|
|
|
opts.on("-p", "--port=port", Integer,
|
2010-02-09 09:03:18 -05:00
|
|
|
"Runs Rails on the specified port.", "Default: 3000") { |v| options[:Port] = v }
|
2014-08-21 12:22:54 -04:00
|
|
|
opts.on("-b", "--binding=IP", String,
|
2014-09-20 05:44:36 -04:00
|
|
|
"Binds Rails to the specified IP.", "Default: localhost") { |v| options[:Host] = v }
|
2009-11-23 20:06:10 -05:00
|
|
|
opts.on("-c", "--config=file", String,
|
2014-08-21 12:22:54 -04:00
|
|
|
"Uses a custom rackup configuration.") { |v| options[:config] = v }
|
|
|
|
opts.on("-d", "--daemon", "Runs server as a Daemon.") { options[:daemonize] = true }
|
2009-11-23 20:06:10 -05:00
|
|
|
opts.on("-e", "--environment=name", String,
|
|
|
|
"Specifies the environment to run this server under (test/development/production).",
|
2010-02-09 09:03:18 -05:00
|
|
|
"Default: development") { |v| options[:environment] = v }
|
2013-11-07 09:15:11 -05:00
|
|
|
opts.on("-P", "--pid=pid", String,
|
2010-07-01 20:20:26 -04:00
|
|
|
"Specifies the PID file.",
|
|
|
|
"Default: tmp/pids/server.pid") { |v| options[:pid] = v }
|
2008-11-22 15:48:32 -05:00
|
|
|
|
2009-11-23 20:06:10 -05:00
|
|
|
opts.separator ""
|
2008-11-22 15:48:32 -05:00
|
|
|
|
2014-08-21 12:22:54 -04:00
|
|
|
opts.on("-h", "--help", "Shows this help message.") { puts opts; exit }
|
2009-11-23 20:06:10 -05:00
|
|
|
end
|
|
|
|
end
|
|
|
|
end
|
2006-06-28 19:41:29 -04:00
|
|
|
|
2010-02-09 16:21:11 -05:00
|
|
|
def initialize(*)
|
|
|
|
super
|
|
|
|
set_environment
|
|
|
|
end
|
|
|
|
|
2013-03-11 15:46:21 -04:00
|
|
|
# TODO: this is no longer required but we keep it for the moment to support older config.ru files.
|
2011-02-28 18:47:03 -05:00
|
|
|
def app
|
2013-03-12 09:09:03 -04:00
|
|
|
@app ||= begin
|
|
|
|
app = super
|
|
|
|
app.respond_to?(:to_app) ? app.to_app : app
|
|
|
|
end
|
2011-02-28 18:47:03 -05:00
|
|
|
end
|
|
|
|
|
2009-11-23 20:06:10 -05:00
|
|
|
def opt_parser
|
|
|
|
Options.new
|
|
|
|
end
|
2008-06-25 17:40:00 -04:00
|
|
|
|
2010-02-09 16:21:11 -05:00
|
|
|
def set_environment
|
|
|
|
ENV["RAILS_ENV"] ||= options[:environment]
|
|
|
|
end
|
2010-01-11 17:01:28 -05:00
|
|
|
|
2010-02-09 16:21:11 -05:00
|
|
|
def start
|
2013-11-06 16:22:10 -05:00
|
|
|
print_boot_information
|
2013-11-06 17:15:17 -05:00
|
|
|
trap(:INT) { exit }
|
2013-11-06 16:22:10 -05:00
|
|
|
create_tmp_directories
|
|
|
|
log_to_stdout if options[:log_stdout]
|
2012-01-20 17:19:21 -05:00
|
|
|
|
2009-11-23 20:06:10 -05:00
|
|
|
super
|
|
|
|
ensure
|
2010-02-06 06:48:02 -05:00
|
|
|
# The '-h' option calls exit before @options is set.
|
|
|
|
# If we call 'options' with it unset, we get double help banners.
|
|
|
|
puts 'Exiting' unless @options && options[:daemonize]
|
2009-11-23 20:06:10 -05:00
|
|
|
end
|
2008-11-22 15:48:32 -05:00
|
|
|
|
2009-11-23 20:06:10 -05:00
|
|
|
def middleware
|
2015-07-10 19:09:09 -04:00
|
|
|
Hash.new([])
|
2009-11-23 20:06:10 -05:00
|
|
|
end
|
2008-11-22 15:48:32 -05:00
|
|
|
|
2009-11-23 20:06:10 -05:00
|
|
|
def default_options
|
2009-12-26 19:21:36 -05:00
|
|
|
super.merge({
|
2013-11-07 09:15:11 -05:00
|
|
|
Port: 3000,
|
|
|
|
DoNotReverseLookup: true,
|
2015-03-20 11:14:11 -04:00
|
|
|
environment: (ENV['RAILS_ENV'] || ENV['RACK_ENV'] || "development").dup,
|
2013-11-07 09:15:11 -05:00
|
|
|
daemonize: false,
|
2015-06-27 02:29:16 -04:00
|
|
|
pid: File.expand_path("tmp/pids/server.pid")
|
2009-12-26 19:21:36 -05:00
|
|
|
})
|
2009-11-23 20:06:10 -05:00
|
|
|
end
|
2013-11-06 16:22:10 -05:00
|
|
|
|
|
|
|
private
|
|
|
|
|
|
|
|
def print_boot_information
|
2013-11-07 09:15:11 -05:00
|
|
|
url = "#{options[:SSLEnable] ? 'https' : 'http'}://#{options[:Host]}:#{options[:Port]}"
|
|
|
|
puts "=> Booting #{ActiveSupport::Inflector.demodulize(server)}"
|
|
|
|
puts "=> Rails #{Rails.version} application starting in #{Rails.env} on #{url}"
|
2013-11-06 16:22:10 -05:00
|
|
|
puts "=> Run `rails server -h` for more startup options"
|
|
|
|
|
|
|
|
puts "=> Ctrl-C to shutdown server" unless options[:daemonize]
|
|
|
|
end
|
|
|
|
|
|
|
|
def create_tmp_directories
|
2015-01-03 13:20:54 -05:00
|
|
|
%w(cache pids sockets).each do |dir_to_make|
|
2013-11-06 16:22:10 -05:00
|
|
|
FileUtils.mkdir_p(File.join(Rails.root, 'tmp', dir_to_make))
|
|
|
|
end
|
|
|
|
end
|
|
|
|
|
|
|
|
def log_to_stdout
|
|
|
|
wrapped_app # touch the app so the logger is set up
|
|
|
|
|
|
|
|
console = ActiveSupport::Logger.new($stdout)
|
|
|
|
console.formatter = Rails.logger.formatter
|
|
|
|
console.level = Rails.logger.level
|
|
|
|
|
|
|
|
Rails.logger.extend(ActiveSupport::Logger.broadcast(console))
|
|
|
|
end
|
2009-11-23 20:06:10 -05:00
|
|
|
end
|
2008-11-22 15:48:32 -05:00
|
|
|
end
|