From ded817a7d0802cc2aafcdbe4bb256698f6868afd Mon Sep 17 00:00:00 2001 From: Robert Date: Fri, 21 Jul 2017 15:59:34 +0200 Subject: Refs: #3507@4.5h spec setup and refactoring, using Faraday in worker - Setting up correct headers for the Webmock request (Oh Boy) - Refactoring all Faraday requests into `lib/af83/http_fetcher.rb` - Implementing the Download --- lib/af83/http_fetcher.rb | 21 +++++++++++++++++++++ 1 file changed, 21 insertions(+) create mode 100644 lib/af83/http_fetcher.rb (limited to 'lib') diff --git a/lib/af83/http_fetcher.rb b/lib/af83/http_fetcher.rb new file mode 100644 index 000000000..514dd1dc9 --- /dev/null +++ b/lib/af83/http_fetcher.rb @@ -0,0 +1,21 @@ +module AF83 + class HTTPFetcher + def self.get_resource(*args) + new.get_resource(*args) + end + + def get_resource(host:, path:, token: nil, params: {}, parse_json: false) + Faraday.new(url: host) do |c| + c.headers['Authorization'] = "Token token=#{token.inspect}" if token + c.adapter Faraday.default_adapter + + resp = c.get path, params + if resp.status == 200 + return parse_json ? JSON.parse(resp.body) : resp.body + else + raise "Error on api request status : #{resp.status} => #{resp.body}" + end + end + end + end +end -- cgit v1.2.3