Sha256: 8745d4f6e517b6dad2d5c683a4a71e8fb9567bc6adbc95623c8b57806e06100d

Contents?: true

Size: 1.92 KB

Versions: 2

Compression:

Stored size: 1.92 KB

Contents

# Copyright (c) 2020 Contrast Security, Inc. See https://www.contrastsecurity.com/enduser-terms-0317a for more details.
# frozen_string_literal: true

cs__scoped_require 'contrast/agent/patching/policy/patcher'
cs__scoped_require 'contrast/components/interface'

# This is our patch of the Array class required to handle propagation
# Disclaimer: there may be a better way, but we're in a 'get it work' state.
# Hopefully, we'll be in a 'get it right' state soon.
class Array
  include Contrast::Components::Interface

  access_component :scope

  ARRAY_JOIN_HASH = {
      'class_name' => 'Array',
      'instance_method' => true,
      'method_visibility' => 'public',
      'method_name' => 'join',
      'action' => 'CUSTOM',
      'source' => 'O',
      'target' => 'R',
      'patch_class' => 'NOOP',
      'patch_method' => '__cs_track_join'
  }.cs__freeze
  ARRAY_JOIN_NODE = Contrast::Agent::Assess::Policy::PropagationNode.new(ARRAY_JOIN_HASH)

  # When you call join, they use an internal thing, so there's no good way to get at the thing being returned.
  # Multiple Strings are appended with the #join method. Because that
  # operation happens in C, we have to do it here rather than rely on the
  # patch of our String append or concat methods.
  def __cs_track_join separator, ret
    return ret if Contrast::Agent::Patching::Policy::Patcher.skip_assess_analysis?

    with_contrast_scope do
      shift = 0
      separator_length = separator.nil? ? 0 : separator.to_s.length
      each do |obj|
        if obj # skip nil here
          ret.cs__copy_from(obj, shift)
          shift += obj.to_s.length
        end
        shift += separator_length
      end
      return ret unless ret.cs__tracked?

      ret.cs__properties.cleanup_tags
      ret.cs__properties.build_event(
          ARRAY_JOIN_NODE,
          ret,
          self,
          ret,
          [separator])
      ret
    end
  end
end
cs__scoped_require 'cs__assess_array/cs__assess_array'

Version data entries

2 entries across 2 versions & 1 rubygems

Version Path
contrast-agent-3.8.5 lib/contrast/core_extensions/assess/array.rb
contrast-agent-3.8.4 lib/contrast/core_extensions/assess/array.rb