mirror of
https://github.com/mastodon/mastodon.git
synced 2024-12-23 01:25:36 +00:00
ddd0bb69e1
If Mastodon accesses to the hidden service via transparent proxy, it's needed to avoid checking whether it's a private address, since `.onion` is resolved to a private address. I was previously using the `HIDDEN_SERVICE_VIA_TRANSPARENT_PROXY` to provide that function. However, I realized that using `HIDDEN_SERVICE_VIA_TRANSPARENT_PROXY` is redundant, since this specification is always used with `ALLOW_ACCESS_TO_HIDDEN_SERVICE`. Therefore, I decided to integrate the setting of `HIDDEN_SERVICE_VIA_TRANSPARENT_PROXY` into` ALLOW_ACCESS_TO_HIDDEN_SERVICE`.
25 lines
1.1 KiB
Ruby
25 lines
1.1 KiB
Ruby
Rails.application.configure do
|
|
config.x.http_client_proxy = {}
|
|
if ENV['http_proxy'].present?
|
|
proxy = URI.parse(ENV['http_proxy'])
|
|
raise "Unsupported proxy type: #{proxy.scheme}" unless %w(http https).include? proxy.scheme
|
|
raise "No proxy host" unless proxy.host
|
|
|
|
host = proxy.host
|
|
host = host[1...-1] if host[0] == '[' #for IPv6 address
|
|
config.x.http_client_proxy[:proxy] = { proxy_address: host, proxy_port: proxy.port, proxy_username: proxy.user, proxy_password: proxy.password }.compact
|
|
end
|
|
|
|
config.x.access_to_hidden_service = ENV['ALLOW_ACCESS_TO_HIDDEN_SERVICE'] == 'true'
|
|
end
|
|
|
|
module Goldfinger
|
|
def self.finger(uri, opts = {})
|
|
to_hidden = /\.(onion|i2p)(:\d+)?$/.match(uri)
|
|
raise Mastodon::HostValidationError, 'Instance does not support hidden service connections' if !Rails.configuration.x.access_to_hidden_service && to_hidden
|
|
opts = { ssl: !to_hidden, headers: {} }.merge(Rails.configuration.x.http_client_proxy).merge(opts)
|
|
opts[:headers]['User-Agent'] ||= Mastodon::Version.user_agent
|
|
Goldfinger::Client.new(uri, opts).finger
|
|
end
|
|
end
|