16 lines
431 B
Ruby
16 lines
431 B
Ruby
|
# frozen_string_literal: true
|
||
|
|
||
|
module ActionDispatch
|
||
|
module CookieJarExtensions
|
||
|
private
|
||
|
|
||
|
# Monkey-patch ActionDispatch to serve secure cookies to Tor Hidden Service
|
||
|
# users. Otherwise, ActionDispatch would drop the cookie over HTTP.
|
||
|
def write_cookie?(*)
|
||
|
request.headers['Host'].ends_with?('.onion') || super
|
||
|
end
|
||
|
end
|
||
|
end
|
||
|
|
||
|
ActionDispatch::Cookies::CookieJar.prepend(ActionDispatch::CookieJarExtensions)
|