Merge branch 'main' into glitch-soc/merge-upstream
Conflicts: - `app/models/custom_emoji.rb`: Slight refactor upstream, next to a line that was different in glitch-soc because of our local configurable limits on custom emoji size. Ported upstream changes. - `yarn.lock`: Not really a conflict, upstream dependency textually too close to a glitch-soc-only dependency. Updated upstream dependency as upstream.
This commit is contained in:
		
						commit
						1af4ef2859
					
				
					 18 changed files with 275 additions and 256 deletions
				
			
		
							
								
								
									
										6
									
								
								Gemfile
									
									
									
									
									
								
							
							
						
						
									
										6
									
								
								Gemfile
									
									
									
									
									
								
							|  | @ -17,15 +17,15 @@ gem 'makara', '~> 0.5' | ||||||
| gem 'pghero', '~> 2.8' | gem 'pghero', '~> 2.8' | ||||||
| gem 'dotenv-rails', '~> 2.7' | gem 'dotenv-rails', '~> 2.7' | ||||||
| 
 | 
 | ||||||
| gem 'aws-sdk-s3', '~> 1.102', require: false | gem 'aws-sdk-s3', '~> 1.103', require: false | ||||||
| gem 'fog-core', '<= 2.1.0' | gem 'fog-core', '<= 2.1.0' | ||||||
| gem 'fog-openstack', '~> 0.3', require: false | gem 'fog-openstack', '~> 0.3', require: false | ||||||
| gem 'paperclip', '~> 6.0' | gem 'kt-paperclip', '~> 7.0' | ||||||
| gem 'blurhash', '~> 0.1' | gem 'blurhash', '~> 0.1' | ||||||
| 
 | 
 | ||||||
| gem 'active_model_serializers', '~> 0.10' | gem 'active_model_serializers', '~> 0.10' | ||||||
| gem 'addressable', '~> 2.8' | gem 'addressable', '~> 2.8' | ||||||
| gem 'bootsnap', '~> 1.8.1', require: false | gem 'bootsnap', '~> 1.9.1', require: false | ||||||
| gem 'browser' | gem 'browser' | ||||||
| gem 'charlock_holmes', '~> 0.7.7' | gem 'charlock_holmes', '~> 0.7.7' | ||||||
| gem 'iso-639' | gem 'iso-639' | ||||||
|  |  | ||||||
							
								
								
									
										45
									
								
								Gemfile.lock
									
									
									
									
									
								
							
							
						
						
									
										45
									
								
								Gemfile.lock
									
									
									
									
									
								
							|  | @ -79,7 +79,7 @@ GEM | ||||||
|       encryptor (~> 3.0.0) |       encryptor (~> 3.0.0) | ||||||
|     awrence (1.1.1) |     awrence (1.1.1) | ||||||
|     aws-eventstream (1.2.0) |     aws-eventstream (1.2.0) | ||||||
|     aws-partitions (1.496.0) |     aws-partitions (1.503.0) | ||||||
|     aws-sdk-core (3.121.0) |     aws-sdk-core (3.121.0) | ||||||
|       aws-eventstream (~> 1, >= 1.0.2) |       aws-eventstream (~> 1, >= 1.0.2) | ||||||
|       aws-partitions (~> 1, >= 1.239.0) |       aws-partitions (~> 1, >= 1.239.0) | ||||||
|  | @ -88,7 +88,7 @@ GEM | ||||||
|     aws-sdk-kms (1.48.0) |     aws-sdk-kms (1.48.0) | ||||||
|       aws-sdk-core (~> 3, >= 3.120.0) |       aws-sdk-core (~> 3, >= 3.120.0) | ||||||
|       aws-sigv4 (~> 1.1) |       aws-sigv4 (~> 1.1) | ||||||
|     aws-sdk-s3 (1.102.0) |     aws-sdk-s3 (1.103.0) | ||||||
|       aws-sdk-core (~> 3, >= 3.120.0) |       aws-sdk-core (~> 3, >= 3.120.0) | ||||||
|       aws-sdk-kms (~> 1) |       aws-sdk-kms (~> 1) | ||||||
|       aws-sigv4 (~> 1.4) |       aws-sigv4 (~> 1.4) | ||||||
|  | @ -104,7 +104,7 @@ GEM | ||||||
|       debug_inspector (>= 0.0.1) |       debug_inspector (>= 0.0.1) | ||||||
|     blurhash (0.1.5) |     blurhash (0.1.5) | ||||||
|       ffi (~> 1.14) |       ffi (~> 1.14) | ||||||
|     bootsnap (1.8.1) |     bootsnap (1.9.1) | ||||||
|       msgpack (~> 1.0) |       msgpack (~> 1.0) | ||||||
|     brakeman (5.1.1) |     brakeman (5.1.1) | ||||||
|     browser (4.2.0) |     browser (4.2.0) | ||||||
|  | @ -188,7 +188,7 @@ GEM | ||||||
|     docile (1.3.4) |     docile (1.3.4) | ||||||
|     domain_name (0.5.20190701) |     domain_name (0.5.20190701) | ||||||
|       unf (>= 0.0.5, < 1.0.0) |       unf (>= 0.0.5, < 1.0.0) | ||||||
|     doorkeeper (5.5.2) |     doorkeeper (5.5.3) | ||||||
|       railties (>= 5) |       railties (>= 5) | ||||||
|     dotenv (2.7.6) |     dotenv (2.7.6) | ||||||
|     dotenv-rails (2.7.6) |     dotenv-rails (2.7.6) | ||||||
|  | @ -292,7 +292,7 @@ GEM | ||||||
|     jmespath (1.4.0) |     jmespath (1.4.0) | ||||||
|     json (2.5.1) |     json (2.5.1) | ||||||
|     json-canonicalization (0.2.1) |     json-canonicalization (0.2.1) | ||||||
|     json-ld (3.1.9) |     json-ld (3.1.10) | ||||||
|       htmlentities (~> 4.3) |       htmlentities (~> 4.3) | ||||||
|       json-canonicalization (~> 0.2) |       json-canonicalization (~> 0.2) | ||||||
|       link_header (~> 0.0, >= 0.0.8) |       link_header (~> 0.0, >= 0.0.8) | ||||||
|  | @ -316,6 +316,12 @@ GEM | ||||||
|       activerecord |       activerecord | ||||||
|       kaminari-core (= 1.2.1) |       kaminari-core (= 1.2.1) | ||||||
|     kaminari-core (1.2.1) |     kaminari-core (1.2.1) | ||||||
|  |     kt-paperclip (7.0.0) | ||||||
|  |       activemodel (>= 4.2.0) | ||||||
|  |       activesupport (>= 4.2.0) | ||||||
|  |       marcel (~> 1.0.1) | ||||||
|  |       mime-types | ||||||
|  |       terrapin (~> 0.6.0) | ||||||
|     launchy (2.5.0) |     launchy (2.5.0) | ||||||
|       addressable (~> 2.7) |       addressable (~> 2.7) | ||||||
|     letter_opener (1.7.0) |     letter_opener (1.7.0) | ||||||
|  | @ -351,9 +357,6 @@ GEM | ||||||
|     mime-types (3.3.1) |     mime-types (3.3.1) | ||||||
|       mime-types-data (~> 3.2015) |       mime-types-data (~> 3.2015) | ||||||
|     mime-types-data (3.2020.0512) |     mime-types-data (3.2020.0512) | ||||||
|     mimemagic (0.3.10) |  | ||||||
|       nokogiri (~> 1) |  | ||||||
|       rake |  | ||||||
|     mini_mime (1.1.1) |     mini_mime (1.1.1) | ||||||
|     mini_portile2 (2.6.1) |     mini_portile2 (2.6.1) | ||||||
|     minitest (5.14.4) |     minitest (5.14.4) | ||||||
|  | @ -365,7 +368,7 @@ GEM | ||||||
|       net-ssh (>= 2.6.5, < 7.0.0) |       net-ssh (>= 2.6.5, < 7.0.0) | ||||||
|     net-ssh (6.1.0) |     net-ssh (6.1.0) | ||||||
|     nio4r (2.5.8) |     nio4r (2.5.8) | ||||||
|     nokogiri (1.12.4) |     nokogiri (1.12.5) | ||||||
|       mini_portile2 (~> 2.6.1) |       mini_portile2 (~> 2.6.1) | ||||||
|       racc (~> 1.4) |       racc (~> 1.4) | ||||||
|     nsa (0.2.8) |     nsa (0.2.8) | ||||||
|  | @ -391,14 +394,8 @@ GEM | ||||||
|     openssl-signature_algorithm (0.4.0) |     openssl-signature_algorithm (0.4.0) | ||||||
|     orm_adapter (0.5.0) |     orm_adapter (0.5.0) | ||||||
|     ox (2.14.5) |     ox (2.14.5) | ||||||
|     paperclip (6.0.0) |  | ||||||
|       activemodel (>= 4.2.0) |  | ||||||
|       activesupport (>= 4.2.0) |  | ||||||
|       mime-types |  | ||||||
|       mimemagic (~> 0.3.0) |  | ||||||
|       terrapin (~> 0.6.0) |  | ||||||
|     parallel (1.21.0) |     parallel (1.21.0) | ||||||
|     parallel_tests (3.7.1) |     parallel_tests (3.7.3) | ||||||
|       parallel |       parallel | ||||||
|     parser (3.0.2.0) |     parser (3.0.2.0) | ||||||
|       ast (~> 2.4.1) |       ast (~> 2.4.1) | ||||||
|  | @ -568,11 +565,11 @@ GEM | ||||||
|       sidekiq (>= 3) |       sidekiq (>= 3) | ||||||
|       thwait |       thwait | ||||||
|       tilt (>= 1.4.0) |       tilt (>= 1.4.0) | ||||||
|     sidekiq-unique-jobs (7.1.5) |     sidekiq-unique-jobs (7.1.7) | ||||||
|       brpoplpush-redis_script (> 0.1.1, <= 2.0.0) |       brpoplpush-redis_script (> 0.1.1, <= 2.0.0) | ||||||
|       concurrent-ruby (~> 1.0, >= 1.0.5) |       concurrent-ruby (~> 1.0, >= 1.0.5) | ||||||
|       sidekiq (>= 5.0, < 7.0) |       sidekiq (>= 5.0, < 8.0) | ||||||
|       thor (>= 0.20, < 2.0) |       thor (>= 0.20, < 3.0) | ||||||
|     simple-navigation (4.3.0) |     simple-navigation (4.3.0) | ||||||
|       activesupport (>= 2.3.2) |       activesupport (>= 2.3.2) | ||||||
|     simple_form (5.1.0) |     simple_form (5.1.0) | ||||||
|  | @ -626,7 +623,7 @@ GEM | ||||||
|       unf (~> 0.1.0) |       unf (~> 0.1.0) | ||||||
|     tzinfo (2.0.4) |     tzinfo (2.0.4) | ||||||
|       concurrent-ruby (~> 1.0) |       concurrent-ruby (~> 1.0) | ||||||
|     tzinfo-data (1.2021.1) |     tzinfo-data (1.2021.2) | ||||||
|       tzinfo (>= 1.0.0) |       tzinfo (>= 1.0.0) | ||||||
|     unf (0.1.4) |     unf (0.1.4) | ||||||
|       unf_ext |       unf_ext | ||||||
|  | @ -649,7 +646,7 @@ GEM | ||||||
|       addressable (>= 2.8.0) |       addressable (>= 2.8.0) | ||||||
|       crack (>= 0.3.2) |       crack (>= 0.3.2) | ||||||
|       hashdiff (>= 0.4.0, < 2.0.0) |       hashdiff (>= 0.4.0, < 2.0.0) | ||||||
|     webpacker (5.4.2) |     webpacker (5.4.3) | ||||||
|       activesupport (>= 5.2) |       activesupport (>= 5.2) | ||||||
|       rack-proxy (>= 0.6.1) |       rack-proxy (>= 0.6.1) | ||||||
|       railties (>= 5.2) |       railties (>= 5.2) | ||||||
|  | @ -674,11 +671,11 @@ DEPENDENCIES | ||||||
|   active_record_query_trace (~> 1.8) |   active_record_query_trace (~> 1.8) | ||||||
|   addressable (~> 2.8) |   addressable (~> 2.8) | ||||||
|   annotate (~> 3.1) |   annotate (~> 3.1) | ||||||
|   aws-sdk-s3 (~> 1.102) |   aws-sdk-s3 (~> 1.103) | ||||||
|   better_errors (~> 2.9) |   better_errors (~> 2.9) | ||||||
|   binding_of_caller (~> 1.0) |   binding_of_caller (~> 1.0) | ||||||
|   blurhash (~> 0.1) |   blurhash (~> 0.1) | ||||||
|   bootsnap (~> 1.8.1) |   bootsnap (~> 1.9.1) | ||||||
|   brakeman (~> 5.1) |   brakeman (~> 5.1) | ||||||
|   browser |   browser | ||||||
|   bullet (~> 6.1) |   bullet (~> 6.1) | ||||||
|  | @ -721,6 +718,7 @@ DEPENDENCIES | ||||||
|   json-ld |   json-ld | ||||||
|   json-ld-preloaded (~> 3.1) |   json-ld-preloaded (~> 3.1) | ||||||
|   kaminari (~> 1.2) |   kaminari (~> 1.2) | ||||||
|  |   kt-paperclip (~> 7.0) | ||||||
|   letter_opener (~> 1.7) |   letter_opener (~> 1.7) | ||||||
|   letter_opener_web (~> 1.4) |   letter_opener_web (~> 1.4) | ||||||
|   link_header (~> 0.0) |   link_header (~> 0.0) | ||||||
|  | @ -739,7 +737,6 @@ DEPENDENCIES | ||||||
|   omniauth-rails_csrf_protection (~> 0.1) |   omniauth-rails_csrf_protection (~> 0.1) | ||||||
|   omniauth-saml (~> 1.10) |   omniauth-saml (~> 1.10) | ||||||
|   ox (~> 2.14) |   ox (~> 2.14) | ||||||
|   paperclip (~> 6.0) |  | ||||||
|   parallel (~> 1.21) |   parallel (~> 1.21) | ||||||
|   parallel_tests (~> 3.7) |   parallel_tests (~> 3.7) | ||||||
|   parslet |   parslet | ||||||
|  |  | ||||||
|  | @ -2,7 +2,7 @@ | ||||||
| 
 | 
 | ||||||
| class FastGeometryParser | class FastGeometryParser | ||||||
|   def self.from_file(file) |   def self.from_file(file) | ||||||
|     width, height = FastImage.size(file.path) |     width, height = FastImage.size(file) | ||||||
| 
 | 
 | ||||||
|     raise Paperclip::Errors::NotIdentifiedByImageMagickError if width.nil? |     raise Paperclip::Errors::NotIdentifiedByImageMagickError if width.nil? | ||||||
| 
 | 
 | ||||||
|  |  | ||||||
|  | @ -62,12 +62,12 @@ class Account < ApplicationRecord | ||||||
|   MENTION_RE    = /(?<=^|[^\/[:word:]])@((#{USERNAME_RE})(?:@[[:word:]\.\-]+[[:word:]]+)?)/i |   MENTION_RE    = /(?<=^|[^\/[:word:]])@((#{USERNAME_RE})(?:@[[:word:]\.\-]+[[:word:]]+)?)/i | ||||||
|   URL_PREFIX_RE = /\Ahttp(s?):\/\/[^\/]+/ |   URL_PREFIX_RE = /\Ahttp(s?):\/\/[^\/]+/ | ||||||
| 
 | 
 | ||||||
|  |   include Attachmentable | ||||||
|   include AccountAssociations |   include AccountAssociations | ||||||
|   include AccountAvatar |   include AccountAvatar | ||||||
|   include AccountFinderConcern |   include AccountFinderConcern | ||||||
|   include AccountHeader |   include AccountHeader | ||||||
|   include AccountInteractions |   include AccountInteractions | ||||||
|   include Attachmentable |  | ||||||
|   include Paginable |   include Paginable | ||||||
|   include AccountCounters |   include AccountCounters | ||||||
|   include DomainNormalizable |   include DomainNormalizable | ||||||
|  |  | ||||||
|  | @ -15,51 +15,48 @@ module Attachmentable | ||||||
|   # those files, it is necessary to use the output of the |   # those files, it is necessary to use the output of the | ||||||
|   # `file` utility instead |   # `file` utility instead | ||||||
|   INCORRECT_CONTENT_TYPES = %w( |   INCORRECT_CONTENT_TYPES = %w( | ||||||
|  |     audio/vorbis | ||||||
|     video/ogg |     video/ogg | ||||||
|     video/webm |     video/webm | ||||||
|   ).freeze |   ).freeze | ||||||
| 
 | 
 | ||||||
|   included do |   included do | ||||||
|     before_post_process :obfuscate_file_name |     def self.has_attached_file(name, options = {}) # rubocop:disable Naming/PredicateName | ||||||
|     before_post_process :set_file_extensions |       options = { validate_media_type: false }.merge(options) | ||||||
|     before_post_process :check_image_dimensions |       super(name, options) | ||||||
|     before_post_process :set_file_content_type |       send(:"before_#{name}_post_process") do | ||||||
|  |         attachment = send(name) | ||||||
|  |         check_image_dimension(attachment) | ||||||
|  |         set_file_content_type(attachment) | ||||||
|  |         obfuscate_file_name(attachment) | ||||||
|  |         set_file_extension(attachment) | ||||||
|  |         Paperclip::Validators::MediaTypeSpoofDetectionValidator.new(attributes: [name]).validate(self) | ||||||
|  |       end | ||||||
|  |     end | ||||||
|   end |   end | ||||||
| 
 | 
 | ||||||
|   private |   private | ||||||
| 
 | 
 | ||||||
|   def set_file_content_type |   def set_file_content_type(attachment) # rubocop:disable Naming/AccessorMethodName | ||||||
|     self.class.attachment_definitions.each_key do |attachment_name| |     return if attachment.blank? || attachment.queued_for_write[:original].blank? || !INCORRECT_CONTENT_TYPES.include?(attachment.instance_read(:content_type)) | ||||||
|       attachment = send(attachment_name) |  | ||||||
| 
 |  | ||||||
|       next if attachment.blank? || attachment.queued_for_write[:original].blank? || !INCORRECT_CONTENT_TYPES.include?(attachment.instance_read(:content_type)) |  | ||||||
| 
 | 
 | ||||||
|     attachment.instance_write :content_type, calculated_content_type(attachment) |     attachment.instance_write :content_type, calculated_content_type(attachment) | ||||||
|   end |   end | ||||||
|   end |  | ||||||
| 
 | 
 | ||||||
|   def set_file_extensions |   def set_file_extension(attachment) # rubocop:disable Naming/AccessorMethodName | ||||||
|     self.class.attachment_definitions.each_key do |attachment_name| |     return if attachment.blank? | ||||||
|       attachment = send(attachment_name) |  | ||||||
| 
 |  | ||||||
|       next if attachment.blank? |  | ||||||
| 
 | 
 | ||||||
|     attachment.instance_write :file_name, [Paperclip::Interpolations.basename(attachment, :original), appropriate_extension(attachment)].delete_if(&:blank?).join('.') |     attachment.instance_write :file_name, [Paperclip::Interpolations.basename(attachment, :original), appropriate_extension(attachment)].delete_if(&:blank?).join('.') | ||||||
|   end |   end | ||||||
|   end |  | ||||||
| 
 | 
 | ||||||
|   def check_image_dimensions |   def check_image_dimension(attachment) | ||||||
|     self.class.attachment_definitions.each_key do |attachment_name| |     return if attachment.blank? || !/image.*/.match?(attachment.content_type) || attachment.queued_for_write[:original].blank? | ||||||
|       attachment = send(attachment_name) |  | ||||||
| 
 |  | ||||||
|       next if attachment.blank? || !/image.*/.match?(attachment.content_type) || attachment.queued_for_write[:original].blank? |  | ||||||
| 
 | 
 | ||||||
|     width, height = FastImage.size(attachment.queued_for_write[:original].path) |     width, height = FastImage.size(attachment.queued_for_write[:original].path) | ||||||
|     matrix_limit  = attachment.content_type == 'image/gif' ? GIF_MATRIX_LIMIT : MAX_MATRIX_LIMIT |     matrix_limit  = attachment.content_type == 'image/gif' ? GIF_MATRIX_LIMIT : MAX_MATRIX_LIMIT | ||||||
| 
 | 
 | ||||||
|     raise Mastodon::DimensionsValidationError, "#{width}x#{height} images are not supported" if width.present? && height.present? && (width * height > matrix_limit) |     raise Mastodon::DimensionsValidationError, "#{width}x#{height} images are not supported" if width.present? && height.present? && (width * height > matrix_limit) | ||||||
|   end |   end | ||||||
|   end |  | ||||||
| 
 | 
 | ||||||
|   def appropriate_extension(attachment) |   def appropriate_extension(attachment) | ||||||
|     mime_type = MIME::Types[attachment.content_type] |     mime_type = MIME::Types[attachment.content_type] | ||||||
|  | @ -79,13 +76,9 @@ module Attachmentable | ||||||
|     '' |     '' | ||||||
|   end |   end | ||||||
| 
 | 
 | ||||||
|   def obfuscate_file_name |   def obfuscate_file_name(attachment) | ||||||
|     self.class.attachment_definitions.each_key do |attachment_name| |     return if attachment.blank? || attachment.queued_for_write[:original].blank? || attachment.options[:preserve_files] | ||||||
|       attachment = send(attachment_name) |  | ||||||
| 
 |  | ||||||
|       next if attachment.blank? || attachment.queued_for_write[:original].blank? || attachment.options[:preserve_files] |  | ||||||
| 
 | 
 | ||||||
|     attachment.instance_write :file_name, SecureRandom.hex(8) + File.extname(attachment.instance_read(:file_name)) |     attachment.instance_write :file_name, SecureRandom.hex(8) + File.extname(attachment.instance_read(:file_name)) | ||||||
|   end |   end | ||||||
|   end |  | ||||||
| end | end | ||||||
|  |  | ||||||
|  | @ -21,6 +21,8 @@ | ||||||
| # | # | ||||||
| 
 | 
 | ||||||
| class CustomEmoji < ApplicationRecord | class CustomEmoji < ApplicationRecord | ||||||
|  |   include Attachmentable | ||||||
|  | 
 | ||||||
|   LOCAL_LIMIT = (ENV['MAX_EMOJI_SIZE'] || 50.kilobytes).to_i |   LOCAL_LIMIT = (ENV['MAX_EMOJI_SIZE'] || 50.kilobytes).to_i | ||||||
|   LIMIT       = [LOCAL_LIMIT, (ENV['MAX_REMOTE_EMOJI_SIZE'] || 200.kilobytes).to_i].max |   LIMIT       = [LOCAL_LIMIT, (ENV['MAX_REMOTE_EMOJI_SIZE'] || 200.kilobytes).to_i].max | ||||||
| 
 | 
 | ||||||
|  | @ -35,7 +37,7 @@ class CustomEmoji < ApplicationRecord | ||||||
|   belongs_to :category, class_name: 'CustomEmojiCategory', optional: true |   belongs_to :category, class_name: 'CustomEmojiCategory', optional: true | ||||||
|   has_one :local_counterpart, -> { where(domain: nil) }, class_name: 'CustomEmoji', primary_key: :shortcode, foreign_key: :shortcode |   has_one :local_counterpart, -> { where(domain: nil) }, class_name: 'CustomEmoji', primary_key: :shortcode, foreign_key: :shortcode | ||||||
| 
 | 
 | ||||||
|   has_attached_file :image, styles: { static: { format: 'png', convert_options: '-coalesce -strip' } } |   has_attached_file :image, styles: { static: { format: 'png', convert_options: '-coalesce -strip' } }, validate_media_type: false | ||||||
| 
 | 
 | ||||||
|   before_validation :downcase_domain |   before_validation :downcase_domain | ||||||
| 
 | 
 | ||||||
|  | @ -52,8 +54,6 @@ class CustomEmoji < ApplicationRecord | ||||||
| 
 | 
 | ||||||
|   remotable_attachment :image, LIMIT |   remotable_attachment :image, LIMIT | ||||||
| 
 | 
 | ||||||
|   include Attachmentable |  | ||||||
| 
 |  | ||||||
|   after_commit :remove_entity_cache |   after_commit :remove_entity_cache | ||||||
| 
 | 
 | ||||||
|   def local? |   def local? | ||||||
|  |  | ||||||
|  | @ -31,6 +31,8 @@ | ||||||
| class MediaAttachment < ApplicationRecord | class MediaAttachment < ApplicationRecord | ||||||
|   self.inheritance_column = nil |   self.inheritance_column = nil | ||||||
| 
 | 
 | ||||||
|  |   include Attachmentable | ||||||
|  | 
 | ||||||
|   enum type: [:image, :gifv, :video, :unknown, :audio] |   enum type: [:image, :gifv, :video, :unknown, :audio] | ||||||
|   enum processing: [:queued, :in_progress, :complete, :failed], _prefix: true |   enum processing: [:queued, :in_progress, :complete, :failed], _prefix: true | ||||||
| 
 | 
 | ||||||
|  | @ -50,7 +52,7 @@ class MediaAttachment < ApplicationRecord | ||||||
|   IMAGE_MIME_TYPES             = %w(image/jpeg image/png image/gif).freeze |   IMAGE_MIME_TYPES             = %w(image/jpeg image/png image/gif).freeze | ||||||
|   VIDEO_MIME_TYPES             = %w(video/webm video/mp4 video/quicktime video/ogg).freeze |   VIDEO_MIME_TYPES             = %w(video/webm video/mp4 video/quicktime video/ogg).freeze | ||||||
|   VIDEO_CONVERTIBLE_MIME_TYPES = %w(video/webm video/quicktime).freeze |   VIDEO_CONVERTIBLE_MIME_TYPES = %w(video/webm video/quicktime).freeze | ||||||
|   AUDIO_MIME_TYPES             = %w(audio/wave audio/wav audio/x-wav audio/x-pn-wave audio/ogg audio/mpeg audio/mp3 audio/webm audio/flac audio/aac audio/m4a audio/x-m4a audio/mp4 audio/3gpp video/x-ms-asf).freeze |   AUDIO_MIME_TYPES             = %w(audio/wave audio/wav audio/x-wav audio/x-pn-wave audio/ogg audio/vorbis audio/mpeg audio/mp3 audio/webm audio/flac audio/aac audio/m4a audio/x-m4a audio/mp4 audio/3gpp video/x-ms-asf).freeze | ||||||
| 
 | 
 | ||||||
|   BLURHASH_OPTIONS = { |   BLURHASH_OPTIONS = { | ||||||
|     x_comp: 4, |     x_comp: 4, | ||||||
|  | @ -182,8 +184,6 @@ class MediaAttachment < ApplicationRecord | ||||||
|   validates_attachment_size :thumbnail, less_than: IMAGE_LIMIT |   validates_attachment_size :thumbnail, less_than: IMAGE_LIMIT | ||||||
|   remotable_attachment :thumbnail, IMAGE_LIMIT, suppress_errors: true, download_on_assign: false |   remotable_attachment :thumbnail, IMAGE_LIMIT, suppress_errors: true, download_on_assign: false | ||||||
| 
 | 
 | ||||||
|   include Attachmentable |  | ||||||
| 
 |  | ||||||
|   validates :account, presence: true |   validates :account, presence: true | ||||||
|   validates :description, length: { maximum: MAX_DESCRIPTION_LENGTH }, if: :local? |   validates :description, length: { maximum: MAX_DESCRIPTION_LENGTH }, if: :local? | ||||||
|   validates :file, presence: true, if: :local? |   validates :file, presence: true, if: :local? | ||||||
|  |  | ||||||
|  | @ -27,6 +27,8 @@ | ||||||
| # | # | ||||||
| 
 | 
 | ||||||
| class PreviewCard < ApplicationRecord | class PreviewCard < ApplicationRecord | ||||||
|  |   include Attachmentable | ||||||
|  | 
 | ||||||
|   IMAGE_MIME_TYPES = ['image/jpeg', 'image/png', 'image/gif'].freeze |   IMAGE_MIME_TYPES = ['image/jpeg', 'image/png', 'image/gif'].freeze | ||||||
|   LIMIT = 1.megabytes |   LIMIT = 1.megabytes | ||||||
| 
 | 
 | ||||||
|  | @ -41,9 +43,7 @@ class PreviewCard < ApplicationRecord | ||||||
| 
 | 
 | ||||||
|   has_and_belongs_to_many :statuses |   has_and_belongs_to_many :statuses | ||||||
| 
 | 
 | ||||||
|   has_attached_file :image, processors: [:thumbnail, :blurhash_transcoder], styles: ->(f) { image_styles(f) }, convert_options: { all: '-quality 80 -strip' } |   has_attached_file :image, processors: [:thumbnail, :blurhash_transcoder], styles: ->(f) { image_styles(f) }, convert_options: { all: '-quality 80 -strip' }, validate_media_type: false | ||||||
| 
 |  | ||||||
|   include Attachmentable |  | ||||||
| 
 | 
 | ||||||
|   validates :url, presence: true, uniqueness: true |   validates :url, presence: true, uniqueness: true | ||||||
|   validates_attachment_content_type :image, content_type: IMAGE_MIME_TYPES |   validates_attachment_content_type :image, content_type: IMAGE_MIME_TYPES | ||||||
|  |  | ||||||
|  | @ -25,11 +25,8 @@ require_relative '../lib/exceptions' | ||||||
| require_relative '../lib/enumerable' | require_relative '../lib/enumerable' | ||||||
| require_relative '../lib/sanitize_ext/sanitize_config' | require_relative '../lib/sanitize_ext/sanitize_config' | ||||||
| require_relative '../lib/redis/namespace_extensions' | require_relative '../lib/redis/namespace_extensions' | ||||||
| require_relative '../lib/paperclip/schema_extensions' |  | ||||||
| require_relative '../lib/paperclip/validation_extensions' |  | ||||||
| require_relative '../lib/paperclip/url_generator_extensions' | require_relative '../lib/paperclip/url_generator_extensions' | ||||||
| require_relative '../lib/paperclip/attachment_extensions' | require_relative '../lib/paperclip/attachment_extensions' | ||||||
| require_relative '../lib/paperclip/media_type_spoof_detector_extensions' |  | ||||||
| require_relative '../lib/paperclip/lazy_thumbnail' | require_relative '../lib/paperclip/lazy_thumbnail' | ||||||
| require_relative '../lib/paperclip/gif_transcoder' | require_relative '../lib/paperclip/gif_transcoder' | ||||||
| require_relative '../lib/paperclip/transcoder' | require_relative '../lib/paperclip/transcoder' | ||||||
|  |  | ||||||
|  | @ -6,6 +6,35 @@ module Paperclip | ||||||
|       instance_read(:meta) |       instance_read(:meta) | ||||||
|     end |     end | ||||||
| 
 | 
 | ||||||
|  |     # monkey-patch to avoid unlinking too avoid unlinking source file too early | ||||||
|  |     # see https://github.com/kreeti/kt-paperclip/issues/64 | ||||||
|  |     def post_process_style(name, style) #:nodoc: | ||||||
|  |       raise "Style #{name} has no processors defined." if style.processors.blank? | ||||||
|  | 
 | ||||||
|  |       intermediate_files = [] | ||||||
|  |       original = @queued_for_write[:original] | ||||||
|  |       # if we're processing the original, close + unlink the source tempfile | ||||||
|  |       intermediate_files << original if name == :original | ||||||
|  | 
 | ||||||
|  |       @queued_for_write[name] = style.processors. | ||||||
|  |                                 inject(original) do |file, processor| | ||||||
|  |         file = Paperclip.processor(processor).make(file, style.processor_options, self) | ||||||
|  |         intermediate_files << file unless file == original | ||||||
|  |         file | ||||||
|  |       end | ||||||
|  | 
 | ||||||
|  |       unadapted_file = @queued_for_write[name] | ||||||
|  |       @queued_for_write[name] = Paperclip.io_adapters. | ||||||
|  |                                 for(@queued_for_write[name], @options[:adapter_options]) | ||||||
|  |       unadapted_file.close if unadapted_file.respond_to?(:close) | ||||||
|  |       @queued_for_write[name] | ||||||
|  |     rescue Paperclip::Errors::NotIdentifiedByImageMagickError => e | ||||||
|  |       log("An error was received while processing: #{e.inspect}") | ||||||
|  |       (@errors[:processing] ||= []) << e.message if @options[:whiny] | ||||||
|  |     ensure | ||||||
|  |       unlink_files(intermediate_files) | ||||||
|  |     end | ||||||
|  | 
 | ||||||
|     # We overwrite this method to support delayed processing in |     # We overwrite this method to support delayed processing in | ||||||
|     # Sidekiq. Since we process the original file to reduce disk |     # Sidekiq. Since we process the original file to reduce disk | ||||||
|     # usage, and we still want to generate thumbnails straight |     # usage, and we still want to generate thumbnails straight | ||||||
|  |  | ||||||
|  | @ -1,35 +0,0 @@ | ||||||
| # frozen_string_literal: true |  | ||||||
| 
 |  | ||||||
| module Paperclip |  | ||||||
|   module MediaTypeSpoofDetectorExtensions |  | ||||||
|     def mapping_override_mismatch? |  | ||||||
|       !Array(mapped_content_type).include?(calculated_content_type) && !Array(mapped_content_type).include?(type_from_mime_magic) |  | ||||||
|     end |  | ||||||
| 
 |  | ||||||
|     def calculated_media_type_from_mime_magic |  | ||||||
|       @calculated_media_type_from_mime_magic ||= type_from_mime_magic.split('/').first |  | ||||||
|     end |  | ||||||
| 
 |  | ||||||
|     def calculated_type_mismatch? |  | ||||||
|       !media_types_from_name.include?(calculated_media_type) && !media_types_from_name.include?(calculated_media_type_from_mime_magic) |  | ||||||
|     end |  | ||||||
| 
 |  | ||||||
|     def type_from_mime_magic |  | ||||||
|       @type_from_mime_magic ||= begin |  | ||||||
|         begin |  | ||||||
|           File.open(@file.path) do |file| |  | ||||||
|             MimeMagic.by_magic(file)&.type || '' |  | ||||||
|           end |  | ||||||
|         rescue Errno::ENOENT |  | ||||||
|           '' |  | ||||||
|         end |  | ||||||
|       end |  | ||||||
|     end |  | ||||||
| 
 |  | ||||||
|     def type_from_file_command |  | ||||||
|       @type_from_file_command ||= FileCommandContentTypeDetector.new(@file.path).detect |  | ||||||
|     end |  | ||||||
|   end |  | ||||||
| end |  | ||||||
| 
 |  | ||||||
| Paperclip::MediaTypeSpoofDetector.prepend(Paperclip::MediaTypeSpoofDetectorExtensions) |  | ||||||
|  | @ -1,37 +0,0 @@ | ||||||
| # frozen_string_literal: true |  | ||||||
| 
 |  | ||||||
| # Monkey-patch various Paperclip methods for Ruby 3.0 compatibility |  | ||||||
| 
 |  | ||||||
| module Paperclip |  | ||||||
|   module Schema |  | ||||||
|     module StatementsExtensions |  | ||||||
|       def add_attachment(table_name, *attachment_names) |  | ||||||
|         raise ArgumentError, 'Please specify attachment name in your add_attachment call in your migration.' if attachment_names.empty? |  | ||||||
| 
 |  | ||||||
|         options = attachment_names.extract_options! |  | ||||||
| 
 |  | ||||||
|         attachment_names.each do |attachment_name| |  | ||||||
|           COLUMNS.each_pair do |column_name, column_type| |  | ||||||
|             column_options = options.merge(options[column_name.to_sym] || {}) |  | ||||||
|             add_column(table_name, "#{attachment_name}_#{column_name}", column_type, **column_options) |  | ||||||
|           end |  | ||||||
|         end |  | ||||||
|       end |  | ||||||
|     end |  | ||||||
| 
 |  | ||||||
|     module TableDefinitionExtensions |  | ||||||
|       def attachment(*attachment_names) |  | ||||||
|         options = attachment_names.extract_options! |  | ||||||
|         attachment_names.each do |attachment_name| |  | ||||||
|           COLUMNS.each_pair do |column_name, column_type| |  | ||||||
|             column_options = options.merge(options[column_name.to_sym] || {}) |  | ||||||
|             column("#{attachment_name}_#{column_name}", column_type, **column_options) |  | ||||||
|           end |  | ||||||
|         end |  | ||||||
|       end |  | ||||||
|     end |  | ||||||
|   end |  | ||||||
| end |  | ||||||
| 
 |  | ||||||
| Paperclip::Schema::Statements.prepend(Paperclip::Schema::StatementsExtensions) |  | ||||||
| Paperclip::Schema::TableDefinition.prepend(Paperclip::Schema::TableDefinitionExtensions) |  | ||||||
|  | @ -2,16 +2,6 @@ | ||||||
| 
 | 
 | ||||||
| module Paperclip | module Paperclip | ||||||
|   module UrlGeneratorExtensions |   module UrlGeneratorExtensions | ||||||
|     # Monkey-patch Paperclip to use Addressable::URI's normalization instead |  | ||||||
|     # of the long-deprecated URI.esacpe |  | ||||||
|     def escape_url(url) |  | ||||||
|       if url.respond_to?(:escape) |  | ||||||
|         url.escape |  | ||||||
|       else |  | ||||||
|         Addressable::URI.parse(url).normalize.to_str.gsub(escape_regex) { |m| "%#{m.ord.to_s(16).upcase}" } |  | ||||||
|       end |  | ||||||
|     end |  | ||||||
| 
 |  | ||||||
|     def for_as_default(style_name) |     def for_as_default(style_name) | ||||||
|       attachment_options[:interpolator].interpolate(default_url, @attachment, style_name) |       attachment_options[:interpolator].interpolate(default_url, @attachment, style_name) | ||||||
|     end |     end | ||||||
|  |  | ||||||
|  | @ -1,58 +0,0 @@ | ||||||
| # frozen_string_literal: true |  | ||||||
| 
 |  | ||||||
| # Monkey-patch various Paperclip validators for Ruby 3.0 compatibility |  | ||||||
| 
 |  | ||||||
| module Paperclip |  | ||||||
|   module Validators |  | ||||||
|     module AttachmentSizeValidatorExtensions |  | ||||||
|       def validate_each(record, attr_name, _value) |  | ||||||
|         base_attr_name = attr_name |  | ||||||
|         attr_name = "#{attr_name}_file_size".to_sym |  | ||||||
|         value = record.send(:read_attribute_for_validation, attr_name) |  | ||||||
| 
 |  | ||||||
|         if value.present? |  | ||||||
|           options.slice(*Paperclip::Validators::AttachmentSizeValidator::AVAILABLE_CHECKS).each do |option, option_value| |  | ||||||
|             option_value = option_value.call(record) if option_value.is_a?(Proc) |  | ||||||
|             option_value = extract_option_value(option, option_value) |  | ||||||
| 
 |  | ||||||
|             next if value.send(Paperclip::Validators::AttachmentSizeValidator::CHECKS[option], option_value) |  | ||||||
| 
 |  | ||||||
|             error_message_key = options[:in] ? :in_between : option |  | ||||||
|             [attr_name, base_attr_name].each do |error_attr_name| |  | ||||||
|               record.errors.add(error_attr_name, error_message_key, **filtered_options(value).merge( |  | ||||||
|                 min: min_value_in_human_size(record), |  | ||||||
|                 max: max_value_in_human_size(record), |  | ||||||
|                 count: human_size(option_value) |  | ||||||
|               )) |  | ||||||
|             end |  | ||||||
|           end |  | ||||||
|         end |  | ||||||
|       end |  | ||||||
|     end |  | ||||||
| 
 |  | ||||||
|     module AttachmentContentTypeValidatorExtensions |  | ||||||
|       def mark_invalid(record, attribute, types) |  | ||||||
|         record.errors.add attribute, :invalid, **options.merge({ types: types.join(', ') }) |  | ||||||
|       end |  | ||||||
|     end |  | ||||||
| 
 |  | ||||||
|     module AttachmentPresenceValidatorExtensions |  | ||||||
|       def validate_each(record, attribute, _value) |  | ||||||
|         if record.send("#{attribute}_file_name").blank? |  | ||||||
|           record.errors.add(attribute, :blank, **options) |  | ||||||
|         end |  | ||||||
|       end |  | ||||||
|     end |  | ||||||
| 
 |  | ||||||
|     module AttachmentFileNameValidatorExtensions |  | ||||||
|       def mark_invalid(record, attribute, patterns) |  | ||||||
|         record.errors.add attribute, :invalid, options.merge({ names: patterns.join(', ') }) |  | ||||||
|       end |  | ||||||
|     end |  | ||||||
|   end |  | ||||||
| end |  | ||||||
| 
 |  | ||||||
| Paperclip::Validators::AttachmentSizeValidator.prepend(Paperclip::Validators::AttachmentSizeValidatorExtensions) |  | ||||||
| Paperclip::Validators::AttachmentContentTypeValidator.prepend(Paperclip::Validators::AttachmentContentTypeValidatorExtensions) |  | ||||||
| Paperclip::Validators::AttachmentPresenceValidator.prepend(Paperclip::Validators::AttachmentPresenceValidatorExtensions) |  | ||||||
| Paperclip::Validators::AttachmentFileNameValidator.prepend(Paperclip::Validators::AttachmentFileNameValidatorExtensions) |  | ||||||
							
								
								
									
										14
									
								
								package.json
									
									
									
									
									
								
							
							
						
						
									
										14
									
								
								package.json
									
									
									
									
									
								
							|  | @ -74,7 +74,7 @@ | ||||||
|     "array-includes": "^3.1.3", |     "array-includes": "^3.1.3", | ||||||
|     "atrament": "0.2.4", |     "atrament": "0.2.4", | ||||||
|     "arrow-key-navigation": "^1.2.0", |     "arrow-key-navigation": "^1.2.0", | ||||||
|     "autoprefixer": "^9.8.6", |     "autoprefixer": "^9.8.7", | ||||||
|     "axios": "^0.21.4", |     "axios": "^0.21.4", | ||||||
|     "babel-loader": "^8.2.2", |     "babel-loader": "^8.2.2", | ||||||
|     "babel-plugin-lodash": "^3.3.4", |     "babel-plugin-lodash": "^3.3.4", | ||||||
|  | @ -99,7 +99,7 @@ | ||||||
|     "favico.js": "^0.3.10", |     "favico.js": "^0.3.10", | ||||||
|     "file-loader": "^6.2.0", |     "file-loader": "^6.2.0", | ||||||
|     "font-awesome": "^4.7.0", |     "font-awesome": "^4.7.0", | ||||||
|     "glob": "^7.1.7", |     "glob": "^7.2.0", | ||||||
|     "history": "^4.10.1", |     "history": "^4.10.1", | ||||||
|     "http-link-header": "^1.0.3", |     "http-link-header": "^1.0.3", | ||||||
|     "immutable": "^3.8.2", |     "immutable": "^3.8.2", | ||||||
|  | @ -176,27 +176,27 @@ | ||||||
|   }, |   }, | ||||||
|   "devDependencies": { |   "devDependencies": { | ||||||
|     "@testing-library/jest-dom": "^5.14.1", |     "@testing-library/jest-dom": "^5.14.1", | ||||||
|     "@testing-library/react": "^12.1.0", |     "@testing-library/react": "^12.1.1", | ||||||
|     "babel-eslint": "^10.1.0", |     "babel-eslint": "^10.1.0", | ||||||
|     "babel-jest": "^27.2.0", |     "babel-jest": "^27.2.2", | ||||||
|     "eslint": "^7.32.0", |     "eslint": "^7.32.0", | ||||||
|     "eslint-plugin-import": "~2.24.2", |     "eslint-plugin-import": "~2.24.2", | ||||||
|     "eslint-plugin-jsx-a11y": "~6.4.1", |     "eslint-plugin-jsx-a11y": "~6.4.1", | ||||||
|     "eslint-plugin-promise": "~5.1.0", |     "eslint-plugin-promise": "~5.1.0", | ||||||
|     "eslint-plugin-react": "~7.25.1", |     "eslint-plugin-react": "~7.26.0", | ||||||
|     "jest": "^27.2.0", |     "jest": "^27.2.0", | ||||||
|     "raf": "^3.4.1", |     "raf": "^3.4.1", | ||||||
|     "react-intl-translations-manager": "^5.0.3", |     "react-intl-translations-manager": "^5.0.3", | ||||||
|     "react-test-renderer": "^16.14.0", |     "react-test-renderer": "^16.14.0", | ||||||
|     "sass-lint": "^1.13.1", |     "sass-lint": "^1.13.1", | ||||||
|     "webpack-dev-server": "^3.11.2", |     "webpack-dev-server": "^3.11.2", | ||||||
|     "yargs": "^17.1.1" |     "yargs": "^17.2.1" | ||||||
|   }, |   }, | ||||||
|   "resolutions": { |   "resolutions": { | ||||||
|     "kind-of": "^6.0.3" |     "kind-of": "^6.0.3" | ||||||
|   }, |   }, | ||||||
|   "optionalDependencies": { |   "optionalDependencies": { | ||||||
|     "bufferutil": "^4.0.3", |     "bufferutil": "^4.0.3", | ||||||
|     "utf-8-validate": "^5.0.5" |     "utf-8-validate": "^5.0.6" | ||||||
|   } |   } | ||||||
| } | } | ||||||
|  |  | ||||||
							
								
								
									
										
											BIN
										
									
								
								spec/fixtures/files/boop.ogg
									
									
									
									
										vendored
									
									
										Normal file
									
								
							
							
						
						
									
										
											BIN
										
									
								
								spec/fixtures/files/boop.ogg
									
									
									
									
										vendored
									
									
										Normal file
									
								
							
										
											Binary file not shown.
										
									
								
							|  | @ -114,6 +114,30 @@ RSpec.describe MediaAttachment, type: :model do | ||||||
|     end |     end | ||||||
|   end |   end | ||||||
| 
 | 
 | ||||||
|  |   describe 'ogg with cover art' do | ||||||
|  |     let(:media) { MediaAttachment.create(account: Fabricate(:account), file: attachment_fixture('boop.ogg')) } | ||||||
|  | 
 | ||||||
|  |     it 'detects it as an audio file' do | ||||||
|  |       expect(media.type).to eq 'audio' | ||||||
|  |     end | ||||||
|  | 
 | ||||||
|  |     it 'sets meta for the duration' do | ||||||
|  |       expect(media.file.meta['original']['duration']).to be_within(0.05).of(0.235102) | ||||||
|  |     end | ||||||
|  | 
 | ||||||
|  |     it 'extracts thumbnail' do | ||||||
|  |       expect(media.thumbnail.present?).to eq true | ||||||
|  |     end | ||||||
|  | 
 | ||||||
|  |     it 'extracts colors from thumbnail' do | ||||||
|  |       expect(media.file.meta['colors']['background']).to eq '#3088d4' | ||||||
|  |     end | ||||||
|  | 
 | ||||||
|  |     it 'gives the file a random name' do | ||||||
|  |       expect(media.file_file_name).to_not eq 'boop.ogg' | ||||||
|  |     end | ||||||
|  |   end | ||||||
|  | 
 | ||||||
|   describe 'jpeg' do |   describe 'jpeg' do | ||||||
|     let(:media) { MediaAttachment.create(account: Fabricate(:account), file: attachment_fixture('attachment.jpg')) } |     let(:media) { MediaAttachment.create(account: Fabricate(:account), file: attachment_fixture('attachment.jpg')) } | ||||||
| 
 | 
 | ||||||
|  |  | ||||||
							
								
								
									
										187
									
								
								yarn.lock
									
									
									
									
									
								
							
							
						
						
									
										187
									
								
								yarn.lock
									
									
									
									
									
								
							|  | @ -1380,10 +1380,10 @@ | ||||||
|     jest-haste-map "^27.2.0" |     jest-haste-map "^27.2.0" | ||||||
|     jest-runtime "^27.2.0" |     jest-runtime "^27.2.0" | ||||||
| 
 | 
 | ||||||
| "@jest/transform@^27.2.0": | "@jest/transform@^27.2.0", "@jest/transform@^27.2.2": | ||||||
|   version "27.2.0" |   version "27.2.2" | ||||||
|   resolved "https://registry.yarnpkg.com/@jest/transform/-/transform-27.2.0.tgz#e7e6e49d2591792db2385c33cdbb4379d407068d" |   resolved "https://registry.yarnpkg.com/@jest/transform/-/transform-27.2.2.tgz#89b16b4de84354fb48d15712b3ea34cadc1cb600" | ||||||
|   integrity sha512-Q8Q/8xXIZYllk1AF7Ou5sV3egOZsdY/Wlv09CSbcexBRcC1Qt6lVZ7jRFAZtbHsEEzvOCyFEC4PcrwKwyjXtCg== |   integrity sha512-l4Z/7PpajrOjCiXLWLfMY7fgljY0H8EwW7qdzPXXuv2aQF8kY2+Uyj3O+9Popnaw1V7JCw32L8EeI/thqFDkPA== | ||||||
|   dependencies: |   dependencies: | ||||||
|     "@babel/core" "^7.1.0" |     "@babel/core" "^7.1.0" | ||||||
|     "@jest/types" "^27.1.1" |     "@jest/types" "^27.1.1" | ||||||
|  | @ -1392,7 +1392,7 @@ | ||||||
|     convert-source-map "^1.4.0" |     convert-source-map "^1.4.0" | ||||||
|     fast-json-stable-stringify "^2.0.0" |     fast-json-stable-stringify "^2.0.0" | ||||||
|     graceful-fs "^4.2.4" |     graceful-fs "^4.2.4" | ||||||
|     jest-haste-map "^27.2.0" |     jest-haste-map "^27.2.2" | ||||||
|     jest-regex-util "^27.0.6" |     jest-regex-util "^27.0.6" | ||||||
|     jest-util "^27.2.0" |     jest-util "^27.2.0" | ||||||
|     micromatch "^4.0.4" |     micromatch "^4.0.4" | ||||||
|  | @ -1482,10 +1482,10 @@ | ||||||
|     lodash "^4.17.15" |     lodash "^4.17.15" | ||||||
|     redent "^3.0.0" |     redent "^3.0.0" | ||||||
| 
 | 
 | ||||||
| "@testing-library/react@^12.1.0": | "@testing-library/react@^12.1.1": | ||||||
|   version "12.1.0" |   version "12.1.1" | ||||||
|   resolved "https://registry.yarnpkg.com/@testing-library/react/-/react-12.1.0.tgz#3e9a4002b0b8f986a738a2f88fc458b5af319f35" |   resolved "https://registry.yarnpkg.com/@testing-library/react/-/react-12.1.1.tgz#e693943aa48d0190099acdc3928a751d73bcf7d5" | ||||||
|   integrity sha512-Ge3Ht3qXE82Yv9lyPpQ7ZWgzo/HgOcHu569Y4ZGWcZME38iOFiOg87qnu6hTEa8jTJVL7zYovnvD3GE2nsNIoQ== |   integrity sha512-JDyWbvMuedEpP6SPL4Cvbhk59TVxQ3pwuR6ZfJHdRsHuxDd/ziSMA3nVM3fViaSbsQhuQFE/mvFrPrvQbL5kRQ== | ||||||
|   dependencies: |   dependencies: | ||||||
|     "@babel/runtime" "^7.12.5" |     "@babel/runtime" "^7.12.5" | ||||||
|     "@testing-library/dom" "^8.0.0" |     "@testing-library/dom" "^8.0.0" | ||||||
|  | @ -2268,14 +2268,14 @@ atrament@0.2.4: | ||||||
|   resolved "https://registry.yarnpkg.com/atrament/-/atrament-0.2.4.tgz#6f78196edfcd194e568b7c0b9c88201ec371ac66" |   resolved "https://registry.yarnpkg.com/atrament/-/atrament-0.2.4.tgz#6f78196edfcd194e568b7c0b9c88201ec371ac66" | ||||||
|   integrity sha512-hSA9VwW6COMwvRhSEO4uZweZ91YGOdHqwvslNyrJZG+8mzc4qx/qMsDZBuAeXFeWZO/QKtRjIXguOUy1aNMl3A== |   integrity sha512-hSA9VwW6COMwvRhSEO4uZweZ91YGOdHqwvslNyrJZG+8mzc4qx/qMsDZBuAeXFeWZO/QKtRjIXguOUy1aNMl3A== | ||||||
| 
 | 
 | ||||||
| autoprefixer@^9.8.6: | autoprefixer@^9.8.7: | ||||||
|   version "9.8.6" |   version "9.8.7" | ||||||
|   resolved "https://registry.yarnpkg.com/autoprefixer/-/autoprefixer-9.8.6.tgz#3b73594ca1bf9266320c5acf1588d74dea74210f" |   resolved "https://registry.yarnpkg.com/autoprefixer/-/autoprefixer-9.8.7.tgz#e3c12de18a800af1a1a8155fbc01dc7de29ea184" | ||||||
|   integrity sha512-XrvP4VVHdRBCdX1S3WXVD8+RyG9qeb1D5Sn1DeLiG2xfSpzellk5k54xbUERJ3M5DggQxes39UGOTP8CFrEGbg== |   integrity sha512-7Hg99B1eTH5+LgmUBUSmov1Z3bsggQJS7v3IMGo6wcScnbRuvtMc871J9J+4bSbIqa9LSX/zypFXJ8sXHpMJeQ== | ||||||
|   dependencies: |   dependencies: | ||||||
|     browserslist "^4.12.0" |     browserslist "^4.12.0" | ||||||
|     caniuse-lite "^1.0.30001109" |     caniuse-lite "^1.0.30001109" | ||||||
|     colorette "^1.2.1" |     nanocolors "^0.2.8" | ||||||
|     normalize-range "^0.1.2" |     normalize-range "^0.1.2" | ||||||
|     num2fraction "^1.2.2" |     num2fraction "^1.2.2" | ||||||
|     postcss "^7.0.32" |     postcss "^7.0.32" | ||||||
|  | @ -2310,12 +2310,12 @@ babel-eslint@^10.1.0: | ||||||
|     eslint-visitor-keys "^1.0.0" |     eslint-visitor-keys "^1.0.0" | ||||||
|     resolve "^1.12.0" |     resolve "^1.12.0" | ||||||
| 
 | 
 | ||||||
| babel-jest@^27.2.0: | babel-jest@^27.2.0, babel-jest@^27.2.2: | ||||||
|   version "27.2.0" |   version "27.2.2" | ||||||
|   resolved "https://registry.yarnpkg.com/babel-jest/-/babel-jest-27.2.0.tgz#c0f129a81f1197028aeb4447acbc04564c8bfc52" |   resolved "https://registry.yarnpkg.com/babel-jest/-/babel-jest-27.2.2.tgz#d7e96f3f6f56be692de948092697e1bfea7f1184" | ||||||
|   integrity sha512-bS2p+KGGVVmWXBa8+i6SO/xzpiz2Q/2LnqLbQknPKefWXVZ67YIjA4iXup/jMOEZplga9PpWn+wrdb3UdDwRaA== |   integrity sha512-XNFNNfGKnZXzhej7TleVP4s9ktH5JjRW8Rmcbb223JJwKB/gmTyeWN0JfiPtSgnjIjDXtKNoixiy0QUHtv3vFA== | ||||||
|   dependencies: |   dependencies: | ||||||
|     "@jest/transform" "^27.2.0" |     "@jest/transform" "^27.2.2" | ||||||
|     "@jest/types" "^27.1.1" |     "@jest/types" "^27.1.1" | ||||||
|     "@types/babel__core" "^7.1.14" |     "@types/babel__core" "^7.1.14" | ||||||
|     babel-plugin-istanbul "^6.0.0" |     babel-plugin-istanbul "^6.0.0" | ||||||
|  | @ -3142,7 +3142,7 @@ color@^3.0.0: | ||||||
|     color-convert "^1.9.1" |     color-convert "^1.9.1" | ||||||
|     color-string "^1.5.2" |     color-string "^1.5.2" | ||||||
| 
 | 
 | ||||||
| colorette@^1.2.1, colorette@^1.2.2: | colorette@^1.2.2: | ||||||
|   version "1.2.2" |   version "1.2.2" | ||||||
|   resolved "https://registry.yarnpkg.com/colorette/-/colorette-1.2.2.tgz#cbcc79d5e99caea2dbf10eb3a26fd8b3e6acfa94" |   resolved "https://registry.yarnpkg.com/colorette/-/colorette-1.2.2.tgz#cbcc79d5e99caea2dbf10eb3a26fd8b3e6acfa94" | ||||||
|   integrity sha512-MKGMzyfeuutC/ZJ1cba9NqcNpfeqMUcYmyF1ZFY6/Cn7CNSAKx6a+s48sqLqyAiZuaP2TcqMhoo+dlwFnVxT9w== |   integrity sha512-MKGMzyfeuutC/ZJ1cba9NqcNpfeqMUcYmyF1ZFY6/Cn7CNSAKx6a+s48sqLqyAiZuaP2TcqMhoo+dlwFnVxT9w== | ||||||
|  | @ -4141,6 +4141,30 @@ es-abstract@^1.18.0-next.0, es-abstract@^1.18.0-next.1, es-abstract@^1.18.0-next | ||||||
|     string.prototype.trimend "^1.0.3" |     string.prototype.trimend "^1.0.3" | ||||||
|     string.prototype.trimstart "^1.0.3" |     string.prototype.trimstart "^1.0.3" | ||||||
| 
 | 
 | ||||||
|  | es-abstract@^1.18.1: | ||||||
|  |   version "1.18.6" | ||||||
|  |   resolved "https://registry.yarnpkg.com/es-abstract/-/es-abstract-1.18.6.tgz#2c44e3ea7a6255039164d26559777a6d978cb456" | ||||||
|  |   integrity sha512-kAeIT4cku5eNLNuUKhlmtuk1/TRZvQoYccn6TO0cSVdf1kzB0T7+dYuVK9MWM7l+/53W2Q8M7N2c6MQvhXFcUQ== | ||||||
|  |   dependencies: | ||||||
|  |     call-bind "^1.0.2" | ||||||
|  |     es-to-primitive "^1.2.1" | ||||||
|  |     function-bind "^1.1.1" | ||||||
|  |     get-intrinsic "^1.1.1" | ||||||
|  |     get-symbol-description "^1.0.0" | ||||||
|  |     has "^1.0.3" | ||||||
|  |     has-symbols "^1.0.2" | ||||||
|  |     internal-slot "^1.0.3" | ||||||
|  |     is-callable "^1.2.4" | ||||||
|  |     is-negative-zero "^2.0.1" | ||||||
|  |     is-regex "^1.1.4" | ||||||
|  |     is-string "^1.0.7" | ||||||
|  |     object-inspect "^1.11.0" | ||||||
|  |     object-keys "^1.1.1" | ||||||
|  |     object.assign "^4.1.2" | ||||||
|  |     string.prototype.trimend "^1.0.4" | ||||||
|  |     string.prototype.trimstart "^1.0.4" | ||||||
|  |     unbox-primitive "^1.0.1" | ||||||
|  | 
 | ||||||
| es-abstract@^1.18.2: | es-abstract@^1.18.2: | ||||||
|   version "1.18.3" |   version "1.18.3" | ||||||
|   resolved "https://registry.yarnpkg.com/es-abstract/-/es-abstract-1.18.3.tgz#25c4c3380a27aa203c44b2b685bba94da31b63e0" |   resolved "https://registry.yarnpkg.com/es-abstract/-/es-abstract-1.18.3.tgz#25c4c3380a27aa203c44b2b685bba94da31b63e0" | ||||||
|  | @ -4345,23 +4369,24 @@ eslint-plugin-promise@~5.1.0: | ||||||
|   resolved "https://registry.yarnpkg.com/eslint-plugin-promise/-/eslint-plugin-promise-5.1.0.tgz#fb2188fb734e4557993733b41aa1a688f46c6f24" |   resolved "https://registry.yarnpkg.com/eslint-plugin-promise/-/eslint-plugin-promise-5.1.0.tgz#fb2188fb734e4557993733b41aa1a688f46c6f24" | ||||||
|   integrity sha512-NGmI6BH5L12pl7ScQHbg7tvtk4wPxxj8yPHH47NvSmMtFneC077PSeY3huFj06ZWZvtbfxSPt3RuOQD5XcR4ng== |   integrity sha512-NGmI6BH5L12pl7ScQHbg7tvtk4wPxxj8yPHH47NvSmMtFneC077PSeY3huFj06ZWZvtbfxSPt3RuOQD5XcR4ng== | ||||||
| 
 | 
 | ||||||
| eslint-plugin-react@~7.25.1: | eslint-plugin-react@~7.26.0: | ||||||
|   version "7.25.1" |   version "7.26.0" | ||||||
|   resolved "https://registry.yarnpkg.com/eslint-plugin-react/-/eslint-plugin-react-7.25.1.tgz#9286b7cd9bf917d40309760f403e53016eda8331" |   resolved "https://registry.yarnpkg.com/eslint-plugin-react/-/eslint-plugin-react-7.26.0.tgz#3ae019a35d542b98e5af9e2f96b89c232c74b55b" | ||||||
|   integrity sha512-P4j9K1dHoFXxDNP05AtixcJEvIT6ht8FhYKsrkY0MPCPaUMYijhpWwNiRDZVtA8KFuZOkGSeft6QwH8KuVpJug== |   integrity sha512-dceliS5itjk4EZdQYtLMz6GulcsasguIs+VTXuiC7Q5IPIdGTkyfXVdmsQOqEhlD9MciofH4cMcT1bw1WWNxCQ== | ||||||
|   dependencies: |   dependencies: | ||||||
|     array-includes "^3.1.3" |     array-includes "^3.1.3" | ||||||
|     array.prototype.flatmap "^1.2.4" |     array.prototype.flatmap "^1.2.4" | ||||||
|     doctrine "^2.1.0" |     doctrine "^2.1.0" | ||||||
|     estraverse "^5.2.0" |     estraverse "^5.2.0" | ||||||
|     has "^1.0.3" |  | ||||||
|     jsx-ast-utils "^2.4.1 || ^3.0.0" |     jsx-ast-utils "^2.4.1 || ^3.0.0" | ||||||
|     minimatch "^3.0.4" |     minimatch "^3.0.4" | ||||||
|     object.entries "^1.1.4" |     object.entries "^1.1.4" | ||||||
|     object.fromentries "^2.0.4" |     object.fromentries "^2.0.4" | ||||||
|  |     object.hasown "^1.0.0" | ||||||
|     object.values "^1.1.4" |     object.values "^1.1.4" | ||||||
|     prop-types "^15.7.2" |     prop-types "^15.7.2" | ||||||
|     resolve "^2.0.0-next.3" |     resolve "^2.0.0-next.3" | ||||||
|  |     semver "^6.3.0" | ||||||
|     string.prototype.matchall "^4.0.5" |     string.prototype.matchall "^4.0.5" | ||||||
| 
 | 
 | ||||||
| eslint-scope@^4.0.3: | eslint-scope@^4.0.3: | ||||||
|  | @ -5093,6 +5118,14 @@ get-stream@^6.0.0: | ||||||
|   resolved "https://registry.yarnpkg.com/get-stream/-/get-stream-6.0.1.tgz#a262d8eef67aced57c2852ad6167526a43cbf7b7" |   resolved "https://registry.yarnpkg.com/get-stream/-/get-stream-6.0.1.tgz#a262d8eef67aced57c2852ad6167526a43cbf7b7" | ||||||
|   integrity sha512-ts6Wi+2j3jQjqi70w5AlN8DFnkSwC+MqmxEzdEALB2qXZYV3X/b1CTfgPLGJNMeAWxdPfU8FO1ms3NUfaHCPYg== |   integrity sha512-ts6Wi+2j3jQjqi70w5AlN8DFnkSwC+MqmxEzdEALB2qXZYV3X/b1CTfgPLGJNMeAWxdPfU8FO1ms3NUfaHCPYg== | ||||||
| 
 | 
 | ||||||
|  | get-symbol-description@^1.0.0: | ||||||
|  |   version "1.0.0" | ||||||
|  |   resolved "https://registry.yarnpkg.com/get-symbol-description/-/get-symbol-description-1.0.0.tgz#7fdb81c900101fbd564dd5f1a30af5aadc1e58d6" | ||||||
|  |   integrity sha512-2EmdH1YvIQiZpltCNgkuiUnyukzxM/R6NDJX31Ke3BG1Nq5b0S2PhX59UKi9vZpPDQVdqn+1IcaAwnzTT5vCjw== | ||||||
|  |   dependencies: | ||||||
|  |     call-bind "^1.0.2" | ||||||
|  |     get-intrinsic "^1.1.1" | ||||||
|  | 
 | ||||||
| get-value@^2.0.3, get-value@^2.0.6: | get-value@^2.0.3, get-value@^2.0.6: | ||||||
|   version "2.0.6" |   version "2.0.6" | ||||||
|   resolved "https://registry.yarnpkg.com/get-value/-/get-value-2.0.6.tgz#dc15ca1c672387ca76bd37ac0a395ba2042a2c28" |   resolved "https://registry.yarnpkg.com/get-value/-/get-value-2.0.6.tgz#dc15ca1c672387ca76bd37ac0a395ba2042a2c28" | ||||||
|  | @ -5113,7 +5146,19 @@ glob-parent@^5.1.2, glob-parent@~5.1.0: | ||||||
|   dependencies: |   dependencies: | ||||||
|     is-glob "^4.0.1" |     is-glob "^4.0.1" | ||||||
| 
 | 
 | ||||||
| glob@^7.0.0, glob@^7.0.3, glob@^7.1.1, glob@^7.1.2, glob@^7.1.3, glob@^7.1.4, glob@^7.1.7, glob@~7.1.1: | glob@^7.0.0, glob@^7.0.3, glob@^7.1.1, glob@^7.1.2, glob@^7.1.3, glob@^7.1.4, glob@^7.2.0: | ||||||
|  |   version "7.2.0" | ||||||
|  |   resolved "https://registry.yarnpkg.com/glob/-/glob-7.2.0.tgz#d15535af7732e02e948f4c41628bd910293f6023" | ||||||
|  |   integrity sha512-lmLf6gtyrPq8tTjSmrO94wBeQbFR3HbLHbuyD69wuyQkImp2hWqMGB47OX65FBkPffO641IP9jWa1z4ivqG26Q== | ||||||
|  |   dependencies: | ||||||
|  |     fs.realpath "^1.0.0" | ||||||
|  |     inflight "^1.0.4" | ||||||
|  |     inherits "2" | ||||||
|  |     minimatch "^3.0.4" | ||||||
|  |     once "^1.3.0" | ||||||
|  |     path-is-absolute "^1.0.0" | ||||||
|  | 
 | ||||||
|  | glob@~7.1.1: | ||||||
|   version "7.1.7" |   version "7.1.7" | ||||||
|   resolved "https://registry.yarnpkg.com/glob/-/glob-7.1.7.tgz#3b193e9233f01d42d0b3f78294bbeeb418f94a90" |   resolved "https://registry.yarnpkg.com/glob/-/glob-7.1.7.tgz#3b193e9233f01d42d0b3f78294bbeeb418f94a90" | ||||||
|   integrity sha512-OvD9ENzPLbegENnYP5UUfJIirTg4+XwMWGaQfQTY0JenxNvvIKP3U3/tAQSPIu/lHxXYSZmpXlUHeqAIdKzBLQ== |   integrity sha512-OvD9ENzPLbegENnYP5UUfJIirTg4+XwMWGaQfQTY0JenxNvvIKP3U3/tAQSPIu/lHxXYSZmpXlUHeqAIdKzBLQ== | ||||||
|  | @ -5259,6 +5304,13 @@ has-symbols@^1.0.2: | ||||||
|   resolved "https://registry.yarnpkg.com/has-symbols/-/has-symbols-1.0.2.tgz#165d3070c00309752a1236a479331e3ac56f1423" |   resolved "https://registry.yarnpkg.com/has-symbols/-/has-symbols-1.0.2.tgz#165d3070c00309752a1236a479331e3ac56f1423" | ||||||
|   integrity sha512-chXa79rL/UC2KlX17jo3vRGz0azaWEx5tGqZg5pO3NUyEJVB17dMruQlzCCOfUvElghKcm5194+BCRvi2Rv/Gw== |   integrity sha512-chXa79rL/UC2KlX17jo3vRGz0azaWEx5tGqZg5pO3NUyEJVB17dMruQlzCCOfUvElghKcm5194+BCRvi2Rv/Gw== | ||||||
| 
 | 
 | ||||||
|  | has-tostringtag@^1.0.0: | ||||||
|  |   version "1.0.0" | ||||||
|  |   resolved "https://registry.yarnpkg.com/has-tostringtag/-/has-tostringtag-1.0.0.tgz#7e133818a7d394734f941e73c3d3f9291e658b25" | ||||||
|  |   integrity sha512-kFjcSNhnlGV1kyoGk7OXKSawH5JOb/LzUc5w9B02hOTO0dfFRjbHQKvg1d6cf3HbeUmtU9VbbV3qzZ2Teh97WQ== | ||||||
|  |   dependencies: | ||||||
|  |     has-symbols "^1.0.2" | ||||||
|  | 
 | ||||||
| has-unicode@^2.0.1: | has-unicode@^2.0.1: | ||||||
|   version "2.0.1" |   version "2.0.1" | ||||||
|   resolved "https://registry.yarnpkg.com/has-unicode/-/has-unicode-2.0.1.tgz#e0e6fe6a28cf51138855e086d1691e771de2a8b9" |   resolved "https://registry.yarnpkg.com/has-unicode/-/has-unicode-2.0.1.tgz#e0e6fe6a28cf51138855e086d1691e771de2a8b9" | ||||||
|  | @ -5845,6 +5897,11 @@ is-callable@^1.2.3: | ||||||
|   resolved "https://registry.yarnpkg.com/is-callable/-/is-callable-1.2.3.tgz#8b1e0500b73a1d76c70487636f368e519de8db8e" |   resolved "https://registry.yarnpkg.com/is-callable/-/is-callable-1.2.3.tgz#8b1e0500b73a1d76c70487636f368e519de8db8e" | ||||||
|   integrity sha512-J1DcMe8UYTBSrKezuIUTUwjXsho29693unXM2YhJUTR2txK/eG47bvNa/wipPFmZFgr/N6f1GA66dv0mEyTIyQ== |   integrity sha512-J1DcMe8UYTBSrKezuIUTUwjXsho29693unXM2YhJUTR2txK/eG47bvNa/wipPFmZFgr/N6f1GA66dv0mEyTIyQ== | ||||||
| 
 | 
 | ||||||
|  | is-callable@^1.2.4: | ||||||
|  |   version "1.2.4" | ||||||
|  |   resolved "https://registry.yarnpkg.com/is-callable/-/is-callable-1.2.4.tgz#47301d58dd0259407865547853df6d61fe471945" | ||||||
|  |   integrity sha512-nsuwtxZfMX67Oryl9LCQ+upnC0Z0BgpwntpS89m1H/TLF0zNfzfLMV/9Wa/6MZsj0acpEjAO0KF1xT6ZdLl95w== | ||||||
|  | 
 | ||||||
| is-ci@^3.0.0: | is-ci@^3.0.0: | ||||||
|   version "3.0.0" |   version "3.0.0" | ||||||
|   resolved "https://registry.yarnpkg.com/is-ci/-/is-ci-3.0.0.tgz#c7e7be3c9d8eef7d0fa144390bd1e4b88dc4c994" |   resolved "https://registry.yarnpkg.com/is-ci/-/is-ci-3.0.0.tgz#c7e7be3c9d8eef7d0fa144390bd1e4b88dc4c994" | ||||||
|  | @ -6080,6 +6137,14 @@ is-regex@^1.1.3: | ||||||
|     call-bind "^1.0.2" |     call-bind "^1.0.2" | ||||||
|     has-symbols "^1.0.2" |     has-symbols "^1.0.2" | ||||||
| 
 | 
 | ||||||
|  | is-regex@^1.1.4: | ||||||
|  |   version "1.1.4" | ||||||
|  |   resolved "https://registry.yarnpkg.com/is-regex/-/is-regex-1.1.4.tgz#eef5663cd59fa4c0ae339505323df6854bb15958" | ||||||
|  |   integrity sha512-kvRdxDsxZjhzUX07ZnLydzS1TU/TJlTUHHY4YLL87e37oUA49DfkLqgy+VjFocowy29cKvcSiu+kIv728jTTVg== | ||||||
|  |   dependencies: | ||||||
|  |     call-bind "^1.0.2" | ||||||
|  |     has-tostringtag "^1.0.0" | ||||||
|  | 
 | ||||||
| is-resolvable@^1.0.0: | is-resolvable@^1.0.0: | ||||||
|   version "1.1.0" |   version "1.1.0" | ||||||
|   resolved "https://registry.yarnpkg.com/is-resolvable/-/is-resolvable-1.1.0.tgz#fb18f87ce1feb925169c9a407c19318a3206ed88" |   resolved "https://registry.yarnpkg.com/is-resolvable/-/is-resolvable-1.1.0.tgz#fb18f87ce1feb925169c9a407c19318a3206ed88" | ||||||
|  | @ -6105,6 +6170,13 @@ is-string@^1.0.6: | ||||||
|   resolved "https://registry.yarnpkg.com/is-string/-/is-string-1.0.6.tgz#3fe5d5992fb0d93404f32584d4b0179a71b54a5f" |   resolved "https://registry.yarnpkg.com/is-string/-/is-string-1.0.6.tgz#3fe5d5992fb0d93404f32584d4b0179a71b54a5f" | ||||||
|   integrity sha512-2gdzbKUuqtQ3lYNrUTQYoClPhm7oQu4UdpSZMp1/DGgkHBT8E2Z1l0yMdb6D4zNAxwDiMv8MdulKROJGNl0Q0w== |   integrity sha512-2gdzbKUuqtQ3lYNrUTQYoClPhm7oQu4UdpSZMp1/DGgkHBT8E2Z1l0yMdb6D4zNAxwDiMv8MdulKROJGNl0Q0w== | ||||||
| 
 | 
 | ||||||
|  | is-string@^1.0.7: | ||||||
|  |   version "1.0.7" | ||||||
|  |   resolved "https://registry.yarnpkg.com/is-string/-/is-string-1.0.7.tgz#0dd12bf2006f255bb58f695110eff7491eebc0fd" | ||||||
|  |   integrity sha512-tE2UXzivje6ofPW7l23cjDOMa09gb7xlAqG6jG5ej6uPV32TlWP3NKPigtaGeHNu9fohccRYvIiZMfOOnOYUtg== | ||||||
|  |   dependencies: | ||||||
|  |     has-tostringtag "^1.0.0" | ||||||
|  | 
 | ||||||
| is-symbol@^1.0.2: | is-symbol@^1.0.2: | ||||||
|   version "1.0.3" |   version "1.0.3" | ||||||
|   resolved "https://registry.yarnpkg.com/is-symbol/-/is-symbol-1.0.3.tgz#38e1014b9e6329be0de9d24a414fd7441ec61937" |   resolved "https://registry.yarnpkg.com/is-symbol/-/is-symbol-1.0.3.tgz#38e1014b9e6329be0de9d24a414fd7441ec61937" | ||||||
|  | @ -6379,6 +6451,26 @@ jest-haste-map@^27.2.0: | ||||||
|   optionalDependencies: |   optionalDependencies: | ||||||
|     fsevents "^2.3.2" |     fsevents "^2.3.2" | ||||||
| 
 | 
 | ||||||
|  | jest-haste-map@^27.2.2: | ||||||
|  |   version "27.2.2" | ||||||
|  |   resolved "https://registry.yarnpkg.com/jest-haste-map/-/jest-haste-map-27.2.2.tgz#81ccb57b1e1cd513aaaadf5016aad5dab0ede552" | ||||||
|  |   integrity sha512-kaKiq+GbAvk6/sq++Ymor4Vzk6+lr0vbKs2HDVPdkKsHX2lIJRyvhypZG/QsNfQnROKWIZSpUpGuv2HySSosvA== | ||||||
|  |   dependencies: | ||||||
|  |     "@jest/types" "^27.1.1" | ||||||
|  |     "@types/graceful-fs" "^4.1.2" | ||||||
|  |     "@types/node" "*" | ||||||
|  |     anymatch "^3.0.3" | ||||||
|  |     fb-watchman "^2.0.0" | ||||||
|  |     graceful-fs "^4.2.4" | ||||||
|  |     jest-regex-util "^27.0.6" | ||||||
|  |     jest-serializer "^27.0.6" | ||||||
|  |     jest-util "^27.2.0" | ||||||
|  |     jest-worker "^27.2.2" | ||||||
|  |     micromatch "^4.0.4" | ||||||
|  |     walker "^1.0.7" | ||||||
|  |   optionalDependencies: | ||||||
|  |     fsevents "^2.3.2" | ||||||
|  | 
 | ||||||
| jest-jasmine2@^27.2.0: | jest-jasmine2@^27.2.0: | ||||||
|   version "27.2.0" |   version "27.2.0" | ||||||
|   resolved "https://registry.yarnpkg.com/jest-jasmine2/-/jest-jasmine2-27.2.0.tgz#1ece0ee37c348b59ed3dfcfe509fc24e3377b12d" |   resolved "https://registry.yarnpkg.com/jest-jasmine2/-/jest-jasmine2-27.2.0.tgz#1ece0ee37c348b59ed3dfcfe509fc24e3377b12d" | ||||||
|  | @ -6633,6 +6725,15 @@ jest-worker@^27.2.0: | ||||||
|     merge-stream "^2.0.0" |     merge-stream "^2.0.0" | ||||||
|     supports-color "^8.0.0" |     supports-color "^8.0.0" | ||||||
| 
 | 
 | ||||||
|  | jest-worker@^27.2.2: | ||||||
|  |   version "27.2.2" | ||||||
|  |   resolved "https://registry.yarnpkg.com/jest-worker/-/jest-worker-27.2.2.tgz#636deeae8068abbf2b34b4eb9505f8d4e5bd625c" | ||||||
|  |   integrity sha512-aG1xq9KgWB2CPC8YdMIlI8uZgga2LFNcGbHJxO8ctfXAydSaThR4EewKQGg3tBOC+kS3vhPGgymsBdi9VINjPw== | ||||||
|  |   dependencies: | ||||||
|  |     "@types/node" "*" | ||||||
|  |     merge-stream "^2.0.0" | ||||||
|  |     supports-color "^8.0.0" | ||||||
|  | 
 | ||||||
| jest@^27.2.0: | jest@^27.2.0: | ||||||
|   version "27.2.0" |   version "27.2.0" | ||||||
|   resolved "https://registry.yarnpkg.com/jest/-/jest-27.2.0.tgz#3bc329287d699d26361e2094919630eefdf1ac0d" |   resolved "https://registry.yarnpkg.com/jest/-/jest-27.2.0.tgz#3bc329287d699d26361e2094919630eefdf1ac0d" | ||||||
|  | @ -7394,6 +7495,11 @@ nan@^2.12.1: | ||||||
|   resolved "https://registry.yarnpkg.com/nan/-/nan-2.14.1.tgz#d7be34dfa3105b91494c3147089315eff8874b01" |   resolved "https://registry.yarnpkg.com/nan/-/nan-2.14.1.tgz#d7be34dfa3105b91494c3147089315eff8874b01" | ||||||
|   integrity sha512-isWHgVjnFjh2x2yuJ/tj3JbwoHu3UC2dX5G/88Cm24yB6YopVgxvBObDY7n5xW6ExmFhJpSEQqFPvq9zaXc8Jw== |   integrity sha512-isWHgVjnFjh2x2yuJ/tj3JbwoHu3UC2dX5G/88Cm24yB6YopVgxvBObDY7n5xW6ExmFhJpSEQqFPvq9zaXc8Jw== | ||||||
| 
 | 
 | ||||||
|  | nanocolors@^0.2.8: | ||||||
|  |   version "0.2.11" | ||||||
|  |   resolved "https://registry.yarnpkg.com/nanocolors/-/nanocolors-0.2.11.tgz#f2573e6872f1b70067423fc68bbc9d0de2f3bbee" | ||||||
|  |   integrity sha512-83ttyvfJj66dKMadWfBkEUOEDFfRc8FpzTJvh1MySR/pzWFmFikTQZGOV6kHZRz7yR/heiQ1y/MHBBN5P/e7WQ== | ||||||
|  | 
 | ||||||
| nanoid@^3.1.23: | nanoid@^3.1.23: | ||||||
|   version "3.1.23" |   version "3.1.23" | ||||||
|   resolved "https://registry.yarnpkg.com/nanoid/-/nanoid-3.1.23.tgz#f744086ce7c2bc47ee0a8472574d5c78e4183a81" |   resolved "https://registry.yarnpkg.com/nanoid/-/nanoid-3.1.23.tgz#f744086ce7c2bc47ee0a8472574d5c78e4183a81" | ||||||
|  | @ -7602,6 +7708,11 @@ object-inspect@^1.10.3: | ||||||
|   resolved "https://registry.yarnpkg.com/object-inspect/-/object-inspect-1.10.3.tgz#c2aa7d2d09f50c99375704f7a0adf24c5782d369" |   resolved "https://registry.yarnpkg.com/object-inspect/-/object-inspect-1.10.3.tgz#c2aa7d2d09f50c99375704f7a0adf24c5782d369" | ||||||
|   integrity sha512-e5mCJlSH7poANfC8z8S9s9S2IN5/4Zb3aZ33f5s8YqoazCFzNLloLU8r5VCG+G7WoqLvAAZoVMcy3tp/3X0Plw== |   integrity sha512-e5mCJlSH7poANfC8z8S9s9S2IN5/4Zb3aZ33f5s8YqoazCFzNLloLU8r5VCG+G7WoqLvAAZoVMcy3tp/3X0Plw== | ||||||
| 
 | 
 | ||||||
|  | object-inspect@^1.11.0: | ||||||
|  |   version "1.11.0" | ||||||
|  |   resolved "https://registry.yarnpkg.com/object-inspect/-/object-inspect-1.11.0.tgz#9dceb146cedd4148a0d9e51ab88d34cf509922b1" | ||||||
|  |   integrity sha512-jp7ikS6Sd3GxQfZJPyH3cjcbJF6GZPClgdV+EFygjFLQ5FmW/dRUnTd9PQ9k0JhoNDabWFbpF1yCdSWCC6gexg== | ||||||
|  | 
 | ||||||
| object-inspect@^1.8.0: | object-inspect@^1.8.0: | ||||||
|   version "1.8.0" |   version "1.8.0" | ||||||
|   resolved "https://registry.yarnpkg.com/object-inspect/-/object-inspect-1.8.0.tgz#df807e5ecf53a609cc6bfe93eac3cc7be5b3a9d0" |   resolved "https://registry.yarnpkg.com/object-inspect/-/object-inspect-1.8.0.tgz#df807e5ecf53a609cc6bfe93eac3cc7be5b3a9d0" | ||||||
|  | @ -7679,6 +7790,14 @@ object.getownpropertydescriptors@^2.1.0: | ||||||
|     define-properties "^1.1.3" |     define-properties "^1.1.3" | ||||||
|     es-abstract "^1.17.0-next.1" |     es-abstract "^1.17.0-next.1" | ||||||
| 
 | 
 | ||||||
|  | object.hasown@^1.0.0: | ||||||
|  |   version "1.0.0" | ||||||
|  |   resolved "https://registry.yarnpkg.com/object.hasown/-/object.hasown-1.0.0.tgz#bdbade33cfacfb25d7f26ae2b6cb870bf99905c2" | ||||||
|  |   integrity sha512-qYMF2CLIjxxLGleeM0jrcB4kiv3loGVAjKQKvH8pSU/i2VcRRvUNmxbD+nEMmrXRfORhuVJuH8OtSYCZoue3zA== | ||||||
|  |   dependencies: | ||||||
|  |     define-properties "^1.1.3" | ||||||
|  |     es-abstract "^1.18.1" | ||||||
|  | 
 | ||||||
| object.pick@^1.3.0: | object.pick@^1.3.0: | ||||||
|   version "1.3.0" |   version "1.3.0" | ||||||
|   resolved "https://registry.yarnpkg.com/object.pick/-/object.pick-1.3.0.tgz#87a10ac4c1694bd2e1cbf53591a66141fb5dd747" |   resolved "https://registry.yarnpkg.com/object.pick/-/object.pick-1.3.0.tgz#87a10ac4c1694bd2e1cbf53591a66141fb5dd747" | ||||||
|  | @ -10957,10 +11076,10 @@ user-home@^2.0.0: | ||||||
|   dependencies: |   dependencies: | ||||||
|     os-homedir "^1.0.0" |     os-homedir "^1.0.0" | ||||||
| 
 | 
 | ||||||
| utf-8-validate@^5.0.5: | utf-8-validate@^5.0.6: | ||||||
|   version "5.0.5" |   version "5.0.6" | ||||||
|   resolved "https://registry.yarnpkg.com/utf-8-validate/-/utf-8-validate-5.0.5.tgz#dd32c2e82c72002dc9f02eb67ba6761f43456ca1" |   resolved "https://registry.yarnpkg.com/utf-8-validate/-/utf-8-validate-5.0.6.tgz#e1b3e0a5cc8648a3b44c1799fbb170d1aaaffe80" | ||||||
|   integrity sha512-+pnxRYsS/axEpkrrEpzYfNZGXp0IjC/9RIxwM5gntY4Koi8SHmUGSfxfWqxZdRxrtaoVstuOzUp/rbs3JSPELQ== |   integrity sha512-hoY0gOf9EkCw+nimK21FVKHUIG1BMqSiRwxB/q3A9yKZOrOI99PP77BxmarDqWz6rG3vVYiBWfhG8z2Tl+7fZA== | ||||||
|   dependencies: |   dependencies: | ||||||
|     node-gyp-build "^4.2.0" |     node-gyp-build "^4.2.0" | ||||||
| 
 | 
 | ||||||
|  | @ -11533,10 +11652,10 @@ yargs@^16.0.3: | ||||||
|     y18n "^5.0.5" |     y18n "^5.0.5" | ||||||
|     yargs-parser "^20.2.2" |     yargs-parser "^20.2.2" | ||||||
| 
 | 
 | ||||||
| yargs@^17.1.1: | yargs@^17.2.1: | ||||||
|   version "17.1.1" |   version "17.2.1" | ||||||
|   resolved "https://registry.yarnpkg.com/yargs/-/yargs-17.1.1.tgz#c2a8091564bdb196f7c0a67c1d12e5b85b8067ba" |   resolved "https://registry.yarnpkg.com/yargs/-/yargs-17.2.1.tgz#e2c95b9796a0e1f7f3bf4427863b42e0418191ea" | ||||||
|   integrity sha512-c2k48R0PwKIqKhPMWjeiF6y2xY/gPMUlro0sgxqXpbOIohWiLNXWslsootttv7E1e73QPAMQSg5FeySbVcpsPQ== |   integrity sha512-XfR8du6ua4K6uLGm5S6fA+FIJom/MdJcFNVY8geLlp2v8GYbOXD4EB1tPNZsRn4vBzKGMgb5DRZMeWuFc2GO8Q== | ||||||
|   dependencies: |   dependencies: | ||||||
|     cliui "^7.0.2" |     cliui "^7.0.2" | ||||||
|     escalade "^3.1.1" |     escalade "^3.1.1" | ||||||
|  |  | ||||||
		Loading…
	
		Reference in a new issue