Class: RFlow::Components::HTTP::Server::Connection

Inherits:
EventMachine::Connection
  • Object
show all
Includes:
EventMachine::HttpServer
Defined in:
lib/rflow/components/http/server.rb

Instance Attribute Summary collapse

Instance Method Summary collapse

Instance Attribute Details

#client_ipObject (readonly)

Returns the value of attribute client_ip.



69
70
71
# File 'lib/rflow/components/http/server.rb', line 69

def client_ip
  @client_ip
end

#client_portObject (readonly)

Returns the value of attribute client_port.



69
70
71
# File 'lib/rflow/components/http/server.rb', line 69

def client_port
  @client_port
end

#serverObject

Returns the value of attribute server.



68
69
70
# File 'lib/rflow/components/http/server.rb', line 68

def server
  @server
end

#server_ipObject (readonly)

Returns the value of attribute server_ip.



69
70
71
# File 'lib/rflow/components/http/server.rb', line 69

def server_ip
  @server_ip
end

#server_portObject (readonly)

Returns the value of attribute server_port.



69
70
71
# File 'lib/rflow/components/http/server.rb', line 69

def server_port
  @server_port
end

Instance Method Details

#client_detailsObject



78
79
80
81
82
83
84
# File 'lib/rflow/components/http/server.rb', line 78

def client_details
  if @real_client_ip
    "#{client_ip}:#{client_port} (proxied from #{@real_client_ip}:#{@real_client_port})"
  else
    "#{client_ip}:#{client_port}"
  end
end

#post_initObject



71
72
73
74
75
76
# File 'lib/rflow/components/http/server.rb', line 71

def post_init
  @client_port, @client_ip = Socket.unpack_sockaddr_in(get_peername) rescue ["?", "?.?.?.?"]
  @server_port, @server_ip = Socket.unpack_sockaddr_in(get_sockname) rescue ["?", "?.?.?.?"]
  super
  no_environment_strings
end

#process_http_requestObject



99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
124
125
126
127
128
129
130
131
132
133
134
135
136
# File 'lib/rflow/components/http/server.rb', line 99

def process_http_request
  RFlow.logger.debug { "#{server.name}: Received HTTP request from #{client_details} to #{server_details} for #{@http_request_uri}" }

  server.request_port.send_message(RFlow::Message.new('RFlow::Message::Data::HTTP::Request').tap do |m|
    m.data.client_ip    = client_ip
    m.data.client_port  = client_port
    m.data.server_ip    = server_ip
    m.data.server_port  = server_port

    m.data.method       = @http_request_method
    m.data.uri          = @http_request_uri
    m.data.query_string = @http_query_string
    m.data.protocol     = @http_protocol
    m.data.content      = @http_post_content
    m.data.headers      = {}

    @http_headers.split(/\0/).each do |header|
      name, val = header.split(/:\s*/, 2)
      m.data.headers[name] = val
      if server.proxy_real_client_ip_header && (name == server.proxy_real_client_ip_header)
        @real_client_ip ||= val
      elsif server.proxy_real_client_port_header && (name == server.proxy_real_client_port_header)
        @real_client_port ||= val
      elsif server.proxy_real_server_ip_header && (name == server.proxy_real_server_ip_header)
        @real_server_ip ||= val
      elsif server.proxy_real_server_port_header && (name == server.proxy_real_server_port_header)
        @real_server_port ||= val
      end
    end

    m.provenance << RFlow::Message::ProcessingEvent.new(server.uuid, Time.now.utc).tap do |e|
      e.context = signature.to_s
      e.completed_at = Time.now.utc
    end
  end)
rescue Exception => e
  RFlow.logger.error "#{server.name}: Error processing HTTP request from #{client_details} to #{server_details} for #{@http_request_uri}: #{e.class.name}: #{e.message}, because: #{e.backtrace.inspect}"
end

#receive_data(data) ⇒ Object



94
95
96
97
# File 'lib/rflow/components/http/server.rb', line 94

def receive_data(data)
  RFlow.logger.debug { "#{server.name}: Received #{data.bytesize} bytes of data from #{client_details} to #{server_details}" }
  super
end

#send_http_response(response_message = nil) ⇒ Object



138
139
140
141
142
143
144
145
146
147
148
149
150
151
152
153
154
155
156
157
158
159
# File 'lib/rflow/components/http/server.rb', line 138

def send_http_response(response_message = nil)
  resp = EventMachine::DelegatedHttpResponse.new(self).tap do |r|
    # Default values
    r.status                  = 200
    r.content                 = ""
    r.headers["Content-Type"] = "text/html"
    r.headers["Server"]       = "Apache"

    if response_message
      r.status  = response_message.data.status_code
      r.content = response_message.data.content
      response_message.data.headers.each do |header, value|
        r.headers[header] = value
      end
    end
  end

  RFlow.logger.debug { "#{server.name}: Sending an HTTP response #{resp.status} to #{client_details}" }

  resp.send_response
  close_connection_after_writing
end

#server_detailsObject



86
87
88
89
90
91
92
# File 'lib/rflow/components/http/server.rb', line 86

def server_details
  if @real_server_ip
    "#{server_ip}:#{server_port} (proxied as #{@real_server_ip}:#{@real_server_port})"
  else
    "#{server_ip}:#{server_port}"
  end
end

#unbind(reason = nil) ⇒ Object

Called when a connection is torn down for whatever reason. Remove this connection from the server’s list



163
164
165
166
167
168
# File 'lib/rflow/components/http/server.rb', line 163

def unbind(reason = nil)
  RFlow.logger.debug { "#{server.name}: Disconnected from HTTP client #{client_details}#{reason.nil? ? '' : " due to '#{reason}'"}" }
  server.closed_connections.write(signature.to_s, ClosedConnection.new(client_details))
  server.connections.delete(signature.to_s)
  super()
end