From 5bf9df1ebffd85604206d1baf81a5a92158a117a Mon Sep 17 00:00:00 2001 From: nopedial Date: Mon, 14 Oct 2013 11:15:12 +0200 Subject: implement fetch into output model --- lib/oxidized/api/rest.rb | 19 +++++-------------- 1 file changed, 5 insertions(+), 14 deletions(-) (limited to 'lib/oxidized/api') diff --git a/lib/oxidized/api/rest.rb b/lib/oxidized/api/rest.rb index 4bf464b..d876917 100644 --- a/lib/oxidized/api/rest.rb +++ b/lib/oxidized/api/rest.rb @@ -41,20 +41,11 @@ module Oxidized # /nodes/show/node - returns data about node when /show\/(.*)/ send res, @nodes.show($1) - when /fetch\/(.*)/ # primitive node fetch implementation for file config - /nodes/fetch/$ip_address - if CFG.output[:default] == "file" and $1 != '' # ugly hack to disable configuration fetch for non ascii configurations and ensure that argument is received - @cfg_root = CFG.output[:file] - File.open("#{@cfg_root[:directory]}/#{$1}", "r") do |pipe| - @res_config = [] - while ( line = pipe.gets ) do - @res_config << line # store configuration into an array to format and send - end - end - send res, @res_config - elsif CFG.output[:default] != "file" and $1 != '' - send res, "oxidized 0.0.14 support fetch for ascii configuration files only." # return error to end user - else # return error if no argument is received - send res, "missing argument - example: /nodes/fetch/192.0.2.1" + when /fetch\/(.*)/ + begin + send res, @nodes.fetch($1) + rescue Oxidized::NotSupported => e + send res, e end end end -- cgit v1.2.1