diff options
| author | Martin Schimandl | 2017-10-14 11:06:55 +0200 |
|---|---|---|
| committer | Martin Schimandl | 2017-12-03 11:37:18 +0100 |
| commit | e363889d27bb7fddaea513fb733c3c050d3af144 (patch) | |
| tree | 569b6e46cde22688f3111aa07a56d85ea27880ac /Library/Homebrew | |
| parent | 0d53831b902e2c9df5e6540822d1a8fd4672577d (diff) | |
| download | brew-e363889d27bb7fddaea513fb733c3c050d3af144.tar.bz2 | |
Add audit check for URL schema
Diffstat (limited to 'Library/Homebrew')
| -rw-r--r-- | Library/Homebrew/cask/lib/hbc/audit.rb | 73 |
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" |
