| 
									
										
										
										
											2025-02-24 14:49:33 -08:00
										 |  |  | # typed: strict | 
					
						
							| 
									
										
										
										
											2019-04-19 15:38:03 +09:00
										 |  |  | # frozen_string_literal: true | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2020-08-09 01:34:07 +02:00
										 |  |  | require "cask/audit" | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2018-09-06 08:29:14 +02:00
										 |  |  | module Cask | 
					
						
							| 
									
										
										
										
											2020-08-24 21:33:45 +02:00
										 |  |  |   # Helper class for auditing all available languages of a cask. | 
					
						
							| 
									
										
										
										
											2016-09-24 13:52:43 +02:00
										 |  |  |   class Auditor | 
					
						
							| 
									
										
										
										
											2025-02-24 14:49:33 -08:00
										 |  |  |     # TODO: use argument forwarding (...) when Sorbet supports it in strict mode | 
					
						
							|  |  |  |     sig { | 
					
						
							|  |  |  |       params( | 
					
						
							|  |  |  |         cask: ::Cask::Cask, audit_download: T::Boolean, audit_online: T.nilable(T::Boolean), | 
					
						
							|  |  |  |         audit_strict: T.nilable(T::Boolean), audit_signing: T.nilable(T::Boolean), | 
					
						
							| 
									
										
										
										
											2025-06-23 16:08:13 +01:00
										 |  |  |         audit_new_cask: T.nilable(T::Boolean), quarantine: T::Boolean, | 
					
						
							| 
									
										
										
										
											2025-02-24 14:49:33 -08:00
										 |  |  |         any_named_args: T::Boolean, language: T.nilable(String), only: T::Array[String], except: T::Array[String] | 
					
						
							|  |  |  |       ).returns(T::Set[String]) | 
					
						
							|  |  |  |     } | 
					
						
							|  |  |  |     def self.audit( | 
					
						
							|  |  |  |       cask, audit_download: false, audit_online: nil, audit_strict: nil, audit_signing: nil, | 
					
						
							| 
									
										
										
										
											2025-06-23 16:08:13 +01:00
										 |  |  |       audit_new_cask: nil, quarantine: false, any_named_args: false, language: nil, | 
					
						
							| 
									
										
										
										
											2025-02-24 14:49:33 -08:00
										 |  |  |       only: [], except: [] | 
					
						
							|  |  |  |     ) | 
					
						
							|  |  |  |       new( | 
					
						
							| 
									
										
										
										
											2025-06-23 16:08:13 +01:00
										 |  |  |         cask, audit_download:, audit_online:, audit_strict:, audit_signing:, | 
					
						
							| 
									
										
										
										
											2025-02-24 14:49:33 -08:00
										 |  |  |         audit_new_cask:, quarantine:, any_named_args:, language:, only:, except: | 
					
						
							|  |  |  |       ).audit | 
					
						
							| 
									
										
										
										
											2016-10-24 04:08:56 -04:00
										 |  |  |     end | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2025-02-24 14:49:33 -08:00
										 |  |  |     sig { returns(::Cask::Cask) } | 
					
						
							|  |  |  |     attr_reader :cask | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     sig { returns(T.nilable(String)) } | 
					
						
							|  |  |  |     attr_reader :language | 
					
						
							| 
									
										
										
										
											2016-10-24 04:08:56 -04:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2025-02-24 14:49:33 -08:00
										 |  |  |     sig { | 
					
						
							|  |  |  |       params( | 
					
						
							|  |  |  |         cask: ::Cask::Cask, audit_download: T::Boolean, audit_online: T.nilable(T::Boolean), | 
					
						
							|  |  |  |         audit_strict: T.nilable(T::Boolean), audit_signing: T.nilable(T::Boolean), | 
					
						
							| 
									
										
										
										
											2025-06-23 16:08:13 +01:00
										 |  |  |         audit_new_cask: T.nilable(T::Boolean), quarantine: T::Boolean, | 
					
						
							| 
									
										
										
										
											2025-02-24 14:49:33 -08:00
										 |  |  |         any_named_args: T::Boolean, language: T.nilable(String), only: T::Array[String], except: T::Array[String] | 
					
						
							|  |  |  |       ).void | 
					
						
							|  |  |  |     } | 
					
						
							| 
									
										
										
										
											2020-09-04 04:14:37 +02:00
										 |  |  |     def initialize( | 
					
						
							|  |  |  |       cask, | 
					
						
							| 
									
										
										
										
											2025-02-24 14:49:33 -08:00
										 |  |  |       audit_download: false, | 
					
						
							| 
									
										
										
										
											2020-09-04 04:14:37 +02:00
										 |  |  |       audit_online: nil, | 
					
						
							|  |  |  |       audit_strict: nil, | 
					
						
							| 
									
										
										
										
											2022-08-01 14:30:04 +02:00
										 |  |  |       audit_signing: nil, | 
					
						
							| 
									
										
										
										
											2020-09-04 04:14:37 +02:00
										 |  |  |       audit_new_cask: nil, | 
					
						
							| 
									
										
										
										
											2025-02-24 14:49:33 -08:00
										 |  |  |       quarantine: false, | 
					
						
							|  |  |  |       any_named_args: false, | 
					
						
							| 
									
										
										
										
											2021-03-21 13:59:43 -04:00
										 |  |  |       language: nil, | 
					
						
							| 
									
										
										
										
											2023-02-05 15:22:06 +01:00
										 |  |  |       only: [], | 
					
						
							|  |  |  |       except: [] | 
					
						
							| 
									
										
										
										
											2020-09-04 04:14:37 +02:00
										 |  |  |     ) | 
					
						
							| 
									
										
										
										
											2016-10-24 04:08:56 -04:00
										 |  |  |       @cask = cask | 
					
						
							|  |  |  |       @audit_download = audit_download | 
					
						
							| 
									
										
										
										
											2020-04-23 21:16:17 +02:00
										 |  |  |       @audit_online = audit_online | 
					
						
							|  |  |  |       @audit_new_cask = audit_new_cask | 
					
						
							| 
									
										
										
										
											2020-09-04 04:14:37 +02:00
										 |  |  |       @audit_strict = audit_strict | 
					
						
							| 
									
										
										
										
											2022-08-01 14:30:04 +02:00
										 |  |  |       @audit_signing = audit_signing | 
					
						
							| 
									
										
										
										
											2018-08-31 13:16:11 +00:00
										 |  |  |       @quarantine = quarantine | 
					
						
							| 
									
										
										
										
											2021-01-07 13:31:14 +00:00
										 |  |  |       @any_named_args = any_named_args | 
					
						
							| 
									
										
										
										
											2020-08-01 02:30:46 +02:00
										 |  |  |       @language = language | 
					
						
							| 
									
										
										
										
											2023-02-05 15:22:06 +01:00
										 |  |  |       @only = only | 
					
						
							|  |  |  |       @except = except | 
					
						
							| 
									
										
										
										
											2016-10-24 04:08:56 -04:00
										 |  |  |     end | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2023-02-28 18:54:27 +11:00
										 |  |  |     LANGUAGE_BLOCK_LIMIT = 10
 | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2025-02-24 14:49:33 -08:00
										 |  |  |     sig { returns(T::Set[String]) } | 
					
						
							| 
									
										
										
										
											2016-10-24 04:08:56 -04:00
										 |  |  |     def audit | 
					
						
							| 
									
										
										
										
											2020-07-28 09:08:37 +02:00
										 |  |  |       errors = Set.new | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2025-04-23 09:16:38 -04:00
										 |  |  |       if !language && !(blocks = language_blocks).empty? | 
					
						
							| 
									
										
										
										
											2025-02-24 14:49:33 -08:00
										 |  |  |         sample_languages = if blocks.length > LANGUAGE_BLOCK_LIMIT && !@audit_new_cask | 
					
						
							|  |  |  |           sample_keys = T.must(blocks.keys.sample(LANGUAGE_BLOCK_LIMIT)) | 
					
						
							| 
									
										
										
										
											2024-02-04 15:19:29 +01:00
										 |  |  |           ohai "Auditing a sample of available languages for #{cask}: " \ | 
					
						
							|  |  |  |                "#{sample_keys.map { |lang| lang[0].to_s }.to_sentence}" | 
					
						
							| 
									
										
										
										
											2025-02-24 14:49:33 -08:00
										 |  |  |           blocks.select { |k| sample_keys.include?(k) } | 
					
						
							| 
									
										
										
										
											2023-02-28 18:54:27 +11:00
										 |  |  |         else | 
					
						
							| 
									
										
										
										
											2025-02-24 14:49:33 -08:00
										 |  |  |           blocks | 
					
						
							| 
									
										
										
										
											2023-02-28 18:54:27 +11:00
										 |  |  |         end | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |         sample_languages.each_key do |l| | 
					
						
							| 
									
										
										
										
											2020-07-28 09:08:37 +02:00
										 |  |  |           audit = audit_languages(l) | 
					
						
							| 
									
										
										
										
											2023-03-30 23:52:24 +01:00
										 |  |  |           if audit.summary.present? && output_summary?(audit) | 
					
						
							| 
									
										
										
										
											2021-03-21 13:59:43 -04:00
										 |  |  |             ohai "Auditing language: #{l.map { |lang| "'#{lang}'" }.to_sentence}" if output_summary? | 
					
						
							| 
									
										
										
										
											2023-03-30 23:52:24 +01:00
										 |  |  |             puts audit.summary | 
					
						
							| 
									
										
										
										
											2021-03-21 13:59:43 -04:00
										 |  |  |           end | 
					
						
							| 
									
										
										
										
											2020-07-28 09:08:37 +02:00
										 |  |  |           errors += audit.errors | 
					
						
							|  |  |  |         end | 
					
						
							| 
									
										
										
										
											2016-09-25 22:47:31 +02:00
										 |  |  |       else | 
					
						
							| 
									
										
										
										
											2020-07-28 09:08:37 +02:00
										 |  |  |         audit = audit_cask_instance(cask) | 
					
						
							| 
									
										
										
										
											2023-03-30 23:52:24 +01:00
										 |  |  |         puts audit.summary if audit.summary.present? && output_summary?(audit) | 
					
						
							| 
									
										
										
										
											2020-07-28 09:08:37 +02:00
										 |  |  |         errors += audit.errors | 
					
						
							| 
									
										
										
										
											2016-09-25 22:47:31 +02:00
										 |  |  |       end | 
					
						
							| 
									
										
										
										
											2020-07-28 09:08:37 +02:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2023-04-04 17:22:00 +01:00
										 |  |  |       errors | 
					
						
							| 
									
										
										
										
											2016-09-25 22:47:31 +02:00
										 |  |  |     end | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2016-10-24 04:08:56 -04:00
										 |  |  |     private | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2025-02-24 14:49:33 -08:00
										 |  |  |     sig { params(audit: T.nilable(Audit)).returns(T::Boolean) } | 
					
						
							| 
									
										
										
										
											2021-01-07 13:31:14 +00:00
										 |  |  |     def output_summary?(audit = nil) | 
					
						
							| 
									
										
										
										
											2025-02-24 14:49:33 -08:00
										 |  |  |       return true if @any_named_args | 
					
						
							|  |  |  |       return true if @audit_strict | 
					
						
							|  |  |  |       return false if audit.nil? | 
					
						
							| 
									
										
										
										
											2021-01-07 13:31:14 +00:00
										 |  |  | 
 | 
					
						
							|  |  |  |       audit.errors? | 
					
						
							|  |  |  |     end | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2025-02-24 14:49:33 -08:00
										 |  |  |     sig { params(languages: T::Array[String]).returns(::Cask::Audit) } | 
					
						
							| 
									
										
										
										
											2021-03-21 13:59:43 -04:00
										 |  |  |     def audit_languages(languages) | 
					
						
							| 
									
										
										
										
											2020-09-29 23:46:30 +02:00
										 |  |  |       original_config = cask.config | 
					
						
							| 
									
										
										
										
											2024-03-07 16:20:20 +00:00
										 |  |  |       localized_config = original_config.merge(Config.new(explicit: { languages: })) | 
					
						
							| 
									
										
										
										
											2020-09-29 23:46:30 +02:00
										 |  |  |       cask.config = localized_config | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |       audit_cask_instance(cask) | 
					
						
							|  |  |  |     ensure | 
					
						
							|  |  |  |       cask.config = original_config | 
					
						
							| 
									
										
										
										
											2016-10-24 04:08:56 -04:00
										 |  |  |     end | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2025-02-24 14:49:33 -08:00
										 |  |  |     sig { params(cask: ::Cask::Cask).returns(::Cask::Audit) } | 
					
						
							| 
									
										
										
										
											2016-10-24 04:08:56 -04:00
										 |  |  |     def audit_cask_instance(cask) | 
					
						
							| 
									
										
										
										
											2020-09-04 04:14:37 +02:00
										 |  |  |       audit = Audit.new( | 
					
						
							|  |  |  |         cask, | 
					
						
							| 
									
										
										
										
											2025-06-23 16:08:13 +01:00
										 |  |  |         online:     @audit_online, | 
					
						
							|  |  |  |         strict:     @audit_strict, | 
					
						
							|  |  |  |         signing:    @audit_signing, | 
					
						
							|  |  |  |         new_cask:   @audit_new_cask, | 
					
						
							|  |  |  |         download:   @audit_download, | 
					
						
							|  |  |  |         quarantine: @quarantine, | 
					
						
							|  |  |  |         only:       @only, | 
					
						
							|  |  |  |         except:     @except, | 
					
						
							| 
									
										
										
										
											2020-09-04 04:14:37 +02:00
										 |  |  |       ) | 
					
						
							| 
									
										
										
										
											2016-09-24 13:52:43 +02:00
										 |  |  |       audit.run! | 
					
						
							|  |  |  |     end | 
					
						
							| 
									
										
										
										
											2016-10-24 04:08:56 -04:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2025-04-23 09:16:38 -04:00
										 |  |  |     sig { returns(T::Hash[T::Array[String], T.proc.returns(T.untyped)]) } | 
					
						
							| 
									
										
										
										
											2016-10-24 04:08:56 -04:00
										 |  |  |     def language_blocks | 
					
						
							|  |  |  |       cask.instance_variable_get(:@dsl).instance_variable_get(:@language_blocks) | 
					
						
							|  |  |  |     end | 
					
						
							| 
									
										
										
										
											2016-08-18 22:11:42 +03:00
										 |  |  |   end | 
					
						
							|  |  |  | end |