summaryrefslogtreecommitdiff
path: root/lib/nickserver/dispatcher.rb
blob: 7a584e504c058ca6ef38a6cee2ae6f40f00471fb (plain)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
#
# Dispatcher
#
# Dispatch a request so it get's handled by the correct handler.
#
# The dispatcher hands a request to one handler after the other until one of
# them responds.
#
# This is similar to the Chain of Responsibility patter but we iterate over the
# 'handler_chain' array instead of a linked list.
#
# To change the order of handlers or add other handlers change the array in the
# handler_chain function.
#

require 'nickserver/request'
require 'nickserver/request_handlers/invalid_email_handler'
require 'nickserver/request_handlers/local_email_handler'
require 'nickserver/request_handlers/hkp_email_handler'
require 'nickserver/request_handlers/fingerprint_handler'

module Nickserver
  class Dispatcher

    def initialize(responder)
      @responder = responder
    end

    def respond_to(params, headers)
      request = Nickserver::Request.new params, headers
      response = handle request
      send_response response
    end

    protected

    def handle(request)
      handler_chain.each do |handler|
        response = handler.call request
        return response if response
      end
    rescue RuntimeError => exc
      puts "Error: #{exc}"
      puts exc.backtrace
      ErrorResponse.new(exc.to_s)
    end

    def handler_chain
      [
        RequestHandlers::InvalidEmailHandler,
        RequestHandlers::LocalEmailHandler,
        RequestHandlers::HkpEmailHandler,
        RequestHandlers::FingerprintHandler,
        Proc.new { Nickserver::Response.new(404, "404 Not Found\n") }
      ]
    end

    def send_response(response)
      responder.respond response.status, response.content
    end

    attr_reader :responder

  end
end