54 lines
1.8 KiB
Ruby
54 lines
1.8 KiB
Ruby
# frozen_string_literal: true
|
|
#
|
|
# This patch updates SawyerResource class to not allow Ruby methods to be overridden and accessed.
|
|
# Any attempt to access a Ruby method will result in an exception.
|
|
module SawyerClassPatch
|
|
def attr_accessor(*attrs)
|
|
attrs.each do |attribute|
|
|
class_eval do
|
|
# rubocop:disable Gitlab/ModuleWithInstanceVariables
|
|
if method_defined?(attribute) || method_defined?("#{attribute}=") || method_defined?("#{attribute}?")
|
|
define_method attribute do
|
|
raise Sawyer::Error,
|
|
"Sawyer method \"#{attribute}\" overlaps Ruby method. Convert to a hash to access the attribute."
|
|
end
|
|
|
|
define_method "#{attribute}=" do |value|
|
|
raise Sawyer::Error,
|
|
"Sawyer method \"#{attribute}\" overlaps Ruby method. Convert to a hash to access the attribute."
|
|
end
|
|
|
|
define_method "#{attribute}?" do
|
|
raise Sawyer::Error,
|
|
"Sawyer method \"#{attribute}\" overlaps Ruby method. Convert to a hash to access the attribute."
|
|
end
|
|
else
|
|
define_method attribute do
|
|
Gitlab::Import::Logger.warn(
|
|
Gitlab::ApplicationContext.current.merge(
|
|
{
|
|
message: 'Sawyer attribute called',
|
|
attribute: attribute,
|
|
caller: Gitlab::BacktraceCleaner.clean_backtrace(caller)
|
|
}
|
|
)
|
|
)
|
|
|
|
@attrs[attribute.to_sym]
|
|
end
|
|
|
|
define_method "#{attribute}=" do |value|
|
|
@attrs[attribute.to_sym] = value
|
|
end
|
|
|
|
define_method "#{attribute}?" do
|
|
!!@attrs[attribute.to_sym]
|
|
end
|
|
end
|
|
end
|
|
# rubocop:enable Gitlab/ModuleWithInstanceVariables
|
|
end
|
|
end
|
|
end
|
|
|
|
Sawyer::Resource.singleton_class.prepend(SawyerClassPatch)
|