This repository has been archived on 2024-07-22. You can view files and clone it, but cannot push or open issues or pull requests.
2021-02-11 14:47:05 -08:00
|
|
|
# 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?(*)
|
2021-02-19 00:56:14 -08:00
|
|
|
request.host.end_with?('.onion') || super
|
2021-02-11 14:47:05 -08:00
|
|
|
end
|
|
|
|
end
|
|
|
|
end
|
|
|
|
|
|
|
|
ActionDispatch::Cookies::CookieJar.prepend(ActionDispatch::CookieJarExtensions)
|
2021-02-13 15:10:52 -08:00
|
|
|
|
|
|
|
module Rack
|
|
|
|
module SessionPersistedExtensions
|
|
|
|
def security_matches?(request, options)
|
2021-02-19 00:56:14 -08:00
|
|
|
request.host.end_with?('.onion') || super
|
2021-02-13 15:10:52 -08:00
|
|
|
end
|
|
|
|
end
|
|
|
|
end
|
|
|
|
|
|
|
|
Rack::Session::Abstract::Persisted.prepend(Rack::SessionPersistedExtensions)
|