diff options
author | Rick Bradley <rick@rickbradley.com> | 2007-10-16 18:08:18 -0500 |
---|---|---|
committer | Rick Bradley <rick@rickbradley.com> | 2007-10-16 18:08:18 -0500 |
commit | 705f76fa1d9a95c54560a82e68c1c47b27755361 (patch) | |
tree | 20406046da4b83489252beb1ff2a70e3789d1d24 /lib/puppet/network/http/handler.rb | |
parent | ce349683b76ab9d21f4d89e2ec818c0755848a1d (diff) | |
download | puppet-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.rb | 16 |
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 |