# Copyright (c) 2021 Contrast Security, Inc. See https://www.contrastsecurity.com/enduser-terms-0317a for more details. # frozen_string_literal: true require 'contrast/utils/class_util' require 'contrast/utils/object_share' require 'contrast/agent/assess/tracker' module Contrast module Agent module Assess # This class is a convenient holder of our version of an Object. It # creates a String version of the Object from the original provided # and keeps reference to the original's Tags, letting us determine if it # was tracked when we try to report to TeamServer. # # @attr_reader object [String, nil] the Contrast string representing the # object. # @attr_reader object_type [String] the name of the object's module. # @attr_reader tags [Hash{String => Contrast::Agent::Assess::Tag}, nil] # the tags on the object before it was captured. # # TODO: RUBY-1083 determine if this is expensive and/or worth not storing # these values directly on ContrastEvent and passing them around. Args # probably make the argument for wrapping them b/c otherwise we'll have # to keep two arrays in synch or make an array of arrays, at which # point, we may as well make this. class ContrastObject attr_reader :object, :object_type, :tags # Capture the details about the object which we need to render it in # TeamServer. # # @param object [Object, nil] the thing to keep a Contrast String of def initialize object if object @object = Contrast::Utils::ClassUtil.to_contrast_string(object) @object_type = object.cs__class.cs__name # TODO: RUBY-1084 determine if we need to copy these tags to # restore immutability. For instance, if these tags were on a # String that was then #reverse!'d, would our tags be wrong? @tags = Contrast::Agent::Assess::Tracker.properties(object)&.tags else @object = Contrast::Utils::ObjectShare::NIL_STRING @object_type = nil.cs__class.cs__name end end def tracked? tags&.any? end end end end end