aboutsummaryrefslogtreecommitdiffstats
path: root/Library/Homebrew
diff options
context:
space:
mode:
authorMartin Schimandl2017-10-14 11:06:55 +0200
committerMartin Schimandl2017-12-03 11:37:18 +0100
commite363889d27bb7fddaea513fb733c3c050d3af144 (patch)
tree569b6e46cde22688f3111aa07a56d85ea27880ac /Library/Homebrew
parent0d53831b902e2c9df5e6540822d1a8fd4672577d (diff)
downloadbrew-e363889d27bb7fddaea513fb733c3c050d3af144.tar.bz2
Add audit check for URL schema
Diffstat (limited to 'Library/Homebrew')
-rw-r--r--Library/Homebrew/cask/lib/hbc/audit.rb73
1 files changed, 73 insertions, 0 deletions
diff --git a/Library/Homebrew/cask/lib/hbc/audit.rb b/Library/Homebrew/cask/lib/hbc/audit.rb
index d757b0623..8520f651f 100644
--- a/Library/Homebrew/cask/lib/hbc/audit.rb
+++ b/Library/Homebrew/cask/lib/hbc/audit.rb
@@ -30,6 +30,7 @@ module Hbc
check_url
check_generic_artifacts
check_token_conflicts
+ check_https_availability
check_download
check_single_pre_postflight
check_single_uninstall_zap
@@ -275,6 +276,78 @@ module Hbc
"#{core_tap.default_remote}/blob/master/Formula/#{cask.token}.rb"
end
+ def check_https_availability
+ check_url_for_https_availability(cask.homepage) unless cask.url.to_s.empty?
+ check_url_for_https_availability(cask.appcast) unless cask.appcast.to_s.empty?
+ check_url_for_https_availability(cask.homepage) unless cask.homepage.to_s.empty?
+ end
+
+ def check_url_for_https_availability(url_to_check)
+ if schema_http?(url_to_check)
+ result, effective_url = access_url(url_to_check.sub(/^http:/, 'https:'))
+ if schema_https?(effective_url) && result == 1
+ add_error "Change #{url_to_check} to #{url_to_check.sub(/^http:/, 'https:')}"
+ else
+ result, effective_url = access_url(url_to_check)
+
+ if result == 0
+ add_error "URL is not reachable #{url_to_check}"
+ end
+ end
+ else
+ result, effective_url = access_url(url_to_check)
+ if result == 1 && schema_https?(effective_url)
+ return
+ else
+ result, effective_url = access_url(url_to_check.sub(/^https:/, 'http:'))
+ if result == 1 && schema_http?(effective_url)
+ add_error "Change #{url_to_check} to #{url_to_check.sub(/^https:/, 'http:')}"
+ else
+ add_error "URL is not reachable #{url_to_check}"
+ end
+ end
+ end
+ end
+
+ def access_url(url_to_access)
+ # return values:
+ # 1, effective URL : URL reachable, no schema change
+ # 0, nil : URL unreachable
+ # -1, effective URL : URL reachable, but schema changed
+
+ curl_executable, *args = curl_args(
+ "--compressed", "--location", "--fail",
+ "--write-out", "%{http_code} %{url_effective}",
+ "--output", "/dev/null",
+ url_to_access,
+ user_agent: :fake
+ )
+ result = @command.run(curl_executable, args: args, print_stderr: false)
+ if result.success?
+ http_code, url_effective = result.stdout.chomp.split(' ')
+ odebug "input: #{url_to_access} effective: #{url_effective} code: #{http_code}"
+
+ # Fail if return code not 2XX or 3XX
+ return 0, nil if http_code.to_i < 200 && http_code.to_i > 300
+
+ # Fail if URL schema changed
+ # ([4] is either http[s]:// or http[:]// )
+ return -1, url_effective if url_to_access[4] != url_effective[4]
+
+ return 1, url_effective
+ else
+ return 0, nil
+ end
+ end
+
+ def schema_http?(url)
+ url[/^http:/] ? 1 : nil
+ end
+
+ def schema_https?(url)
+ url[/^https:/] ? 1 : nil
+ end
+
def check_download
return unless download && cask.url
odebug "Auditing download"