Sha256: 89eedf966c3fb3928288484da6346ed2a5d2792fbb4cdd8522873d61c7133ea9
Contents?: true
Size: 1.25 KB
Versions: 4
Compression:
Stored size: 1.25 KB
Contents
#!/usr/bin/env ruby $:<< '../lib' << 'lib' require 'goliath' require 'goliath/plugins/latency' # Goliath uses multi-json, so pick your favorite JSON serializer # require 'json' require 'yajl' if RUBY_PLATFORM != 'java' class Echo < Goliath::API use Goliath::Rack::Tracer # log trace statistics use Goliath::Rack::DefaultMimeType # cleanup accepted media types use Goliath::Rack::Render, 'json' # auto-negotiate response format use Goliath::Rack::Params # parse & merge query and body parameters use Goliath::Rack::Heartbeat # respond to /status with 200, OK (monitoring, etc) # If you are using Golaith version <=0.9.1 you need to Goliath::Rack::ValidationError # to prevent the request from remaining open after an error occurs #use Goliath::Rack::ValidationError use Goliath::Rack::Validation::RequestMethod, %w(GET POST) # allow GET and POST requests only use Goliath::Rack::Validation::RequiredParam, {:key => 'echo'} # must provide ?echo= query or body param plugin Goliath::Plugin::Latency # output reactor latency every second def process_request logger.info "Processing request" {response: env.params['echo']} end def response(env) [200, {}, process_request] end end
Version data entries
4 entries across 4 versions & 1 rubygems
Version | Path |
---|---|
goliath-1.0.2 | examples/echo.rb |
goliath-1.0.1 | examples/echo.rb |
goliath-1.0.0 | examples/echo.rb |
goliath-1.0.0.beta.1 | examples/echo.rb |