summaryrefslogtreecommitdiffstats
path: root/lib/puppet/network/http/handler.rb
diff options
context:
space:
mode:
authorRick Bradley <rick@rickbradley.com>2007-10-16 18:08:18 -0500
committerRick Bradley <rick@rickbradley.com>2007-10-16 18:08:18 -0500
commit705f76fa1d9a95c54560a82e68c1c47b27755361 (patch)
tree20406046da4b83489252beb1ff2a70e3789d1d24 /lib/puppet/network/http/handler.rb
parentce349683b76ab9d21f4d89e2ec818c0755848a1d (diff)
downloadpuppet-705f76fa1d9a95c54560a82e68c1c47b27755361.tar.gz
puppet-705f76fa1d9a95c54560a82e68c1c47b27755361.tar.xz
puppet-705f76fa1d9a95c54560a82e68c1c47b27755361.zip
Argument passing now supported on {webrick,mongrel}+REST.
Diffstat (limited to 'lib/puppet/network/http/handler.rb')
-rw-r--r--lib/puppet/network/http/handler.rb16
1 files changed, 12 insertions, 4 deletions
diff --git a/lib/puppet/network/http/handler.rb b/lib/puppet/network/http/handler.rb
index fb7b5c323..1f63024d6 100644
--- a/lib/puppet/network/http/handler.rb
+++ b/lib/puppet/network/http/handler.rb
@@ -19,22 +19,26 @@ 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}]")
- @model.find(key)
+ args = params(request)
+ @model.find(key, args)
end
def do_search(request, response)
- @model.search
+ args = params(request)
+ @model.search(args)
end
def do_destroy(request, response)
key = request_key(request) || raise(ArgumentError, "Could not locate lookup key in request path [#{path}]")
- @model.destroy(key)
+ args = params(request)
+ @model.destroy(key, args)
end
def do_save(request, response)
data = body(request)
raise ArgumentError, "No data to save" if !data or data.empty?
- @model.new.save(:data => data)
+ args = params(request)
+ @model.new.save(args.merge(:data => data))
end
def find_model_for_handler(handler)
@@ -83,4 +87,8 @@ class Puppet::Network::HTTP::Handler
def body(request)
raise NotImplementedError
end
+
+ def params(request)
+ raise NotImplementedError
+ end
end