summaryrefslogtreecommitdiff
path: root/lib/drb
diff options
context:
space:
mode:
authorseki <seki@b2dd03c8-39d4-4d8f-98ff-823fe69b080e>2005-02-13 13:53:25 +0000
committerseki <seki@b2dd03c8-39d4-4d8f-98ff-823fe69b080e>2005-02-13 13:53:25 +0000
commit2847325f99ccc35a2c94785fb12be3726be6983f (patch)
treea774e89647dde64803437a42b4e26d6a3e5b86c1 /lib/drb
parentf19caf73002a24347cdd43f5287f060596363fbf (diff)
add safe_level, default_safe_level
git-svn-id: svn+ssh://ci.ruby-lang.org/ruby/branches/ruby_1_8@7963 b2dd03c8-39d4-4d8f-98ff-823fe69b080e
Diffstat (limited to 'lib/drb')
-rw-r--r--lib/drb/drb.rb35
1 files changed, 30 insertions, 5 deletions
diff --git a/lib/drb/drb.rb b/lib/drb/drb.rb
index eb68f909da..ab2cba894f 100644
--- a/lib/drb/drb.rb
+++ b/lib/drb/drb.rb
@@ -1186,6 +1186,7 @@ module DRb
@@argc_limit = 256
@@load_limit = 256 * 102400
@@verbose = false
+ @@safe_level = 0
# Set the default value for the :argc_limit option.
#
@@ -1215,6 +1216,10 @@ module DRb
@@idconv = idconv
end
+ def self.default_sefe_level(level)
+ @@level = level
+ end
+
# Set the default value of the :verbose option.
#
# See #new(). The initial default value is false.
@@ -1233,7 +1238,8 @@ module DRb
:verbose => @@verbose,
:tcp_acl => @@acl,
:load_limit => @@load_limit,
- :argc_limit => @@argc_limit
+ :argc_limit => @@argc_limit,
+ :safe_level => @@safe_level
}
default_config.update(hash)
end
@@ -1298,6 +1304,7 @@ module DRb
@front = front
@idconv = @config[:idconv]
+ @safe_level = @config[:safe_level]
@grp = ThreadGroup.new
@thread = run
@@ -1326,6 +1333,8 @@ module DRb
# The configuration of this DRbServer
attr_reader :config
+ attr_reader :safe_level
+
# Set whether to operate in verbose mode.
#
# In verbose mode, failed calls are logged to stdout.
@@ -1391,7 +1400,7 @@ module DRb
#
# These methods are not callable via dRuby.
INSECURE_METHOD = [
- :__send__, :instance_eval, :module_eval, :class_eval
+ :__send__
]
# Has a method been included in the list of insecure methods?
@@ -1436,6 +1445,7 @@ module DRb
class InvokeMethod # :nodoc:
def initialize(drb_server, client)
@drb_server = drb_server
+ @safe_level = drb_server.safe_level
@client = client
end
@@ -1443,10 +1453,25 @@ module DRb
@result = nil
@succ = false
setup_message
- if @block
- @result = perform_with_block
+
+ if $SAFE < @safe_level
+ if @block
+ @result = Thread.new {
+ $SAFE = @safe_level
+ perform_with_block
+ }.value
+ else
+ @result = Thread.new {
+ $SAFE = @safe_level
+ perform_without_block
+ }.value
+ end
else
- @result = perform_without_block
+ if @block
+ @result = perform_with_block
+ else
+ @result = perform_without_block
+ end
end
@succ = true
if @msg_id == :to_ary && @result.class == Array