You can not select more than 25 topics
Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.
40 lines
1.6 KiB
40 lines
1.6 KiB
From ec462b7b974fc34110437010f862780fb2ee39a3 Mon Sep 17 00:00:00 2001
|
|
From: Daniel Drake <dsd@laptop.org>
|
|
Date: Thu, 14 Feb 2013 15:05:10 -0600
|
|
Subject: [PATCH] (#18781) Be more tolerant of old clients in WEBrick server
|
|
|
|
In #18781 and #6117 there are cases of relatively simplistic puppet
|
|
setups failing between old versions of the puppet client (which
|
|
always use HTTP GET) and new versions of the puppet WEBrick server
|
|
(which has a relatively low limit on the size of a valid GET: 2083
|
|
bytes).
|
|
|
|
While there are other non-WEBrick server options available, WEBrick
|
|
has the advantage of simplicity, so it would be nice to keep it working.
|
|
|
|
Here we patch the WEBrick constant which specifies the maximum size of
|
|
a HTTP GET request, increasing it to a value that should work for common
|
|
setups.
|
|
---
|
|
lib/puppet/util/monkey_patches.rb | 9 +++++++++
|
|
1 file changed, 9 insertions(+)
|
|
|
|
Index: puppet-3.1.0/lib/puppet/util/monkey_patches.rb
|
|
===================================================================
|
|
--- puppet-3.1.0.orig/lib/puppet/util/monkey_patches.rb
|
|
+++ puppet-3.1.0/lib/puppet/util/monkey_patches.rb
|
|
@@ -356,3 +356,13 @@ unless Dir.respond_to?(:mktmpdir)
|
|
end
|
|
end
|
|
end
|
|
+
|
|
+# Old puppet clients may make large GET requests, lets be reasonably tolerant
|
|
+# in our default WEBrick server.
|
|
+require 'webrick'
|
|
+if defined?(WEBrick::HTTPRequest::MAX_URI_LENGTH) and WEBrick::HTTPRequest::MAX_URI_LENGTH < 8192
|
|
+ # Silence ruby warning: already initialized constant MAX_URI_LENGTH
|
|
+ v, $VERBOSE = $VERBOSE, nil
|
|
+ WEBrick::HTTPRequest.const_set("MAX_URI_LENGTH", 8192)
|
|
+ $VERBOSE = v
|
|
+end
|