From dc54ccdcba8946b153685961b90adab4c34c5e04 Mon Sep 17 00:00:00 2001 From: Samuel Williams Date: Sun, 5 Jan 2025 11:48:36 +1300 Subject: [PATCH] Improve compatibility of rackup handler, w.r.t sinatra. --- examples/sinatra/Gemfile | 9 ++- examples/sinatra/Gemfile.lock | 104 ++++++++++++++++++++++++++++++++++ examples/sinatra/app.rb | 18 ++++++ examples/sinatra/config.ru | 1 + lib/falcon/rackup/handler.rb | 2 - lib/rack/handler/falcon.rb | 10 +++- lib/rackup/handler/falcon.rb | 8 ++- releases.md | 4 ++ 8 files changed, 150 insertions(+), 6 deletions(-) create mode 100644 examples/sinatra/Gemfile.lock create mode 100755 examples/sinatra/app.rb diff --git a/examples/sinatra/Gemfile b/examples/sinatra/Gemfile index afbfe0de..8a993078 100644 --- a/examples/sinatra/Gemfile +++ b/examples/sinatra/Gemfile @@ -4,4 +4,11 @@ source "https://rubygems.org" gem "sinatra" -gem "falcon" +gem "falcon", path: "../.." + +# Rack dependency: + +gem "rack", "~> 2.0" +# or: +# gem "rack", "~> 3.0" +# gem "rackup" diff --git a/examples/sinatra/Gemfile.lock b/examples/sinatra/Gemfile.lock new file mode 100644 index 00000000..85ef4ad3 --- /dev/null +++ b/examples/sinatra/Gemfile.lock @@ -0,0 +1,104 @@ +PATH + remote: ../.. + specs: + falcon (0.48.3) + async + async-container (~> 0.18) + async-http (~> 0.75) + async-http-cache (~> 0.4) + async-service (~> 0.10) + bundler + localhost (~> 1.1) + openssl (~> 3.0) + process-metrics (~> 0.2) + protocol-http (~> 0.31) + protocol-rack (~> 0.7) + samovar (~> 2.3) + +GEM + remote: https://rubygems.org/ + specs: + async (2.21.1) + console (~> 1.29) + fiber-annotation + io-event (~> 1.6, >= 1.6.5) + async-container (0.18.3) + async (~> 2.10) + async-http (0.86.0) + async (>= 2.10.2) + async-pool (~> 0.9) + io-endpoint (~> 0.14) + io-stream (~> 0.6) + metrics (~> 0.12) + protocol-http (~> 0.43) + protocol-http1 (>= 0.28.1) + protocol-http2 (~> 0.22) + traces (~> 0.10) + async-http-cache (0.4.4) + async-http (~> 0.56) + async-pool (0.10.2) + async (>= 1.25) + traces + async-service (0.12.0) + async + async-container (~> 0.16) + base64 (0.2.0) + console (1.29.2) + fiber-annotation + fiber-local (~> 1.1) + json + fiber-annotation (0.2.0) + fiber-local (1.1.0) + fiber-storage + fiber-storage (1.0.0) + io-endpoint (0.14.0) + io-event (1.7.5) + io-stream (0.6.1) + json (2.9.1) + localhost (1.3.1) + mapping (1.1.1) + metrics (0.12.1) + mustermann (3.0.3) + ruby2_keywords (~> 0.0.1) + openssl (3.3.0) + process-metrics (0.3.0) + console (~> 1.8) + json (~> 2) + samovar (~> 2.1) + protocol-hpack (1.5.1) + protocol-http (0.47.1) + protocol-http1 (0.28.1) + protocol-http (~> 0.22) + protocol-http2 (0.22.0) + protocol-hpack (~> 1.4) + protocol-http (~> 0.18) + protocol-rack (0.11.1) + protocol-http (~> 0.43) + rack (>= 1.0) + rack (2.2.10) + rack-protection (3.2.0) + base64 (>= 0.1.0) + rack (~> 2.2, >= 2.2.4) + ruby2_keywords (0.0.5) + samovar (2.3.0) + console (~> 1.0) + mapping (~> 1.0) + sinatra (3.2.0) + mustermann (~> 3.0) + rack (~> 2.2, >= 2.2.4) + rack-protection (= 3.2.0) + tilt (~> 2.0) + tilt (2.5.0) + traces (0.14.1) + +PLATFORMS + ruby + x86_64-linux + +DEPENDENCIES + falcon! + rack (~> 2.0) + sinatra + +BUNDLED WITH + 2.5.22 diff --git a/examples/sinatra/app.rb b/examples/sinatra/app.rb new file mode 100755 index 00000000..47ccc23e --- /dev/null +++ b/examples/sinatra/app.rb @@ -0,0 +1,18 @@ +#!/usr/bin/env ruby + +# To run this example, you need to install the `sinatra` gem: +# $ bundle install +# $ bundle exec ./app.rb + +require 'sinatra/base' + +class Server < Sinatra::Application + set :server, :falcon + + # Hello World: + get '/' do + "Hello, World!" + end +end + +Server.run! diff --git a/examples/sinatra/config.ru b/examples/sinatra/config.ru index 09edbd7a..f96e3cae 100755 --- a/examples/sinatra/config.ru +++ b/examples/sinatra/config.ru @@ -5,6 +5,7 @@ # Middleware that responds to incoming requests: require "sinatra/base" + class MyApp < Sinatra::Base get "/" do response = Faraday.get "http://sushi.com/nigiri/sake.json" diff --git a/lib/falcon/rackup/handler.rb b/lib/falcon/rackup/handler.rb index a6c1bf78..b1ca7b14 100644 --- a/lib/falcon/rackup/handler.rb +++ b/lib/falcon/rackup/handler.rb @@ -3,8 +3,6 @@ # Released under the MIT License. # Copyright, 2024, by Samuel Williams. -require "rackup/handler" - require_relative "../../falcon" require "kernel/sync" diff --git a/lib/rack/handler/falcon.rb b/lib/rack/handler/falcon.rb index 3b319c7b..f2949b27 100644 --- a/lib/rack/handler/falcon.rb +++ b/lib/rack/handler/falcon.rb @@ -8,9 +8,15 @@ require_relative "../../falcon/rackup/handler" +# Generally speaking, you should not require this file directly, or assume the existance of the `Rack::Handler::Falcon` constant. Instead, use `Rack::Handler.get(:falcon)` to load and access the handler. + module Rack module Handler - Falcon = ::Falcon::Rackup::Handler - register :falcon, Falcon + # Rack (v2) expects the constant to be in the `Rack::Handler` namespace, so we define a new handler class in the `Rack::Handler` namespace that inherits from `Falcon::Rackup::Handler`. + class Falcon < ::Falcon::Rackup::Handler + end + + # Rack (v2) expects a string for the handler constant name. `Falcon.to_s` returns a more human friendly name, so we explicitly pass `Falcon.name` to `register` to ensure Rack can find the handler using the registered name. + register :falcon, Falcon.name end end diff --git a/lib/rackup/handler/falcon.rb b/lib/rackup/handler/falcon.rb index 9f3e73f0..13949a69 100644 --- a/lib/rackup/handler/falcon.rb +++ b/lib/rackup/handler/falcon.rb @@ -7,9 +7,15 @@ require_relative "../../falcon/rackup/handler" +# Generally speaking, you should not require this file directly, or assume the existance of the `Rackup::Handler::Falcon` constant. Instead, use `Rackup::Handler.get(:falcon)` to load and access the handler. + module Rackup module Handler - Falcon = ::Falcon::Rackup::Handler + # Sinatra (and possibly others) try to extract the name using the final part of the class path, so we define a new class in the `Rack::Handler` namespace that inherits from `Falcon::Rackup::Handler`, that follows that convention. + class Falcon < ::Falcon::Rackup::Handler + end + + # Rack (v3) expects a class for the handler constant, so we explicitly pass `Falcon` to `register` to ensure Rack can find the handler using the registered name. register :falcon, Falcon end end diff --git a/releases.md b/releases.md index 236eb5ea..808d659e 100644 --- a/releases.md +++ b/releases.md @@ -1,5 +1,9 @@ # Releases +## Unreleased + + - Improve compatibility of rackup handler w.r.t. sinatra. + ## v0.47.8 - Fix Falcon Supervisor implementation: due to invalid code, it was unable to start.