2018-12-13 13:39:08 +05:30
|
|
|
# frozen_string_literal: true
|
|
|
|
|
2018-03-26 14:24:53 +05:30
|
|
|
# This class is part of the Gitlab::HTTP wrapper. Depending on the value
|
|
|
|
# of the global setting allow_local_requests_from_hooks_and_services this adapter
|
|
|
|
# will allow/block connection to internal IPs and/or urls.
|
|
|
|
#
|
2018-12-13 13:39:08 +05:30
|
|
|
# This functionality can be overridden by providing the setting the option
|
2018-03-26 14:24:53 +05:30
|
|
|
# allow_local_requests = true in the request. For example:
|
|
|
|
# Gitlab::HTTP.get('http://www.gitlab.com', allow_local_requests: true)
|
|
|
|
#
|
|
|
|
# This option will take precedence over the global setting.
|
|
|
|
module Gitlab
|
|
|
|
class ProxyHTTPConnectionAdapter < HTTParty::ConnectionAdapter
|
|
|
|
def connection
|
2018-05-09 12:01:36 +05:30
|
|
|
unless allow_local_requests?
|
|
|
|
begin
|
|
|
|
Gitlab::UrlBlocker.validate!(uri, allow_local_network: false)
|
|
|
|
rescue Gitlab::UrlBlocker::BlockedUrlError => e
|
|
|
|
raise Gitlab::HTTP::BlockedUrlError, "URL '#{uri}' is blocked: #{e.message}"
|
|
|
|
end
|
2018-03-26 14:24:53 +05:30
|
|
|
end
|
|
|
|
|
|
|
|
super
|
|
|
|
end
|
|
|
|
|
|
|
|
private
|
|
|
|
|
|
|
|
def allow_local_requests?
|
|
|
|
options.fetch(:allow_local_requests, allow_settings_local_requests?)
|
|
|
|
end
|
|
|
|
|
|
|
|
def allow_settings_local_requests?
|
|
|
|
Gitlab::CurrentSettings.allow_local_requests_from_hooks_and_services?
|
|
|
|
end
|
|
|
|
end
|
|
|
|
end
|