summaryrefslogtreecommitdiffstats
path: root/lib/puppet
diff options
context:
space:
mode:
authorRick Bradley <rick@rickbradley.com>2007-10-23 12:09:05 -0500
committerRick Bradley <rick@rickbradley.com>2007-10-23 12:09:05 -0500
commite7bfe0bf9b525d6216cbb24be99357d33c0b87ec (patch)
treefc9b59dbb6ae9f77de3176a7b32343547e3b1d81 /lib/puppet
parentd28a9041039860beb9e19da267bbad40ecebf8f1 (diff)
downloadpuppet-e7bfe0bf9b525d6216cbb24be99357d33c0b87ec.tar.gz
puppet-e7bfe0bf9b525d6216cbb24be99357d33c0b87ec.tar.xz
puppet-e7bfe0bf9b525d6216cbb24be99357d33c0b87ec.zip
Finish serializing successful results (via calls to to_yaml, etc.) for REST handlers. Refactor request building in REST handler specs.
Diffstat (limited to 'lib/puppet')
-rw-r--r--lib/puppet/network/http/handler.rb14
-rw-r--r--lib/puppet/network/http/mongrel/rest.rb1
-rw-r--r--lib/puppet/network/http/webrick/rest.rb1
3 files changed, 12 insertions, 4 deletions
diff --git a/lib/puppet/network/http/handler.rb b/lib/puppet/network/http/handler.rb
index 9b21946c7..2a537c767 100644
--- a/lib/puppet/network/http/handler.rb
+++ b/lib/puppet/network/http/handler.rb
@@ -20,25 +20,31 @@ class Puppet::Network::HTTP::Handler
def do_find(request, response)
key = request_key(request) || raise(ArgumentError, "Could not locate lookup key in request path [#{path}]")
args = params(request)
- encode_result(request, response, @model.find(key, args))
+ result = @model.find(key, args).to_yaml
+ encode_result(request, response, result)
end
def do_search(request, response)
args = params(request)
- encode_result(request, response, @model.search(args))
+ result = @model.search(args).collect {|obj| obj.to_yaml }
+ encode_result(request, response, result)
+
end
def do_destroy(request, response)
key = request_key(request) || raise(ArgumentError, "Could not locate lookup key in request path [#{path}]")
args = params(request)
- encode_result(request, response, @model.destroy(key, args))
+ result = @model.destroy(key, args)
+ encode_result(request, response, YAML.dump(result))
end
def do_save(request, response)
data = body(request)
raise ArgumentError, "No data to save" if !data or data.empty?
args = params(request)
- encode_result(request, response, @model.new.save(args.merge(:data => data)))
+ obj = @model.new
+ result = obj.save(args.merge(:data => data)).to_yaml
+ encode_result(request, response, result)
end
def find_model_for_handler(handler)
diff --git a/lib/puppet/network/http/mongrel/rest.rb b/lib/puppet/network/http/mongrel/rest.rb
index 0d29a822e..f22b4c4c9 100644
--- a/lib/puppet/network/http/mongrel/rest.rb
+++ b/lib/puppet/network/http/mongrel/rest.rb
@@ -31,6 +31,7 @@ class Puppet::Network::HTTP::MongrelREST < Puppet::Network::HTTP::Handler
def encode_result(request, response, result)
response.start(200) do |head, body|
+ body.write(result)
end
end
end
diff --git a/lib/puppet/network/http/webrick/rest.rb b/lib/puppet/network/http/webrick/rest.rb
index d30f9318b..8782df14f 100644
--- a/lib/puppet/network/http/webrick/rest.rb
+++ b/lib/puppet/network/http/webrick/rest.rb
@@ -36,5 +36,6 @@ class Puppet::Network::HTTP::WEBrickREST < Puppet::Network::HTTP::Handler
def encode_result(request, response, result)
response.status = 200
+ response.body = result
end
end \ No newline at end of file