diff options
author | Rick Bradley <rick@rickbradley.com> | 2007-10-16 15:38:41 -0500 |
---|---|---|
committer | Rick Bradley <rick@rickbradley.com> | 2007-10-16 15:38:41 -0500 |
commit | 216dd8c47ea42338c2dee0bf6528cdd7e37e0028 (patch) | |
tree | f0e2ad2f1b52210b10427e6593820b0f6c09061c /lib/puppet | |
parent | abbc824ff4a565f0a0f1362b779252e876b86168 (diff) | |
download | puppet-216dd8c47ea42338c2dee0bf6528cdd7e37e0028.tar.gz puppet-216dd8c47ea42338c2dee0bf6528cdd7e37e0028.tar.xz puppet-216dd8c47ea42338c2dee0bf6528cdd7e37e0028.zip |
Refactoring, argument processing for model methods.
Diffstat (limited to 'lib/puppet')
-rw-r--r-- | lib/puppet/network/http/handler.rb | 42 | ||||
-rw-r--r-- | lib/puppet/network/http/mongrel/rest.rb | 10 | ||||
-rw-r--r-- | lib/puppet/network/http/webrick/rest.rb | 10 |
3 files changed, 53 insertions, 9 deletions
diff --git a/lib/puppet/network/http/handler.rb b/lib/puppet/network/http/handler.rb index 77df113e6..fb7b5c323 100644 --- a/lib/puppet/network/http/handler.rb +++ b/lib/puppet/network/http/handler.rb @@ -8,15 +8,35 @@ class Puppet::Network::HTTP::Handler # handle an HTTP request coming from Mongrel def process(request, response) - return @model.find if get?(request) and singular?(request) - return @model.search if get?(request) and plural?(request) - return @model.destroy if delete?(request) and singular?(request) - return @model.new.save if put?(request) and singular?(request) + return do_find(request, response) if get?(request) and singular?(request) + return do_search(request, response) if get?(request) and plural?(request) + return do_destroy(request, response) if delete?(request) and singular?(request) + return do_save(request, response) if put?(request) and singular?(request) raise ArgumentError, "Did not understand HTTP #{http_method(request)} request for '#{path(request)}'" end private + def do_find(request, response) + key = request_key(request) || raise(ArgumentError, "Could not locate lookup key in request path [#{path}]") + @model.find(key) + end + + def do_search(request, response) + @model.search + end + + def do_destroy(request, response) + key = request_key(request) || raise(ArgumentError, "Could not locate lookup key in request path [#{path}]") + @model.destroy(key) + 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) + end + def find_model_for_handler(handler) Puppet::Indirector::Indirection.model(handler) || raise(ArgumentError, "Cannot locate indirection [#{handler}].") @@ -45,14 +65,22 @@ class Puppet::Network::HTTP::Handler # methods specific to a given web server def register_handler - raise UnimplementedError + raise NotImplementedError end def http_method(request) - raise UnimplementedError + raise NotImplementedError end def path(request) - raise UnimplementedError + raise NotImplementedError end + + def request_key(request) + raise NotImplementedError + end + + def body(request) + raise NotImplementedError + end end diff --git a/lib/puppet/network/http/mongrel/rest.rb b/lib/puppet/network/http/mongrel/rest.rb index 4c795481b..f7807b19f 100644 --- a/lib/puppet/network/http/mongrel/rest.rb +++ b/lib/puppet/network/http/mongrel/rest.rb @@ -14,6 +14,14 @@ class Puppet::Network::HTTP::MongrelREST < Puppet::Network::HTTP::Handler end def path(request) - request.params[Mongrel::Const::REQUEST_PATH] + '/' + request.params[Mongrel::Const::REQUEST_PATH].split('/')[1] + end + + def request_key(request) + request.params[Mongrel::Const::REQUEST_PATH].split('/')[2] + end + + def body(request) + request.body end end diff --git a/lib/puppet/network/http/webrick/rest.rb b/lib/puppet/network/http/webrick/rest.rb index ed29cfb75..bfcd0784d 100644 --- a/lib/puppet/network/http/webrick/rest.rb +++ b/lib/puppet/network/http/webrick/rest.rb @@ -19,6 +19,14 @@ class Puppet::Network::HTTP::WEBrickREST < Puppet::Network::HTTP::Handler end def path(request) - request.path + '/' + request.path.split('/')[1] + end + + def request_key(request) + request.path.split('/')[2] + end + + def body(request) + request.body end end
\ No newline at end of file |