class Async::HTTP::Protocol::HTTP2::Server
def accept_stream(stream_id)
def accept_stream(stream_id) super do Request::Stream.create(self, stream_id) end end
def close(error = nil)
def close(error = nil) if @requests # Stop the request loop: @requests.enqueue(nil) @requests = nil end super end
def each(task: Task.current)
def each(task: Task.current) task.annotate("Reading #{version} requests for #{self.class}.") # It's possible the connection has died before we get here... @requests&.async do |task, request| task.annotate("Incoming request: #{request.method} #{request.path.inspect}.") @count += 1 begin response = yield(request) rescue # We need to close the stream if the user code blows up while generating a response: request.stream.send_reset_stream(::Protocol::HTTP2::INTERNAL_ERROR) raise else request.send_response(response) end end # Maybe we should add some synchronisation here - i.e. only exit once all requests are finished. end
def initialize(stream)
def initialize(stream) # Used by some generic methods in Connetion: @stream = stream framer = ::Protocol::HTTP2::Framer.new(stream) super(framer) @requests = Async::Queue.new end