aboutsummaryrefslogtreecommitdiff
path: root/app/helpers/webfinger_helper.rb
diff options
context:
space:
mode:
authorTakeshi Umeda <noel.yoshiba@gmail.com>2021-01-10 11:17:55 +0900
committerGitHub <noreply@github.com>2021-01-10 11:17:55 +0900
commit98a2603dc163210d3a0aab0a0c2b8ef74c7e5eb0 (patch)
tree761694d2d697c58faf02a3ff9ef26bf045fc0274 /app/helpers/webfinger_helper.rb
parent7cd4ed7d4298626d2b141cd6d8378e95bc248824 (diff)
parent087ed84367537ac168ed3e00bb7eb4bd582dc3d0 (diff)
downloadmastodon-feature-limited-visibility-bearcaps.tar
mastodon-feature-limited-visibility-bearcaps.tar.gz
mastodon-feature-limited-visibility-bearcaps.tar.bz2
mastodon-feature-limited-visibility-bearcaps.zip
Merge branch 'master' into feature-limited-visibility-bearcapsfeature-limited-visibility-bearcaps
Diffstat (limited to 'app/helpers/webfinger_helper.rb')
-rw-r--r--app/helpers/webfinger_helper.rb33
1 files changed, 1 insertions, 32 deletions
diff --git a/app/helpers/webfinger_helper.rb b/app/helpers/webfinger_helper.rb
index ab7ca4698..482f4e19e 100644
--- a/app/helpers/webfinger_helper.rb
+++ b/app/helpers/webfinger_helper.rb
@@ -1,38 +1,7 @@
# frozen_string_literal: true
-# Monkey-patch on monkey-patch.
-# Because it conflicts with the request.rb patch.
-class HTTP::Timeout::PerOperationOriginal < HTTP::Timeout::PerOperation
- def connect(socket_class, host, port, nodelay = false)
- ::Timeout.timeout(@connect_timeout, HTTP::TimeoutError) do
- @socket = socket_class.open(host, port)
- @socket.setsockopt(Socket::IPPROTO_TCP, Socket::TCP_NODELAY, 1) if nodelay
- end
- end
-end
-
module WebfingerHelper
def webfinger!(uri)
- hidden_service_uri = /\.(onion|i2p)(:\d+)?$/.match(uri)
-
- raise Mastodon::HostValidationError, 'Instance does not support hidden service connections' if !Rails.configuration.x.access_to_hidden_service && hidden_service_uri
-
- opts = {
- ssl: !hidden_service_uri,
-
- headers: {
- 'User-Agent': Mastodon::Version.user_agent,
- },
-
- timeout_class: HTTP::Timeout::PerOperationOriginal,
-
- timeout_options: {
- write_timeout: 10,
- connect_timeout: 5,
- read_timeout: 10,
- },
- }
-
- Goldfinger::Client.new(uri, opts.merge(Rails.configuration.x.http_client_proxy)).finger
+ Webfinger.new(uri).perform
end
end