hiera_remote 0.0.1

Sign up to get free protection for your applications and to get access to all the features.
data/.gitignore ADDED
@@ -0,0 +1,17 @@
1
+ *.gem
2
+ *.rbc
3
+ .bundle
4
+ .config
5
+ .yardoc
6
+ Gemfile.lock
7
+ InstalledFiles
8
+ _yardoc
9
+ coverage
10
+ doc/
11
+ lib/bundler/man
12
+ pkg
13
+ rdoc
14
+ spec/reports
15
+ test/tmp
16
+ test/version_tmp
17
+ tmp
data/Gemfile ADDED
@@ -0,0 +1,4 @@
1
+ source 'https://rubygems.org'
2
+
3
+ # Specify your gem's dependencies in hiera_remote.gemspec
4
+ gemspec
data/LICENSE.txt ADDED
@@ -0,0 +1,22 @@
1
+ Copyright (c) 2013 Dan Jung
2
+
3
+ MIT License
4
+
5
+ Permission is hereby granted, free of charge, to any person obtaining
6
+ a copy of this software and associated documentation files (the
7
+ "Software"), to deal in the Software without restriction, including
8
+ without limitation the rights to use, copy, modify, merge, publish,
9
+ distribute, sublicense, and/or sell copies of the Software, and to
10
+ permit persons to whom the Software is furnished to do so, subject to
11
+ the following conditions:
12
+
13
+ The above copyright notice and this permission notice shall be
14
+ included in all copies or substantial portions of the Software.
15
+
16
+ THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND,
17
+ EXPRESS OR IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF
18
+ MERCHANTABILITY, FITNESS FOR A PARTICULAR PURPOSE AND
19
+ NONINFRINGEMENT. IN NO EVENT SHALL THE AUTHORS OR COPYRIGHT HOLDERS BE
20
+ LIABLE FOR ANY CLAIM, DAMAGES OR OTHER LIABILITY, WHETHER IN AN ACTION
21
+ OF CONTRACT, TORT OR OTHERWISE, ARISING FROM, OUT OF OR IN CONNECTION
22
+ WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN THE SOFTWARE.
data/README.md ADDED
@@ -0,0 +1,29 @@
1
+ # HieraRemote
2
+
3
+ TODO: Write a gem description
4
+
5
+ ## Installation
6
+
7
+ Add this line to your application's Gemfile:
8
+
9
+ gem 'hiera_remote'
10
+
11
+ And then execute:
12
+
13
+ $ bundle
14
+
15
+ Or install it yourself as:
16
+
17
+ $ gem install hiera_remote
18
+
19
+ ## Usage
20
+
21
+ TODO: Write usage instructions here
22
+
23
+ ## Contributing
24
+
25
+ 1. Fork it
26
+ 2. Create your feature branch (`git checkout -b my-new-feature`)
27
+ 3. Commit your changes (`git commit -am 'Add some feature'`)
28
+ 4. Push to the branch (`git push origin my-new-feature`)
29
+ 5. Create new Pull Request
data/Rakefile ADDED
@@ -0,0 +1 @@
1
+ require "bundler/gem_tasks"
@@ -0,0 +1,23 @@
1
+ # coding: utf-8
2
+ lib = File.expand_path('../lib', __FILE__)
3
+ $LOAD_PATH.unshift(lib) unless $LOAD_PATH.include?(lib)
4
+ require 'hiera_remote/version'
5
+
6
+ Gem::Specification.new do |spec|
7
+ spec.name = "hiera_remote"
8
+ spec.version = HieraRemote::VERSION
9
+ spec.authors = ["Dan Jung"]
10
+ spec.email = ["djung@rsmart.com"]
11
+ spec.description = %q{Query hiera server via http}
12
+ spec.summary = %q{hiera remote lookup}
13
+ spec.homepage = "http://rubygems.org"
14
+ spec.license = "MIT"
15
+
16
+ spec.files = `git ls-files`.split($/)
17
+ spec.executables = spec.files.grep(%r{^bin/}) { |f| File.basename(f) }
18
+ spec.test_files = spec.files.grep(%r{^(test|spec|features)/})
19
+ spec.require_paths = ["lib"]
20
+
21
+ spec.add_development_dependency "bundler", "~> 1.3"
22
+ spec.add_development_dependency "rake"
23
+ end
@@ -0,0 +1,135 @@
1
+ class Hiera
2
+ module Backend
3
+ class Http_backend
4
+
5
+ def initialize
6
+ require 'net/http'
7
+ require 'net/https'
8
+ @config = Config[:http]
9
+
10
+ @http = Net::HTTP.new(@config[:host], @config[:port])
11
+ @http.read_timeout = @config[:http_read_timeout] || 10
12
+ @http.open_timeout = @config[:http_connect_timeout] || 10
13
+
14
+ if @config[:use_ssl]
15
+ @http.use_ssl = true
16
+ if @config[:ssl_cert]
17
+ @http.verify_mode = OpenSSL::SSL::VERIFY_PEER
18
+ store = OpenSSL::X509::Store.new
19
+ store.add_cert(OpenSSL::X509::Certificate.new(File.read(@config[:ssl_ca_cert])))
20
+ @http.cert_store = store
21
+
22
+ @http.key = OpenSSL::PKey::RSA.new(File.read(@config[:ssl_key]))
23
+ @http.cert = OpenSSL::X509::Certificate.new(File.read(@config[:ssl_cert]))
24
+
25
+ end
26
+ else
27
+ @http.use_ssl = false
28
+ end
29
+ end
30
+
31
+ def lookup(key, scope, order_override, resolution_type)
32
+
33
+ answer = nil
34
+
35
+ paths = @config[:paths].map { |p| Backend.parse_string(p, scope, { 'key' => key }) }
36
+ paths.insert(0, order_override) if order_override
37
+
38
+
39
+ paths.each do |path|
40
+
41
+ Hiera.debug("[hiera-http]: Lookup #{key} from #{@config[:host]}:#{@config[:port]}#{path}")
42
+ httpreq = Net::HTTP::Get.new(path)
43
+
44
+ begin
45
+ httpres = @http.request(httpreq)
46
+ rescue Exception => e
47
+ Hiera.warn("[hiera-http]: Net::HTTP threw exception #{e.message}")
48
+ raise Exception, e.message unless @config[:failure] == 'graceful'
49
+ next
50
+ end
51
+
52
+ unless (httpres.kind_of?(Net::HTTPSuccess) || httpres.kind_of?(Net::HTTPNotFound))
53
+ Hiera.debug("[hiera-http]: bad http response from #{@config[:host]}:#{@config[:port]}#{path}")
54
+ Hiera.debug("HTTP response code was #{httpres.code}")
55
+ raise Exception, 'Bad HTTP response' unless @config[:failure] == 'graceful'
56
+ next
57
+ end
58
+
59
+ result = self.parse_response(key, httpres.body)
60
+ next unless !result.nil?
61
+
62
+ parsed_result = Backend.parse_answer(result, scope)
63
+
64
+ case resolution_type
65
+ when :array
66
+ answer ||= []
67
+ answer << parsed_result
68
+ when :hash
69
+ answer ||= {}
70
+ answer = parsed_result.merge answer
71
+ else
72
+ answer = parsed_result
73
+ break
74
+ end
75
+ end
76
+ answer
77
+ end
78
+
79
+
80
+ def parse_response(key,answer)
81
+
82
+ return nil unless answer
83
+
84
+ Hiera.debug("[hiera-http]: Query returned data, parsing response as #{@config[:output] || 'plain'}")
85
+
86
+ case @config[:output]
87
+
88
+ when 'plain'
89
+ # When the output format is configured as plain we assume that if the
90
+ # endpoint URL returns an HTTP success then the contents of the response
91
+ # body is the value itself, or nil.
92
+ #
93
+ answer
94
+ when 'json'
95
+ # If JSON is specified as the output format, assume the output of the
96
+ # endpoint URL is a JSON document and return keypart that matched our
97
+ # lookup key
98
+ self.json_handler(key,answer)
99
+ when 'yaml'
100
+ # If YAML is specified as the output format, assume the output of the
101
+ # endpoint URL is a YAML document and return keypart that matched our
102
+ # lookup key
103
+ self.yaml_handler(key,answer)
104
+ else
105
+ answer
106
+ end
107
+ end
108
+
109
+ # Handlers
110
+ # Here we define specific handlers to parse the output of the http request
111
+ # and return a value. Currently we support YAML and JSON
112
+ #
113
+ def json_handler(key,answer)
114
+ require 'rubygems'
115
+ require 'json'
116
+ JSON.parse(answer)[key]
117
+ end
118
+
119
+ def yaml_handler(key, answer)
120
+ require 'yaml'
121
+ require 'pp'
122
+ if YAML.parse(answer)[key].nil?
123
+ return nil
124
+ else
125
+ #puts YAML.parse(answer)[key].transform
126
+ test = YAML.parse(answer)[key].transform
127
+ #puts "|#{key}:#{test}:#{test.class}|"
128
+ return test
129
+ end
130
+ end
131
+
132
+ end
133
+ end
134
+ end
135
+
@@ -0,0 +1,3 @@
1
+ module HieraRemote
2
+ VERSION = "0.0.1"
3
+ end
@@ -0,0 +1,5 @@
1
+ require "hiera_remote/version"
2
+
3
+ module HieraRemote
4
+ # Your code goes here...
5
+ end
metadata ADDED
@@ -0,0 +1,87 @@
1
+ --- !ruby/object:Gem::Specification
2
+ name: hiera_remote
3
+ version: !ruby/object:Gem::Version
4
+ version: 0.0.1
5
+ prerelease:
6
+ platform: ruby
7
+ authors:
8
+ - Dan Jung
9
+ autorequire:
10
+ bindir: bin
11
+ cert_chain: []
12
+ date: 2013-07-20 00:00:00.000000000 Z
13
+ dependencies:
14
+ - !ruby/object:Gem::Dependency
15
+ name: bundler
16
+ requirement: !ruby/object:Gem::Requirement
17
+ none: false
18
+ requirements:
19
+ - - ~>
20
+ - !ruby/object:Gem::Version
21
+ version: '1.3'
22
+ type: :development
23
+ prerelease: false
24
+ version_requirements: !ruby/object:Gem::Requirement
25
+ none: false
26
+ requirements:
27
+ - - ~>
28
+ - !ruby/object:Gem::Version
29
+ version: '1.3'
30
+ - !ruby/object:Gem::Dependency
31
+ name: rake
32
+ requirement: !ruby/object:Gem::Requirement
33
+ none: false
34
+ requirements:
35
+ - - ! '>='
36
+ - !ruby/object:Gem::Version
37
+ version: '0'
38
+ type: :development
39
+ prerelease: false
40
+ version_requirements: !ruby/object:Gem::Requirement
41
+ none: false
42
+ requirements:
43
+ - - ! '>='
44
+ - !ruby/object:Gem::Version
45
+ version: '0'
46
+ description: Query hiera server via http
47
+ email:
48
+ - djung@rsmart.com
49
+ executables: []
50
+ extensions: []
51
+ extra_rdoc_files: []
52
+ files:
53
+ - .gitignore
54
+ - Gemfile
55
+ - LICENSE.txt
56
+ - README.md
57
+ - Rakefile
58
+ - hiera_remote.gemspec
59
+ - lib/hiera/backend/http_backend.rb
60
+ - lib/hiera_remote.rb
61
+ - lib/hiera_remote/version.rb
62
+ homepage: http://rubygems.org
63
+ licenses:
64
+ - MIT
65
+ post_install_message:
66
+ rdoc_options: []
67
+ require_paths:
68
+ - lib
69
+ required_ruby_version: !ruby/object:Gem::Requirement
70
+ none: false
71
+ requirements:
72
+ - - ! '>='
73
+ - !ruby/object:Gem::Version
74
+ version: '0'
75
+ required_rubygems_version: !ruby/object:Gem::Requirement
76
+ none: false
77
+ requirements:
78
+ - - ! '>='
79
+ - !ruby/object:Gem::Version
80
+ version: '0'
81
+ requirements: []
82
+ rubyforge_project:
83
+ rubygems_version: 1.8.25
84
+ signing_key:
85
+ specification_version: 3
86
+ summary: hiera remote lookup
87
+ test_files: []