diff options
author | Dmitriy Zaporozhets <dmitriy.zaporozhets@gmail.com> | 2013-03-23 05:56:27 -0700 |
---|---|---|
committer | Dmitriy Zaporozhets <dmitriy.zaporozhets@gmail.com> | 2013-03-23 05:56:27 -0700 |
commit | 07d17a8b3e7fd6cae2118c360e5381973f75dd9b (patch) | |
tree | cf5bbd1c02107d2e38981daa312bc267cf780ca5 /lib/gitlab_net.rb | |
parent | 601450c30d66a17b3b445f0ca7367eae458efcdd (diff) | |
parent | acdeb0bf1f7660031183e5fea785d6d665013284 (diff) | |
download | gitlab-shell-07d17a8b3e7fd6cae2118c360e5381973f75dd9b.tar.gz |
Merge pull request #23 from regru/http_settings_option
http_settings configuration option added.
Diffstat (limited to 'lib/gitlab_net.rb')
-rw-r--r-- | lib/gitlab_net.rb | 15 |
1 files changed, 14 insertions, 1 deletions
diff --git a/lib/gitlab_net.rb b/lib/gitlab_net.rb index 884d95e..ef4d915 100644 --- a/lib/gitlab_net.rb +++ b/lib/gitlab_net.rb @@ -30,15 +30,28 @@ class GitlabNet protected + def config + @config ||= GitlabConfig.new + end + def host - "#{GitlabConfig.new.gitlab_url}/api/v3/internal" + "#{config.gitlab_url}/api/v3/internal" end def get(url) url = URI.parse(url) http = Net::HTTP.new(url.host, url.port) http.use_ssl = (url.port == 443) + + if config.http_settings['self_signed_cert'] && http.use_ssl? + http.verify_mode = OpenSSL::SSL::VERIFY_NONE + end + request = Net::HTTP::Get.new(url.request_uri) + if config.http_settings['user'] && config.http_settings['password'] + request.basic_auth config.http_settings['user'], config.http_settings['password'] + end + http.start {|http| http.request(request) } end end |