summaryrefslogtreecommitdiff
path: root/lib/chef/http/cookie_manager.rb
diff options
context:
space:
mode:
authordanielsdeleo <dan@opscode.com>2013-10-04 13:59:14 -0700
committerdanielsdeleo <dan@opscode.com>2013-10-08 15:01:47 -0700
commit56cc74a74f627663f7b5bbfef3d477d885925f56 (patch)
tree33dc2dcf19af24f7877922aa560e337e0caa075f /lib/chef/http/cookie_manager.rb
parente97402977c16e86259e6dc234ca45ef79e858788 (diff)
downloadchef-56cc74a74f627663f7b5bbfef3d477d885925f56.tar.gz
Extract HTTP cookie handling to middleware
Diffstat (limited to 'lib/chef/http/cookie_manager.rb')
-rw-r--r--lib/chef/http/cookie_manager.rb51
1 files changed, 51 insertions, 0 deletions
diff --git a/lib/chef/http/cookie_manager.rb b/lib/chef/http/cookie_manager.rb
new file mode 100644
index 0000000000..5c96b9e115
--- /dev/null
+++ b/lib/chef/http/cookie_manager.rb
@@ -0,0 +1,51 @@
+#--
+# Author:: Daniel DeLeo (<dan@opscode.com>)
+# Copyright:: Copyright (c) 2013 Opscode, Inc.
+# License:: Apache License, Version 2.0
+#
+# Licensed under the Apache License, Version 2.0 (the "License");
+# you may not use this file except in compliance with the License.
+# You may obtain a copy of the License at
+#
+# http://www.apache.org/licenses/LICENSE-2.0
+#
+# Unless required by applicable law or agreed to in writing, software
+# distributed under the License is distributed on an "AS IS" BASIS,
+# WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
+# See the License for the specific language governing permissions and
+# limitations under the License.
+#
+
+require 'chef/http/cookie_jar'
+
+class Chef
+ class HTTP
+
+ # An HTTP middleware to manage storing/sending cookies in HTTP requests.
+ # Most HTTP communication in Chef does not need cookies, it was originally
+ # implemented to support OpenID, but it's not known who might be relying on
+ # it, so it's included with Chef::REST
+ class CookieManager
+
+ def initialize(options={})
+ @cookies = CookieJar.instance
+ end
+
+ def handle_request(method, url, headers={}, data=false)
+ host, port = url.host, url.port
+ if @cookies.has_key?("#{host}:#{port}")
+ headers['Cookie'] = @cookies["#{host}:#{port}"]
+ end
+ [method, url, headers, data]
+ end
+
+ def handle_response(http_response, rest_request, return_value)
+ if http_response['set-cookie']
+ @cookies["#{host}:#{port}"] = http_response['set-cookie']
+ end
+ [http_response, rest_request, return_value]
+ end
+
+ end
+ end
+end