2016-04-13 11:47:33 +00:00
|
|
|
# encoding: utf-8
|
|
|
|
# author: Christoph Hartmann
|
|
|
|
# author: Dominik Richter
|
|
|
|
|
|
|
|
require 'net/http'
|
|
|
|
require 'uri'
|
|
|
|
|
|
|
|
module Compliance
|
|
|
|
# implements a simple http abstraction on top of Net::HTTP
|
|
|
|
class HTTP
|
|
|
|
# generic get requires
|
2016-11-30 14:30:11 +00:00
|
|
|
def self.get(url, headers = nil, insecure)
|
2017-05-30 16:02:52 +00:00
|
|
|
uri = _parse_url(url)
|
2016-04-13 11:47:33 +00:00
|
|
|
req = Net::HTTP::Get.new(uri.path)
|
2017-11-21 07:49:41 +00:00
|
|
|
headers&.each do |key, value|
|
|
|
|
req.add_field(key, value)
|
2016-04-13 11:47:33 +00:00
|
|
|
end
|
|
|
|
send_request(uri, req, insecure)
|
|
|
|
end
|
|
|
|
|
|
|
|
# generic post request
|
|
|
|
def self.post(url, token, insecure, basic_auth = false)
|
|
|
|
# form request
|
2017-05-30 16:02:52 +00:00
|
|
|
uri = _parse_url(url)
|
2016-04-13 11:47:33 +00:00
|
|
|
req = Net::HTTP::Post.new(uri.path)
|
|
|
|
if basic_auth
|
|
|
|
req.basic_auth token, ''
|
|
|
|
else
|
|
|
|
req['Authorization'] = "Bearer #{token}"
|
|
|
|
end
|
|
|
|
req.form_data={}
|
|
|
|
|
|
|
|
send_request(uri, req, insecure)
|
|
|
|
end
|
|
|
|
|
|
|
|
# post a file
|
2016-11-30 14:30:11 +00:00
|
|
|
def self.post_file(url, headers, file_path, insecure)
|
2017-05-30 16:02:52 +00:00
|
|
|
uri = _parse_url(url)
|
2017-02-08 22:49:16 +00:00
|
|
|
raise "Unable to parse URL: #{url}" if uri.nil? || uri.host.nil?
|
2016-04-13 11:47:33 +00:00
|
|
|
http = Net::HTTP.new(uri.host, uri.port)
|
|
|
|
|
|
|
|
# set connection flags
|
|
|
|
http.use_ssl = (uri.scheme == 'https')
|
|
|
|
http.verify_mode = OpenSSL::SSL::VERIFY_NONE if insecure
|
|
|
|
|
|
|
|
req = Net::HTTP::Post.new(uri.path)
|
2016-11-30 14:30:11 +00:00
|
|
|
headers.each do |key, value|
|
|
|
|
req.add_field(key, value)
|
2016-04-13 11:47:33 +00:00
|
|
|
end
|
|
|
|
|
|
|
|
req.body_stream=File.open(file_path, 'rb')
|
|
|
|
req.add_field('Content-Length', File.size(file_path))
|
|
|
|
req.add_field('Content-Type', 'application/x-gtar')
|
|
|
|
|
|
|
|
boundary = 'INSPEC-PROFILE-UPLOAD'
|
|
|
|
req.add_field('session', boundary)
|
|
|
|
res=http.request(req)
|
|
|
|
res
|
|
|
|
end
|
|
|
|
|
|
|
|
# sends a http requests
|
|
|
|
def self.send_request(uri, req, insecure)
|
|
|
|
opts = {
|
|
|
|
use_ssl: uri.scheme == 'https',
|
|
|
|
}
|
|
|
|
opts[:verify_mode] = OpenSSL::SSL::VERIFY_NONE if insecure
|
|
|
|
|
2017-02-08 22:49:16 +00:00
|
|
|
raise "Unable to parse URI: #{uri}" if uri.nil? || uri.host.nil?
|
2017-02-08 07:47:20 +00:00
|
|
|
res = Net::HTTP.start(uri.host, uri.port, opts) { |http|
|
2016-04-13 11:47:33 +00:00
|
|
|
http.request(req)
|
|
|
|
}
|
|
|
|
res
|
2017-02-08 07:47:20 +00:00
|
|
|
rescue OpenSSL::SSL::SSLError => e
|
|
|
|
raise e unless e.message.include? 'certificate verify failed'
|
|
|
|
|
|
|
|
puts "Error: Failed to connect to #{uri}."
|
|
|
|
puts 'If the server uses a self-signed certificate, please re-run the login command with the --insecure option.'
|
|
|
|
exit 1
|
2016-04-13 11:47:33 +00:00
|
|
|
end
|
2017-05-30 16:02:52 +00:00
|
|
|
|
|
|
|
def self._parse_url(url)
|
|
|
|
url = "https://#{url}" if URI.parse(url).scheme.nil?
|
|
|
|
URI.parse(url)
|
|
|
|
end
|
2016-04-13 11:47:33 +00:00
|
|
|
end
|
|
|
|
end
|