summaryrefslogtreecommitdiffstats
path: root/lib
diff options
context:
space:
mode:
authorMarius Balteanu <marius.balteanu@zitec.com>2023-12-22 02:08:53 +0000
committerMarius Balteanu <marius.balteanu@zitec.com>2023-12-22 02:08:53 +0000
commitc17b42509b2a79e53d19facfa00fcc16ec401cf9 (patch)
treebf1b7b3f3f35d34448129b0c35e387cb0d78f23a /lib
parentcb10b529cb4c7413abc1c8b5390f549b38a1220a (diff)
downloadredmine-c17b42509b2a79e53d19facfa00fcc16ec401cf9.tar.gz
redmine-c17b42509b2a79e53d19facfa00fcc16ec401cf9.zip
Fixes attachments functionality for (custom) plugins broken since fix for CVE-2022-44030 by adding a dynamic routing constraint which can be modified by plugins (#39862).
Patch by @jkraemer. git-svn-id: https://svn.redmine.org/redmine/trunk@22551 e93f8b46-1217-0410-a6f0-8f06a7374b81
Diffstat (limited to 'lib')
-rw-r--r--lib/plugins/acts_as_attachable/lib/acts_as_attachable.rb24
1 files changed, 24 insertions, 0 deletions
diff --git a/lib/plugins/acts_as_attachable/lib/acts_as_attachable.rb b/lib/plugins/acts_as_attachable/lib/acts_as_attachable.rb
index 4a069980d..9c09a7870 100644
--- a/lib/plugins/acts_as_attachable/lib/acts_as_attachable.rb
+++ b/lib/plugins/acts_as_attachable/lib/acts_as_attachable.rb
@@ -20,6 +20,30 @@
module Redmine
module Acts
module Attachable
+
+ class ObjectTypeConstraint
+ cattr_accessor :object_types
+
+ self.object_types = Concurrent::Set.new(%w[
+ issues versions news messages wiki_pages projects documents journals
+ ])
+
+ class << self
+ def matches?(request)
+ request.path_parameters[:object_type] =~ param_expression
+ end
+
+ def register_object_type(type)
+ object_types << type
+ @param_expression = nil
+ end
+
+ def param_expression
+ @param_expression ||= Regexp.new("^(#{object_types.join("|")})$")
+ end
+ end
+ end
+
def self.included(base)
base.extend ClassMethods
end