lib/nephos-server/routing/execute.rb in nephos-server-0.1.11 vs lib/nephos-server/routing/execute.rb in nephos-server-0.1.12
- old
+ new
@@ -21,24 +21,28 @@
def self.parse_path path, verb
route = File.join(["/"] + path)
return ALL.find{|e| e[:match] =~ route and e[:verb] == verb}
end
+ def self.parse_env(env, route)
+ verb = env["REQUEST_METHOD"]
+ from = env["REMOTE_ADDR"]
+ path = route.path.split("/").select{|e|not e.to_s.empty?}
+ args = Hash[route.query.to_s.split("&").map{|e| e.split("=")}]
+ return {route: route, verb: verb, from: from, path: path, args: args}
+ end
+
def self.execute(env)
begin
route = URI.parse(env['REQUEST_URI'])
rescue => err
puts "uri err #{err.message}".red
return render(status: 500)
end
- verb = env["REQUEST_METHOD"]
- from = env["REMOTE_ADDR"]
- path = route.path.split("/").select{|e|not e.to_s.empty?}
- args = Hash[route.query.to_s.split("&").map{|e| e.split("=")}]
- puts "#{from} [#{verb}] \t ---> \t #{route}"
- parsed = {route: route, verb: verb, from: from, path: path, args: args}
- call = parse_path(path, verb)
- return render status: 404 if call.nil?
+ parsed = parse_env(env, route)
+ puts "#{parsed[:from]} [#{parsed[:verb]}] \t ---> \t #{route}"
+ call = parse_path(parsed[:path], parsed[:verb])
+ return render(status: 404) if call.nil?
begin
controller = Module.const_get(call[:controller]).new(env, parsed, call)
return render(controller.send(call[:method]) || {status: 500})
rescue => err
return render(status: 500)